1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-08-05 13:35:25 +02:00

upgraded Ember and Bootstrap, merged changes

This commit is contained in:
sauls8t 2018-01-22 10:31:03 +00:00
parent b4fd42da38
commit 5dd7d9c181
114 changed files with 9814 additions and 1361 deletions

View file

@ -25,7 +25,9 @@ export default {
Read: 1,
Feedback: 2,
Contribute: 3,
Approve: 4
Approve: 4,
Approved: 5,
Rejected: 6,
},
UserActivityType: {
@ -38,6 +40,7 @@ export default {
Reverted: 7,
PublishedTemplate: 8,
PublishedBlock: 9,
Feedback: 10
Feedback: 10,
Rejected: 11,
}
};

49
gui/app/utils/group-by.js Normal file
View file

@ -0,0 +1,49 @@
// Copyright (c) 2013 Stefan Penner and Ember App Kit Contributors
// MIT License
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
import Object from '@ember/object'
import { get } from '@ember/object';
import { computed } from '@ember/object';
export default function(groupBy) {
var dependentKey = 'content.@each.' + groupBy;
return computed(dependentKey, function(){
var result = [];
this.get('content').forEach(function(item){
var hasGroup = !!result.findBy('group', get(item, groupBy));
if (!hasGroup) {
result.pushObject(Object.create({
group: get(item, groupBy),
content: []
}));
}
result.findBy('group', get(item, groupBy)).get('content').pushObject(item);
});
return result;
});
}

View file

@ -49,12 +49,16 @@ let UserModel = BaseModel.extend({
active: false,
editor: false,
admin: false,
accounts: [],
fullname: computed('firstname', 'lastname', function () {
return `${this.get('firstname')} ${this.get('lastname')}`;
}),
init() {
this._super(...arguments);
this.accounts = [];
},
generateInitials() {
let first = this.get('firstname').trim();
let last = this.get('lastname').trim();
@ -96,8 +100,8 @@ let DocumentModel = BaseModel.extend({
userId: "",
tags: "",
template: "",
protection: constants.ProtectionType.None,
approval: constants.ApprovalType.None,
protection: 0,
approval: 0,
slug: computed('name', function () {
return stringUtil.makeSlug(this.get('name'));
@ -142,7 +146,10 @@ let FolderModel = BaseModel.extend({
},
// client-side prop that holds who can see this folder
sharedWith: [],
init() {
this._super(...arguments);
this.sharedWith = [];
}
});
let AttachmentModel = BaseModel.extend({
@ -159,12 +166,13 @@ let PageModel = BaseModel.extend({
orgId: "",
contentType: "",
level: 1,
sequence: 0,
sequence: 1004,
revisions: 0,
title: "",
body: "",
rawBody: "",
meta: {},
status: 0,
relativeId: '',
tagName: computed('level', function () {
return "h" + this.get('level');
@ -178,6 +186,11 @@ let PageModel = BaseModel.extend({
let tocIndent = this.get('tocIndent');
return `margin-left-${tocIndent}`;
}),
init() {
this._super(...arguments);
this.meta = {};
}
});
let PageMetaModel = BaseModel.extend({
@ -185,8 +198,12 @@ let PageMetaModel = BaseModel.extend({
documentId: "",
orgId: "",
rawBody: "",
config: {},
externalSource: false,
init() {
this._super(...arguments);
this.config = {};
}
});
let SectionModel = BaseModel.extend({

View file

@ -23,20 +23,23 @@ function getState(toc, page) {
downDisabled: true,
indentDisabled: true,
outdentDisabled: true,
pageId: ''
};
if (is.undefined(page)) {
return state;
}
var index = _.indexOf(toc, page, false);
state.pageId = page.get('id');
var index = _.findIndex(toc, function(i) { return i.get('page.id') === page.get('id'); });
if (index === -1) {
return state;
}
var upPage = toc[index - 1];
var downPage = toc[index + 1];
var upPage = _.isUndefined(toc[index - 1]) ? toc[index - 1] : toc[index - 1].get('page');
var downPage = _.isUndefined(toc[index + 1]) ? toc[index + 1] : toc[index + 1].get('page');
if (_.isUndefined(upPage)) {
state.tocTools.upTarget = '';
@ -50,17 +53,17 @@ function getState(toc, page) {
// can we indent?
if (!_.isUndefined(upPage)) {
// can only go up if someone is same or higher level?
var index2 = _.indexOf(toc, upPage, false);
var index2 = _.findIndex(toc, function(i) { return i.get('page.id') === upPage.get('id'); });
if (index2 !== -1) {
// up
for (var i = index2; i >= 0; i--) {
if (page.get('level') > toc[i].get('level')) {
if (page.get('level') > toc[i].get('page.level')) {
break;
}
if (page.get('level') === toc[i].get('level')) {
state.tocTools.upTarget = toc[i].id;
if (page.get('level') === toc[i].get('page.level')) {
state.tocTools.upTarget = toc[i].get('page.id');
break;
}
}
@ -78,16 +81,16 @@ function getState(toc, page) {
// can we go down?
if (!_.isUndefined(downPage)) {
// can only go down if someone below is at our level or higher
var index3 = _.indexOf(toc, downPage, false);
var index3 = _.findIndex(toc, function(i) { return i.get('page.id') === downPage.get('id'); });
if (index3 !== -1) {
for (var i3 = index3; i3 < toc.length; i3++) {
if (toc[i3].get('level') < page.get('level')) {
if (toc[i3].get('page.level') < page.get('level')) {
break;
}
if (page.get('level') === toc[i3].get('level')) {
state.tocTools.downTarget = toc[i3].get('id');
if (page.get('level') === toc[i3].get('page.level')) {
state.tocTools.downTarget = toc[i3].get('page.id');
break;
}
}
@ -115,23 +118,25 @@ function getState(toc, page) {
// move up page and any associated kids
function moveUp(state, pages, current) {
var page1 = _.findWhere(pages, { id: state.tocTools.upTarget });
var page1 = _.find(pages, function(i) { return i.get('page.id') === state.tocTools.upTarget });
var page2 = null;
var pendingChanges = [];
if (is.not.undefined(page1)) page1 = page1.get('page');
if (is.undefined(current) || is.undefined(page1)) {
return pendingChanges;
}
var index1 = _.indexOf(pages, page1, false);
var index1 = _.findIndex(pages, function(i) { return i.get('page.id') === page1.get('id'); });
if (index1 !== -1) {
page2 = pages[index1 - 1];
if (is.not.undefined(pages[index1 - 1])) page2 = pages[index1 - 1].get('page');
}
var sequence1 = page1.get('sequence');
var sequence2 = is.not.null(page2) && is.not.undefined(page2) ? page2.get('sequence') : 0;
var index = _.indexOf(pages, current, false);
var index = _.findIndex(pages, function(i) { return i.get('page.id') === current.get('id'); });
if (index !== -1) {
var sequence = (sequence1 + sequence2) / 2;
@ -142,14 +147,14 @@ function moveUp(state, pages, current) {
});
for (var i = index + 1; i < pages.length; i++) {
if (pages[i].get('level') <= current.get('level')) {
if (pages[i].get('page.level') <= current.get('level')) {
break;
}
sequence = (sequence + page1.get('sequence')) / 2;
pendingChanges.push({
pageId: pages[i].get('id'),
pageId: pages[i].get('page.id'),
sequence: sequence
});
}
@ -160,9 +165,11 @@ function moveUp(state, pages, current) {
// move down page and any associated kids
function moveDown(state, pages, current) {
var pageIndex = _.indexOf(pages, current, false);
var downTarget = _.findWhere(pages, { id: state.tocTools.downTarget });
var downTargetIndex = _.indexOf(pages, downTarget, false);
var pageIndex = _.findIndex(pages, function(i) { return i.get('page.id') === current.get('id'); });
var downTarget = _.find(pages, function(i) { return i.get('page.id') === state.tocTools.downTarget; });
if (is.not.undefined(downTarget)) downTarget = downTarget.get('page');
var downTargetIndex = _.findIndex(pages, function(i) { return i.get('page.id') === downTarget.get('id'); });
var pendingChanges = [];
if (pageIndex === -1 || downTargetIndex === -1) {
@ -173,25 +180,28 @@ function moveDown(state, pages, current) {
var upperSequence = 0;
var cutOff = _.rest(pages, downTargetIndex);
var siblings = _.reject(cutOff, function (p) {
return p.get('level') !== current.get('level') || p.get('id') === current.get('id') || p.get('id') === downTarget.get('id');
return p.get('page.level') !== current.get('level') || p.get('page.id') === current.get('id') || p.get('page.id') === downTarget.get('id');
});
if (siblings.length > 0) {
var aboveThisGuy = siblings[0];
var belowThisGuy = pages[_.indexOf(pages, aboveThisGuy, false) - 1];
var aboveThisGuy = siblings[0].get('page');
var belowThisGuyIndex = _.findIndex(pages, function(i) { return i.get('page.id') === aboveThisGuy.get('id'); })
var belowThisGuy = pages[belowThisGuyIndex - 1];
if (is.not.null(belowThisGuy)) belowThisGuy = belowThisGuy.get('page');
if (is.not.null(belowThisGuy) && belowThisGuy.get('level') > current.get('level')) {
startingSequence = (aboveThisGuy.get('sequence') + belowThisGuy.get('sequence')) / 2;
upperSequence = aboveThisGuy.get('sequence');
} else {
var otherGuy = pages[downTargetIndex + 1];
var otherGuy = pages[downTargetIndex + 1].get('page');
startingSequence = (otherGuy.get('sequence') + downTarget.get('sequence')) / 2;
upperSequence = otherGuy.get('sequence');
}
} else {
// startingSequence = downTarget.sequence * 2;
startingSequence = cutOff[cutOff.length - 1].get('sequence') * 2;
startingSequence = cutOff[cutOff.length - 1].get('page.sequence') * 2;
upperSequence = startingSequence * 2;
}
@ -203,14 +213,14 @@ function moveDown(state, pages, current) {
var sequence = (startingSequence + upperSequence) / 2;
for (var i = pageIndex + 1; i < pages.length; i++) {
if (pages[i].get('level') <= current.get('level')) {
if (pages[i].get('page.level') <= current.get('level')) {
break;
}
var sequence2 = (sequence + upperSequence) / 2;
pendingChanges.push({
pageId: pages[i].get('id'),
pageId: pages[i].get('page.id'),
sequence: sequence2
});
}
@ -220,7 +230,7 @@ function moveDown(state, pages, current) {
// indent page and any associated kisds
function indent(state, pages, current) {
var pageIndex = _.indexOf(pages, current, false);
var pageIndex = _.findIndex(pages, function(i) { return i.get('page.id') === current.get('id'); });
var pendingChanges = [];
pendingChanges.push({
@ -229,13 +239,13 @@ function indent(state, pages, current) {
});
for (var i = pageIndex + 1; i < pages.length; i++) {
if (pages[i].get('level') <= current.get('level')) {
if (pages[i].get('page.level') <= current.get('level')) {
break;
}
pendingChanges.push({
pageId: pages[i].get('id'),
level: pages[i].get('level') + state.tocTools.indentIncrement
pageId: pages[i].get('page.id'),
level: pages[i].get('page.level') + state.tocTools.indentIncrement
});
}
@ -243,7 +253,7 @@ function indent(state, pages, current) {
}
function outdent(state, pages, current) {
var pageIndex = _.indexOf(pages, current, false);
var pageIndex = _.findIndex(pages, function(i) { return i.get('page.id') === current.get('id'); });
var pendingChanges = [];
pendingChanges.push({
@ -252,13 +262,13 @@ function outdent(state, pages, current) {
});
for (var i = pageIndex + 1; i < pages.length; i++) {
if (pages[i].get('level') <= current.get('level')) {
if (pages[i].get('page.level') <= current.get('level')) {
break;
}
pendingChanges.push({
pageId: pages[i].get('id'),
level: pages[i].get('level') - 1
pageId: pages[i].get('page.id'),
level: pages[i].get('page.level') - 1
});
}