UNPKG

jodit

Version:

Jodit is awesome and usefully wysiwyg editor with filebrowser

115 lines (96 loc) 3.11 kB
/*! * Jodit Editor (https://xdsoft.net/jodit/) * Licensed under GNU General Public License version 2 or later or a commercial license or MIT; * For GPL see LICENSE-GPL.txt in the project root for license information. * For MIT see LICENSE-MIT.txt in the project root for license information. * For commercial licenses see https://xdsoft.net/jodit/commercial/ * Copyright (c) 2013-2019 Valeriy Chupurnov. All rights reserved. https://xdsoft.net */ import { Dialog } from './dialog'; import { ToolbarIcon } from '../toolbar/icon'; /** * Show `promt` dialog. Work without Jodit object * * @method Promt * @param {string} msg Message * @param {string|function} [title] Title or callback * @param {function} [callback] callback. The first argument is the value entered * @param {string} [placeholder] Placeholder for input * @example * ```javascript * Jodit.Promt("Enter your name", "Promt Dialog", function (name) { * if (name.length < 3) { * Jodit.Alert("The name must be at least 3 letters"); * return false; * } * // do something * }); * ``` */ export const Promt = ( msg: string, title: string | (() => false | void) | undefined, callback: (value: string) => false | void, placeholder?: string, defaultValue?: string ): Dialog => { const dialog: Dialog = new Dialog(), cancelButton: HTMLAnchorElement = dialog.create.fromHTML( '<a href="javascript:void(0)" style="float:right;" class="jodit_button">' + ToolbarIcon.getIcon('cancel') + '<span>' + Jodit.prototype.i18n('Cancel') + '</span></a>' ) as HTMLAnchorElement, okButton: HTMLAnchorElement = dialog.create.fromHTML( '<a href="javascript:void(0)" style="float:left;" class="jodit_button">' + ToolbarIcon.getIcon('check') + '<span>' + Jodit.prototype.i18n('Ok') + '</span></a>' ) as HTMLAnchorElement, form: HTMLFormElement = dialog.create.element('form', { class: 'jodit_promt' }), inputElement: HTMLInputElement = dialog.create.element('input', { autofocus: true, class: 'jodit_input' }), labelElement: HTMLLabelElement = dialog.create.element( 'label' ) as HTMLLabelElement; if (typeof title === 'function') { callback = title; title = undefined; } if (placeholder) { inputElement.setAttribute('placeholder', placeholder); } labelElement.appendChild(dialog.create.text(msg)); form.appendChild(labelElement); form.appendChild(inputElement); cancelButton.addEventListener('click', dialog.close, false); const onclick = () => { if ( !callback || typeof callback !== 'function' || callback(inputElement.value) !== false ) { dialog.close(); } }; okButton.addEventListener('click', onclick); form.addEventListener('submit', () => { onclick(); return false; }); dialog.setFooter([okButton, cancelButton]); dialog.open(form, (title as string) || '&nbsp;', true, true); inputElement.focus(); if (defaultValue !== undefined && defaultValue.length) { inputElement.value = defaultValue; inputElement.select(); } return dialog; }; import { Jodit } from '../../Jodit';