Skip to content

Commit

Permalink
Add dropDownMenuItems in editor API
Browse files Browse the repository at this point in the history
Make FileInputView extendible for adding
custom menu items via menuName.

REDMINE-20881
  • Loading branch information
DanielKuhn committed Dec 12, 2024
1 parent 5d13dc6 commit fd4d76a
Show file tree
Hide file tree
Showing 5 changed files with 137 additions and 0 deletions.
72 changes: 72 additions & 0 deletions package/spec/editor/api/DropDownMenuItems-spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
import {DropDownMenuItems} from 'pageflow/editor/api/DropDownMenuItems';

import sinon from 'sinon';

describe('DropDownMenuItems', () => {
describe('#register/#findAllByMenuName', () => {
it(
'allows getting a list of menu items by menu name',
() => {
var dropDownMenuItems = new DropDownMenuItems();

dropDownMenuItems.register({
name: 'custom',
label: 'Custom Item',
selected: () => {}
}, {
menuName: 'someMenu',
});

var menuItem = dropDownMenuItems.findAllByMenuName('someMenu')[0];

expect(menuItem.name).toBe('custom');
}
);

it(
'only returns the list of menu items for the specified menu name',
() => {
var dropDownMenuItems = new DropDownMenuItems();

dropDownMenuItems.register({
name: 'custom',
label: 'Custom Item',
selected: () => {}
}, {
menuName: 'someOtherMenu',
});

var menuItems = dropDownMenuItems.findAllByMenuName('someMenu');

expect(menuItems.length).toBe(0);
}
);

it(
'allows registering multiple menu items per menu name',
() => {
var dropDownMenuItems = new DropDownMenuItems();

dropDownMenuItems.register({
name: 'custom1',
label: 'Custom Item 1',
selected: () => {}
}, {
menuName: 'someMenu',
});

dropDownMenuItems.register({
name: 'custom2',
label: 'Custom Item 2',
selected: () => {}
}, {
menuName: 'someMenu',
});

var menuItems = dropDownMenuItems.findAllByMenuName('someMenu');

expect(menuItems.length).toBe(2);
}
);
});
});
37 changes: 37 additions & 0 deletions package/spec/editor/views/inputs/FileInputView-spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import Backbone from 'backbone';

import * as support from '$support';
import {DropDownButton} from '$support/dominos/editor';
import {editor} from 'pageflow/editor';

describe('FileInputView', () => {
let testContext;
Expand Down Expand Up @@ -65,6 +66,42 @@ describe('FileInputView', () => {
});
});

it('can render additional drop down menu item registered via editor API', () => {
const fixture = support.factories.imageFilesFixture({
imageFileAttributes: {perma_id: 5}
});
const model = new Configuration({
file_id: 5,
});
const handler = jest.fn();

editor.dropDownMenuItems.register({
name: 'api_custom',
label: 'Custom Item added via editor API',
selected: handler
}, {
menuName: 'backdropImageFileInput',
}
)

var fileInputView = new FileInputView({
collection: fixture.imageFiles,
model: model,
propertyName: 'file_id',
dropDownMenuName: 'backdropImageFileInput'
});

fileInputView.render();
var dropDownButton = DropDownButton.find(fileInputView);
dropDownButton.selectMenuItemByLabel('Custom Item added via editor API');

expect(handler).toHaveBeenCalledWith({
inputModel: model,
propertyName: 'file_id',
file: fixture.imageFile
});
});

it('supports nested items in additional drop down menu items', () => {
const fixture = support.factories.imageFilesFixture({
imageFileAttributes: {perma_id: 5}
Expand Down
14 changes: 14 additions & 0 deletions package/src/editor/api/DropDownMenuItems.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import {Object} from 'pageflow/ui';

export const DropDownMenuItems = Object.extend({
initialize: function() {
this.menuItems = {};
},
register: function(menuItem, {menuName}) {
this.menuItems[menuName] = this.menuItems[menuName] || [];
this.menuItems[menuName].push(menuItem);
},
findAllByMenuName: function(menuName) {
return this.menuItems[menuName] || [];
}
});
7 changes: 7 additions & 0 deletions package/src/editor/api/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import _ from 'underscore';
import {Object} from 'pageflow/ui';

import {CommonPageConfigurationTabs} from './CommonPageConfigurationTabs';
import {DropDownMenuItems} from './DropDownMenuItems';
import {FailuresAPI} from './Failures';
import {FileTypes} from './FileTypes';
import {FileImporters} from './FileImporters'
Expand Down Expand Up @@ -79,6 +80,12 @@ export const EditorApi = Object.extend(
* @memberof editor
*/
this.fileImporters = new FileImporters();

/**
* List of additional menu items for dropdown menus
* @memberof editor
*/
this.dropDownMenuItems = new DropDownMenuItems();
},

/**
Expand Down
7 changes: 7 additions & 0 deletions package/src/editor/views/inputs/FileInputView.js
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,13 @@ export const FileInputView = Marionette.ItemView.extend({
items.add(this._createCustomMenuItem(file, item));
});

if (this.options.dropDownMenuName) {
const customItems = editor.dropDownMenuItems.findAllByMenuName(this.options.dropDownMenuName);
_.each(customItems, item => {
items.add(this._createCustomMenuItem(file, item));
});
}

items.add(new FileInputView.EditFileSettingsMenuItem({
name: 'edit_file_settings',
label: I18n.t('pageflow.editor.views.inputs.file_input.edit_file_settings')
Expand Down

0 comments on commit fd4d76a

Please sign in to comment.