META-INF.resources._diffs.plugins.uinumberinput.plugin.js Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.liferay.frontend.editor.ckeditor.web
Show all versions of com.liferay.frontend.editor.ckeditor.web
Liferay Frontend Editor CKEditor Web
The newest version!
/**
* SPDX-FileCopyrightText: (c) 2000 Liferay, Inc. https://liferay.com
* SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
*/
(function () {
const pluginName = 'uinumberinput';
if (CKEDITOR.plugins.get(pluginName)) {
return;
}
const template = new CKEDITOR.template((data) => {
const output = [''];
if (data.label) {
output.push('');
}
output.push(
''
);
output.push('');
return output.join('');
});
CKEDITOR.ui.balloonToolbarNumberInput = CKEDITOR.tools.createClass({
// eslint-disable-next-line
$: function (definition) {
CKEDITOR.tools.extend(this, definition, {
change: definition.change || function () {},
label: definition.label || '',
max: definition.max,
min: definition.min || 0,
modes: {wysiwyg: 1},
step: definition.step || 1,
value: definition.value || 0,
});
},
base: CKEDITOR.event,
proto: {
render(editor, output) {
const id = CKEDITOR.tools.getNextId();
this._id = id;
const input = this;
this._editor = editor;
const instance = {
input,
};
const changeFn = CKEDITOR.tools.addFunction((event) => {
event.preventDefault();
const value = event.target.valueAsNumber;
input.value = value;
input.change(value);
input.fire(
'change',
{
value,
},
input._editor
);
});
const params = {
changeFn,
id,
label: this.label,
max: this.max,
min: this.min,
step: this.step,
value: this.value,
};
template.output(params, output);
this._element = this._editor.document.findOne(`#${id}`);
return instance;
},
},
});
CKEDITOR.ui.balloonToolbarNumberInput.handler = {
create(definition) {
return new CKEDITOR.ui.balloonToolbarNumberInput(definition);
},
};
CKEDITOR.UI_BALLOON_NUMBER_INPUT = 'balloonToolbarNumberInput';
CKEDITOR.tools.extend(CKEDITOR.ui.prototype, {
addBalloonToolbarNumberInput(name, definition) {
this.add(name, CKEDITOR.UI_BALLOON_NUMBER_INPUT, definition);
},
});
CKEDITOR.plugins.add(pluginName, {
init(editor) {
editor.ui.addHandler(
CKEDITOR.UI_BALLOON_NUMBER_INPUT,
CKEDITOR.ui.balloonToolbarNumberInput.handler
);
},
});
})();
© 2015 - 2025 Weber Informatics LLC | Privacy Policy