1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-19 13:19:43 +02:00
documize/gui/app/pods/document/index/controller.js

227 lines
7 KiB
JavaScript
Raw Normal View History

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 { Promise as EmberPromise } from 'rsvp';
import { inject as service } from '@ember/service';
import Controller from '@ember/controller';
2017-10-03 17:52:03 -04:00
import TooltipMixin from '../../../mixins/tooltip';
2017-03-03 20:17:49 +00:00
export default Controller.extend(TooltipMixin, {
documentService: service('document'),
templateService: service('template'),
sectionService: service('section'),
linkService: service('link'),
// currentPageId: '',
2017-12-11 11:40:12 +00:00
tab: 'content',
queryParams: ['currentPageId'],
2017-03-03 20:17:49 +00:00
actions: {
2017-12-11 11:40:12 +00:00
onTabChange(tab) {
this.set('tab', tab);
if (tab === 'content') {
this.send('refresh');
}
2017-12-11 11:40:12 +00:00
},
onShowPage(pageId) {
this.set('tab', 'content');
this.get('browser').scrollTo(`#page-${pageId}`);
},
2017-03-03 20:17:49 +00:00
onSaveDocument(doc) {
this.get('documentService').save(doc);
2017-12-04 14:47:44 +00:00
this.get('browser').setTitle(doc.get('name'));
this.get('browser').setMetaDescription(doc.get('excerpt'));
2017-03-03 20:17:49 +00:00
},
onCopyPage(pageId, targetDocumentId) {
2017-12-14 16:48:12 +00:00
let documentId = this.get('document.id');
2017-03-03 20:17:49 +00:00
this.get('documentService').copyPage(documentId, pageId, targetDocumentId).then(() => {
// refresh data if copied to same document
if (documentId === targetDocumentId) {
this.set('pageId', '');
2017-08-08 11:24:21 +01:00
this.get('target._routerMicrolib').refresh();
2017-05-10 08:13:53 +01:00
2017-12-14 16:48:12 +00:00
this.get('linkService').getDocumentLinks(this.get('document.id')).then((links) => {
this.set('links', links);
2017-05-10 08:13:53 +01:00
});
2017-03-03 20:17:49 +00:00
}
});
},
onMovePage(pageId, targetDocumentId) {
2017-12-14 16:48:12 +00:00
let documentId = this.get('document.id');
2017-03-03 20:17:49 +00:00
this.get('documentService').copyPage(documentId, pageId, targetDocumentId).then(() => {
this.send('onPageDeleted', { id: pageId, children: false });
});
},
onSavePage(page, meta) {
let document = this.get('document');
let documentId = document.get('id');
let constants = this.get('constants');
// if document approval mode is locked return
if (document.get('protection') == constants.ProtectionType.Lock) {
// should not really happen
return;
}
// Go ahead and save edits as normal
2017-03-03 20:17:49 +00:00
let model = {
page: page.toJSON({ includeId: true }),
meta: meta.toJSON({ includeId: true })
};
this.get('documentService').updatePage(documentId, page.get('id'), model).then((/*up*/) => {
this.get('documentService').fetchPages(documentId, this.get('session.user.id')).then((pages) => {
this.set('pages', pages);
this.get('linkService').getDocumentLinks(documentId).then((links) => {
this.set('links', links);
});
2017-05-10 08:13:53 +01:00
});
2017-03-03 20:17:49 +00:00
});
},
onPageDeleted(deletePage) {
2017-12-14 16:48:12 +00:00
let documentId = this.get('document.id');
2017-03-03 20:17:49 +00:00
let deleteId = deletePage.id;
let deleteChildren = deletePage.children;
let pendingChanges = [];
let pages = this.get('pages');
let pageIndex = _.findIndex(pages, function(i) { return i.get('page.id') === deleteId; });
let item = pages[pageIndex];
2017-03-03 20:17:49 +00:00
// select affected pages
for (var i = pageIndex + 1; i < pages.get('length'); i++) {
if (i === pageIndex + 1 && pages[i].get('page.level') === item.get('page.level')) break;
if (pages[i].get('page.level') <= item.get('page.level')) break;
2017-03-03 20:17:49 +00:00
pendingChanges.push({ pageId: pages[i].get('page.id'), level: pages[i].get('page.level') - 1 });
2017-03-03 20:17:49 +00:00
}
this.set('currentPageId', null);
2017-03-03 20:17:49 +00:00
if (deleteChildren) {
pendingChanges.push({ pageId: deleteId });
2017-03-03 20:17:49 +00:00
this.get('documentService').deletePages(documentId, deleteId, pendingChanges).then(() => {
this.get('documentService').fetchPages(this.get('document.id'), this.get('session.user.id')).then((pages) => {
this.set('pages', pages);
});
2017-03-03 20:17:49 +00:00
});
} else {
this.get('documentService').deletePage(documentId, deleteId).then(() => {
this.get('documentService').fetchPages(this.get('document.id'), this.get('session.user.id')).then((pages) => {
this.set('pages', pages);
});
2017-03-03 20:17:49 +00:00
});
}
},
onInsertSection(data) {
return new EmberPromise((resolve) => {
2017-12-14 16:48:12 +00:00
this.get('documentService').addPage(this.get('document.id'), data).then((newPage) => {
2017-03-03 20:17:49 +00:00
let data = this.get('store').normalize('page', newPage);
this.get('store').push(data);
this.get('documentService').fetchPages(this.get('document.id'), this.get('session.user.id')).then((pages) => {
2017-12-14 16:48:12 +00:00
this.set('pages', pages);
this.eventBus.publish('documentPageAdded', newPage.id);
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',
2017-12-14 16:48:12 +00:00
this.get('folder.id'),
this.get('folder.slug'),
this.get('document.id'),
this.get('document.slug'),
2017-03-04 19:20:01 +00:00
newPage.id);
2017-03-04 21:07:39 +00:00
} else {
this.set('currentPageId', newPage.id);
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 EmberPromise((resolve) => {
2017-03-04 21:07:39 +00:00
this.get('sectionService').deleteBlock(blockId).then(() => {
resolve();
});
});
},
onSavePageAsBlock(block) {
return new EmberPromise((resolve) => {
2017-03-04 21:07:39 +00:00
this.get('sectionService').addBlock(block).then(() => {
resolve();
});
});
},
onDocumentDelete() {
2017-12-14 16:48:12 +00:00
this.get('documentService').deleteDocument(this.get('document.id')).then(() => {
this.transitionToRoute('folder', this.get('folder.id'), this.get('folder.slug'));
});
},
onSaveTemplate(name, desc) {
2017-12-14 16:48:12 +00:00
this.get('templateService').saveAsTemplate(this.get('document.id'), name, desc).then(function () {});
},
onPageSequenceChange(currentPageId, changes) {
this.set('currentPageId', currentPageId);
2017-12-14 16:48:12 +00:00
this.get('documentService').changePageSequence(this.get('document.id'), changes).then(() => {
this.get('documentService').fetchPages(this.get('document.id'), this.get('session.user.id')).then( (pages) => {
2017-12-14 16:48:12 +00:00
this.set('pages', pages);
2017-03-03 20:17:49 +00:00
});
});
},
onPageLevelChange(currentPageId, changes) {
this.set('currentPageId', currentPageId);
2017-12-14 16:48:12 +00:00
this.get('documentService').changePageLevel(this.get('document.id'), changes).then(() => {
this.get('documentService').fetchPages(this.get('document.id'), this.get('session.user.id')).then( (pages) => {
2017-12-14 16:48:12 +00:00
this.set('pages', pages);
2017-03-03 20:17:49 +00:00
});
});
2017-03-07 16:10:13 +00:00
},
onTagChange(tags) {
2017-12-14 16:48:12 +00:00
let doc = this.get('document');
doc.set('tags', tags);
this.get('documentService').save(doc);
2017-12-11 13:45:56 +00:00
},
onRollback(pageId, revisionId) {
2017-12-14 16:48:12 +00:00
this.get('documentService').rollbackPage(this.get('document.id'), pageId, revisionId).then(() => {
2017-12-11 13:45:56 +00:00
this.set('tab', 'content');
this.get('target._routerMicrolib').refresh();
});
},
refresh() {
this.get('documentService').fetchPages(this.get('document.id'), this.get('session.user.id')).then((data) => {
this.set('pages', data);
});
this.get('sectionService').getSpaceBlocks(this.get('folder.id')).then((data) => {
this.set('blocks', data);
});
}
2017-03-03 20:17:49 +00:00
}
});