pxx-vue-quill 1.0.104 → 1.0.105

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -7,7 +7,7 @@
7
7
  *
8
8
  * Copyright (c) 2025 Pxx-Team
9
9
  * Released under the MIT license
10
- * Date: 2025-09-10T02:22:02.488Z
10
+ * Date: 2025-09-10T02:29:22.095Z
11
11
  */
12
12
  (function (global, factory) {
13
13
  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('vue')) :
@@ -1993,27 +1993,6 @@
1993
1993
  return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
1994
1994
  }
1995
1995
 
1996
- function getAugmentedNamespace(n) {
1997
- var f = n.default;
1998
- if (typeof f == "function") {
1999
- var a = function () {
2000
- return f.apply(this, arguments);
2001
- };
2002
- a.prototype = f.prototype;
2003
- } else a = {};
2004
- Object.defineProperty(a, '__esModule', {value: true});
2005
- Object.keys(n).forEach(function (k) {
2006
- var d = Object.getOwnPropertyDescriptor(n, k);
2007
- Object.defineProperty(a, k, d.get ? d : {
2008
- enumerable: true,
2009
- get: function () {
2010
- return n[k];
2011
- }
2012
- });
2013
- });
2014
- return a;
2015
- }
2016
-
2017
1996
  var quill = {exports: {}};
2018
1997
 
2019
1998
  (function (module, exports) {
@@ -18665,1718 +18644,221 @@
18665
18644
  }
18666
18645
  });
18667
18646
 
18668
- var dist = {};
18669
-
18670
- var Options = {};
18671
-
18672
- var BlotSpec = {};
18673
-
18674
- var BlotFormatter$1 = {};
18675
-
18676
- var isMergeableObject = function isMergeableObject(value) {
18677
- return isNonNullObject(value)
18678
- && !isSpecial(value)
18679
- };
18680
-
18681
- function isNonNullObject(value) {
18682
- return !!value && typeof value === 'object'
18683
- }
18684
-
18685
- function isSpecial(value) {
18686
- var stringValue = Object.prototype.toString.call(value);
18687
-
18688
- return stringValue === '[object RegExp]'
18689
- || stringValue === '[object Date]'
18690
- || isReactElement(value)
18691
- }
18692
-
18693
- // see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25
18694
- var canUseSymbol = typeof Symbol === 'function' && Symbol.for;
18695
- var REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7;
18696
-
18697
- function isReactElement(value) {
18698
- return value.$$typeof === REACT_ELEMENT_TYPE
18699
- }
18700
-
18701
- function emptyTarget(val) {
18702
- return Array.isArray(val) ? [] : {}
18703
- }
18704
-
18705
- function cloneUnlessOtherwiseSpecified(value, options) {
18706
- return (options.clone !== false && options.isMergeableObject(value))
18707
- ? deepmerge(emptyTarget(value), value, options)
18708
- : value
18709
- }
18710
-
18711
- function defaultArrayMerge(target, source, options) {
18712
- return target.concat(source).map(function(element) {
18713
- return cloneUnlessOtherwiseSpecified(element, options)
18714
- })
18647
+ const BlotFormatterModule = require('quill-blot-formatter');
18648
+ const BlotFormatter = BlotFormatterModule.default;
18649
+ function useBlotFormatter(editor, enableImageResize = true) {
18650
+ const quillRef = vue.ref(null);
18651
+ const removeQuillBlotFormatter = () => {
18652
+ var _a;
18653
+ try {
18654
+ const blotFormatter = (_a = quillRef.value) === null || _a === void 0 ? void 0 : _a.getModule('blotFormatter');
18655
+ if (blotFormatter && blotFormatter.overlay) {
18656
+ const overlay = blotFormatter.overlay;
18657
+ if (overlay.parentNode) {
18658
+ overlay.parentNode.removeChild(overlay);
18659
+ }
18660
+ }
18661
+ }
18662
+ catch (error) {
18663
+ console.warn('移除blotFormatter overlay时出错:', error);
18664
+ }
18665
+ };
18666
+ const handleBlotFormatterClick = (event) => {
18667
+ var _a;
18668
+ if (!editor.value)
18669
+ return;
18670
+ const blotFormatter = (_a = quillRef.value) === null || _a === void 0 ? void 0 : _a.getModule('blotFormatter');
18671
+ if (!blotFormatter || !blotFormatter.overlay)
18672
+ return;
18673
+ const isClickInsideEditor = editor.value.contains(event.target);
18674
+ if (!isClickInsideEditor) {
18675
+ removeQuillBlotFormatter();
18676
+ }
18677
+ };
18678
+ const configureBlotFormatter = () => {
18679
+ if (!quillRef.value)
18680
+ return;
18681
+ const blotFormatter = quillRef.value.getModule('blotFormatter');
18682
+ if (blotFormatter) {
18683
+ const originalShow = blotFormatter.show.bind(blotFormatter);
18684
+ blotFormatter.show = function (spec) {
18685
+ var _a;
18686
+ originalShow(spec);
18687
+ const target = (_a = this.currentSpec) === null || _a === void 0 ? void 0 : _a.getTargetElement();
18688
+ if (target && target.tagName === 'IMG') {
18689
+ target.style.maxWidth = '100%';
18690
+ target.style.height = 'auto';
18691
+ target.style.objectFit = 'contain';
18692
+ const width = target.getAttribute('width');
18693
+ if (width) {
18694
+ const naturalWidth = target.naturalWidth;
18695
+ const naturalHeight = target.naturalHeight;
18696
+ if (naturalWidth && naturalHeight) {
18697
+ const aspectRatio = naturalHeight / naturalWidth;
18698
+ const newHeight = Math.round(parseInt(width) * aspectRatio);
18699
+ target.setAttribute('height', '' + newHeight);
18700
+ }
18701
+ }
18702
+ }
18703
+ };
18704
+ }
18705
+ };
18706
+ const applyImageStyle = () => {
18707
+ var _a;
18708
+ if (!quillRef.value)
18709
+ return;
18710
+ const editorElement = (_a = editor.value) === null || _a === void 0 ? void 0 : _a.querySelector('.ql-editor');
18711
+ if (editorElement) {
18712
+ const images = editorElement.querySelectorAll('img');
18713
+ images.forEach(img => {
18714
+ img.style.maxWidth = '100%';
18715
+ img.style.height = 'auto';
18716
+ img.style.objectFit = 'contain';
18717
+ });
18718
+ }
18719
+ };
18720
+ const registerBlotFormatter = () => {
18721
+ if (!enableImageResize) {
18722
+ return;
18723
+ }
18724
+ try {
18725
+ Quill.register('modules/blotFormatter', BlotFormatter);
18726
+ console.log('BlotFormatter模块已注册');
18727
+ }
18728
+ catch (error) {
18729
+ console.warn('注册BlotFormatter模块时出错:', error);
18730
+ }
18731
+ };
18732
+ const getBlotFormatterConfig = () => {
18733
+ if (!enableImageResize) {
18734
+ return {};
18735
+ }
18736
+ return {
18737
+ modules: {
18738
+ blotFormatter: true
18739
+ }
18740
+ };
18741
+ };
18742
+ vue.onBeforeUnmount(() => {
18743
+ removeQuillBlotFormatter();
18744
+ });
18745
+ const setQuill = (quillInstance) => {
18746
+ quillRef.value = quillInstance;
18747
+ };
18748
+ return {
18749
+ quillRef,
18750
+ setQuill,
18751
+ handleBlotFormatterClick,
18752
+ configureBlotFormatter,
18753
+ applyImageStyle,
18754
+ registerBlotFormatter,
18755
+ getBlotFormatterConfig
18756
+ };
18715
18757
  }
18716
18758
 
18717
- function mergeObject(target, source, options) {
18718
- var destination = {};
18719
- if (options.isMergeableObject(target)) {
18720
- Object.keys(target).forEach(function(key) {
18721
- destination[key] = cloneUnlessOtherwiseSpecified(target[key], options);
18722
- });
18723
- }
18724
- Object.keys(source).forEach(function(key) {
18725
- if (!options.isMergeableObject(source[key]) || !target[key]) {
18726
- destination[key] = cloneUnlessOtherwiseSpecified(source[key], options);
18727
- } else {
18728
- destination[key] = deepmerge(target[key], source[key], options);
18729
- }
18730
- });
18731
- return destination
18759
+ function useLinkClick(editor, initialHandleCustomLink) {
18760
+ const quillRef = vue.ref(null);
18761
+ const handleCustomLinkRef = vue.ref(initialHandleCustomLink || null);
18762
+ const handleLinkClick = (event) => {
18763
+ if (!quillRef.value || !handleCustomLinkRef.value)
18764
+ return;
18765
+ const target = event.target;
18766
+ if (target.tagName === 'A') {
18767
+ event.preventDefault();
18768
+ event.stopPropagation();
18769
+ try {
18770
+ const linkElement = target;
18771
+ const linkUrl = linkElement.getAttribute('href') || '';
18772
+ const linkText = linkElement.textContent || '';
18773
+ const range = quillRef.value.getSelection();
18774
+ if (range) {
18775
+ const [blot] = quillRef.value.getLeaf(range.index);
18776
+ if (blot && blot.parent && blot.parent.domNode.tagName === 'A') {
18777
+ const linkBlot = blot.parent;
18778
+ const linkIndex = quillRef.value.getIndex(linkBlot);
18779
+ const linkLength = linkBlot.length();
18780
+ quillRef.value.setSelection(linkIndex, linkLength);
18781
+ handleCustomLinkRef.value(true, { url: linkUrl, text: linkText });
18782
+ }
18783
+ }
18784
+ }
18785
+ catch (error) {
18786
+ console.warn('选中链接失败:', error);
18787
+ }
18788
+ }
18789
+ };
18790
+ const addLinkClickListener = () => {
18791
+ if (!quillRef.value)
18792
+ return;
18793
+ vue.nextTick(() => {
18794
+ var _a;
18795
+ const editorElement = (_a = editor.value) === null || _a === void 0 ? void 0 : _a.querySelector('.ql-editor');
18796
+ if (editorElement) {
18797
+ editorElement.removeEventListener('click', handleLinkClick);
18798
+ editorElement.addEventListener('click', handleLinkClick);
18799
+ }
18800
+ });
18801
+ };
18802
+ const setQuill = (quillInstance) => {
18803
+ quillRef.value = quillInstance;
18804
+ };
18805
+ const setHandleCustomLink = (fn) => {
18806
+ handleCustomLinkRef.value = fn;
18807
+ };
18808
+ return {
18809
+ quillRef,
18810
+ setQuill,
18811
+ setHandleCustomLink,
18812
+ handleLinkClick,
18813
+ addLinkClickListener
18814
+ };
18732
18815
  }
18733
18816
 
18734
- function deepmerge(target, source, options) {
18735
- options = options || {};
18736
- options.arrayMerge = options.arrayMerge || defaultArrayMerge;
18737
- options.isMergeableObject = options.isMergeableObject || isMergeableObject;
18738
-
18739
- var sourceIsArray = Array.isArray(source);
18740
- var targetIsArray = Array.isArray(target);
18741
- var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;
18742
-
18743
- if (!sourceAndTargetTypesMatch) {
18744
- return cloneUnlessOtherwiseSpecified(source, options)
18745
- } else if (sourceIsArray) {
18746
- return options.arrayMerge(target, source, options)
18747
- } else {
18748
- return mergeObject(target, source, options)
18749
- }
18817
+ function useGlobalClick() {
18818
+ const clickHandlers = vue.ref([]);
18819
+ const handleGlobalClick = (event) => {
18820
+ clickHandlers.value.forEach(handler => {
18821
+ try {
18822
+ handler(event);
18823
+ }
18824
+ catch (error) {
18825
+ console.warn('全局点击事件处理函数执行出错:', error);
18826
+ }
18827
+ });
18828
+ };
18829
+ const addClickHandler = (handler) => {
18830
+ if (typeof handler === 'function' && !clickHandlers.value.includes(handler)) {
18831
+ clickHandlers.value.push(handler);
18832
+ }
18833
+ };
18834
+ const clearClickHandlers = () => {
18835
+ clickHandlers.value = [];
18836
+ };
18837
+ vue.onMounted(() => {
18838
+ window.addEventListener('click', handleGlobalClick);
18839
+ });
18840
+ vue.onBeforeUnmount(() => {
18841
+ window.removeEventListener('click', handleGlobalClick);
18842
+ clearClickHandlers();
18843
+ });
18844
+ return {
18845
+ clickHandlers: clickHandlers.value,
18846
+ addClickHandler,
18847
+ clearClickHandlers,
18848
+ handleGlobalClick
18849
+ };
18750
18850
  }
18751
18851
 
18752
- deepmerge.all = function deepmergeAll(array, options) {
18753
- if (!Array.isArray(array)) {
18754
- throw new Error('first argument should be an array')
18755
- }
18756
-
18757
- return array.reduce(function(prev, next) {
18758
- return deepmerge(prev, next, options)
18759
- }, {})
18760
- };
18761
-
18762
- var deepmerge_1 = deepmerge;
18763
-
18764
- var es = /*#__PURE__*/Object.freeze({
18765
- __proto__: null,
18766
- 'default': deepmerge_1
18767
- });
18768
-
18769
- var require$$0 = /*@__PURE__*/getAugmentedNamespace(es);
18770
-
18771
- var Action = {};
18772
-
18773
- var hasRequiredAction;
18774
-
18775
- function requireAction () {
18776
- if (hasRequiredAction) return Action;
18777
- hasRequiredAction = 1;
18778
-
18779
- Object.defineProperty(Action, "__esModule", {
18780
- value: true
18781
- });
18782
-
18783
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
18784
-
18785
- var _BlotFormatter = requireBlotFormatter();
18786
-
18787
- _interopRequireDefault(_BlotFormatter);
18788
-
18789
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18790
-
18791
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
18792
-
18793
- var Action$1 = function () {
18794
- function Action(formatter) {
18795
- _classCallCheck(this, Action);
18796
-
18797
- this.formatter = formatter;
18798
- }
18799
-
18800
- _createClass(Action, [{
18801
- key: 'onCreate',
18802
- value: function onCreate() {}
18803
- }, {
18804
- key: 'onDestroy',
18805
- value: function onDestroy() {}
18806
- }, {
18807
- key: 'onUpdate',
18808
- value: function onUpdate() {}
18809
- }]);
18810
-
18811
- return Action;
18812
- }();
18813
-
18814
- Action.default = Action$1;
18815
- return Action;
18816
- }
18817
-
18818
- var hasRequiredBlotFormatter;
18819
-
18820
- function requireBlotFormatter () {
18821
- if (hasRequiredBlotFormatter) return BlotFormatter$1;
18822
- hasRequiredBlotFormatter = 1;
18823
-
18824
- Object.defineProperty(BlotFormatter$1, "__esModule", {
18825
- value: true
18826
- });
18827
-
18828
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
18829
-
18830
- var _deepmerge = require$$0;
18831
-
18832
- var _deepmerge2 = _interopRequireDefault(_deepmerge);
18833
-
18834
- var _Options = requireOptions();
18835
-
18836
- var _Options2 = _interopRequireDefault(_Options);
18837
-
18838
- var _Action = requireAction();
18839
-
18840
- _interopRequireDefault(_Action);
18841
-
18842
- var _BlotSpec = requireBlotSpec();
18843
-
18844
- _interopRequireDefault(_BlotSpec);
18845
-
18846
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18847
-
18848
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
18849
-
18850
- var dontMerge = function dontMerge(destination, source) {
18851
- return source;
18852
- };
18853
-
18854
- var BlotFormatter = function () {
18855
- function BlotFormatter(quill) {
18856
- var _this = this;
18857
-
18858
- var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
18859
-
18860
- _classCallCheck(this, BlotFormatter);
18861
-
18862
- this.onClick = function () {
18863
- _this.hide();
18864
- };
18865
-
18866
- this.quill = quill;
18867
- this.options = (0, _deepmerge2.default)(_Options2.default, options, { arrayMerge: dontMerge });
18868
- this.currentSpec = null;
18869
- this.actions = [];
18870
- this.overlay = document.createElement('div');
18871
- this.overlay.classList.add(this.options.overlay.className);
18872
- if (this.options.overlay.style) {
18873
- Object.assign(this.overlay.style, this.options.overlay.style);
18874
- }
18875
-
18876
- // disable native image resizing on firefox
18877
- document.execCommand('enableObjectResizing', false, 'false'); // eslint-disable-line no-undef
18878
- this.quill.root.parentNode.style.position = this.quill.root.parentNode.style.position || 'relative';
18879
-
18880
- this.quill.root.addEventListener('click', this.onClick);
18881
- this.specs = this.options.specs.map(function (SpecClass) {
18882
- return new SpecClass(_this);
18883
- });
18884
- this.specs.forEach(function (spec) {
18885
- return spec.init();
18886
- });
18887
- }
18888
-
18889
- _createClass(BlotFormatter, [{
18890
- key: 'show',
18891
- value: function show(spec) {
18892
- this.currentSpec = spec;
18893
- this.currentSpec.setSelection();
18894
- this.setUserSelect('none');
18895
- this.quill.root.parentNode.appendChild(this.overlay);
18896
- this.repositionOverlay();
18897
- this.createActions(spec);
18898
- }
18899
- }, {
18900
- key: 'hide',
18901
- value: function hide() {
18902
- if (!this.currentSpec) {
18903
- return;
18904
- }
18905
-
18906
- this.currentSpec.onHide();
18907
- this.currentSpec = null;
18908
- this.quill.root.parentNode.removeChild(this.overlay);
18909
- this.overlay.style.setProperty('display', 'none');
18910
- this.setUserSelect('');
18911
- this.destroyActions();
18912
- }
18913
- }, {
18914
- key: 'update',
18915
- value: function update() {
18916
- this.repositionOverlay();
18917
- this.actions.forEach(function (action) {
18918
- return action.onUpdate();
18919
- });
18920
- }
18921
- }, {
18922
- key: 'createActions',
18923
- value: function createActions(spec) {
18924
- var _this2 = this;
18925
-
18926
- this.actions = spec.getActions().map(function (ActionClass) {
18927
- var action = new ActionClass(_this2);
18928
- action.onCreate();
18929
- return action;
18930
- });
18931
- }
18932
- }, {
18933
- key: 'destroyActions',
18934
- value: function destroyActions() {
18935
- this.actions.forEach(function (action) {
18936
- return action.onDestroy();
18937
- });
18938
- this.actions = [];
18939
- }
18940
- }, {
18941
- key: 'repositionOverlay',
18942
- value: function repositionOverlay() {
18943
- if (!this.currentSpec) {
18944
- return;
18945
- }
18946
-
18947
- var overlayTarget = this.currentSpec.getOverlayElement();
18948
- if (!overlayTarget) {
18949
- return;
18950
- }
18951
-
18952
- var parent = this.quill.root.parentNode;
18953
- var specRect = overlayTarget.getBoundingClientRect();
18954
- var parentRect = parent.getBoundingClientRect();
18955
-
18956
- Object.assign(this.overlay.style, {
18957
- display: 'block',
18958
- left: specRect.left - parentRect.left - 1 + parent.scrollLeft + 'px',
18959
- top: specRect.top - parentRect.top + parent.scrollTop + 'px',
18960
- width: specRect.width + 'px',
18961
- height: specRect.height + 'px'
18962
- });
18963
- }
18964
- }, {
18965
- key: 'setUserSelect',
18966
- value: function setUserSelect(value) {
18967
- var _this3 = this;
18968
-
18969
- var props = ['userSelect', 'mozUserSelect', 'webkitUserSelect', 'msUserSelect'];
18970
-
18971
- props.forEach(function (prop) {
18972
- // set on contenteditable element and <html>
18973
- _this3.quill.root.style.setProperty(prop, value);
18974
- if (document.documentElement) {
18975
- document.documentElement.style.setProperty(prop, value);
18976
- }
18977
- });
18978
- }
18979
- }]);
18980
-
18981
- return BlotFormatter;
18982
- }();
18983
-
18984
- BlotFormatter$1.default = BlotFormatter;
18985
- return BlotFormatter$1;
18986
- }
18987
-
18988
- var AlignAction = {};
18989
-
18990
- var DefaultAligner$1 = {};
18991
-
18992
- Object.defineProperty(DefaultAligner$1, "__esModule", {
18993
- value: true
18994
- });
18995
-
18996
- var _createClass$1 = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
18997
-
18998
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
18999
-
19000
- function _classCallCheck$1(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19001
-
19002
- var LEFT_ALIGN = 'left';
19003
- var CENTER_ALIGN = 'center';
19004
- var RIGHT_ALIGN = 'right';
19005
-
19006
- var DefaultAligner = function () {
19007
- function DefaultAligner(options) {
19008
- var _this = this,
19009
- _alignments;
19010
-
19011
- _classCallCheck$1(this, DefaultAligner);
19012
-
19013
- this.applyStyle = options.aligner.applyStyle;
19014
- this.alignAttribute = options.attribute;
19015
- this.alignments = (_alignments = {}, _defineProperty(_alignments, LEFT_ALIGN, {
19016
- name: LEFT_ALIGN,
19017
- icon: options.icons.left,
19018
- apply: function apply(el) {
19019
- _this.setAlignment(el, LEFT_ALIGN);
19020
- _this.setStyle(el, 'inline', 'left', '0 1em 1em 0');
19021
- }
19022
- }), _defineProperty(_alignments, CENTER_ALIGN, {
19023
- name: CENTER_ALIGN,
19024
- icon: options.icons.center,
19025
- apply: function apply(el) {
19026
- _this.setAlignment(el, CENTER_ALIGN);
19027
- _this.setStyle(el, 'block', null, 'auto');
19028
- }
19029
- }), _defineProperty(_alignments, RIGHT_ALIGN, {
19030
- name: RIGHT_ALIGN,
19031
- icon: options.icons.right,
19032
- apply: function apply(el) {
19033
- _this.setAlignment(el, RIGHT_ALIGN);
19034
- _this.setStyle(el, 'inline', 'right', '0 0 1em 1em');
19035
- }
19036
- }), _alignments);
19037
- }
19038
-
19039
- _createClass$1(DefaultAligner, [{
19040
- key: 'getAlignments',
19041
- value: function getAlignments() {
19042
- var _this2 = this;
19043
-
19044
- return Object.keys(this.alignments).map(function (k) {
19045
- return _this2.alignments[k];
19046
- });
19047
- }
19048
- }, {
19049
- key: 'clear',
19050
- value: function clear(el) {
19051
- el.removeAttribute(this.alignAttribute);
19052
- this.setStyle(el, null, null, null);
19053
- }
19054
- }, {
19055
- key: 'isAligned',
19056
- value: function isAligned(el, alignment) {
19057
- return el.getAttribute(this.alignAttribute) === alignment.name;
19058
- }
19059
- }, {
19060
- key: 'setAlignment',
19061
- value: function setAlignment(el, value) {
19062
- el.setAttribute(this.alignAttribute, value);
19063
- }
19064
- }, {
19065
- key: 'setStyle',
19066
- value: function setStyle(el, display, float, margin) {
19067
- if (this.applyStyle) {
19068
- el.style.setProperty('display', display);
19069
- el.style.setProperty('float', float);
19070
- el.style.setProperty('margin', margin);
19071
- }
19072
- }
19073
- }]);
19074
-
19075
- return DefaultAligner;
19076
- }();
19077
-
19078
- DefaultAligner$1.default = DefaultAligner;
19079
-
19080
- var Toolbar = {};
19081
-
19082
- var hasRequiredToolbar;
19083
-
19084
- function requireToolbar () {
19085
- if (hasRequiredToolbar) return Toolbar;
19086
- hasRequiredToolbar = 1;
19087
-
19088
- var _BlotFormatter = requireBlotFormatter();
19089
-
19090
- _interopRequireDefault(_BlotFormatter);
19091
-
19092
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19093
- return Toolbar;
19094
- }
19095
-
19096
- var DefaultToolbar = {};
19097
-
19098
- var hasRequiredDefaultToolbar;
19099
-
19100
- function requireDefaultToolbar () {
19101
- if (hasRequiredDefaultToolbar) return DefaultToolbar;
19102
- hasRequiredDefaultToolbar = 1;
19103
-
19104
- Object.defineProperty(DefaultToolbar, "__esModule", {
19105
- value: true
19106
- });
19107
-
19108
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
19109
-
19110
- requireToolbar();
19111
-
19112
- var _BlotFormatter = requireBlotFormatter();
19113
-
19114
- _interopRequireDefault(_BlotFormatter);
19115
-
19116
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19117
-
19118
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19119
-
19120
- var DefaultToolbar$1 = function () {
19121
- function DefaultToolbar() {
19122
- _classCallCheck(this, DefaultToolbar);
19123
-
19124
- this.toolbar = null;
19125
- this.buttons = [];
19126
- }
19127
-
19128
- _createClass(DefaultToolbar, [{
19129
- key: 'create',
19130
- value: function create(formatter, aligner) {
19131
- var toolbar = document.createElement('div');
19132
- toolbar.classList.add(formatter.options.align.toolbar.mainClassName);
19133
- this.addToolbarStyle(formatter, toolbar);
19134
- this.addButtons(formatter, toolbar, aligner);
19135
-
19136
- this.toolbar = toolbar;
19137
- return this.toolbar;
19138
- }
19139
- }, {
19140
- key: 'destroy',
19141
- value: function destroy() {
19142
- this.toolbar = null;
19143
- this.buttons = [];
19144
- }
19145
- }, {
19146
- key: 'getElement',
19147
- value: function getElement() {
19148
- return this.toolbar;
19149
- }
19150
- }, {
19151
- key: 'addToolbarStyle',
19152
- value: function addToolbarStyle(formatter, toolbar) {
19153
- if (formatter.options.align.toolbar.mainStyle) {
19154
- Object.assign(toolbar.style, formatter.options.align.toolbar.mainStyle);
19155
- }
19156
- }
19157
- }, {
19158
- key: 'addButtonStyle',
19159
- value: function addButtonStyle(button, index, formatter) {
19160
- if (formatter.options.align.toolbar.buttonStyle) {
19161
- Object.assign(button.style, formatter.options.align.toolbar.buttonStyle);
19162
- if (index > 0) {
19163
- button.style.borderLeftWidth = '0'; // eslint-disable-line no-param-reassign
19164
- }
19165
- }
19166
-
19167
- if (formatter.options.align.toolbar.svgStyle) {
19168
- Object.assign(button.children[0].style, formatter.options.align.toolbar.svgStyle);
19169
- }
19170
- }
19171
- }, {
19172
- key: 'addButtons',
19173
- value: function addButtons(formatter, toolbar, aligner) {
19174
- var _this = this;
19175
-
19176
- aligner.getAlignments().forEach(function (alignment, i) {
19177
- var button = document.createElement('span');
19178
- button.classList.add(formatter.options.align.toolbar.buttonClassName);
19179
- button.innerHTML = alignment.icon;
19180
- button.addEventListener('click', function () {
19181
- _this.onButtonClick(button, formatter, alignment, aligner);
19182
- });
19183
- _this.preselectButton(button, alignment, formatter, aligner);
19184
- _this.addButtonStyle(button, i, formatter);
19185
- _this.buttons.push(button);
19186
- toolbar.appendChild(button);
19187
- });
19188
- }
19189
- }, {
19190
- key: 'preselectButton',
19191
- value: function preselectButton(button, alignment, formatter, aligner) {
19192
- if (!formatter.currentSpec) {
19193
- return;
19194
- }
19195
-
19196
- var target = formatter.currentSpec.getTargetElement();
19197
- if (!target) {
19198
- return;
19199
- }
19200
-
19201
- if (aligner.isAligned(target, alignment)) {
19202
- this.selectButton(formatter, button);
19203
- }
19204
- }
19205
- }, {
19206
- key: 'onButtonClick',
19207
- value: function onButtonClick(button, formatter, alignment, aligner) {
19208
- if (!formatter.currentSpec) {
19209
- return;
19210
- }
19211
-
19212
- var target = formatter.currentSpec.getTargetElement();
19213
- if (!target) {
19214
- return;
19215
- }
19216
-
19217
- this.clickButton(button, target, formatter, alignment, aligner);
19218
- }
19219
- }, {
19220
- key: 'clickButton',
19221
- value: function clickButton(button, alignTarget, formatter, alignment, aligner) {
19222
- var _this2 = this;
19223
-
19224
- this.buttons.forEach(function (b) {
19225
- _this2.deselectButton(formatter, b);
19226
- });
19227
- if (aligner.isAligned(alignTarget, alignment)) {
19228
- if (formatter.options.align.toolbar.allowDeselect) {
19229
- aligner.clear(alignTarget);
19230
- } else {
19231
- this.selectButton(formatter, button);
19232
- }
19233
- } else {
19234
- this.selectButton(formatter, button);
19235
- alignment.apply(alignTarget);
19236
- }
19237
-
19238
- formatter.update();
19239
- }
19240
- }, {
19241
- key: 'selectButton',
19242
- value: function selectButton(formatter, button) {
19243
- button.classList.add('is-selected');
19244
- if (formatter.options.align.toolbar.addButtonSelectStyle) {
19245
- button.style.setProperty('filter', 'invert(20%)');
19246
- }
19247
- }
19248
- }, {
19249
- key: 'deselectButton',
19250
- value: function deselectButton(formatter, button) {
19251
- button.classList.remove('is-selected');
19252
- if (formatter.options.align.toolbar.addButtonSelectStyle) {
19253
- button.style.removeProperty('filter');
19254
- }
19255
- }
19256
- }]);
19257
-
19258
- return DefaultToolbar;
19259
- }();
19260
-
19261
- DefaultToolbar.default = DefaultToolbar$1;
19262
- return DefaultToolbar;
19263
- }
19264
-
19265
- var hasRequiredAlignAction;
19266
-
19267
- function requireAlignAction () {
19268
- if (hasRequiredAlignAction) return AlignAction;
19269
- hasRequiredAlignAction = 1;
19270
-
19271
- Object.defineProperty(AlignAction, "__esModule", {
19272
- value: true
19273
- });
19274
-
19275
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
19276
-
19277
- var _Action2 = requireAction();
19278
-
19279
- var _Action3 = _interopRequireDefault(_Action2);
19280
-
19281
- var _BlotFormatter = requireBlotFormatter();
19282
-
19283
- _interopRequireDefault(_BlotFormatter);
19284
-
19285
- var _DefaultAligner = DefaultAligner$1;
19286
-
19287
- var _DefaultAligner2 = _interopRequireDefault(_DefaultAligner);
19288
-
19289
- requireToolbar();
19290
-
19291
- var _DefaultToolbar = requireDefaultToolbar();
19292
-
19293
- var _DefaultToolbar2 = _interopRequireDefault(_DefaultToolbar);
19294
-
19295
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19296
-
19297
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19298
-
19299
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
19300
-
19301
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
19302
-
19303
- var AlignAction$1 = function (_Action) {
19304
- _inherits(AlignAction, _Action);
19305
-
19306
- function AlignAction(formatter) {
19307
- _classCallCheck(this, AlignAction);
19308
-
19309
- var _this = _possibleConstructorReturn(this, (AlignAction.__proto__ || Object.getPrototypeOf(AlignAction)).call(this, formatter));
19310
-
19311
- _this.aligner = new _DefaultAligner2.default(formatter.options.align);
19312
- _this.toolbar = new _DefaultToolbar2.default();
19313
- return _this;
19314
- }
19315
-
19316
- _createClass(AlignAction, [{
19317
- key: 'onCreate',
19318
- value: function onCreate() {
19319
- var toolbar = this.toolbar.create(this.formatter, this.aligner);
19320
- this.formatter.overlay.appendChild(toolbar);
19321
- }
19322
- }, {
19323
- key: 'onDestroy',
19324
- value: function onDestroy() {
19325
- var toolbar = this.toolbar.getElement();
19326
- if (!toolbar) {
19327
- return;
19328
- }
19329
-
19330
- this.formatter.overlay.removeChild(toolbar);
19331
- this.toolbar.destroy();
19332
- }
19333
- }]);
19334
-
19335
- return AlignAction;
19336
- }(_Action3.default);
19337
-
19338
- AlignAction.default = AlignAction$1;
19339
- return AlignAction;
19340
- }
19341
-
19342
- var ResizeAction$1 = {};
19343
-
19344
- Object.defineProperty(ResizeAction$1, "__esModule", {
19345
- value: true
19346
- });
19347
-
19348
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
19349
-
19350
- var _Action2 = requireAction();
19351
-
19352
- var _Action3 = _interopRequireDefault(_Action2);
19353
-
19354
- var _BlotFormatter = requireBlotFormatter();
19355
-
19356
- _interopRequireDefault(_BlotFormatter);
19357
-
19358
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19359
-
19360
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19361
-
19362
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
19363
-
19364
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
19365
-
19366
- var ResizeAction = function (_Action) {
19367
- _inherits(ResizeAction, _Action);
19368
-
19369
- function ResizeAction(formatter) {
19370
- _classCallCheck(this, ResizeAction);
19371
-
19372
- var _this = _possibleConstructorReturn(this, (ResizeAction.__proto__ || Object.getPrototypeOf(ResizeAction)).call(this, formatter));
19373
-
19374
- _this.onMouseDown = function (event) {
19375
- if (!(event.target instanceof HTMLElement)) {
19376
- return;
19377
- }
19378
- _this.dragHandle = event.target;
19379
- _this.setCursor(_this.dragHandle.style.cursor);
19380
-
19381
- if (!_this.formatter.currentSpec) {
19382
- return;
19383
- }
19384
-
19385
- var target = _this.formatter.currentSpec.getTargetElement();
19386
- if (!target) {
19387
- return;
19388
- }
19389
-
19390
- var rect = target.getBoundingClientRect();
19391
-
19392
- _this.dragStartX = event.clientX;
19393
- _this.preDragWidth = rect.width;
19394
- _this.targetRatio = rect.height / rect.width;
19395
-
19396
- document.addEventListener('mousemove', _this.onDrag);
19397
- document.addEventListener('mouseup', _this.onMouseUp);
19398
- };
19399
-
19400
- _this.onDrag = function (event) {
19401
- if (!_this.formatter.currentSpec) {
19402
- return;
19403
- }
19404
-
19405
- var target = _this.formatter.currentSpec.getTargetElement();
19406
- if (!target) {
19407
- return;
19408
- }
19409
-
19410
- var deltaX = event.clientX - _this.dragStartX;
19411
- var newWidth = 0;
19412
-
19413
- if (_this.dragHandle === _this.topLeftHandle || _this.dragHandle === _this.bottomLeftHandle) {
19414
- newWidth = Math.round(_this.preDragWidth - deltaX);
19415
- } else {
19416
- newWidth = Math.round(_this.preDragWidth + deltaX);
19417
- }
19418
-
19419
- var newHeight = _this.targetRatio * newWidth;
19420
-
19421
- target.setAttribute('width', '' + newWidth);
19422
- target.setAttribute('height', '' + newHeight);
19423
-
19424
- _this.formatter.update();
19425
- };
19426
-
19427
- _this.onMouseUp = function () {
19428
- _this.setCursor('');
19429
- document.removeEventListener('mousemove', _this.onDrag);
19430
- document.removeEventListener('mouseup', _this.onMouseUp);
19431
- };
19432
-
19433
- _this.topLeftHandle = _this.createHandle('top-left', 'nwse-resize');
19434
- _this.topRightHandle = _this.createHandle('top-right', 'nesw-resize');
19435
- _this.bottomRightHandle = _this.createHandle('bottom-right', 'nwse-resize');
19436
- _this.bottomLeftHandle = _this.createHandle('bottom-left', 'nesw-resize');
19437
- _this.dragHandle = null;
19438
- _this.dragStartX = 0;
19439
- _this.preDragWidth = 0;
19440
- _this.targetRatio = 0;
19441
- return _this;
19442
- }
19443
-
19444
- _createClass(ResizeAction, [{
19445
- key: 'onCreate',
19446
- value: function onCreate() {
19447
- this.formatter.overlay.appendChild(this.topLeftHandle);
19448
- this.formatter.overlay.appendChild(this.topRightHandle);
19449
- this.formatter.overlay.appendChild(this.bottomRightHandle);
19450
- this.formatter.overlay.appendChild(this.bottomLeftHandle);
19451
-
19452
- this.repositionHandles(this.formatter.options.resize.handleStyle);
19453
- }
19454
- }, {
19455
- key: 'onDestroy',
19456
- value: function onDestroy() {
19457
- this.setCursor('');
19458
- this.formatter.overlay.removeChild(this.topLeftHandle);
19459
- this.formatter.overlay.removeChild(this.topRightHandle);
19460
- this.formatter.overlay.removeChild(this.bottomRightHandle);
19461
- this.formatter.overlay.removeChild(this.bottomLeftHandle);
19462
- }
19463
- }, {
19464
- key: 'createHandle',
19465
- value: function createHandle(position, cursor) {
19466
- var box = document.createElement('div');
19467
- box.classList.add(this.formatter.options.resize.handleClassName);
19468
- box.setAttribute('data-position', position);
19469
- box.style.cursor = cursor;
19470
-
19471
- if (this.formatter.options.resize.handleStyle) {
19472
- Object.assign(box.style, this.formatter.options.resize.handleStyle);
19473
- }
19474
-
19475
- box.addEventListener('mousedown', this.onMouseDown);
19476
-
19477
- return box;
19478
- }
19479
- }, {
19480
- key: 'repositionHandles',
19481
- value: function repositionHandles(handleStyle) {
19482
- var handleXOffset = '0px';
19483
- var handleYOffset = '0px';
19484
- if (handleStyle) {
19485
- if (handleStyle.width) {
19486
- handleXOffset = -parseFloat(handleStyle.width) / 2 + 'px';
19487
- }
19488
- if (handleStyle.height) {
19489
- handleYOffset = -parseFloat(handleStyle.height) / 2 + 'px';
19490
- }
19491
- }
19492
-
19493
- Object.assign(this.topLeftHandle.style, { left: handleXOffset, top: handleYOffset });
19494
- Object.assign(this.topRightHandle.style, { right: handleXOffset, top: handleYOffset });
19495
- Object.assign(this.bottomRightHandle.style, { right: handleXOffset, bottom: handleYOffset });
19496
- Object.assign(this.bottomLeftHandle.style, { left: handleXOffset, bottom: handleYOffset });
19497
- }
19498
- }, {
19499
- key: 'setCursor',
19500
- value: function setCursor(value) {
19501
- if (document.body) {
19502
- document.body.style.cursor = value;
19503
- }
19504
-
19505
- if (this.formatter.currentSpec) {
19506
- var target = this.formatter.currentSpec.getOverlayElement();
19507
- if (target) {
19508
- target.style.cursor = value;
19509
- }
19510
- }
19511
- }
19512
- }]);
19513
-
19514
- return ResizeAction;
19515
- }(_Action3.default);
19516
-
19517
- ResizeAction$1.default = ResizeAction;
19518
-
19519
- var DeleteAction = {};
19520
-
19521
- var hasRequiredDeleteAction;
19522
-
19523
- function requireDeleteAction () {
19524
- if (hasRequiredDeleteAction) return DeleteAction;
19525
- hasRequiredDeleteAction = 1;
19526
-
19527
- Object.defineProperty(DeleteAction, "__esModule", {
19528
- value: true
19529
- });
19530
-
19531
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
19532
-
19533
- var _quill = quill.exports;
19534
-
19535
- var _quill2 = _interopRequireDefault(_quill);
19536
-
19537
- var _Action2 = requireAction();
19538
-
19539
- var _Action3 = _interopRequireDefault(_Action2);
19540
-
19541
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19542
-
19543
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19544
-
19545
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
19546
-
19547
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
19548
-
19549
- var DeleteAction$1 = function (_Action) {
19550
- _inherits(DeleteAction, _Action);
19551
-
19552
- function DeleteAction() {
19553
- var _ref;
19554
-
19555
- var _temp, _this, _ret;
19556
-
19557
- _classCallCheck(this, DeleteAction);
19558
-
19559
- for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
19560
- args[_key] = arguments[_key];
19561
- }
19562
-
19563
- return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = DeleteAction.__proto__ || Object.getPrototypeOf(DeleteAction)).call.apply(_ref, [this].concat(args))), _this), _this.onKeyUp = function (e) {
19564
- if (!_this.formatter.currentSpec) {
19565
- return;
19566
- }
19567
-
19568
- // delete or backspace
19569
- if (e.keyCode === 46 || e.keyCode === 8) {
19570
- var blot = _quill2.default.find(_this.formatter.currentSpec.getTargetElement());
19571
- if (blot) {
19572
- blot.deleteAt(0);
19573
- }
19574
- _this.formatter.hide();
19575
- }
19576
- }, _temp), _possibleConstructorReturn(_this, _ret);
19577
- }
19578
-
19579
- _createClass(DeleteAction, [{
19580
- key: 'onCreate',
19581
- value: function onCreate() {
19582
- document.addEventListener('keyup', this.onKeyUp, true);
19583
- this.formatter.quill.root.addEventListener('input', this.onKeyUp, true);
19584
- }
19585
- }, {
19586
- key: 'onDestroy',
19587
- value: function onDestroy() {
19588
- document.removeEventListener('keyup', this.onKeyUp);
19589
- this.formatter.quill.root.removeEventListener('input', this.onKeyUp);
19590
- }
19591
- }]);
19592
-
19593
- return DeleteAction;
19594
- }(_Action3.default);
19595
-
19596
- DeleteAction.default = DeleteAction$1;
19597
- return DeleteAction;
19598
- }
19599
-
19600
- var hasRequiredBlotSpec;
19601
-
19602
- function requireBlotSpec () {
19603
- if (hasRequiredBlotSpec) return BlotSpec;
19604
- hasRequiredBlotSpec = 1;
19605
-
19606
- Object.defineProperty(BlotSpec, "__esModule", {
19607
- value: true
19608
- });
19609
-
19610
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
19611
-
19612
- var _BlotFormatter = requireBlotFormatter();
19613
-
19614
- _interopRequireDefault(_BlotFormatter);
19615
-
19616
- var _Action = requireAction();
19617
-
19618
- _interopRequireDefault(_Action);
19619
-
19620
- var _AlignAction = requireAlignAction();
19621
-
19622
- var _AlignAction2 = _interopRequireDefault(_AlignAction);
19623
-
19624
- var _ResizeAction = ResizeAction$1;
19625
-
19626
- var _ResizeAction2 = _interopRequireDefault(_ResizeAction);
19627
-
19628
- var _DeleteAction = requireDeleteAction();
19629
-
19630
- var _DeleteAction2 = _interopRequireDefault(_DeleteAction);
19631
-
19632
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19633
-
19634
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19635
-
19636
- var BlotSpec$1 = function () {
19637
- function BlotSpec(formatter) {
19638
- _classCallCheck(this, BlotSpec);
19639
-
19640
- this.formatter = formatter;
19641
- }
19642
-
19643
- _createClass(BlotSpec, [{
19644
- key: 'init',
19645
- value: function init() {}
19646
- }, {
19647
- key: 'getActions',
19648
- value: function getActions() {
19649
- return [_AlignAction2.default, _ResizeAction2.default, _DeleteAction2.default];
19650
- }
19651
- }, {
19652
- key: 'getTargetElement',
19653
- value: function getTargetElement() {
19654
- return null;
19655
- }
19656
- }, {
19657
- key: 'getOverlayElement',
19658
- value: function getOverlayElement() {
19659
- return this.getTargetElement();
19660
- }
19661
- }, {
19662
- key: 'setSelection',
19663
- value: function setSelection() {
19664
- this.formatter.quill.setSelection(null);
19665
- }
19666
- }, {
19667
- key: 'onHide',
19668
- value: function onHide() {}
19669
- }]);
19670
-
19671
- return BlotSpec;
19672
- }();
19673
-
19674
- BlotSpec.default = BlotSpec$1;
19675
- return BlotSpec;
19676
- }
19677
-
19678
- var ImageSpec = {};
19679
-
19680
- var hasRequiredImageSpec;
19681
-
19682
- function requireImageSpec () {
19683
- if (hasRequiredImageSpec) return ImageSpec;
19684
- hasRequiredImageSpec = 1;
19685
-
19686
- Object.defineProperty(ImageSpec, "__esModule", {
19687
- value: true
19688
- });
19689
-
19690
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
19691
-
19692
- var _BlotSpec2 = requireBlotSpec();
19693
-
19694
- var _BlotSpec3 = _interopRequireDefault(_BlotSpec2);
19695
-
19696
- var _BlotFormatter = requireBlotFormatter();
19697
-
19698
- _interopRequireDefault(_BlotFormatter);
19699
-
19700
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19701
-
19702
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19703
-
19704
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
19705
-
19706
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
19707
-
19708
- var ImageSpec$1 = function (_BlotSpec) {
19709
- _inherits(ImageSpec, _BlotSpec);
19710
-
19711
- function ImageSpec(formatter) {
19712
- _classCallCheck(this, ImageSpec);
19713
-
19714
- var _this = _possibleConstructorReturn(this, (ImageSpec.__proto__ || Object.getPrototypeOf(ImageSpec)).call(this, formatter));
19715
-
19716
- _this.onClick = function (event) {
19717
- var el = event.target;
19718
- if (!(el instanceof HTMLElement) || el.tagName !== 'IMG') {
19719
- return;
19720
- }
19721
-
19722
- _this.img = el;
19723
- _this.formatter.show(_this);
19724
- };
19725
-
19726
- _this.img = null;
19727
- return _this;
19728
- }
19729
-
19730
- _createClass(ImageSpec, [{
19731
- key: 'init',
19732
- value: function init() {
19733
- this.formatter.quill.root.addEventListener('click', this.onClick);
19734
- }
19735
- }, {
19736
- key: 'getTargetElement',
19737
- value: function getTargetElement() {
19738
- return this.img;
19739
- }
19740
- }, {
19741
- key: 'onHide',
19742
- value: function onHide() {
19743
- this.img = null;
19744
- }
19745
- }]);
19746
-
19747
- return ImageSpec;
19748
- }(_BlotSpec3.default);
19749
-
19750
- ImageSpec.default = ImageSpec$1;
19751
- return ImageSpec;
19752
- }
19753
-
19754
- var IframeVideoSpec = {};
19755
-
19756
- var UnclickableBlotSpec = {};
19757
-
19758
- var hasRequiredUnclickableBlotSpec;
19759
-
19760
- function requireUnclickableBlotSpec () {
19761
- if (hasRequiredUnclickableBlotSpec) return UnclickableBlotSpec;
19762
- hasRequiredUnclickableBlotSpec = 1;
19763
-
19764
- Object.defineProperty(UnclickableBlotSpec, "__esModule", {
19765
- value: true
19766
- });
19767
-
19768
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
19769
-
19770
- var _BlotSpec2 = requireBlotSpec();
19771
-
19772
- var _BlotSpec3 = _interopRequireDefault(_BlotSpec2);
19773
-
19774
- var _BlotFormatter = requireBlotFormatter();
19775
-
19776
- _interopRequireDefault(_BlotFormatter);
19777
-
19778
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19779
-
19780
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19781
-
19782
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
19783
-
19784
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
19785
-
19786
- var MOUSE_ENTER_ATTRIBUTE = 'data-blot-formatter-unclickable-bound';
19787
- var PROXY_IMAGE_CLASS = 'blot-formatter__proxy-image';
19788
-
19789
- var UnclickableBlotSpec$1 = function (_BlotSpec) {
19790
- _inherits(UnclickableBlotSpec, _BlotSpec);
19791
-
19792
- function UnclickableBlotSpec(formatter, selector) {
19793
- _classCallCheck(this, UnclickableBlotSpec);
19794
-
19795
- var _this = _possibleConstructorReturn(this, (UnclickableBlotSpec.__proto__ || Object.getPrototypeOf(UnclickableBlotSpec)).call(this, formatter));
19796
-
19797
- _this.onTextChange = function () {
19798
- Array.from(document.querySelectorAll(_this.selector + ':not([' + MOUSE_ENTER_ATTRIBUTE + '])')).forEach(function (unclickable) {
19799
- unclickable.setAttribute(MOUSE_ENTER_ATTRIBUTE, 'true');
19800
- unclickable.addEventListener('mouseenter', _this.onMouseEnter);
19801
- });
19802
- };
19803
-
19804
- _this.onMouseEnter = function (event) {
19805
- var unclickable = event.target;
19806
- if (!(unclickable instanceof HTMLElement)) {
19807
- return;
19808
- }
19809
-
19810
- _this.nextUnclickable = unclickable;
19811
- _this.repositionProxyImage(_this.nextUnclickable);
19812
- };
19813
-
19814
- _this.onProxyImageClick = function () {
19815
- _this.unclickable = _this.nextUnclickable;
19816
- _this.nextUnclickable = null;
19817
- _this.formatter.show(_this);
19818
- _this.hideProxyImage();
19819
- };
19820
-
19821
- _this.selector = selector;
19822
- _this.unclickable = null;
19823
- _this.nextUnclickable = null;
19824
- return _this;
19825
- }
19826
-
19827
- _createClass(UnclickableBlotSpec, [{
19828
- key: 'init',
19829
- value: function init() {
19830
- if (document.body) {
19831
- /*
19832
- it's important that this is attached to the body instead of the root quill element.
19833
- this prevents the click event from overlapping with ImageSpec
19834
- */
19835
- document.body.appendChild(this.createProxyImage());
19836
- }
19837
-
19838
- this.hideProxyImage();
19839
- this.proxyImage.addEventListener('click', this.onProxyImageClick);
19840
- this.formatter.quill.on('text-change', this.onTextChange);
19841
- }
19842
- }, {
19843
- key: 'getTargetElement',
19844
- value: function getTargetElement() {
19845
- return this.unclickable;
19846
- }
19847
- }, {
19848
- key: 'getOverlayElement',
19849
- value: function getOverlayElement() {
19850
- return this.unclickable;
19851
- }
19852
- }, {
19853
- key: 'onHide',
19854
- value: function onHide() {
19855
- this.hideProxyImage();
19856
- this.nextUnclickable = null;
19857
- this.unclickable = null;
19858
- }
19859
- }, {
19860
- key: 'createProxyImage',
19861
- value: function createProxyImage() {
19862
- var canvas = document.createElement('canvas');
19863
- var context = canvas.getContext('2d');
19864
- context.globalAlpha = 0;
19865
- context.fillRect(0, 0, 1, 1);
19866
-
19867
- this.proxyImage = document.createElement('img');
19868
- this.proxyImage.src = canvas.toDataURL('image/png');
19869
- this.proxyImage.classList.add(PROXY_IMAGE_CLASS);
19870
-
19871
- Object.assign(this.proxyImage.style, {
19872
- position: 'absolute',
19873
- margin: '0'
19874
- });
19875
-
19876
- return this.proxyImage;
19877
- }
19878
- }, {
19879
- key: 'hideProxyImage',
19880
- value: function hideProxyImage() {
19881
- Object.assign(this.proxyImage.style, {
19882
- display: 'none'
19883
- });
19884
- }
19885
- }, {
19886
- key: 'repositionProxyImage',
19887
- value: function repositionProxyImage(unclickable) {
19888
- var rect = unclickable.getBoundingClientRect();
19889
-
19890
- Object.assign(this.proxyImage.style, {
19891
- display: 'block',
19892
- left: rect.left + window.pageXOffset + 'px',
19893
- top: rect.top + window.pageYOffset + 'px',
19894
- width: rect.width + 'px',
19895
- height: rect.height + 'px'
19896
- });
19897
- }
19898
- }]);
19899
-
19900
- return UnclickableBlotSpec;
19901
- }(_BlotSpec3.default);
19902
-
19903
- UnclickableBlotSpec.default = UnclickableBlotSpec$1;
19904
- return UnclickableBlotSpec;
19905
- }
19906
-
19907
- var hasRequiredIframeVideoSpec;
19908
-
19909
- function requireIframeVideoSpec () {
19910
- if (hasRequiredIframeVideoSpec) return IframeVideoSpec;
19911
- hasRequiredIframeVideoSpec = 1;
19912
-
19913
- Object.defineProperty(IframeVideoSpec, "__esModule", {
19914
- value: true
19915
- });
19916
-
19917
- var _UnclickableBlotSpec2 = requireUnclickableBlotSpec();
19918
-
19919
- var _UnclickableBlotSpec3 = _interopRequireDefault(_UnclickableBlotSpec2);
19920
-
19921
- var _BlotFormatter = requireBlotFormatter();
19922
-
19923
- _interopRequireDefault(_BlotFormatter);
19924
-
19925
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19926
-
19927
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19928
-
19929
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
19930
-
19931
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
19932
-
19933
- var IframeVideoSpec$1 = function (_UnclickableBlotSpec) {
19934
- _inherits(IframeVideoSpec, _UnclickableBlotSpec);
19935
-
19936
- function IframeVideoSpec(formatter) {
19937
- _classCallCheck(this, IframeVideoSpec);
19938
-
19939
- return _possibleConstructorReturn(this, (IframeVideoSpec.__proto__ || Object.getPrototypeOf(IframeVideoSpec)).call(this, formatter, 'iframe.ql-video'));
19940
- }
19941
-
19942
- return IframeVideoSpec;
19943
- }(_UnclickableBlotSpec3.default);
19944
-
19945
- IframeVideoSpec.default = IframeVideoSpec$1;
19946
- return IframeVideoSpec;
19947
- }
19948
-
19949
- var hasRequiredOptions;
19950
-
19951
- function requireOptions () {
19952
- if (hasRequiredOptions) return Options;
19953
- hasRequiredOptions = 1;
19954
-
19955
- Object.defineProperty(Options, "__esModule", {
19956
- value: true
19957
- });
19958
-
19959
- var _BlotSpec = requireBlotSpec();
19960
-
19961
- _interopRequireDefault(_BlotSpec);
19962
-
19963
- var _ImageSpec = requireImageSpec();
19964
-
19965
- var _ImageSpec2 = _interopRequireDefault(_ImageSpec);
19966
-
19967
- var _IframeVideoSpec = requireIframeVideoSpec();
19968
-
19969
- var _IframeVideoSpec2 = _interopRequireDefault(_IframeVideoSpec);
19970
-
19971
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19972
-
19973
- var DefaultOptions = {
19974
- specs: [_ImageSpec2.default, _IframeVideoSpec2.default],
19975
- overlay: {
19976
- className: 'blot-formatter__overlay',
19977
- style: {
19978
- position: 'absolute',
19979
- boxSizing: 'border-box',
19980
- border: '1px dashed #444'
19981
- }
19982
- },
19983
- align: {
19984
- attribute: 'data-align',
19985
- aligner: {
19986
- applyStyle: true
19987
- },
19988
- icons: {
19989
- left: '\n <svg viewbox="0 0 18 18">\n <line class="ql-stroke" x1="3" x2="15" y1="9" y2="9"></line>\n <line class="ql-stroke" x1="3" x2="13" y1="14" y2="14"></line>\n <line class="ql-stroke" x1="3" x2="9" y1="4" y2="4"></line>\n </svg>\n ',
19990
- center: '\n <svg viewbox="0 0 18 18">\n <line class="ql-stroke" x1="15" x2="3" y1="9" y2="9"></line>\n <line class="ql-stroke" x1="14" x2="4" y1="14" y2="14"></line>\n <line class="ql-stroke" x1="12" x2="6" y1="4" y2="4"></line>\n </svg>\n ',
19991
- right: '\n <svg viewbox="0 0 18 18">\n <line class="ql-stroke" x1="15" x2="3" y1="9" y2="9"></line>\n <line class="ql-stroke" x1="15" x2="5" y1="14" y2="14"></line>\n <line class="ql-stroke" x1="15" x2="9" y1="4" y2="4"></line>\n </svg>\n '
19992
- },
19993
- toolbar: {
19994
- allowDeselect: true,
19995
- mainClassName: 'blot-formatter__toolbar',
19996
- mainStyle: {
19997
- position: 'absolute',
19998
- top: '-12px',
19999
- right: '0',
20000
- left: '0',
20001
- height: '0',
20002
- minWidth: '100px',
20003
- font: '12px/1.0 Arial, Helvetica, sans-serif',
20004
- textAlign: 'center',
20005
- color: '#333',
20006
- boxSizing: 'border-box',
20007
- cursor: 'default',
20008
- zIndex: '1'
20009
- },
20010
- buttonClassName: 'blot-formatter__toolbar-button',
20011
- addButtonSelectStyle: true,
20012
- buttonStyle: {
20013
- display: 'inline-block',
20014
- width: '24px',
20015
- height: '24px',
20016
- background: 'white',
20017
- border: '1px solid #999',
20018
- verticalAlign: 'middle'
20019
- },
20020
- svgStyle: {
20021
- display: 'inline-block',
20022
- width: '24px',
20023
- height: '24px',
20024
- background: 'white',
20025
- border: '1px solid #999',
20026
- verticalAlign: 'middle'
20027
- }
20028
- }
20029
- },
20030
- resize: {
20031
- handleClassName: 'blot-formatter__resize-handle',
20032
- handleStyle: {
20033
- position: 'absolute',
20034
- height: '12px',
20035
- width: '12px',
20036
- backgroundColor: 'white',
20037
- border: '1px solid #777',
20038
- boxSizing: 'border-box',
20039
- opacity: '0.80'
20040
- }
20041
- }
20042
- };
20043
-
20044
- Options.default = DefaultOptions;
20045
- return Options;
20046
- }
20047
-
20048
- (function (exports) {
20049
-
20050
- Object.defineProperty(exports, "__esModule", {
20051
- value: true
20052
- });
20053
-
20054
- var _Options = requireOptions();
20055
-
20056
- Object.defineProperty(exports, 'DefaultOptions', {
20057
- enumerable: true,
20058
- get: function get() {
20059
- return _interopRequireDefault(_Options).default;
20060
- }
20061
- });
20062
-
20063
- var _BlotFormatter = requireBlotFormatter();
20064
-
20065
- Object.defineProperty(exports, 'default', {
20066
- enumerable: true,
20067
- get: function get() {
20068
- return _interopRequireDefault(_BlotFormatter).default;
20069
- }
20070
- });
20071
-
20072
- var _Action = requireAction();
20073
-
20074
- Object.defineProperty(exports, 'Action', {
20075
- enumerable: true,
20076
- get: function get() {
20077
- return _interopRequireDefault(_Action).default;
20078
- }
20079
- });
20080
-
20081
- var _AlignAction = requireAlignAction();
20082
-
20083
- Object.defineProperty(exports, 'AlignAction', {
20084
- enumerable: true,
20085
- get: function get() {
20086
- return _interopRequireDefault(_AlignAction).default;
20087
- }
20088
- });
20089
-
20090
- var _DefaultAligner = DefaultAligner$1;
20091
-
20092
- Object.defineProperty(exports, 'DefaultAligner', {
20093
- enumerable: true,
20094
- get: function get() {
20095
- return _interopRequireDefault(_DefaultAligner).default;
20096
- }
20097
- });
20098
-
20099
- var _DefaultToolbar = requireDefaultToolbar();
20100
-
20101
- Object.defineProperty(exports, 'DefaultToolbar', {
20102
- enumerable: true,
20103
- get: function get() {
20104
- return _interopRequireDefault(_DefaultToolbar).default;
20105
- }
20106
- });
20107
-
20108
- var _DeleteAction = requireDeleteAction();
20109
-
20110
- Object.defineProperty(exports, 'DeleteAction', {
20111
- enumerable: true,
20112
- get: function get() {
20113
- return _interopRequireDefault(_DeleteAction).default;
20114
- }
20115
- });
20116
-
20117
- var _ResizeAction = ResizeAction$1;
20118
-
20119
- Object.defineProperty(exports, 'ResizeAction', {
20120
- enumerable: true,
20121
- get: function get() {
20122
- return _interopRequireDefault(_ResizeAction).default;
20123
- }
20124
- });
20125
-
20126
- var _BlotSpec = requireBlotSpec();
20127
-
20128
- Object.defineProperty(exports, 'BlotSpec', {
20129
- enumerable: true,
20130
- get: function get() {
20131
- return _interopRequireDefault(_BlotSpec).default;
20132
- }
20133
- });
20134
-
20135
- var _ImageSpec = requireImageSpec();
20136
-
20137
- Object.defineProperty(exports, 'ImageSpec', {
20138
- enumerable: true,
20139
- get: function get() {
20140
- return _interopRequireDefault(_ImageSpec).default;
20141
- }
20142
- });
20143
-
20144
- var _UnclickableBlotSpec = requireUnclickableBlotSpec();
20145
-
20146
- Object.defineProperty(exports, 'UnclickableBlotSpec', {
20147
- enumerable: true,
20148
- get: function get() {
20149
- return _interopRequireDefault(_UnclickableBlotSpec).default;
20150
- }
20151
- });
20152
-
20153
- var _IframeVideoSpec = requireIframeVideoSpec();
20154
-
20155
- Object.defineProperty(exports, 'IframeVideoSpec', {
20156
- enumerable: true,
20157
- get: function get() {
20158
- return _interopRequireDefault(_IframeVideoSpec).default;
20159
- }
20160
- });
20161
-
20162
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
20163
- } (dist));
20164
-
20165
- var BlotFormatter = /*@__PURE__*/getDefaultExportFromCjs(dist);
20166
-
20167
- function useBlotFormatter(editor, enableImageResize = true) {
20168
- const quillRef = vue.ref(null);
20169
- const removeQuillBlotFormatter = () => {
20170
- var _a;
20171
- try {
20172
- const blotFormatter = (_a = quillRef.value) === null || _a === void 0 ? void 0 : _a.getModule('blotFormatter');
20173
- if (blotFormatter && blotFormatter.overlay) {
20174
- const overlay = blotFormatter.overlay;
20175
- if (overlay.parentNode) {
20176
- overlay.parentNode.removeChild(overlay);
20177
- }
20178
- }
20179
- }
20180
- catch (error) {
20181
- console.warn('移除blotFormatter overlay时出错:', error);
20182
- }
20183
- };
20184
- const handleBlotFormatterClick = (event) => {
20185
- var _a;
20186
- if (!editor.value)
20187
- return;
20188
- const blotFormatter = (_a = quillRef.value) === null || _a === void 0 ? void 0 : _a.getModule('blotFormatter');
20189
- if (!blotFormatter || !blotFormatter.overlay)
20190
- return;
20191
- const isClickInsideEditor = editor.value.contains(event.target);
20192
- if (!isClickInsideEditor) {
20193
- removeQuillBlotFormatter();
20194
- }
20195
- };
20196
- const configureBlotFormatter = () => {
20197
- if (!quillRef.value)
20198
- return;
20199
- const blotFormatter = quillRef.value.getModule('blotFormatter');
20200
- if (blotFormatter) {
20201
- const originalShow = blotFormatter.show.bind(blotFormatter);
20202
- blotFormatter.show = function (spec) {
20203
- var _a;
20204
- originalShow(spec);
20205
- const target = (_a = this.currentSpec) === null || _a === void 0 ? void 0 : _a.getTargetElement();
20206
- if (target && target.tagName === 'IMG') {
20207
- target.style.maxWidth = '100%';
20208
- target.style.height = 'auto';
20209
- target.style.objectFit = 'contain';
20210
- const width = target.getAttribute('width');
20211
- if (width) {
20212
- const naturalWidth = target.naturalWidth;
20213
- const naturalHeight = target.naturalHeight;
20214
- if (naturalWidth && naturalHeight) {
20215
- const aspectRatio = naturalHeight / naturalWidth;
20216
- const newHeight = Math.round(parseInt(width) * aspectRatio);
20217
- target.setAttribute('height', '' + newHeight);
20218
- }
20219
- }
20220
- }
20221
- };
20222
- }
20223
- };
20224
- const applyImageStyle = () => {
20225
- var _a;
20226
- if (!quillRef.value)
20227
- return;
20228
- const editorElement = (_a = editor.value) === null || _a === void 0 ? void 0 : _a.querySelector('.ql-editor');
20229
- if (editorElement) {
20230
- const images = editorElement.querySelectorAll('img');
20231
- images.forEach(img => {
20232
- img.style.maxWidth = '100%';
20233
- img.style.height = 'auto';
20234
- img.style.objectFit = 'contain';
20235
- });
20236
- }
20237
- };
20238
- const registerBlotFormatter = () => {
20239
- if (!enableImageResize) {
20240
- return;
20241
- }
20242
- try {
20243
- Quill.register('modules/blotFormatter', BlotFormatter);
20244
- console.log('BlotFormatter模块已注册');
20245
- }
20246
- catch (error) {
20247
- console.warn('注册BlotFormatter模块时出错:', error);
20248
- }
20249
- };
20250
- const getBlotFormatterConfig = () => {
20251
- if (!enableImageResize) {
20252
- return {};
20253
- }
20254
- return {
20255
- modules: {
20256
- blotFormatter: true
20257
- }
20258
- };
20259
- };
20260
- vue.onBeforeUnmount(() => {
20261
- removeQuillBlotFormatter();
20262
- });
20263
- const setQuill = (quillInstance) => {
20264
- quillRef.value = quillInstance;
20265
- };
20266
- return {
20267
- quillRef,
20268
- setQuill,
20269
- handleBlotFormatterClick,
20270
- configureBlotFormatter,
20271
- applyImageStyle,
20272
- registerBlotFormatter,
20273
- getBlotFormatterConfig
20274
- };
20275
- }
20276
-
20277
- function useLinkClick(editor, initialHandleCustomLink) {
20278
- const quillRef = vue.ref(null);
20279
- const handleCustomLinkRef = vue.ref(initialHandleCustomLink || null);
20280
- const handleLinkClick = (event) => {
20281
- if (!quillRef.value || !handleCustomLinkRef.value)
20282
- return;
20283
- const target = event.target;
20284
- if (target.tagName === 'A') {
20285
- event.preventDefault();
20286
- event.stopPropagation();
20287
- try {
20288
- const linkElement = target;
20289
- const linkUrl = linkElement.getAttribute('href') || '';
20290
- const linkText = linkElement.textContent || '';
20291
- const range = quillRef.value.getSelection();
20292
- if (range) {
20293
- const [blot] = quillRef.value.getLeaf(range.index);
20294
- if (blot && blot.parent && blot.parent.domNode.tagName === 'A') {
20295
- const linkBlot = blot.parent;
20296
- const linkIndex = quillRef.value.getIndex(linkBlot);
20297
- const linkLength = linkBlot.length();
20298
- quillRef.value.setSelection(linkIndex, linkLength);
20299
- handleCustomLinkRef.value(true, { url: linkUrl, text: linkText });
20300
- }
20301
- }
20302
- }
20303
- catch (error) {
20304
- console.warn('选中链接失败:', error);
20305
- }
20306
- }
20307
- };
20308
- const addLinkClickListener = () => {
20309
- if (!quillRef.value)
20310
- return;
20311
- vue.nextTick(() => {
20312
- var _a;
20313
- const editorElement = (_a = editor.value) === null || _a === void 0 ? void 0 : _a.querySelector('.ql-editor');
20314
- if (editorElement) {
20315
- editorElement.removeEventListener('click', handleLinkClick);
20316
- editorElement.addEventListener('click', handleLinkClick);
20317
- }
20318
- });
20319
- };
20320
- const setQuill = (quillInstance) => {
20321
- quillRef.value = quillInstance;
20322
- };
20323
- const setHandleCustomLink = (fn) => {
20324
- handleCustomLinkRef.value = fn;
20325
- };
20326
- return {
20327
- quillRef,
20328
- setQuill,
20329
- setHandleCustomLink,
20330
- handleLinkClick,
20331
- addLinkClickListener
20332
- };
20333
- }
20334
-
20335
- function useGlobalClick() {
20336
- const clickHandlers = vue.ref([]);
20337
- const handleGlobalClick = (event) => {
20338
- clickHandlers.value.forEach(handler => {
20339
- try {
20340
- handler(event);
20341
- }
20342
- catch (error) {
20343
- console.warn('全局点击事件处理函数执行出错:', error);
20344
- }
20345
- });
20346
- };
20347
- const addClickHandler = (handler) => {
20348
- if (typeof handler === 'function' && !clickHandlers.value.includes(handler)) {
20349
- clickHandlers.value.push(handler);
20350
- }
20351
- };
20352
- const clearClickHandlers = () => {
20353
- clickHandlers.value = [];
20354
- };
20355
- vue.onMounted(() => {
20356
- window.addEventListener('click', handleGlobalClick);
20357
- });
20358
- vue.onBeforeUnmount(() => {
20359
- window.removeEventListener('click', handleGlobalClick);
20360
- clearClickHandlers();
20361
- });
20362
- return {
20363
- clickHandlers: clickHandlers.value,
20364
- addClickHandler,
20365
- clearClickHandlers,
20366
- handleGlobalClick
20367
- };
20368
- }
20369
-
20370
- const boldSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M6.794999938146972,7.7800002288818355L9.045000038146974,7.7800002288818355Q9.855000038146972,7.7800002288818355,10.230000038146972,7.442500128881836Q10.605000038146972,7.105000028881836,10.605000038146972,6.505000128881836Q10.605000038146972,6.114999728881836,10.440000038146973,5.860000628881836Q10.275000138146972,5.6050005288818365,9.929999838146973,5.470000228881836Q9.585000038146973,5.335000028881836,9.045000038146974,5.335000028881836L7.139999938146973,5.335000028881836L7.139999938146973,3.385000228881836L9.045000038146974,3.385000228881836Q10.034999838146973,3.385000228881836,10.852499938146973,3.797500608881836Q11.670000038146974,4.2100000388818355,12.142499938146972,4.922500628881836Q12.614999738146974,5.635000228881836,12.614999738146974,6.505000128881836Q12.614999738146974,7.375000028881836,12.142499938146972,8.042500028881836Q11.670000038146974,8.710000028881836,10.860000138146972,9.070000128881837Q10.050000238146973,9.430000328881835,9.045000038146974,9.430000328881835L6.794999938146972,9.430000328881835L6.794999938146972,7.7800002288818355ZM7.139999938146973,12.550000228881835L9.329999938146972,12.550000228881835Q9.900000138146972,12.550000228881835,10.327499838146974,12.354999528881836Q10.755000138146972,12.159999828881835,10.987500238146973,11.807499928881835Q11.219999838146972,11.454999928881836,11.219999838146972,11.020000428881836Q11.219999838146972,10.600000428881836,10.987500238146973,10.232500028881836Q10.755000138146972,9.864999728881836,10.327499838146974,9.647500028881836Q9.900000138146972,9.430000328881835,9.329999938146972,9.430000328881835L6.975000038146972,9.430000328881835L6.975000038146972,7.7800002288818355L9.329999938146972,7.7800002288818355Q10.349999938146972,7.7800002288818355,11.250000038146972,8.200000328881835Q12.149999638146973,8.620000328881837,12.690000538146972,9.362500228881835Q13.229999538146973,10.104999528881836,13.229999538146973,11.034999828881837Q13.229999538146973,11.949999828881836,12.690000538146972,12.752500528881836Q12.149999638146973,13.555000228881836,11.250000038146972,14.027500228881836Q10.349999938146972,14.500000228881836,9.329999938146972,14.500000228881836L7.139999938146973,14.500000228881836L7.139999938146973,12.550000228881835ZM7.064999938146973,14.500000228881836Q6.284999968146972,14.500000228881836,5.872500058146973,14.095000228881837Q5.460000038146973,13.689999228881836,5.460000038146973,12.895000428881836L5.460000038146973,4.989999728881836Q5.460000038146973,4.195000648881836,5.872500058146973,3.789999958881836Q6.284999968146972,3.385000228881836,7.064999938146973,3.385000228881836L7.469999838146973,3.385000228881836L7.469999838146973,14.500000228881836L7.064999938146973,14.500000228881836Z" fill="#555555" fill-opacity="1"/></g></g></svg>`;
20371
- const italicSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M8,3Q7.9015086,3,7.8049095,3.019214718Q7.7083106,3.038429435,7.6173165,3.076120459Q7.5263224,3.11381148,7.4444296,3.16853037Q7.3625371,3.2232492600000002,7.2928932,3.2928932Q7.2232492,3.36253715,7.1685302,3.4444297600000002Q7.1138113999999995,3.52632231,7.0761204,3.61731648Q7.0384293,3.70831072,7.0192146,3.80490965Q6.99999994,3.90150857,7,4Q6.99999994,4.0984913,7.0192146,4.1950902Q7.0384293,4.291689,7.0761204,4.3826833Q7.1138113999999995,4.4736774,7.1685302,4.5555699Q7.2232492,4.6374626,7.2928932,4.7071065999999995Q7.3625371,4.7767504,7.4444296,4.8314693Q7.5263224,4.8861883,7.6173165,4.9238794Q7.7083106,4.9615704,7.8049096,4.9807851Q7.9015086,4.9999999,8,5L9.137146,5L8,13L7,13Q6.90150857,13,6.80490965,13.019215Q6.70831072,13.038429,6.6173164799999995,13.07612Q6.52632231,13.113811,6.44442973,13.16853Q6.36253715,13.223249,6.2928932,13.292892Q6.22324926,13.362536,6.16853037,13.444429Q6.11381148,13.526321,6.076120459,13.617315Q6.038429435,13.708309,6.019214718,13.804909Q6,13.901508,6,14Q6,14.098491,6.019214718,14.195089Q6.038429435,14.291689,6.076120459,14.382683Q6.11381148,14.473677,6.16853037,14.555569Q6.22324926,14.637462,6.2928932,14.707106Q6.36253715,14.77675,6.44442976,14.831469Q6.52632231,14.886187,6.6173164799999995,14.923878Q6.70831072,14.961569,6.80490965,14.980784Q6.90150857,15,7,15L11,15Q11.0984912,15,11.1950898,14.980784Q11.2916889,14.961569,11.382682800000001,14.923878Q11.473677200000001,14.886187,11.5555696,14.831469Q11.6374626,14.77675,11.7071066,14.707106Q11.7767506,14.637462,11.8314691,14.555569Q11.8861876,14.473677,11.9238791,14.382683Q11.9615698,14.291689,11.9807849,14.195089Q12,14.098491,12,14Q12,13.901508,11.9807849,13.804909Q11.9615698,13.708309,11.9238791,13.617315Q11.8861876,13.526321,11.8314691,13.444428Q11.7767506,13.362536,11.7071066,13.292892Q11.6374626,13.223249,11.5555701,13.16853Q11.473677200000001,13.113811,11.382682800000001,13.07612Q11.2916889,13.038429,11.1950903,13.019215Q11.0984912,13,11,13L9.8626451,13L11,5L12,5Q12.0984907,4.9999999,12.1950893,4.9807851Q12.2916884,4.9615703,12.382682800000001,4.9238793Q12.4736767,4.8861883,12.5555696,4.8314693Q12.6374621,4.7767504,12.7071061,4.7071065999999995Q12.776750100000001,4.6374626,12.831468600000001,4.5555699Q12.8861876,4.4736774,12.9238787,4.3826833Q12.9615698,4.291689,12.9807849,4.1950902Q12.999999500000001,4.0984913,13,4Q12.999999500000001,3.90150857,12.980784400000001,3.80490965Q12.9615698,3.70831072,12.9238787,3.61731648Q12.8861876,3.52632231,12.8314691,3.44442973Q12.7767506,3.36253715,12.7071066,3.2928932Q12.6374626,3.2232492600000002,12.5555696,3.16853037Q12.4736767,3.11381148,12.382682800000001,3.076120459Q12.2916884,3.038429435,12.1950898,3.019214718Q12.0984907,3,12,3L8,3Z" fill-rule="evenodd" fill="#555555" fill-opacity="1"/></g></g></svg>`;
20372
- const underlineSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M5.000117301940918,14.500022450683593L5.000117301940918,14.500022450683593Q5.000117301940918,14.450777450683594,5.009724660740918,14.402477450683593Q5.019332019940918,14.354177450683594,5.038177530940918,14.308679450683593Q5.057023040940918,14.263182450683594,5.084382488940918,14.222236450683594Q5.111741931940918,14.181290450683594,5.146563901940918,14.146469450683593Q5.181385871940918,14.111646450683594,5.222332181940918,14.084286450683594Q5.263278451940918,14.056927450683594,5.308775541940918,14.038082450683595Q5.354272661940918,14.019237450683594,5.402572121940918,14.009630450683593Q5.450871581940918,14.000022450683593,5.500117301940918,14.000022450683593L12.500117301940918,14.000022450683593Q12.549362201940918,14.000022450683593,12.597661501940918,14.009629450683594Q12.645960801940918,14.019237450683594,12.691457701940918,14.038082450683595Q12.736954701940917,14.056926450683594,12.777901601940918,14.084285450683593Q12.818847701940918,14.111645450683593,12.853670101940917,14.146468450683594Q12.888492101940919,14.181289450683593,12.915851601940918,14.222235450683593Q12.943210601940919,14.263181450683593,12.962056201940918,14.308679450683593Q12.980901701940919,14.354177450683594,12.990509501940917,14.402477450683593Q13.00011680194092,14.450777450683594,13.000117301940918,14.500022450683593L13.000117301940918,14.500022450683593Q13.00011680194092,14.549268450683593,12.990509001940918,14.597566450683594Q12.980901701940919,14.645866450683593,12.962056201940918,14.691363450683594Q12.943210601940919,14.736860450683594,12.915851601940918,14.777807450683595Q12.888492101940919,14.818753450683595,12.853670101940917,14.853575450683593Q12.818847701940918,14.888397450683593,12.777901601940918,14.915756450683594Q12.736954701940917,14.943115450683594,12.691457701940918,14.961960450683593Q12.645960801940918,14.980806450683593,12.597661501940918,14.990413450683594Q12.549362201940918,15.000021450683594,12.500117301940918,15.000022450683593L5.500117301940918,15.000022450683593Q5.450871581940918,15.000021450683594,5.402572121940918,14.990414450683593Q5.354272661940918,14.980806450683593,5.308775541940918,14.961960450683593Q5.263278451940918,14.943115450683594,5.222332161940918,14.915756450683594Q5.181385871940918,14.888397450683593,5.146563901940918,14.853574450683594Q5.111741931940918,14.818752450683593,5.084382488940918,14.777806450683594Q5.057023040940918,14.736860450683594,5.038177530940918,14.691363450683594Q5.019332019940918,14.645866450683593,5.009724660740918,14.597567450683593Q5.000117301940918,14.549268450683593,5.000117301940918,14.500022450683593ZM5.045039176940918,3.548906330683594Q5.045039176940918,3.1015625006835936,5.283039211940918,2.8637809706835937Q5.521039131940918,2.6259994506835938,5.969039081940918,2.6259994506835938L5.997039201940918,2.6259994506835938Q6.445039201940918,2.6259994506835938,6.6830393019409176,2.8637809706835937Q6.921039201940918,3.1015625006835936,6.921039201940918,3.548906330683594L6.921039201940918,9.010000250683593Q6.921039201940918,9.737999950683594,7.180039401940919,10.255999550683594Q7.439039201940918,10.774000150683595,7.908039101940918,11.053999950683593Q8.377039001940918,11.333999650683594,8.993039101940917,11.333999650683594Q9.609039301940918,11.333999650683594,10.085039101940918,11.060999850683594Q10.561039401940917,10.788000150683594,10.820039301940918,10.263000450683593Q11.079039101940918,9.737999950683594,11.079039101940918,9.010000250683593L11.079039101940918,3.548906330683594Q11.079039101940918,3.1015625006835936,11.317039501940918,2.8637809706835937Q11.555039401940917,2.6259994506835938,12.003039401940917,2.6259994506835938L12.031039201940917,2.6259994506835938Q12.479039201940918,2.6259994506835938,12.717039101940918,2.8637809706835937Q12.955039001940918,3.1015625006835936,12.955039001940918,3.548906330683594L12.955039001940918,9.010000250683593Q12.955039001940918,10.144000050683594,12.416039501940919,11.095999750683594Q11.877039901940918,12.048000350683594,10.967039101940918,12.600999850683595Q10.057039301940918,13.154000450683593,8.993039101940917,13.154000450683593Q7.929039001940918,13.154000450683593,7.0190392019409185,12.600999850683595Q6.109039201940918,12.048000350683594,5.577039361940918,11.095999750683594Q5.045039176940918,10.144000050683594,5.045039176940918,9.010000250683593L5.045039176940918,3.548906330683594Z" fill="#555555" fill-opacity="1"/></g></g></svg>`;
20373
- const moreSVG = `<svg t="1756109058354" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="11458" width="18" height="18"><path d="M512 320q-3.150769 0-6.301538-0.315077-3.111385-0.315077-6.183385-0.905846-3.072-0.630154-6.104615-1.536-2.993231-0.905846-5.907693-2.126769-2.914462-1.181538-5.671384-2.678154-2.756923-1.496615-5.395693-3.229539-2.599385-1.732923-5.04123-3.741538-2.441846-1.969231-4.647385-4.214154-2.244923-2.205538-4.214154-4.647385-1.969231-2.441846-3.741538-5.04123-1.732923-2.638769-3.229539-5.395693-1.496615-2.756923-2.678154-5.671384-1.181538-2.914462-2.126769-5.907693-0.905846-3.032615-1.536-6.104615-0.590769-3.072-0.905846-6.222769T448 256q0-3.150769 0.315077-6.301538 0.315077-3.111385 0.905846-6.183385 0.630154-3.072 1.536-6.104615 0.905846-2.993231 2.126769-5.907693 1.181538-2.914462 2.678154-5.671384 1.496615-2.756923 3.229539-5.395693 1.732923-2.599385 3.741538-5.04123 1.969231-2.441846 4.214154-4.647385 2.205538-2.205538 4.647385-4.214154 2.441846-1.969231 5.04123-3.741538 2.638769-1.732923 5.395693-3.229539 2.756923-1.496615 5.671384-2.678154 2.914462-1.181538 5.907693-2.126769 3.032615-0.905846 6.104615-1.536 3.072-0.590769 6.222769-0.905846T512 192q3.150769 0 6.301538 0.315077 3.111385 0.315077 6.183385 0.905846 3.072 0.630154 6.104615 1.536 2.993231 0.905846 5.907693 2.126769 2.914462 1.181538 5.671384 2.678154 2.756923 1.496615 5.395693 3.229539 2.599385 1.732923 5.04123 3.741538 2.441846 1.969231 4.647385 4.214154 2.205538 2.205538 4.214154 4.647385 1.969231 2.441846 3.741538 5.04123 1.732923 2.638769 3.229539 5.395693 1.496615 2.756923 2.678154 5.671384 1.181538 2.914462 2.126769 5.907693 0.905846 3.032615 1.536 6.104615 0.590769 3.072 0.905846 6.222769t0.315077 6.262154q0 3.150769-0.315077 6.301538-0.315077 3.111385-0.905846 6.183385-0.630154 3.072-1.536 6.104615-0.905846 2.993231-2.126769 5.907693-1.181538 2.914462-2.678154 5.671384-1.496615 2.756923-3.229539 5.395693-1.732923 2.599385-3.741538 5.04123-1.969231 2.441846-4.214154 4.647385-2.205538 2.244923-4.647385 4.214154-2.441846 1.969231-5.04123 3.741538-2.638769 1.732923-5.395693 3.229539-2.756923 1.496615-5.671384 2.678154-2.914462 1.181538-5.907693 2.126769-3.032615 0.905846-6.104615 1.536-3.072 0.590769-6.222769 0.905846T512 320z m0 256q-3.150769 0-6.301538-0.315077-3.111385-0.315077-6.183385-0.905846-3.072-0.630154-6.104615-1.536-2.993231-0.905846-5.907693-2.126769-2.914462-1.181538-5.671384-2.678154-2.756923-1.496615-5.395693-3.229539-2.599385-1.732923-5.04123-3.741538-2.441846-1.969231-4.647385-4.214154-2.244923-2.205538-4.214154-4.647385-1.969231-2.441846-3.741538-5.04123-1.732923-2.638769-3.229539-5.395693-1.496615-2.756923-2.678154-5.671384-1.181538-2.914462-2.126769-5.907693-0.905846-3.032615-1.536-6.104615-0.590769-3.072-0.905846-6.222769T448 512q0-3.150769 0.315077-6.301538 0.315077-3.111385 0.905846-6.183385 0.630154-3.072 1.536-6.104615 0.905846-2.993231 2.126769-5.907693 1.181538-2.914462 2.678154-5.671384 1.496615-2.756923 3.229539-5.395693 1.732923-2.599385 3.741538-5.04123 1.969231-2.441846 4.214154-4.647385 2.205538-2.244923 4.647385-4.214154 2.441846-1.969231 5.04123-3.741538 2.638769-1.732923 5.395693-3.229539 2.756923-1.496615 5.671384-2.678154 2.914462-1.181538 5.907693-2.126769 3.032615-0.905846 6.104615-1.536 3.072-0.590769 6.222769-0.905846T512 448q3.150769 0 6.301538 0.315077 3.111385 0.315077 6.183385 0.905846 3.072 0.630154 6.104615 1.536 2.993231 0.905846 5.907693 2.126769 2.914462 1.181538 5.671384 2.678154 2.756923 1.496615 5.395693 3.229539 2.599385 1.732923 5.04123 3.741538 2.441846 1.969231 4.647385 4.214154 2.205538 2.205538 4.214154 4.647385 1.969231 2.441846 3.741538 5.04123 1.732923 2.638769 3.229539 5.395693 1.496615 2.756923 2.678154 5.671384 1.181538 2.914462 2.126769 5.907693 0.905846 3.032615 1.536 6.104615 0.590769 3.072 0.905846 6.222769t0.315077 6.262154q0 3.150769-0.315077 6.301538-0.315077 3.111385-0.905846 6.183385-0.630154 3.072-1.536 6.104615-0.905846 2.993231-2.126769 5.907693-1.181538 2.914462-2.678154 5.671384-1.496615 2.756923-3.229539 5.395693-1.732923 2.599385-3.741538 5.04123-1.969231 2.441846-4.214154 4.647385-2.205538 2.244923-4.647385 4.214154-2.441846 1.969231-5.04123 3.741538-2.638769 1.732923-5.395693 3.229539-2.756923 1.496615-5.671384 2.678154-2.914462 1.181538-5.907693 2.126769-3.032615 0.905846-6.104615 1.536-3.072 0.590769-6.222769 0.905846T512 576z m0 256q-3.150769 0-6.301538-0.315077-3.111385-0.315077-6.183385-0.905846-3.072-0.630154-6.104615-1.536-2.993231-0.905846-5.907693-2.126769-2.914462-1.181538-5.671384-2.678154-2.756923-1.496615-5.395693-3.229539-2.599385-1.732923-5.04123-3.741538-2.441846-1.969231-4.647385-4.214154-2.244923-2.205538-4.214154-4.647385-1.969231-2.441846-3.741538-5.04123-1.732923-2.638769-3.229539-5.395693-1.496615-2.756923-2.678154-5.671384-1.181538-2.914462-2.126769-5.907693-0.905846-3.032615-1.536-6.104615-0.590769-3.072-0.905846-6.222769t-0.315077-6.262154q0-3.150769 0.315077-6.301538 0.315077-3.111385 0.905846-6.183385 0.630154-3.072 1.536-6.104615 0.905846-2.993231 2.126769-5.907693 1.181538-2.914462 2.678154-5.671384 1.496615-2.756923 3.229539-5.395693 1.732923-2.599385 3.741538-5.04123 1.969231-2.441846 4.214154-4.647385 2.205538-2.205538 4.647385-4.214154 2.441846-1.969231 5.04123-3.741538 2.638769-1.732923 5.395693-3.229539 2.756923-1.496615 5.671384-2.678154 2.914462-1.181538 5.907693-2.126769 3.032615-0.905846 6.104615-1.536 3.072-0.590769 6.222769-0.905846T512 704q3.150769 0 6.301538 0.315077 3.111385 0.315077 6.183385 0.905846 3.072 0.630154 6.104615 1.536 2.993231 0.905846 5.907693 2.126769 2.914462 1.181538 5.671384 2.678154 2.756923 1.496615 5.395693 3.229539 2.599385 1.732923 5.04123 3.741538 2.441846 1.969231 4.647385 4.214154 2.205538 2.205538 4.214154 4.647385 1.969231 2.441846 3.741538 5.04123 1.732923 2.638769 3.229539 5.395693 1.496615 2.756923 2.678154 5.671384 1.181538 2.914462 2.126769 5.907693 0.905846 3.032615 1.536 6.104615 0.590769 3.072 0.905846 6.222769t0.315077 6.262154q0 3.150769-0.315077 6.301538-0.315077 3.111385-0.905846 6.183385-0.630154 3.072-1.536 6.104615-0.905846 2.993231-2.126769 5.907693-1.181538 2.914462-2.678154 5.671384-1.496615 2.756923-3.229539 5.395693-1.732923 2.599385-3.741538 5.04123-1.969231 2.441846-4.214154 4.647385-2.205538 2.205538-4.647385 4.214154-2.441846 1.969231-5.04123 3.741538-2.638769 1.732923-5.395693 3.229539-2.756923 1.496615-5.671384 2.678154-2.914462 1.181538-5.907693 2.126769-3.032615 0.905846-6.104615 1.536-3.072 0.590769-6.222769 0.905846T512 832z" p-id="11459" fill="#555555"></path></svg>`;
20374
- const linkSVG = `<svg t="1756107950494" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="11245" width="18" height="18" style="padding:1px"><path d="M292.693333 564.906667L123.477333 395.648q-55.296-55.338667-54.272-134.4 1.066667-78.336 57.088-134.357333Q182.186667 70.912 260.608 69.845333q79.061333-1.066667 134.4 54.272l194.944 194.986667a40.533333 40.533333 0 0 1 0.938667 0.938667q54.4 55.04 53.333333 133.461333-1.066667 78.336-57.045333 134.357333a42.666667 42.666667 0 1 1-60.330667-60.330666q31.445333-31.488 32.042667-75.178667 0.597333-43.050667-29.269334-72.874667a44.458667 44.458667 0 0 1-0.853333-0.896l-194.133333-194.133333q-72.618667-72.618667-148.053334 2.773333-31.488 31.488-32.085333 75.178667-0.554667 43.050667 29.269333 72.874667l169.258667 169.301333a42.666667 42.666667 0 1 1-60.288 60.330667z m202.538667-69.674667a42.666667 42.666667 0 0 0-60.330667-60.373333q-55.978667 56.021333-57.045333 134.4-1.066667 79.018667 54.272 134.357333a40.362667 40.362667 0 0 0 0.981333 0.938667l1.706667 1.877333 194.986667 194.986667q55.338667 55.296 134.4 54.229333 78.336-1.066667 134.357333-57.045333 55.978667-56.021333 57.045333-134.4 1.066667-79.018667-54.272-134.357334l-169.258666-169.258666a42.666667 42.666667 0 1 0-60.373334 60.330666l169.301334 169.301334q29.866667 29.866667 29.269333 72.874666-0.597333 43.690667-32.042667 75.178667-31.488 31.445333-75.178666 32.042667-43.050667 0.597333-72.874667-29.269334l-194.986667-194.986666a39.68 39.68 0 0 0-0.981333-0.938667 43.52 43.52 0 0 0-1.749333-1.834667q-29.866667-29.866667-29.269334-72.917333 0.554667-43.690667 32.042667-75.136z" p-id="11246" fill="#555555"></path></svg>`;
20375
- const undoSVG = `<svg t="1756107888940" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="10819" width="18" height="18"><path d="M220.086857 374.893714l102.473143 102.473143c10.605714 10.642286 28.818286 3.108571 28.818286-11.922286v-77.275428h261.851428l8.009143 0.146286c98.048 3.364571 169.216 68.754286 169.216 160.182857 0 93.952-75.044571 160.365714-177.225143 160.365714H241.883429l-3.437715 0.256a25.307429 25.307429 0 0 0 3.437715 50.395429h371.346285l8.374857-0.146286c124.708571-3.657143 219.501714-90.148571 219.501715-210.834286 0-123.392-99.035429-211.017143-227.876572-211.017143h-261.851428V260.498286a16.896 16.896 0 0 0-28.818286-11.922286L220.086857 351.049143a16.896 16.896 0 0 0 0 23.844571z" p-id="10820" fill="#555555"></path></svg>`;
20376
- const redoSVG = `<svg t="1756107908999" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="11032" width="18" height="18"><path d="M836.205714 374.893714l-102.473143 102.473143a16.896 16.896 0 0 1-28.818285-11.922286v-77.275428h-261.851429l-8.045714 0.146286c-98.011429 3.364571-169.179429 68.754286-169.179429 160.182857 0 93.952 75.044571 160.365714 177.225143 160.365714h371.346286l3.437714 0.256a25.307429 25.307429 0 0 1-3.437714 50.395429H443.062857l-8.374857-0.146286c-124.708571-3.657143-219.501714-90.148571-219.501714-210.834286 0-123.392 99.035429-211.017143 227.84-211.017143h261.888V260.498286c0-15.030857 18.176-22.564571 28.818285-11.922286l102.473143 102.473143c6.582857 6.582857 6.582857 17.261714 0 23.844571z" p-id="11033" fill="#555555"></path></svg>`;
20377
- const ocrSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="16" height="15" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M3.0000245140625,2.6000244140625L5.5000243140625,2.6000244140625C5.8313951140625,2.6000244140625,6.1000242140625,2.3313953240625,6.1000242140625,2.0000244340625C6.1000242140625,1.6686535440624999,5.8313951140625,1.4000244140625,5.5000243140625,1.4000244140625L3.0000245140625,1.4000244140625Q2.3372827740625,1.4000244140625,1.8686535940625,1.8686535940625Q1.4000244140625,2.3372827740625,1.4000244140625,3.0000245140625L1.4000244140625,5.5000243140625C1.4000244140625,5.8313951140625,1.6686535440624999,6.1000242140625,2.0000244340625,6.1000242140625C2.3313953240625,6.1000242140625,2.6000244140625,5.8313951140625,2.6000244140625,5.5000243140625L2.6000244140625,3.0000245140625Q2.6000244140625,2.6000244140625,3.0000245140625,2.6000244140625ZM12.5000244140625,1.4000244140625L15.0000244140625,1.4000244140625Q15.6627664140625,1.4000244140625,16.1313954140625,1.8686538940625Q16.6000244140625,2.3372834940625,16.6000244140625,3.0000245140625L16.6000244140625,5.5000243140625C16.6000244140625,5.6591539140625,16.5368104140625,5.8117661140625,16.424288414062502,5.9242883140625C16.3117674140625,6.0368099140625,16.1591544140625,6.1000242140625,16.0000244140625,6.1000242140625C15.6686534140625,6.1000242140625,15.4000244140625,5.8313951140625,15.4000244140625,5.5000243140625L15.4000234140625,3.0000245140625Q15.4000234140625,2.6000244140625,15.0000244140625,2.6000244140625L12.5000244140625,2.6000244140625C12.1686534140625,2.6000244140625,11.9000244140625,2.3313953240625,11.9000244140625,2.0000244340625C11.9000244140625,1.6686535440624999,12.1686534140625,1.4000244140625,12.5000244140625,1.4000244140625ZM8.6239776140625,6.4719930140625C8.5439777140625,6.1512432140625,8.3999777140625,5.7421179140625,8.2479777140625,5.4212432140625L9.4959774140625,5.052368214062501C9.6959782140625,5.4293680140625,9.9199772140625,5.9346180140625,9.9999771140625,6.2714929140625L9.3519778140625,6.4719930140625L12.7119784140625,6.4719930140625L12.7119784140625,7.6079931140625L11.5039774140625,7.6079931140625C11.1279774140625,8.6968679140625,10.6159782140625,9.6014929140625,9.9599781140625,10.3461180140625C10.7599773140625,10.9224930140625,11.7279774140625,11.3468685140625,12.8879774140625,11.6029934140625C12.6239774140625,11.8592434140625,12.2799774140625,12.3716184140625,12.1039784140625,12.6918684140625C10.8719778140625,12.3716184140625,9.8719778140625,11.8752434140625,9.0479779140625,11.2107429140625C8.175977714062501,11.8992434140625,7.1199779140625,12.4036184140625,5.8559775140625,12.7558684140625C5.7279777140625,12.4757434140625,5.3759775140625,11.9312434140625,5.1519775140625,11.6591184140625C6.3759775140625,11.3868685140625,7.3839779140625,10.9706182140625,8.1839781140625,10.3781185140625C7.5199776140625,9.6094932140625,7.0079775140625,8.6888685140625,6.5919776140625,7.6079931140625L5.3279776140625,7.6079931140625L5.3279776140625,6.4719930140625L8.6239776140625,6.4719930140625ZM7.7999778140625,7.6079931140625C8.1119776140625,8.344617814062499,8.5359778140625,9.0011186140625,9.0719776140625,9.5694933140625C9.5439777140625,9.0251179140625,9.9199772140625,8.3766184140625,10.1919784140625,7.6079931140625L7.7999778140625,7.6079931140625ZM2.6000244140625,12.5000244140625L2.6000244140625,15.0000244140625Q2.6000244140625,15.4000234140625,3.0000245140625,15.4000234140625L5.5000243140625,15.4000234140625C5.8313951140625,15.4000244140625,6.1000242140625,15.6686534140625,6.1000242140625,16.0000244140625C6.1000242140625,16.3313964140625,5.8313951140625,16.6000254140625,5.5000243140625,16.6000254140625L5.4989548140625,16.6000244140625L3.0000245140625,16.6000244140625Q2.3372834940625,16.6000244140625,1.8686538940625,16.1313954140625Q1.4000244140625,15.6627664140625,1.4000244140625,15.0000244140625L1.4000244140625,12.5000244140625C1.4000244140625,12.1686534140625,1.6686535440624999,11.9000244140625,2.0000244340625,11.9000244140625C2.3313953240625,11.9000244140625,2.6000244140625,12.1686534140625,2.6000244140625,12.5000244140625ZM16.6000244140625,12.5010944140625L16.6000244140625,15.0000244140625Q16.6000244140625,15.6627654140625,16.1313954140625,16.1313954140625Q15.6627654140625,16.6000244140625,15.0000244140625,16.6000244140625L12.5000244140625,16.6000244140625C12.3408944140625,16.6000244140625,12.1882824140625,16.5368104140625,12.0757594140625,16.424288414062502C11.9632384140625,16.3117664140625,11.9000244140625,16.1591544140625,11.9000244140625,16.0000244140625C11.9000244140625,15.6686534140625,12.1686534140625,15.4000244140625,12.5000244140625,15.4000244140625L15.0000244140625,15.4000234140625Q15.4000234140625,15.4000234140625,15.4000234140625,15.0000244140625L15.4000234140625,12.5000244140625C15.4000244140625,12.1686534140625,15.6686534140625,11.9000244140625,16.0000244140625,11.9000244140625C16.3313964140625,11.9000244140625,16.6000254140625,12.1686534140625,16.6000254140625,12.5000244140625L16.6000244140625,12.5010944140625Z" fill-rule="evenodd" fill="#555555" fill-opacity="1"/></g></g></svg>`;
20378
- const mathSVG = `<svg t="1756107836493" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="10608" width="16" height="15"><path d="M877.454222 856.177778q4.835556-4.835556 7.395556-11.093334 2.616889-6.257778 2.616889-13.084444 0-3.413333-0.625778-6.656-0.682667-3.299556-1.991111-6.428444-1.251556-3.072-3.128889-5.859556-1.877333-2.844444-4.266667-5.176889-2.332444-2.389333-5.12-4.266667-2.844444-1.877333-5.916444-3.128888-3.128889-1.308444-6.428445-1.934223-3.299556-0.682667-6.656-0.682666-6.826667 0-13.084444 2.616889-6.257778 2.56-11.036445 7.395555l-54.044444 53.987556H253.155556l325.688888-325.745778q2.389333-2.389333 4.266667-5.12 1.877333-2.844444 3.128889-5.916445 1.308444-3.128889 1.934222-6.428444 0.682667-3.299556 0.682667-6.656 0-3.413333-0.682667-6.656-0.625778-3.299556-1.934222-6.428444-1.251556-3.072-3.128889-5.859556-1.877333-2.844444-4.266667-5.176889L253.155556 162.133333h522.126222l53.930666 53.987556q4.835556 4.835556 11.093334 7.395555 6.257778 2.616889 13.084444 2.616889 3.413333 0 6.656-0.682666 3.299556-0.625778 6.428445-1.934223 3.072-1.251556 5.859555-3.128888 2.844444-1.877333 5.176889-4.266667 2.389333-2.389333 4.266667-5.12 1.877333-2.844444 3.128889-5.916445 1.308444-3.128889 1.934222-6.428444 0.682667-3.299556 0.682667-6.656 0-6.826667-2.616889-13.084444-2.56-6.257778-7.395556-11.036445l-64-64q-4.778667-4.835556-11.036444-7.395555-6.257778-2.616889-13.084445-2.616889H170.666667q-6.826667 0-13.084445 2.616889-6.257778 2.56-11.036444 7.395555-2.389333 2.389333-4.266667 5.12-1.877333 2.844444-3.128889 5.916445-1.308444 3.128889-1.934222 6.428444-0.682667 3.299556-0.682667 6.656 0 3.413333 0.682667 6.656 0.625778 3.299556 1.934222 6.428444 1.251556 3.072 3.128889 5.859556 1.877333 2.844444 4.266667 5.176889L506.311111 512l-359.822222 359.879111q-4.835556 4.778667-7.395556 11.036445-2.616889 6.257778-2.616889 13.084444 0 3.413333 0.682667 6.656 0.625778 3.299556 1.934222 6.428444 1.251556 3.072 3.128889 5.859556 1.877333 2.844444 4.266667 5.176889 2.389333 2.389333 5.12 4.266667 2.844444 1.877333 5.916444 3.128888 3.128889 1.308444 6.428445 1.991112 3.299556 0.625778 6.656 0.625777h618.666666q6.826667 0 13.084445-2.616889 6.257778-2.56 11.036444-7.395555l64-63.943111z" p-id="10609" fill="#555555"></path></svg>`;
20379
- const imageSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M1.87471507,3.83578219Q1.5,4.18540478,1.5,4.6875L1.5,14.312503Q1.50000006,14.814598,1.874716,15.16422Q2.23459671,15.5,2.73684216,15.5L15.263157,15.5Q15.765403,15.5,16.125284,15.164218Q16.499999000000003,14.814597,16.499999000000003,14.312501L16.499999000000003,4.6875Q16.499999000000003,4.18540342,16.125284999999998,3.83578214Q15.765404,3.5,15.263157,3.5L2.73684216,3.5Q2.23459646,3.5,1.87471507,3.83578219ZM2.5,14.312503L2.5,4.6875Q2.5,4.5,2.73684216,4.5L15.263157,4.5Q15.5,4.5,15.5,4.6875L15.5,14.312501Q15.5,14.5,15.263157,14.5L2.73684216,14.5Q2.5,14.5,2.5,14.312503Z" fill-rule="evenodd" fill="#555555" fill-opacity="1" style="mix-blend-mode:passthrough"/></g><g><ellipse cx="5.4375" cy="7.4375" rx="0.4375" ry="0.4375" fill-opacity="0" stroke-opacity="1" stroke="#555555" fill="none" stroke-width="1" stroke-linecap="ROUND" stroke-linejoin="round" style="mix-blend-mode:passthrough"/></g><g><path d="M5.9053998,9.924615948146972L1.7143693,12.841608238146973Q1.61364189,12.911715538146973,1.55682093,13.020492338146973Q1.5,13.129269138146974,1.5,13.251992238146972L1.50000003,14.418008338146972Q1.50000003,14.876594038146973,1.84130602,15.195924738146973Q2.16843581,15.501991738146973,2.62437022,15.501991738146973L15.375628,15.501991738146973Q15.831564,15.501991738146973,16.158693,15.195924738146973Q16.5,14.876594038146973,16.5,14.418007838146973L16.5,13.251992238146972Q16.500000999999997,13.186988838146974,16.48338,13.124146438146973Q16.466759,13.061303638146972,16.434621,13.004799838146972Q16.402485,12.948296338146973,16.356969,12.901887938146972Q16.311453,12.855479738146972,16.255583,12.822251838146972L9.8796926,9.030259398146972Q9.842938400000001,9.008400078146973,9.8030057,8.993099628146974Q9.763073,8.977799118146972,9.721121799999999,8.969501908146972Q9.6791716,8.961204618146972,9.6364217,8.960151608146973Q9.5936708,8.959098578146973,9.551362000000001,8.965320438146973Q9.5090542,8.971542238146972,9.4684162,8.984858218146973Q9.427778199999999,8.998174158146973,9.3899918,9.018197478146973Q9.352206200000001,9.038220708146973,9.3183689,9.064369648146972Q9.284532500000001,9.090518598146973,9.2556267,9.122033748146972L7.6887164,10.830422738146973L6.4904227,9.934544588146972Q6.4273362,9.887379288146972,6.3528042,9.861893948146973Q6.2782726,9.836408678146972,6.1995153,9.835072038146972Q6.1207581,9.833735408146973,6.045404,9.856676968146973Q5.9700503000000005,9.879618528146972,5.9053998,9.924615948146972ZM2.5,13.513173138146973L2.50000006,14.418008338146972Q2.50000006,14.501992238146972,2.62437022,14.501992238146972L15.375628,14.501992238146972Q15.5,14.501992238146972,15.5,14.418007838146973L15.5,13.536368338146973L9.7178593,10.097503488146973L8.1200023,11.839632738146973Q8.0888524,11.873595438146973,8.052019600000001,11.901292338146973Q8.0151863,11.928988938146972,7.9739118,11.949486538146973Q7.9326363,11.969984038146972,7.88831,11.982591638146973Q7.8439837,11.995199238146974,7.7980995,11.999492138146973Q7.7522154,12.003785338146972,7.7063198,11.999619238146973Q7.6604242,11.995453338146973,7.6160631,11.982968338146973Q7.571702,11.970483338146973,7.5303702,11.950099938146973Q7.4890385,11.929716538146973,7.4521289,11.902122038146972L6.1805682,10.951467238146973L2.5,13.513173138146973Z" fill-rule="evenodd" fill="#555555" fill-opacity="1" style="mix-blend-mode:passthrough"/></g></g></svg>`;
18852
+ const boldSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M6.794999938146972,7.7800002288818355L9.045000038146974,7.7800002288818355Q9.855000038146972,7.7800002288818355,10.230000038146972,7.442500128881836Q10.605000038146972,7.105000028881836,10.605000038146972,6.505000128881836Q10.605000038146972,6.114999728881836,10.440000038146973,5.860000628881836Q10.275000138146972,5.6050005288818365,9.929999838146973,5.470000228881836Q9.585000038146973,5.335000028881836,9.045000038146974,5.335000028881836L7.139999938146973,5.335000028881836L7.139999938146973,3.385000228881836L9.045000038146974,3.385000228881836Q10.034999838146973,3.385000228881836,10.852499938146973,3.797500608881836Q11.670000038146974,4.2100000388818355,12.142499938146972,4.922500628881836Q12.614999738146974,5.635000228881836,12.614999738146974,6.505000128881836Q12.614999738146974,7.375000028881836,12.142499938146972,8.042500028881836Q11.670000038146974,8.710000028881836,10.860000138146972,9.070000128881837Q10.050000238146973,9.430000328881835,9.045000038146974,9.430000328881835L6.794999938146972,9.430000328881835L6.794999938146972,7.7800002288818355ZM7.139999938146973,12.550000228881835L9.329999938146972,12.550000228881835Q9.900000138146972,12.550000228881835,10.327499838146974,12.354999528881836Q10.755000138146972,12.159999828881835,10.987500238146973,11.807499928881835Q11.219999838146972,11.454999928881836,11.219999838146972,11.020000428881836Q11.219999838146972,10.600000428881836,10.987500238146973,10.232500028881836Q10.755000138146972,9.864999728881836,10.327499838146974,9.647500028881836Q9.900000138146972,9.430000328881835,9.329999938146972,9.430000328881835L6.975000038146972,9.430000328881835L6.975000038146972,7.7800002288818355L9.329999938146972,7.7800002288818355Q10.349999938146972,7.7800002288818355,11.250000038146972,8.200000328881835Q12.149999638146973,8.620000328881837,12.690000538146972,9.362500228881835Q13.229999538146973,10.104999528881836,13.229999538146973,11.034999828881837Q13.229999538146973,11.949999828881836,12.690000538146972,12.752500528881836Q12.149999638146973,13.555000228881836,11.250000038146972,14.027500228881836Q10.349999938146972,14.500000228881836,9.329999938146972,14.500000228881836L7.139999938146973,14.500000228881836L7.139999938146973,12.550000228881835ZM7.064999938146973,14.500000228881836Q6.284999968146972,14.500000228881836,5.872500058146973,14.095000228881837Q5.460000038146973,13.689999228881836,5.460000038146973,12.895000428881836L5.460000038146973,4.989999728881836Q5.460000038146973,4.195000648881836,5.872500058146973,3.789999958881836Q6.284999968146972,3.385000228881836,7.064999938146973,3.385000228881836L7.469999838146973,3.385000228881836L7.469999838146973,14.500000228881836L7.064999938146973,14.500000228881836Z" fill="#555555" fill-opacity="1"/></g></g></svg>`;
18853
+ const italicSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M8,3Q7.9015086,3,7.8049095,3.019214718Q7.7083106,3.038429435,7.6173165,3.076120459Q7.5263224,3.11381148,7.4444296,3.16853037Q7.3625371,3.2232492600000002,7.2928932,3.2928932Q7.2232492,3.36253715,7.1685302,3.4444297600000002Q7.1138113999999995,3.52632231,7.0761204,3.61731648Q7.0384293,3.70831072,7.0192146,3.80490965Q6.99999994,3.90150857,7,4Q6.99999994,4.0984913,7.0192146,4.1950902Q7.0384293,4.291689,7.0761204,4.3826833Q7.1138113999999995,4.4736774,7.1685302,4.5555699Q7.2232492,4.6374626,7.2928932,4.7071065999999995Q7.3625371,4.7767504,7.4444296,4.8314693Q7.5263224,4.8861883,7.6173165,4.9238794Q7.7083106,4.9615704,7.8049096,4.9807851Q7.9015086,4.9999999,8,5L9.137146,5L8,13L7,13Q6.90150857,13,6.80490965,13.019215Q6.70831072,13.038429,6.6173164799999995,13.07612Q6.52632231,13.113811,6.44442973,13.16853Q6.36253715,13.223249,6.2928932,13.292892Q6.22324926,13.362536,6.16853037,13.444429Q6.11381148,13.526321,6.076120459,13.617315Q6.038429435,13.708309,6.019214718,13.804909Q6,13.901508,6,14Q6,14.098491,6.019214718,14.195089Q6.038429435,14.291689,6.076120459,14.382683Q6.11381148,14.473677,6.16853037,14.555569Q6.22324926,14.637462,6.2928932,14.707106Q6.36253715,14.77675,6.44442976,14.831469Q6.52632231,14.886187,6.6173164799999995,14.923878Q6.70831072,14.961569,6.80490965,14.980784Q6.90150857,15,7,15L11,15Q11.0984912,15,11.1950898,14.980784Q11.2916889,14.961569,11.382682800000001,14.923878Q11.473677200000001,14.886187,11.5555696,14.831469Q11.6374626,14.77675,11.7071066,14.707106Q11.7767506,14.637462,11.8314691,14.555569Q11.8861876,14.473677,11.9238791,14.382683Q11.9615698,14.291689,11.9807849,14.195089Q12,14.098491,12,14Q12,13.901508,11.9807849,13.804909Q11.9615698,13.708309,11.9238791,13.617315Q11.8861876,13.526321,11.8314691,13.444428Q11.7767506,13.362536,11.7071066,13.292892Q11.6374626,13.223249,11.5555701,13.16853Q11.473677200000001,13.113811,11.382682800000001,13.07612Q11.2916889,13.038429,11.1950903,13.019215Q11.0984912,13,11,13L9.8626451,13L11,5L12,5Q12.0984907,4.9999999,12.1950893,4.9807851Q12.2916884,4.9615703,12.382682800000001,4.9238793Q12.4736767,4.8861883,12.5555696,4.8314693Q12.6374621,4.7767504,12.7071061,4.7071065999999995Q12.776750100000001,4.6374626,12.831468600000001,4.5555699Q12.8861876,4.4736774,12.9238787,4.3826833Q12.9615698,4.291689,12.9807849,4.1950902Q12.999999500000001,4.0984913,13,4Q12.999999500000001,3.90150857,12.980784400000001,3.80490965Q12.9615698,3.70831072,12.9238787,3.61731648Q12.8861876,3.52632231,12.8314691,3.44442973Q12.7767506,3.36253715,12.7071066,3.2928932Q12.6374626,3.2232492600000002,12.5555696,3.16853037Q12.4736767,3.11381148,12.382682800000001,3.076120459Q12.2916884,3.038429435,12.1950898,3.019214718Q12.0984907,3,12,3L8,3Z" fill-rule="evenodd" fill="#555555" fill-opacity="1"/></g></g></svg>`;
18854
+ const underlineSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M5.000117301940918,14.500022450683593L5.000117301940918,14.500022450683593Q5.000117301940918,14.450777450683594,5.009724660740918,14.402477450683593Q5.019332019940918,14.354177450683594,5.038177530940918,14.308679450683593Q5.057023040940918,14.263182450683594,5.084382488940918,14.222236450683594Q5.111741931940918,14.181290450683594,5.146563901940918,14.146469450683593Q5.181385871940918,14.111646450683594,5.222332181940918,14.084286450683594Q5.263278451940918,14.056927450683594,5.308775541940918,14.038082450683595Q5.354272661940918,14.019237450683594,5.402572121940918,14.009630450683593Q5.450871581940918,14.000022450683593,5.500117301940918,14.000022450683593L12.500117301940918,14.000022450683593Q12.549362201940918,14.000022450683593,12.597661501940918,14.009629450683594Q12.645960801940918,14.019237450683594,12.691457701940918,14.038082450683595Q12.736954701940917,14.056926450683594,12.777901601940918,14.084285450683593Q12.818847701940918,14.111645450683593,12.853670101940917,14.146468450683594Q12.888492101940919,14.181289450683593,12.915851601940918,14.222235450683593Q12.943210601940919,14.263181450683593,12.962056201940918,14.308679450683593Q12.980901701940919,14.354177450683594,12.990509501940917,14.402477450683593Q13.00011680194092,14.450777450683594,13.000117301940918,14.500022450683593L13.000117301940918,14.500022450683593Q13.00011680194092,14.549268450683593,12.990509001940918,14.597566450683594Q12.980901701940919,14.645866450683593,12.962056201940918,14.691363450683594Q12.943210601940919,14.736860450683594,12.915851601940918,14.777807450683595Q12.888492101940919,14.818753450683595,12.853670101940917,14.853575450683593Q12.818847701940918,14.888397450683593,12.777901601940918,14.915756450683594Q12.736954701940917,14.943115450683594,12.691457701940918,14.961960450683593Q12.645960801940918,14.980806450683593,12.597661501940918,14.990413450683594Q12.549362201940918,15.000021450683594,12.500117301940918,15.000022450683593L5.500117301940918,15.000022450683593Q5.450871581940918,15.000021450683594,5.402572121940918,14.990414450683593Q5.354272661940918,14.980806450683593,5.308775541940918,14.961960450683593Q5.263278451940918,14.943115450683594,5.222332161940918,14.915756450683594Q5.181385871940918,14.888397450683593,5.146563901940918,14.853574450683594Q5.111741931940918,14.818752450683593,5.084382488940918,14.777806450683594Q5.057023040940918,14.736860450683594,5.038177530940918,14.691363450683594Q5.019332019940918,14.645866450683593,5.009724660740918,14.597567450683593Q5.000117301940918,14.549268450683593,5.000117301940918,14.500022450683593ZM5.045039176940918,3.548906330683594Q5.045039176940918,3.1015625006835936,5.283039211940918,2.8637809706835937Q5.521039131940918,2.6259994506835938,5.969039081940918,2.6259994506835938L5.997039201940918,2.6259994506835938Q6.445039201940918,2.6259994506835938,6.6830393019409176,2.8637809706835937Q6.921039201940918,3.1015625006835936,6.921039201940918,3.548906330683594L6.921039201940918,9.010000250683593Q6.921039201940918,9.737999950683594,7.180039401940919,10.255999550683594Q7.439039201940918,10.774000150683595,7.908039101940918,11.053999950683593Q8.377039001940918,11.333999650683594,8.993039101940917,11.333999650683594Q9.609039301940918,11.333999650683594,10.085039101940918,11.060999850683594Q10.561039401940917,10.788000150683594,10.820039301940918,10.263000450683593Q11.079039101940918,9.737999950683594,11.079039101940918,9.010000250683593L11.079039101940918,3.548906330683594Q11.079039101940918,3.1015625006835936,11.317039501940918,2.8637809706835937Q11.555039401940917,2.6259994506835938,12.003039401940917,2.6259994506835938L12.031039201940917,2.6259994506835938Q12.479039201940918,2.6259994506835938,12.717039101940918,2.8637809706835937Q12.955039001940918,3.1015625006835936,12.955039001940918,3.548906330683594L12.955039001940918,9.010000250683593Q12.955039001940918,10.144000050683594,12.416039501940919,11.095999750683594Q11.877039901940918,12.048000350683594,10.967039101940918,12.600999850683595Q10.057039301940918,13.154000450683593,8.993039101940917,13.154000450683593Q7.929039001940918,13.154000450683593,7.0190392019409185,12.600999850683595Q6.109039201940918,12.048000350683594,5.577039361940918,11.095999750683594Q5.045039176940918,10.144000050683594,5.045039176940918,9.010000250683593L5.045039176940918,3.548906330683594Z" fill="#555555" fill-opacity="1"/></g></g></svg>`;
18855
+ const moreSVG = `<svg t="1756109058354" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="11458" width="18" height="18"><path d="M512 320q-3.150769 0-6.301538-0.315077-3.111385-0.315077-6.183385-0.905846-3.072-0.630154-6.104615-1.536-2.993231-0.905846-5.907693-2.126769-2.914462-1.181538-5.671384-2.678154-2.756923-1.496615-5.395693-3.229539-2.599385-1.732923-5.04123-3.741538-2.441846-1.969231-4.647385-4.214154-2.244923-2.205538-4.214154-4.647385-1.969231-2.441846-3.741538-5.04123-1.732923-2.638769-3.229539-5.395693-1.496615-2.756923-2.678154-5.671384-1.181538-2.914462-2.126769-5.907693-0.905846-3.032615-1.536-6.104615-0.590769-3.072-0.905846-6.222769T448 256q0-3.150769 0.315077-6.301538 0.315077-3.111385 0.905846-6.183385 0.630154-3.072 1.536-6.104615 0.905846-2.993231 2.126769-5.907693 1.181538-2.914462 2.678154-5.671384 1.496615-2.756923 3.229539-5.395693 1.732923-2.599385 3.741538-5.04123 1.969231-2.441846 4.214154-4.647385 2.205538-2.205538 4.647385-4.214154 2.441846-1.969231 5.04123-3.741538 2.638769-1.732923 5.395693-3.229539 2.756923-1.496615 5.671384-2.678154 2.914462-1.181538 5.907693-2.126769 3.032615-0.905846 6.104615-1.536 3.072-0.590769 6.222769-0.905846T512 192q3.150769 0 6.301538 0.315077 3.111385 0.315077 6.183385 0.905846 3.072 0.630154 6.104615 1.536 2.993231 0.905846 5.907693 2.126769 2.914462 1.181538 5.671384 2.678154 2.756923 1.496615 5.395693 3.229539 2.599385 1.732923 5.04123 3.741538 2.441846 1.969231 4.647385 4.214154 2.205538 2.205538 4.214154 4.647385 1.969231 2.441846 3.741538 5.04123 1.732923 2.638769 3.229539 5.395693 1.496615 2.756923 2.678154 5.671384 1.181538 2.914462 2.126769 5.907693 0.905846 3.032615 1.536 6.104615 0.590769 3.072 0.905846 6.222769t0.315077 6.262154q0 3.150769-0.315077 6.301538-0.315077 3.111385-0.905846 6.183385-0.630154 3.072-1.536 6.104615-0.905846 2.993231-2.126769 5.907693-1.181538 2.914462-2.678154 5.671384-1.496615 2.756923-3.229539 5.395693-1.732923 2.599385-3.741538 5.04123-1.969231 2.441846-4.214154 4.647385-2.205538 2.244923-4.647385 4.214154-2.441846 1.969231-5.04123 3.741538-2.638769 1.732923-5.395693 3.229539-2.756923 1.496615-5.671384 2.678154-2.914462 1.181538-5.907693 2.126769-3.032615 0.905846-6.104615 1.536-3.072 0.590769-6.222769 0.905846T512 320z m0 256q-3.150769 0-6.301538-0.315077-3.111385-0.315077-6.183385-0.905846-3.072-0.630154-6.104615-1.536-2.993231-0.905846-5.907693-2.126769-2.914462-1.181538-5.671384-2.678154-2.756923-1.496615-5.395693-3.229539-2.599385-1.732923-5.04123-3.741538-2.441846-1.969231-4.647385-4.214154-2.244923-2.205538-4.214154-4.647385-1.969231-2.441846-3.741538-5.04123-1.732923-2.638769-3.229539-5.395693-1.496615-2.756923-2.678154-5.671384-1.181538-2.914462-2.126769-5.907693-0.905846-3.032615-1.536-6.104615-0.590769-3.072-0.905846-6.222769T448 512q0-3.150769 0.315077-6.301538 0.315077-3.111385 0.905846-6.183385 0.630154-3.072 1.536-6.104615 0.905846-2.993231 2.126769-5.907693 1.181538-2.914462 2.678154-5.671384 1.496615-2.756923 3.229539-5.395693 1.732923-2.599385 3.741538-5.04123 1.969231-2.441846 4.214154-4.647385 2.205538-2.244923 4.647385-4.214154 2.441846-1.969231 5.04123-3.741538 2.638769-1.732923 5.395693-3.229539 2.756923-1.496615 5.671384-2.678154 2.914462-1.181538 5.907693-2.126769 3.032615-0.905846 6.104615-1.536 3.072-0.590769 6.222769-0.905846T512 448q3.150769 0 6.301538 0.315077 3.111385 0.315077 6.183385 0.905846 3.072 0.630154 6.104615 1.536 2.993231 0.905846 5.907693 2.126769 2.914462 1.181538 5.671384 2.678154 2.756923 1.496615 5.395693 3.229539 2.599385 1.732923 5.04123 3.741538 2.441846 1.969231 4.647385 4.214154 2.205538 2.205538 4.214154 4.647385 1.969231 2.441846 3.741538 5.04123 1.732923 2.638769 3.229539 5.395693 1.496615 2.756923 2.678154 5.671384 1.181538 2.914462 2.126769 5.907693 0.905846 3.032615 1.536 6.104615 0.590769 3.072 0.905846 6.222769t0.315077 6.262154q0 3.150769-0.315077 6.301538-0.315077 3.111385-0.905846 6.183385-0.630154 3.072-1.536 6.104615-0.905846 2.993231-2.126769 5.907693-1.181538 2.914462-2.678154 5.671384-1.496615 2.756923-3.229539 5.395693-1.732923 2.599385-3.741538 5.04123-1.969231 2.441846-4.214154 4.647385-2.205538 2.244923-4.647385 4.214154-2.441846 1.969231-5.04123 3.741538-2.638769 1.732923-5.395693 3.229539-2.756923 1.496615-5.671384 2.678154-2.914462 1.181538-5.907693 2.126769-3.032615 0.905846-6.104615 1.536-3.072 0.590769-6.222769 0.905846T512 576z m0 256q-3.150769 0-6.301538-0.315077-3.111385-0.315077-6.183385-0.905846-3.072-0.630154-6.104615-1.536-2.993231-0.905846-5.907693-2.126769-2.914462-1.181538-5.671384-2.678154-2.756923-1.496615-5.395693-3.229539-2.599385-1.732923-5.04123-3.741538-2.441846-1.969231-4.647385-4.214154-2.244923-2.205538-4.214154-4.647385-1.969231-2.441846-3.741538-5.04123-1.732923-2.638769-3.229539-5.395693-1.496615-2.756923-2.678154-5.671384-1.181538-2.914462-2.126769-5.907693-0.905846-3.032615-1.536-6.104615-0.590769-3.072-0.905846-6.222769t-0.315077-6.262154q0-3.150769 0.315077-6.301538 0.315077-3.111385 0.905846-6.183385 0.630154-3.072 1.536-6.104615 0.905846-2.993231 2.126769-5.907693 1.181538-2.914462 2.678154-5.671384 1.496615-2.756923 3.229539-5.395693 1.732923-2.599385 3.741538-5.04123 1.969231-2.441846 4.214154-4.647385 2.205538-2.205538 4.647385-4.214154 2.441846-1.969231 5.04123-3.741538 2.638769-1.732923 5.395693-3.229539 2.756923-1.496615 5.671384-2.678154 2.914462-1.181538 5.907693-2.126769 3.032615-0.905846 6.104615-1.536 3.072-0.590769 6.222769-0.905846T512 704q3.150769 0 6.301538 0.315077 3.111385 0.315077 6.183385 0.905846 3.072 0.630154 6.104615 1.536 2.993231 0.905846 5.907693 2.126769 2.914462 1.181538 5.671384 2.678154 2.756923 1.496615 5.395693 3.229539 2.599385 1.732923 5.04123 3.741538 2.441846 1.969231 4.647385 4.214154 2.205538 2.205538 4.214154 4.647385 1.969231 2.441846 3.741538 5.04123 1.732923 2.638769 3.229539 5.395693 1.496615 2.756923 2.678154 5.671384 1.181538 2.914462 2.126769 5.907693 0.905846 3.032615 1.536 6.104615 0.590769 3.072 0.905846 6.222769t0.315077 6.262154q0 3.150769-0.315077 6.301538-0.315077 3.111385-0.905846 6.183385-0.630154 3.072-1.536 6.104615-0.905846 2.993231-2.126769 5.907693-1.181538 2.914462-2.678154 5.671384-1.496615 2.756923-3.229539 5.395693-1.732923 2.599385-3.741538 5.04123-1.969231 2.441846-4.214154 4.647385-2.205538 2.205538-4.647385 4.214154-2.441846 1.969231-5.04123 3.741538-2.638769 1.732923-5.395693 3.229539-2.756923 1.496615-5.671384 2.678154-2.914462 1.181538-5.907693 2.126769-3.032615 0.905846-6.104615 1.536-3.072 0.590769-6.222769 0.905846T512 832z" p-id="11459" fill="#555555"></path></svg>`;
18856
+ const linkSVG = `<svg t="1756107950494" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="11245" width="18" height="18" style="padding:1px"><path d="M292.693333 564.906667L123.477333 395.648q-55.296-55.338667-54.272-134.4 1.066667-78.336 57.088-134.357333Q182.186667 70.912 260.608 69.845333q79.061333-1.066667 134.4 54.272l194.944 194.986667a40.533333 40.533333 0 0 1 0.938667 0.938667q54.4 55.04 53.333333 133.461333-1.066667 78.336-57.045333 134.357333a42.666667 42.666667 0 1 1-60.330667-60.330666q31.445333-31.488 32.042667-75.178667 0.597333-43.050667-29.269334-72.874667a44.458667 44.458667 0 0 1-0.853333-0.896l-194.133333-194.133333q-72.618667-72.618667-148.053334 2.773333-31.488 31.488-32.085333 75.178667-0.554667 43.050667 29.269333 72.874667l169.258667 169.301333a42.666667 42.666667 0 1 1-60.288 60.330667z m202.538667-69.674667a42.666667 42.666667 0 0 0-60.330667-60.373333q-55.978667 56.021333-57.045333 134.4-1.066667 79.018667 54.272 134.357333a40.362667 40.362667 0 0 0 0.981333 0.938667l1.706667 1.877333 194.986667 194.986667q55.338667 55.296 134.4 54.229333 78.336-1.066667 134.357333-57.045333 55.978667-56.021333 57.045333-134.4 1.066667-79.018667-54.272-134.357334l-169.258666-169.258666a42.666667 42.666667 0 1 0-60.373334 60.330666l169.301334 169.301334q29.866667 29.866667 29.269333 72.874666-0.597333 43.690667-32.042667 75.178667-31.488 31.445333-75.178666 32.042667-43.050667 0.597333-72.874667-29.269334l-194.986667-194.986666a39.68 39.68 0 0 0-0.981333-0.938667 43.52 43.52 0 0 0-1.749333-1.834667q-29.866667-29.866667-29.269334-72.917333 0.554667-43.690667 32.042667-75.136z" p-id="11246" fill="#555555"></path></svg>`;
18857
+ const undoSVG = `<svg t="1756107888940" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="10819" width="18" height="18"><path d="M220.086857 374.893714l102.473143 102.473143c10.605714 10.642286 28.818286 3.108571 28.818286-11.922286v-77.275428h261.851428l8.009143 0.146286c98.048 3.364571 169.216 68.754286 169.216 160.182857 0 93.952-75.044571 160.365714-177.225143 160.365714H241.883429l-3.437715 0.256a25.307429 25.307429 0 0 0 3.437715 50.395429h371.346285l8.374857-0.146286c124.708571-3.657143 219.501714-90.148571 219.501715-210.834286 0-123.392-99.035429-211.017143-227.876572-211.017143h-261.851428V260.498286a16.896 16.896 0 0 0-28.818286-11.922286L220.086857 351.049143a16.896 16.896 0 0 0 0 23.844571z" p-id="10820" fill="#555555"></path></svg>`;
18858
+ const redoSVG = `<svg t="1756107908999" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="11032" width="18" height="18"><path d="M836.205714 374.893714l-102.473143 102.473143a16.896 16.896 0 0 1-28.818285-11.922286v-77.275428h-261.851429l-8.045714 0.146286c-98.011429 3.364571-169.179429 68.754286-169.179429 160.182857 0 93.952 75.044571 160.365714 177.225143 160.365714h371.346286l3.437714 0.256a25.307429 25.307429 0 0 1-3.437714 50.395429H443.062857l-8.374857-0.146286c-124.708571-3.657143-219.501714-90.148571-219.501714-210.834286 0-123.392 99.035429-211.017143 227.84-211.017143h261.888V260.498286c0-15.030857 18.176-22.564571 28.818285-11.922286l102.473143 102.473143c6.582857 6.582857 6.582857 17.261714 0 23.844571z" p-id="11033" fill="#555555"></path></svg>`;
18859
+ const ocrSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="16" height="15" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M3.0000245140625,2.6000244140625L5.5000243140625,2.6000244140625C5.8313951140625,2.6000244140625,6.1000242140625,2.3313953240625,6.1000242140625,2.0000244340625C6.1000242140625,1.6686535440624999,5.8313951140625,1.4000244140625,5.5000243140625,1.4000244140625L3.0000245140625,1.4000244140625Q2.3372827740625,1.4000244140625,1.8686535940625,1.8686535940625Q1.4000244140625,2.3372827740625,1.4000244140625,3.0000245140625L1.4000244140625,5.5000243140625C1.4000244140625,5.8313951140625,1.6686535440624999,6.1000242140625,2.0000244340625,6.1000242140625C2.3313953240625,6.1000242140625,2.6000244140625,5.8313951140625,2.6000244140625,5.5000243140625L2.6000244140625,3.0000245140625Q2.6000244140625,2.6000244140625,3.0000245140625,2.6000244140625ZM12.5000244140625,1.4000244140625L15.0000244140625,1.4000244140625Q15.6627664140625,1.4000244140625,16.1313954140625,1.8686538940625Q16.6000244140625,2.3372834940625,16.6000244140625,3.0000245140625L16.6000244140625,5.5000243140625C16.6000244140625,5.6591539140625,16.5368104140625,5.8117661140625,16.424288414062502,5.9242883140625C16.3117674140625,6.0368099140625,16.1591544140625,6.1000242140625,16.0000244140625,6.1000242140625C15.6686534140625,6.1000242140625,15.4000244140625,5.8313951140625,15.4000244140625,5.5000243140625L15.4000234140625,3.0000245140625Q15.4000234140625,2.6000244140625,15.0000244140625,2.6000244140625L12.5000244140625,2.6000244140625C12.1686534140625,2.6000244140625,11.9000244140625,2.3313953240625,11.9000244140625,2.0000244340625C11.9000244140625,1.6686535440624999,12.1686534140625,1.4000244140625,12.5000244140625,1.4000244140625ZM8.6239776140625,6.4719930140625C8.5439777140625,6.1512432140625,8.3999777140625,5.7421179140625,8.2479777140625,5.4212432140625L9.4959774140625,5.052368214062501C9.6959782140625,5.4293680140625,9.9199772140625,5.9346180140625,9.9999771140625,6.2714929140625L9.3519778140625,6.4719930140625L12.7119784140625,6.4719930140625L12.7119784140625,7.6079931140625L11.5039774140625,7.6079931140625C11.1279774140625,8.6968679140625,10.6159782140625,9.6014929140625,9.9599781140625,10.3461180140625C10.7599773140625,10.9224930140625,11.7279774140625,11.3468685140625,12.8879774140625,11.6029934140625C12.6239774140625,11.8592434140625,12.2799774140625,12.3716184140625,12.1039784140625,12.6918684140625C10.8719778140625,12.3716184140625,9.8719778140625,11.8752434140625,9.0479779140625,11.2107429140625C8.175977714062501,11.8992434140625,7.1199779140625,12.4036184140625,5.8559775140625,12.7558684140625C5.7279777140625,12.4757434140625,5.3759775140625,11.9312434140625,5.1519775140625,11.6591184140625C6.3759775140625,11.3868685140625,7.3839779140625,10.9706182140625,8.1839781140625,10.3781185140625C7.5199776140625,9.6094932140625,7.0079775140625,8.6888685140625,6.5919776140625,7.6079931140625L5.3279776140625,7.6079931140625L5.3279776140625,6.4719930140625L8.6239776140625,6.4719930140625ZM7.7999778140625,7.6079931140625C8.1119776140625,8.344617814062499,8.5359778140625,9.0011186140625,9.0719776140625,9.5694933140625C9.5439777140625,9.0251179140625,9.9199772140625,8.3766184140625,10.1919784140625,7.6079931140625L7.7999778140625,7.6079931140625ZM2.6000244140625,12.5000244140625L2.6000244140625,15.0000244140625Q2.6000244140625,15.4000234140625,3.0000245140625,15.4000234140625L5.5000243140625,15.4000234140625C5.8313951140625,15.4000244140625,6.1000242140625,15.6686534140625,6.1000242140625,16.0000244140625C6.1000242140625,16.3313964140625,5.8313951140625,16.6000254140625,5.5000243140625,16.6000254140625L5.4989548140625,16.6000244140625L3.0000245140625,16.6000244140625Q2.3372834940625,16.6000244140625,1.8686538940625,16.1313954140625Q1.4000244140625,15.6627664140625,1.4000244140625,15.0000244140625L1.4000244140625,12.5000244140625C1.4000244140625,12.1686534140625,1.6686535440624999,11.9000244140625,2.0000244340625,11.9000244140625C2.3313953240625,11.9000244140625,2.6000244140625,12.1686534140625,2.6000244140625,12.5000244140625ZM16.6000244140625,12.5010944140625L16.6000244140625,15.0000244140625Q16.6000244140625,15.6627654140625,16.1313954140625,16.1313954140625Q15.6627654140625,16.6000244140625,15.0000244140625,16.6000244140625L12.5000244140625,16.6000244140625C12.3408944140625,16.6000244140625,12.1882824140625,16.5368104140625,12.0757594140625,16.424288414062502C11.9632384140625,16.3117664140625,11.9000244140625,16.1591544140625,11.9000244140625,16.0000244140625C11.9000244140625,15.6686534140625,12.1686534140625,15.4000244140625,12.5000244140625,15.4000244140625L15.0000244140625,15.4000234140625Q15.4000234140625,15.4000234140625,15.4000234140625,15.0000244140625L15.4000234140625,12.5000244140625C15.4000244140625,12.1686534140625,15.6686534140625,11.9000244140625,16.0000244140625,11.9000244140625C16.3313964140625,11.9000244140625,16.6000254140625,12.1686534140625,16.6000254140625,12.5000244140625L16.6000244140625,12.5010944140625Z" fill-rule="evenodd" fill="#555555" fill-opacity="1"/></g></g></svg>`;
18860
+ const mathSVG = `<svg t="1756107836493" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="10608" width="16" height="15"><path d="M877.454222 856.177778q4.835556-4.835556 7.395556-11.093334 2.616889-6.257778 2.616889-13.084444 0-3.413333-0.625778-6.656-0.682667-3.299556-1.991111-6.428444-1.251556-3.072-3.128889-5.859556-1.877333-2.844444-4.266667-5.176889-2.332444-2.389333-5.12-4.266667-2.844444-1.877333-5.916444-3.128888-3.128889-1.308444-6.428445-1.934223-3.299556-0.682667-6.656-0.682666-6.826667 0-13.084444 2.616889-6.257778 2.56-11.036445 7.395555l-54.044444 53.987556H253.155556l325.688888-325.745778q2.389333-2.389333 4.266667-5.12 1.877333-2.844444 3.128889-5.916445 1.308444-3.128889 1.934222-6.428444 0.682667-3.299556 0.682667-6.656 0-3.413333-0.682667-6.656-0.625778-3.299556-1.934222-6.428444-1.251556-3.072-3.128889-5.859556-1.877333-2.844444-4.266667-5.176889L253.155556 162.133333h522.126222l53.930666 53.987556q4.835556 4.835556 11.093334 7.395555 6.257778 2.616889 13.084444 2.616889 3.413333 0 6.656-0.682666 3.299556-0.625778 6.428445-1.934223 3.072-1.251556 5.859555-3.128888 2.844444-1.877333 5.176889-4.266667 2.389333-2.389333 4.266667-5.12 1.877333-2.844444 3.128889-5.916445 1.308444-3.128889 1.934222-6.428444 0.682667-3.299556 0.682667-6.656 0-6.826667-2.616889-13.084444-2.56-6.257778-7.395556-11.036445l-64-64q-4.778667-4.835556-11.036444-7.395555-6.257778-2.616889-13.084445-2.616889H170.666667q-6.826667 0-13.084445 2.616889-6.257778 2.56-11.036444 7.395555-2.389333 2.389333-4.266667 5.12-1.877333 2.844444-3.128889 5.916445-1.308444 3.128889-1.934222 6.428444-0.682667 3.299556-0.682667 6.656 0 3.413333 0.682667 6.656 0.625778 3.299556 1.934222 6.428444 1.251556 3.072 3.128889 5.859556 1.877333 2.844444 4.266667 5.176889L506.311111 512l-359.822222 359.879111q-4.835556 4.778667-7.395556 11.036445-2.616889 6.257778-2.616889 13.084444 0 3.413333 0.682667 6.656 0.625778 3.299556 1.934222 6.428444 1.251556 3.072 3.128889 5.859556 1.877333 2.844444 4.266667 5.176889 2.389333 2.389333 5.12 4.266667 2.844444 1.877333 5.916444 3.128888 3.128889 1.308444 6.428445 1.991112 3.299556 0.625778 6.656 0.625777h618.666666q6.826667 0 13.084445-2.616889 6.257778-2.56 11.036444-7.395555l64-63.943111z" p-id="10609" fill="#555555"></path></svg>`;
18861
+ const imageSVG = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="18" height="18" viewBox="0 0 18 18"><g><g style="opacity:0;"><rect x="0" y="0" width="18" height="18" rx="0" fill="#FFFFFF" fill-opacity="1"/></g><g><path d="M1.87471507,3.83578219Q1.5,4.18540478,1.5,4.6875L1.5,14.312503Q1.50000006,14.814598,1.874716,15.16422Q2.23459671,15.5,2.73684216,15.5L15.263157,15.5Q15.765403,15.5,16.125284,15.164218Q16.499999000000003,14.814597,16.499999000000003,14.312501L16.499999000000003,4.6875Q16.499999000000003,4.18540342,16.125284999999998,3.83578214Q15.765404,3.5,15.263157,3.5L2.73684216,3.5Q2.23459646,3.5,1.87471507,3.83578219ZM2.5,14.312503L2.5,4.6875Q2.5,4.5,2.73684216,4.5L15.263157,4.5Q15.5,4.5,15.5,4.6875L15.5,14.312501Q15.5,14.5,15.263157,14.5L2.73684216,14.5Q2.5,14.5,2.5,14.312503Z" fill-rule="evenodd" fill="#555555" fill-opacity="1" style="mix-blend-mode:passthrough"/></g><g><ellipse cx="5.4375" cy="7.4375" rx="0.4375" ry="0.4375" fill-opacity="0" stroke-opacity="1" stroke="#555555" fill="none" stroke-width="1" stroke-linecap="ROUND" stroke-linejoin="round" style="mix-blend-mode:passthrough"/></g><g><path d="M5.9053998,9.924615948146972L1.7143693,12.841608238146973Q1.61364189,12.911715538146973,1.55682093,13.020492338146973Q1.5,13.129269138146974,1.5,13.251992238146972L1.50000003,14.418008338146972Q1.50000003,14.876594038146973,1.84130602,15.195924738146973Q2.16843581,15.501991738146973,2.62437022,15.501991738146973L15.375628,15.501991738146973Q15.831564,15.501991738146973,16.158693,15.195924738146973Q16.5,14.876594038146973,16.5,14.418007838146973L16.5,13.251992238146972Q16.500000999999997,13.186988838146974,16.48338,13.124146438146973Q16.466759,13.061303638146972,16.434621,13.004799838146972Q16.402485,12.948296338146973,16.356969,12.901887938146972Q16.311453,12.855479738146972,16.255583,12.822251838146972L9.8796926,9.030259398146972Q9.842938400000001,9.008400078146973,9.8030057,8.993099628146974Q9.763073,8.977799118146972,9.721121799999999,8.969501908146972Q9.6791716,8.961204618146972,9.6364217,8.960151608146973Q9.5936708,8.959098578146973,9.551362000000001,8.965320438146973Q9.5090542,8.971542238146972,9.4684162,8.984858218146973Q9.427778199999999,8.998174158146973,9.3899918,9.018197478146973Q9.352206200000001,9.038220708146973,9.3183689,9.064369648146972Q9.284532500000001,9.090518598146973,9.2556267,9.122033748146972L7.6887164,10.830422738146973L6.4904227,9.934544588146972Q6.4273362,9.887379288146972,6.3528042,9.861893948146973Q6.2782726,9.836408678146972,6.1995153,9.835072038146972Q6.1207581,9.833735408146973,6.045404,9.856676968146973Q5.9700503000000005,9.879618528146972,5.9053998,9.924615948146972ZM2.5,13.513173138146973L2.50000006,14.418008338146972Q2.50000006,14.501992238146972,2.62437022,14.501992238146972L15.375628,14.501992238146972Q15.5,14.501992238146972,15.5,14.418007838146973L15.5,13.536368338146973L9.7178593,10.097503488146973L8.1200023,11.839632738146973Q8.0888524,11.873595438146973,8.052019600000001,11.901292338146973Q8.0151863,11.928988938146972,7.9739118,11.949486538146973Q7.9326363,11.969984038146972,7.88831,11.982591638146973Q7.8439837,11.995199238146974,7.7980995,11.999492138146973Q7.7522154,12.003785338146972,7.7063198,11.999619238146973Q7.6604242,11.995453338146973,7.6160631,11.982968338146973Q7.571702,11.970483338146973,7.5303702,11.950099938146973Q7.4890385,11.929716538146973,7.4521289,11.902122038146972L6.1805682,10.951467238146973L2.5,13.513173138146973Z" fill-rule="evenodd" fill="#555555" fill-opacity="1" style="mix-blend-mode:passthrough"/></g></g></svg>`;
20380
18862
 
20381
18863
  const QuillEditor = vue.defineComponent({
20382
18864
  name: 'QuillEditor',
@@ -20895,12 +19377,12 @@
20895
19377
  var _a;
20896
19378
  if (!editor.value)
20897
19379
  return;
20898
- if (props.enableImageResize) {
20899
- registerBlotFormatter();
20900
- }
20901
19380
  options = composeOptions();
20902
19381
  setIcons();
20903
19382
  quill = new Quill(editor.value, options);
19383
+ if (props.enableImageResize) {
19384
+ registerBlotFormatter();
19385
+ }
20904
19386
  setQuill(quill);
20905
19387
  setLinkQuill(quill);
20906
19388
  controlToolbarVisible(false);
@@ -20912,11 +19394,21 @@
20912
19394
  quill.on('selection-change', updateHistoryState);
20913
19395
  addLinkClickListener();
20914
19396
  const toolbarClickHandler = (event) => {
19397
+ var _a;
20915
19398
  const target = event.target;
20916
- if (target.closest('.quill-editor-container')) {
20917
- return;
19399
+ const clickedEditorContainer = target.closest('.quill-editor-container');
19400
+ if (clickedEditorContainer) {
19401
+ const currentEditorContainer = (_a = editor.value) === null || _a === void 0 ? void 0 : _a.closest('.quill-editor-container');
19402
+ if (clickedEditorContainer === currentEditorContainer) {
19403
+ controlToolbarVisible(true);
19404
+ }
19405
+ else {
19406
+ controlToolbarVisible(false);
19407
+ }
19408
+ }
19409
+ else {
19410
+ controlToolbarVisible(false);
20918
19411
  }
20919
- controlToolbarVisible(false);
20920
19412
  };
20921
19413
  addClickHandler(toolbarClickHandler);
20922
19414
  addClickHandler(handleBlotFormatterClick);