123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- /**
- * Copyright (c) Tiny Technologies, Inc. All rights reserved.
- * Licensed under the LGPL or a commercial license.
- * For LGPL see License.txt in the project root for license information.
- * For commercial licenses see https://www.tiny.cloud/
- *
- * Version: 5.1.0 (2019-10-17)
- */
- (function () {
- 'use strict';
- var Cell = function (initial) {
- var value = initial;
- var get = function () {
- return value;
- };
- var set = function (v) {
- value = v;
- };
- var clone = function () {
- return Cell(get());
- };
- return {
- get: get,
- set: set,
- clone: clone
- };
- };
- var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
- var global$1 = tinymce.util.Tools.resolve('tinymce.Env');
- var global$2 = tinymce.util.Tools.resolve('tinymce.util.Delay');
- var fireResizeEditor = function (editor) {
- return editor.fire('ResizeEditor');
- };
- var Events = { fireResizeEditor: fireResizeEditor };
- var getAutoResizeMinHeight = function (editor) {
- return editor.getParam('min_height', editor.getElement().offsetHeight, 'number');
- };
- var getAutoResizeMaxHeight = function (editor) {
- return editor.getParam('max_height', 0, 'number');
- };
- var getAutoResizeOverflowPadding = function (editor) {
- return editor.getParam('autoresize_overflow_padding', 1, 'number');
- };
- var getAutoResizeBottomMargin = function (editor) {
- return editor.getParam('autoresize_bottom_margin', 50, 'number');
- };
- var shouldAutoResizeOnInit = function (editor) {
- return editor.getParam('autoresize_on_init', true, 'boolean');
- };
- var Settings = {
- getAutoResizeMinHeight: getAutoResizeMinHeight,
- getAutoResizeMaxHeight: getAutoResizeMaxHeight,
- getAutoResizeOverflowPadding: getAutoResizeOverflowPadding,
- getAutoResizeBottomMargin: getAutoResizeBottomMargin,
- shouldAutoResizeOnInit: shouldAutoResizeOnInit
- };
- var isFullscreen = function (editor) {
- return editor.plugins.fullscreen && editor.plugins.fullscreen.isFullscreen();
- };
- var wait = function (editor, oldSize, times, interval, callback) {
- global$2.setEditorTimeout(editor, function () {
- resize(editor, oldSize);
- if (times--) {
- wait(editor, oldSize, times, interval, callback);
- } else if (callback) {
- callback();
- }
- }, interval);
- };
- var toggleScrolling = function (editor, state) {
- var body = editor.getBody();
- if (body) {
- body.style.overflowY = state ? '' : 'hidden';
- if (!state) {
- body.scrollTop = 0;
- }
- }
- };
- var parseCssValueToInt = function (dom, elm, name, computed) {
- var value = parseInt(dom.getStyle(elm, name, computed), 10);
- return isNaN(value) ? 0 : value;
- };
- var resize = function (editor, oldSize) {
- var deltaSize, resizeHeight, contentHeight;
- var dom = editor.dom;
- var doc = editor.getDoc();
- if (!doc) {
- return;
- }
- if (isFullscreen(editor)) {
- toggleScrolling(editor, true);
- return;
- }
- var docEle = doc.documentElement;
- var resizeBottomMargin = Settings.getAutoResizeBottomMargin(editor);
- resizeHeight = Settings.getAutoResizeMinHeight(editor);
- var marginTop = parseCssValueToInt(dom, docEle, 'margin-top', true);
- var marginBottom = parseCssValueToInt(dom, docEle, 'margin-bottom', true);
- contentHeight = docEle.offsetHeight + marginTop + marginBottom + resizeBottomMargin;
- if (contentHeight < 0) {
- contentHeight = 0;
- }
- var containerHeight = editor.getContainer().offsetHeight;
- var contentAreaHeight = editor.getContentAreaContainer().offsetHeight;
- var chromeHeight = containerHeight - contentAreaHeight;
- if (contentHeight + chromeHeight > Settings.getAutoResizeMinHeight(editor)) {
- resizeHeight = contentHeight + chromeHeight;
- }
- var maxHeight = Settings.getAutoResizeMaxHeight(editor);
- if (maxHeight && resizeHeight > maxHeight) {
- resizeHeight = maxHeight;
- toggleScrolling(editor, true);
- } else {
- toggleScrolling(editor, false);
- }
- if (resizeHeight !== oldSize.get()) {
- deltaSize = resizeHeight - oldSize.get();
- dom.setStyle(editor.getContainer(), 'height', resizeHeight + 'px');
- oldSize.set(resizeHeight);
- Events.fireResizeEditor(editor);
- if (global$1.browser.isSafari() && global$1.mac) {
- var win = editor.getWin();
- win.scrollTo(win.pageXOffset, win.pageYOffset);
- }
- if (editor.hasFocus()) {
- editor.selection.scrollIntoView(editor.selection.getNode());
- }
- if (global$1.webkit && deltaSize < 0) {
- resize(editor, oldSize);
- }
- }
- };
- var setup = function (editor, oldSize) {
- editor.on('init', function () {
- var overflowPadding = Settings.getAutoResizeOverflowPadding(editor);
- var dom = editor.dom;
- dom.setStyles(editor.getBody(), {
- 'paddingLeft': overflowPadding,
- 'paddingRight': overflowPadding,
- 'min-height': 0
- });
- });
- editor.on('NodeChange SetContent keyup FullscreenStateChanged ResizeContent', function () {
- resize(editor, oldSize);
- });
- if (Settings.shouldAutoResizeOnInit(editor)) {
- editor.on('init', function () {
- wait(editor, oldSize, 20, 100, function () {
- wait(editor, oldSize, 5, 1000);
- });
- });
- }
- };
- var Resize = {
- setup: setup,
- resize: resize
- };
- var register = function (editor, oldSize) {
- editor.addCommand('mceAutoResize', function () {
- Resize.resize(editor, oldSize);
- });
- };
- var Commands = { register: register };
- function Plugin () {
- global.add('autoresize', function (editor) {
- if (!editor.settings.hasOwnProperty('resize')) {
- editor.settings.resize = false;
- }
- if (!editor.inline) {
- var oldSize = Cell(0);
- Commands.register(editor, oldSize);
- Resize.setup(editor, oldSize);
- }
- });
- }
- Plugin();
- }());
|