1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-20 13:49:42 +02:00
documize/gui/app/components/folder/folder-toolbar.js

168 lines
3.9 KiB
JavaScript
Raw Normal View History

2016-07-07 18:54:16 -07: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';
import TooltipMixin from '../../mixins/tooltip';
import AuthMixin from '../../mixins/auth';
2016-07-07 18:54:16 -07:00
const {
inject: { service }
} = Ember;
export default Ember.Component.extend(NotifierMixin, TooltipMixin, AuthMixin, {
folderService: service('folder'),
session: service(),
appMeta: service(),
pinned: service(),
2016-10-06 14:13:02 -07:00
showToolbar: false,
2016-10-24 19:20:29 -07:00
folder: {},
busy: false,
moveFolderId: "",
2016-10-07 10:42:20 -07:00
drop: null,
pinState : {
isPinned: false,
pinId: '',
newName: '',
2017-09-19 09:21:51 +01:00
tip: null
},
2017-09-18 13:35:51 +01:00
deleteSpaceName: '',
2016-07-07 18:54:16 -07:00
2016-10-24 19:20:29 -07:00
didReceiveAttrs() {
let targets = _.reject(this.get('folders'), {
id: this.get('folder').get('id')
});
2016-07-07 18:54:16 -07:00
let folder = this.get('folder');
this.set('pinState.pinId', this.get('pinned').isSpacePinned(folder.get('id')));
this.set('pinState.isPinned', this.get('pinState.pinId') !== '');
2017-09-20 08:28:41 +01:00
this.set('pinState.newName', folder.get('name'));
2016-10-24 19:20:29 -07:00
this.set('movedFolderOptions', targets);
},
2016-07-07 18:54:16 -07:00
didRender() {
2017-09-20 08:28:41 +01:00
this.renderTooltips();
},
renderTooltips() {
this.destroyTooltips();
2016-10-24 19:20:29 -07:00
if (this.get('hasSelectedDocuments')) {
2017-09-14 12:54:57 +01:00
if (this.get('permissions.documentMove')) {
this.addTooltip(document.getElementById("move-documents-button"));
}
if (this.get('permissions.documentDelete')) {
this.addTooltip(document.getElementById("delete-documents-button"));
}
2016-10-24 19:20:29 -07:00
} else {
2017-09-14 12:54:57 +01:00
if (this.get('permissions.spaceOwner')) {
2017-09-13 19:22:38 +01:00
this.addTooltip(document.getElementById("space-delete-button"));
2017-09-14 12:54:57 +01:00
}
if (this.get('permissions.spaceManage')) {
2017-09-13 19:22:38 +01:00
this.addTooltip(document.getElementById("space-settings-button"));
2016-10-24 19:20:29 -07:00
}
2017-09-19 09:21:51 +01:00
if (this.get('session.authenticated')) {
2017-09-20 08:28:41 +01:00
this.addTooltip(document.getElementById("space-unpin-button"));
} else {
this.addTooltip(document.getElementById("space-pin-button"));
2017-09-19 09:21:51 +01:00
}
2016-10-24 19:20:29 -07:00
}
},
2016-10-24 19:20:29 -07:00
willDestroyElement() {
2017-09-20 08:28:41 +01:00
if (this.get('isDestroyed') || this.get('isDestroying')) {
return;
}
2016-10-07 10:42:20 -07:00
if (is.not.null(this.get('drop'))) {
this.get('drop').destroy();
this.set('drop', null);
}
2016-10-24 19:20:29 -07:00
this.destroyTooltips();
},
2016-07-07 18:54:16 -07:00
2016-10-24 19:20:29 -07:00
actions: {
onUnpin() {
this.get('pinned').unpinItem(this.get('pinState.pinId')).then(() => {
this.set('pinState.isPinned', false);
this.set('pinState.pinId', '');
this.eventBus.publish('pinChange');
2017-09-20 08:28:41 +01:00
this.renderTooltips();
});
},
onPin() {
let pin = {
pin: this.get('pinState.newName'),
documentId: '',
folderId: this.get('folder.id')
};
if (is.empty(pin.pin)) {
$('#pin-space-name').addClass('error').focus();
return false;
}
this.get('pinned').pinItem(pin).then((pin) => {
this.set('pinState.isPinned', true);
this.set('pinState.pinId', pin.get('id'));
this.eventBus.publish('pinChange');
2017-09-20 08:28:41 +01:00
this.renderTooltips();
});
return true;
},
2016-10-24 19:20:29 -07:00
deleteDocuments() {
2016-07-07 18:54:16 -07:00
this.attrs.onDeleteDocument();
2016-10-24 19:20:29 -07:00
},
2016-07-07 18:54:16 -07:00
2017-09-18 13:35:51 +01:00
deleteSpace() {
let spaceName = this.get('folder').get('name');
let spaceNameTyped = this.get('deleteSpaceName');
if (spaceNameTyped !== spaceName || spaceNameTyped === '' || spaceName === '') {
$("#delete-space-name").addClass("error").focus();
return false;
}
this.set('deleteSpaceName', '');
$("#delete-space-name").removeClass("error");
this.attrs.onDeleteSpace();
return true;
},
2016-10-24 19:20:29 -07:00
setMoveFolder(folderId) {
this.set('moveFolderId', folderId);
2016-07-07 18:54:16 -07:00
2016-10-24 19:20:29 -07:00
let folders = this.get('folders');
2016-07-07 18:54:16 -07:00
2016-10-24 19:20:29 -07:00
folders.forEach(folder => {
folder.set('selected', folder.id === folderId);
});
},
2016-07-07 18:54:16 -07:00
2016-10-24 19:20:29 -07:00
moveDocuments() {
if (this.get("moveFolderId") === "") {
return false;
}
2016-07-07 18:54:16 -07:00
2016-10-24 19:20:29 -07:00
this.attrs.onMoveDocument(this.get('moveFolderId'));
2016-07-07 18:54:16 -07:00
2016-11-21 19:27:18 -08:00
return true;
}
2016-10-24 19:20:29 -07:00
}
2016-07-07 18:54:16 -07:00
});