123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- /**
- * SPDX-FileCopyrightText: 2017-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2015-2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- (function() {
- /**
- * Construct a new FileActionsMenu instance
- * @constructs FileActionsMenu
- * @memberof OCA.Files
- */
- var FileActionsMenu = OC.Backbone.View.extend({
- tagName: 'div',
- className: 'fileActionsMenu popovermenu bubble hidden open menu',
- /**
- * Current context
- *
- * @type OCA.Files.FileActionContext
- */
- _context: null,
- events: {
- 'click a.action': '_onClickAction'
- },
- template: function(data) {
- return OCA.Files.Templates['fileactionsmenu'](data);
- },
- /**
- * Event handler whenever an action has been clicked within the menu
- *
- * @param {Object} event event object
- */
- _onClickAction: function(event) {
- var $target = $(event.target);
- if (!$target.is('a')) {
- $target = $target.closest('a');
- }
- var fileActions = this._context.fileActions;
- var actionName = $target.attr('data-action');
- var actions = fileActions.getActions(
- fileActions.getCurrentMimeType(),
- fileActions.getCurrentType(),
- fileActions.getCurrentPermissions(),
- fileActions.getCurrentFile()
- );
- var actionSpec = actions[actionName];
- var fileName = this._context.$file.attr('data-file');
- event.stopPropagation();
- event.preventDefault();
- OC.hideMenus();
- actionSpec.action(
- fileName,
- this._context
- );
- },
- /**
- * Renders the menu with the currently set items
- */
- render: function() {
- var self = this;
- var fileActions = this._context.fileActions;
- var actions = fileActions.getActions(
- fileActions.getCurrentMimeType(),
- fileActions.getCurrentType(),
- fileActions.getCurrentPermissions(),
- fileActions.getCurrentFile()
- );
- var defaultAction = fileActions.getCurrentDefaultFileAction();
- var items = _.filter(actions, function(actionSpec) {
- return !defaultAction || actionSpec.name !== defaultAction.name;
- });
- items = _.map(items, function(item) {
- if (_.isFunction(item.displayName)) {
- item = _.extend({}, item);
- item.displayName = item.displayName(self._context);
- }
- if (_.isFunction(item.iconClass)) {
- var fileName = self._context.$file.attr('data-file');
- item = _.extend({}, item);
- item.iconClass = item.iconClass(fileName, self._context);
- }
- if (_.isFunction(item.icon)) {
- var fileName = self._context.$file.attr('data-file');
- item = _.extend({}, item);
- item.icon = item.icon(fileName, self._context);
- }
- item.inline = item.type === OCA.Files.FileActions.TYPE_INLINE
- return item;
- });
- items = items.sort(function(actionA, actionB) {
- var orderA = actionA.order || 0;
- var orderB = actionB.order || 0;
- if (orderB === orderA) {
- return OC.Util.naturalSortCompare(actionA.displayName, actionB.displayName);
- }
- return orderA - orderB;
- });
- items = _.map(items, function(item) {
- item.nameLowerCase = item.name.toLowerCase();
- return item;
- });
- this.$el.html(this.template({
- items: items
- }));
- },
- /**
- * Displays the menu under the given element
- *
- * @param {OCA.Files.FileActionContext} context context
- * @param {Object} $trigger trigger element
- */
- show: function(context) {
- this._context = context;
- this.render();
- this.$el.removeClass('hidden');
- window._nc_event_bus.emit('files:action-menu:opened', {
- el: this.$el[0],
- context,
- })
- OC.showMenu(null, this.$el);
- }
- });
- OCA.Files.FileActionsMenu = FileActionsMenu;
- })();
|