-
Notifications
You must be signed in to change notification settings - Fork 24
/
layout-selector.js
116 lines (101 loc) · 3.15 KB
/
layout-selector.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
(function ($, EventDispatcher, CollageEditor, Collage) {
/**
* A small widget that makes it easy to switch between collage layouts.
*
* @class H5PEditor.Collage.LayoutSelector
* @extends H5P.EventDispatcher
* @param {H5P.jQuery} $container
* @param {Array} layouts
* @param {string} selectedDefault
*/
CollageEditor.LayoutSelector = function ($container, layouts, selectedDefault, clips) {
var self = this;
// Initialize event inheritance
EventDispatcher.call(self);
// In case editor is loaded before collage
Collage = H5P.Collage;
// Create wrapper
var $wrapper = $('<div/>', {
'class': 'h5p-collage-editor-layout-selector'
});
// Keep track of selected layout
var $selected;
/**
* Adds a preview of the given layout.
*
* @private
* @param {string} layout
*/
var addLayout = function (layout) {
var $layout = $('<div/>', {
'class': 'h5p-collage-editor-layout-preview' + (layout.value === selectedDefault ? ' h5p-collage-selected-layout' : ''),
tabIndex: '0',
role: 'button',
title: layout.label,
on: {
click: function () {
selectLayout($layout, layout.value);
},
keydown: function (event) {
if (event.which === 32) {
event.preventDefault();
}
},
keyup: function (event) {
if (event.which === 32) {
selectLayout($layout, layout.value);
}
}
},
appendTo: $wrapper
});
(new Collage.Template(0.25, layout.value)).appendTo($layout);
if (layout.value === selectedDefault) {
$selected = $layout;
}
};
/**
* Selects the given layout.
*
* @private
* @param {H5P.jQuery} $preview
* @param {string} layout
*/
var selectLayout = function ($preview, layout) {
const applyChanges = () => {
$selected.removeClass('h5p-collage-selected-layout');
$selected = $preview.addClass('h5p-collage-selected-layout');
self.warn = false;
self.trigger('layoutChanged', layout);
}
if ($preview === $selected) {
return;
}
if (self.warn) {
const confirmationDialog = CollageEditor.showConfirmationDialog($wrapper, {
headerText: CollageEditor.t('pleaseConfirm'),
dialogText: CollageEditor.t('confirmReset'),
cancelText: H5PEditor.t('core', 'cancel'),
confirmText: H5PEditor.t('core', 'ok'),
});
confirmationDialog.on('canceled', () => {
return;
});
confirmationDialog.on('confirmed', () => {
applyChanges();
});
}
else {
applyChanges();
}
};
// Add options
for (var i = 0; i < layouts.length; i++) {
addLayout(layouts[i]);
}
$wrapper.appendTo($container);
};
// Extends the event dispatcher
CollageEditor.LayoutSelector.prototype = Object.create(EventDispatcher.prototype);
CollageEditor.LayoutSelector.prototype.constructor = CollageEditor.LayoutSelector;
})(H5P.jQuery, H5P.EventDispatcher, H5PEditor.Collage);