import { Strings, Type } from '@ephox/katamari'; import Editor from 'tinymce/core/api/Editor'; import { EditorOptions } from 'tinymce/core/api/OptionTypes'; import { UserListItem } from '../ui/DialogTypes'; type UserImageListCallback = (callback: (imageList: UserListItem[]) => void) => void; const option: { (name: K): (editor: Editor) => EditorOptions[K]; (name: string): (editor: Editor) => T; } = (name: string) => (editor: Editor) => editor.options.get(name); const register = (editor: Editor): void => { const registerOption = editor.options.register; registerOption('image_dimensions', { processor: 'boolean', default: true }); registerOption('image_advtab', { processor: 'boolean', default: false }); registerOption('image_uploadtab', { processor: 'boolean', default: true }); registerOption('image_prepend_url', { processor: 'string', default: '' }); registerOption('image_class_list', { processor: 'object[]' }); registerOption('image_description', { processor: 'boolean', default: true }); registerOption('image_title', { processor: 'boolean', default: false }); registerOption('image_caption', { processor: 'boolean', default: false }); registerOption('image_list', { processor: (value) => { const valid = value === false || Type.isString(value) || Type.isArrayOf(value, Type.isObject) || Type.isFunction(value); return valid ? { value, valid } : { valid: false, message: 'Must be false, a string, an array or a function.' }; }, default: false }); }; const hasDimensions = option('image_dimensions'); const hasAdvTab = option('image_advtab'); const hasUploadTab = option('image_uploadtab'); const getPrependUrl = option('image_prepend_url'); const getClassList = option('image_class_list'); const hasDescription = option('image_description'); const hasImageTitle = option('image_title'); const hasImageCaption = option('image_caption'); const getImageList = option('image_list'); const showAccessibilityOptions = option('a11y_advanced_options'); const isAutomaticUploadsEnabled = option('automatic_uploads'); const hasUploadUrl = (editor: Editor): boolean => Strings.isNotEmpty(editor.options.get('images_upload_url')); const hasUploadHandler = (editor: Editor): boolean => Type.isNonNullable(editor.options.get('images_upload_handler')); export { register, hasDimensions, hasUploadTab, hasAdvTab, getPrependUrl, getClassList, hasDescription, hasImageTitle, hasImageCaption, getImageList, hasUploadUrl, hasUploadHandler, showAccessibilityOptions, isAutomaticUploadsEnabled };