2017-03-03 20:17:49 +00:00
|
|
|
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
|
|
|
|
//
|
|
|
|
// This software (Documize Community Edition) is licensed under
|
|
|
|
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
|
|
|
|
//
|
|
|
|
// You can operate outside the AGPL restrictions by purchasing
|
|
|
|
// Documize Enterprise Edition and obtaining a commercial license
|
|
|
|
// by contacting <sales@documize.com>.
|
|
|
|
//
|
|
|
|
// https://documize.com
|
|
|
|
|
|
|
|
import Ember from 'ember';
|
|
|
|
import NotifierMixin from '../../../mixins/notifier';
|
|
|
|
|
|
|
|
export default Ember.Controller.extend(NotifierMixin, {
|
|
|
|
documentService: Ember.inject.service('document'),
|
|
|
|
templateService: Ember.inject.service('template'),
|
|
|
|
sectionService: Ember.inject.service('section'),
|
2017-05-10 08:13:53 +01:00
|
|
|
linkService: Ember.inject.service('link'),
|
2017-03-03 20:17:49 +00:00
|
|
|
folder: {},
|
|
|
|
pages: [],
|
|
|
|
toggled: false,
|
2017-03-09 12:51:21 +00:00
|
|
|
queryParams: ['pageId', 'tab'],
|
2017-03-19 11:37:18 +00:00
|
|
|
pageId: '',
|
|
|
|
tab: 'index',
|
2017-03-03 20:17:49 +00:00
|
|
|
|
|
|
|
actions: {
|
|
|
|
toggleSidebar() {
|
|
|
|
this.set('toggled', !this.get('toggled'));
|
|
|
|
},
|
|
|
|
|
|
|
|
onSaveDocument(doc) {
|
|
|
|
this.get('documentService').save(doc);
|
|
|
|
this.showNotification('Saved');
|
|
|
|
},
|
|
|
|
|
|
|
|
onCopyPage(pageId, targetDocumentId) {
|
|
|
|
let documentId = this.get('model.document.id');
|
|
|
|
this.get('documentService').copyPage(documentId, pageId, targetDocumentId).then(() => {
|
|
|
|
this.showNotification("Copied");
|
|
|
|
|
|
|
|
// refresh data if copied to same document
|
|
|
|
if (documentId === targetDocumentId) {
|
2017-03-09 17:18:50 +00:00
|
|
|
this.set('pageId', '');
|
2017-03-03 20:17:49 +00:00
|
|
|
this.get('target.router').refresh();
|
2017-05-10 08:13:53 +01:00
|
|
|
|
|
|
|
this.get('linkService').getDocumentLinks(this.get('model.document.id')).then((links) => {
|
|
|
|
this.set('model.links', links);
|
|
|
|
});
|
2017-03-03 20:17:49 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
onMovePage(pageId, targetDocumentId) {
|
|
|
|
let documentId = this.get('model.document.id');
|
|
|
|
|
|
|
|
this.get('documentService').copyPage(documentId, pageId, targetDocumentId).then(() => {
|
|
|
|
this.showNotification("Moved");
|
|
|
|
this.send('onPageDeleted', { id: pageId, children: false });
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
onSavePage(page, meta) {
|
|
|
|
let documentId = this.get('model.document.id');
|
|
|
|
let model = {
|
|
|
|
page: page.toJSON({ includeId: true }),
|
|
|
|
meta: meta.toJSON({ includeId: true })
|
|
|
|
};
|
|
|
|
|
2017-03-14 06:15:35 +00:00
|
|
|
this.get('documentService').updatePage(documentId, page.get('id'), model).then((up) => {
|
|
|
|
page = up;
|
2017-03-09 17:18:50 +00:00
|
|
|
this.set('pageId', page.get('id'));
|
2017-05-10 08:13:53 +01:00
|
|
|
this.get('linkService').getDocumentLinks(this.get('model.document.id')).then((links) => {
|
|
|
|
this.set('model.links', links);
|
|
|
|
});
|
2017-03-03 20:17:49 +00:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
onPageDeleted(deletePage) {
|
|
|
|
let documentId = this.get('model.document.id');
|
|
|
|
let pages = this.get('model.pages');
|
|
|
|
let deleteId = deletePage.id;
|
|
|
|
let deleteChildren = deletePage.children;
|
|
|
|
let page = _.findWhere(pages, {
|
|
|
|
id: deleteId
|
|
|
|
});
|
|
|
|
let pageIndex = _.indexOf(pages, page, false);
|
|
|
|
let pendingChanges = [];
|
|
|
|
|
|
|
|
// select affected pages
|
|
|
|
for (var i = pageIndex + 1; i < pages.get('length'); i++) {
|
|
|
|
if (pages[i].get('level') <= page.get('level')) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
pendingChanges.push({
|
|
|
|
pageId: pages[i].get('id'),
|
|
|
|
level: pages[i].get('level') - 1
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-03-09 17:18:50 +00:00
|
|
|
this.set('pageId', '');
|
|
|
|
|
2017-03-03 20:17:49 +00:00
|
|
|
if (deleteChildren) {
|
|
|
|
// nuke of page tree
|
|
|
|
pendingChanges.push({
|
|
|
|
pageId: deleteId
|
|
|
|
});
|
|
|
|
|
|
|
|
this.get('documentService').deletePages(documentId, deleteId, pendingChanges).then(() => {
|
|
|
|
// update our models so we don't have to reload from db
|
|
|
|
for (var i = 0; i < pendingChanges.length; i++) {
|
|
|
|
let pageId = pendingChanges[i].pageId;
|
|
|
|
this.set('model.pages', _.reject(pages, function (p) { //jshint ignore: line
|
|
|
|
return p.get('id') === pageId;
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
this.set('model.pages', _.sortBy(pages, "sequence"));
|
2017-03-22 09:40:34 +00:00
|
|
|
this.get('target.router').refresh();
|
2017-03-03 20:17:49 +00:00
|
|
|
});
|
|
|
|
} else {
|
|
|
|
// page delete followed by re-leveling child pages
|
|
|
|
this.get('documentService').deletePage(documentId, deleteId).then(() => {
|
|
|
|
this.set('model.pages', _.reject(pages, function (p) {
|
|
|
|
return p.get('id') === deleteId;
|
|
|
|
}));
|
|
|
|
|
|
|
|
this.send('onPageLevelChange', pendingChanges);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
onInsertSection(data) {
|
|
|
|
return new Ember.RSVP.Promise((resolve) => {
|
|
|
|
this.get('documentService').addPage(this.get('model.document.id'), data).then((newPage) => {
|
|
|
|
let data = this.get('store').normalize('page', newPage);
|
|
|
|
this.get('store').push(data);
|
2017-03-09 17:18:50 +00:00
|
|
|
this.set('pageId', newPage.id);
|
2017-03-03 20:17:49 +00:00
|
|
|
|
|
|
|
this.get('documentService').getPages(this.get('model.document.id')).then((pages) => {
|
|
|
|
this.set('model.pages', pages);
|
2017-03-04 19:20:01 +00:00
|
|
|
|
2017-03-04 21:07:39 +00:00
|
|
|
if (newPage.pageType === 'tab') {
|
2017-03-04 19:20:01 +00:00
|
|
|
this.transitionToRoute('document.section',
|
|
|
|
this.get('model.folder.id'),
|
|
|
|
this.get('model.folder.slug'),
|
|
|
|
this.get('model.document.id'),
|
|
|
|
this.get('model.document.slug'),
|
|
|
|
newPage.id);
|
2017-03-04 21:07:39 +00:00
|
|
|
} else {
|
|
|
|
resolve(newPage.id);
|
2017-03-04 19:20:01 +00:00
|
|
|
}
|
2017-03-03 20:17:49 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2017-03-04 21:07:39 +00:00
|
|
|
onDeleteBlock(blockId) {
|
|
|
|
return new Ember.RSVP.Promise((resolve) => {
|
|
|
|
this.get('sectionService').deleteBlock(blockId).then(() => {
|
|
|
|
this.send("showNotification", "Deleted");
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
onSavePageAsBlock(block) {
|
|
|
|
return new Ember.RSVP.Promise((resolve) => {
|
|
|
|
this.get('sectionService').addBlock(block).then(() => {
|
|
|
|
this.showNotification("Published");
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2017-03-07 14:39:06 +00:00
|
|
|
onDocumentDelete() {
|
|
|
|
this.get('documentService').deleteDocument(this.get('model.document.id')).then(() => {
|
|
|
|
this.send("showNotification", "Deleted");
|
|
|
|
this.transitionToRoute('folder', this.get('model.folder.id'), this.get('model.folder.slug'));
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
onSaveTemplate(name, desc) {
|
|
|
|
this.get('templateService').saveAsTemplate(this.get('model.document.id'), name, desc).then(function () {});
|
|
|
|
},
|
|
|
|
|
2017-03-03 20:17:49 +00:00
|
|
|
onPageSequenceChange(changes) {
|
|
|
|
this.get('documentService').changePageSequence(this.get('model.document.id'), changes).then(() => {
|
|
|
|
_.each(changes, (change) => {
|
|
|
|
let pageContent = _.findWhere(this.get('model.pages'), {
|
|
|
|
id: change.pageId
|
|
|
|
});
|
|
|
|
|
|
|
|
if (is.not.undefined(pageContent)) {
|
|
|
|
pageContent.set('sequence', change.sequence);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
this.set('model.pages', this.get('model.pages').sortBy('sequence'));
|
|
|
|
this.get('target.router').refresh();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
onPageLevelChange(changes) {
|
|
|
|
this.get('documentService').changePageLevel(this.get('model.document.id'), changes).then(() => {
|
|
|
|
_.each(changes, (change) => {
|
|
|
|
let pageContent = _.findWhere(this.get('model.pages'), {
|
|
|
|
id: change.pageId
|
|
|
|
});
|
|
|
|
|
|
|
|
if (is.not.undefined(pageContent)) {
|
|
|
|
pageContent.set('level', change.level);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
let pages = this.get('model.pages');
|
|
|
|
pages = pages.sortBy('sequence');
|
|
|
|
this.set('model.pages', []);
|
|
|
|
this.set('model.pages', pages);
|
|
|
|
this.get('target.router').refresh();
|
|
|
|
});
|
2017-03-07 16:10:13 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
onGotoPage(id) {
|
2017-03-09 17:18:50 +00:00
|
|
|
if (this.get('pageId') !== id && id !== '') {
|
|
|
|
this.set('pageId', id);
|
|
|
|
}
|
2017-03-07 14:39:06 +00:00
|
|
|
}
|
2017-03-03 20:17:49 +00:00
|
|
|
}
|
|
|
|
});
|