ckeditor5-livewire 1.4.1 → 1.6.0
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.
- package/dist/hooks/context/context.d.ts.map +1 -1
- package/dist/hooks/editor/editor.d.ts.map +1 -1
- package/dist/hooks/editor/utils/index.d.ts +1 -0
- package/dist/hooks/editor/utils/index.d.ts.map +1 -1
- package/dist/hooks/editor/utils/load-editor-translations.d.ts +2 -1
- package/dist/hooks/editor/utils/load-editor-translations.d.ts.map +1 -1
- package/dist/hooks/editor/utils/resolve-editor-config-translations.d.ts +25 -0
- package/dist/hooks/editor/utils/resolve-editor-config-translations.d.ts.map +1 -0
- package/dist/index.cjs +2 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.mjs +216 -191
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/hooks/context/context.test.ts +77 -52
- package/src/hooks/context/context.ts +9 -1
- package/src/hooks/editor/editor.test.ts +33 -0
- package/src/hooks/editor/editor.ts +8 -1
- package/src/hooks/editor/utils/index.ts +1 -0
- package/src/hooks/editor/utils/load-editor-translations.ts +3 -1
- package/src/hooks/editor/utils/resolve-editor-config-translations.test.ts +131 -0
- package/src/hooks/editor/utils/resolve-editor-config-translations.ts +77 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../../src/hooks/context/context.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE/C,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../../src/hooks/context/context.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE/C,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAW7C;;GAEG;AACH,qBAAa,oBAAqB,SAAQ,SAAS,CAAC,QAAQ,CAAC;IAC3D;;OAEG;IACH,OAAO,CAAC,cAAc,CAAkD;IAExE;;OAEG;IACY,OAAO;IAoDtB;;OAEG;IACY,SAAS;CAoBzB;AAED;;GAEG;AACH,KAAK,QAAQ,GAAG;IACd;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAElB;;OAEG;IACH,OAAO,EAAE,aAAa,CAAC;IAEvB;;OAEG;IACH,QAAQ,EAAE,cAAc,CAAC;CAC1B,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"editor.d.ts","sourceRoot":"","sources":["../../../../src/hooks/editor/editor.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAY,cAAc,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAKxE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"editor.d.ts","sourceRoot":"","sources":["../../../../src/hooks/editor/editor.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAY,cAAc,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAKxE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAuBpC;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,SAAS,CAAC,QAAQ,CAAC;IAC1D;;OAEG;IACH,OAAO,CAAC,aAAa,CAAgC;IAErD;;OAEG;IACY,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IA6BvC;;;OAGG;IACY,SAAS;IAkCxB;;OAEG;IACY,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAMjD;;OAEG;YACW,YAAY;CA8I3B;AA4CD;;GAEG;AACH,MAAM,MAAM,QAAQ,GAAG;IACrB;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC;IAEjB;;OAEG;IACH,QAAQ,EAAE,OAAO,CAAC;IAElB;;OAEG;IACH,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IAEzB;;OAEG;IACH,cAAc,EAAE,MAAM,CAAC;IAEvB;;OAEG;IACH,MAAM,EAAE,YAAY,CAAC;IAErB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAEhC;;OAEG;IACH,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAE9B;;OAEG;IACH,QAAQ,EAAE,cAAc,CAAC;CAC1B,CAAC"}
|
|
@@ -8,6 +8,7 @@ export * from './load-editor-translations';
|
|
|
8
8
|
export * from './normalize-custom-translations';
|
|
9
9
|
export * from './query-editor-editables';
|
|
10
10
|
export * from './resolve-editor-config-elements-references';
|
|
11
|
+
export * from './resolve-editor-config-translations';
|
|
11
12
|
export * from './set-editor-editable-height';
|
|
12
13
|
export * from './wrap-with-watchdog';
|
|
13
14
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/hooks/editor/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,uBAAuB,CAAC;AACtC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6CAA6C,CAAC;AAC5D,cAAc,8BAA8B,CAAC;AAC7C,cAAc,sBAAsB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/hooks/editor/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,uBAAuB,CAAC;AACtC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6CAA6C,CAAC;AAC5D,cAAc,sCAAsC,CAAC;AACrD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,sBAAsB,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Translations } from 'ckeditor5';
|
|
1
2
|
/**
|
|
2
3
|
* Loads all required translations for the editor based on the language configuration.
|
|
3
4
|
*
|
|
@@ -10,5 +11,5 @@
|
|
|
10
11
|
export declare function loadAllEditorTranslations(language: {
|
|
11
12
|
ui: string;
|
|
12
13
|
content: string;
|
|
13
|
-
}, hasPremium: boolean): Promise<
|
|
14
|
+
}, hasPremium: boolean): Promise<Translations[]>;
|
|
14
15
|
//# sourceMappingURL=load-editor-translations.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"load-editor-translations.d.ts","sourceRoot":"","sources":["../../../../../src/hooks/editor/utils/load-editor-translations.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,wBAAsB,yBAAyB,CAC7C,QAAQ,EAAE;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;CAAE,EAC1C,UAAU,EAAE,OAAO,
|
|
1
|
+
{"version":3,"file":"load-editor-translations.d.ts","sourceRoot":"","sources":["../../../../../src/hooks/editor/utils/load-editor-translations.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAE9C;;;;;;;;GAQG;AACH,wBAAsB,yBAAyB,CAC7C,QAAQ,EAAE;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;CAAE,EAC1C,UAAU,EAAE,OAAO,GAClB,OAAO,CAAC,YAAY,EAAE,CAAC,CAYzB"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Translations } from 'ckeditor5';
|
|
2
|
+
/**
|
|
3
|
+
* Resolves translation references in a configuration object.
|
|
4
|
+
*
|
|
5
|
+
* The configuration may contain objects with the form `{ $translation: "some.key" }`.
|
|
6
|
+
* These are replaced with the actual string from the provided translations map.
|
|
7
|
+
*
|
|
8
|
+
* The function will walk the provided object recursively, handling arrays and
|
|
9
|
+
* nested objects. Primitive values are returned as-is. If a translation key is
|
|
10
|
+
* not present in the map, a warning is logged and `null` is returned for that
|
|
11
|
+
* value.
|
|
12
|
+
*
|
|
13
|
+
* @param translations - An array of CKEditor `Translations` objects. Each translation
|
|
14
|
+
* pack will be searched in order for the requested key, and the
|
|
15
|
+
* first matching value will be returned. This mirrors the format
|
|
16
|
+
* returned by `loadAllEditorTranslations` and simplifies the
|
|
17
|
+
* caller's API.
|
|
18
|
+
* @param language - Language identifier to look up in the packs. Only this locale
|
|
19
|
+
* will be consulted, ensuring that keys from other languages are
|
|
20
|
+
* ignored even if they appear earlier in the array.
|
|
21
|
+
* @param obj - Configuration object to process
|
|
22
|
+
* @returns Processed configuration object with resolved translations.
|
|
23
|
+
*/
|
|
24
|
+
export declare function resolveEditorConfigTranslations<T>(translations: Translations[], language: string, obj: T): T;
|
|
25
|
+
//# sourceMappingURL=resolve-editor-config-translations.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-editor-config-translations.d.ts","sourceRoot":"","sources":["../../../../../src/hooks/editor/utils/resolve-editor-config-translations.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAE9C;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,+BAA+B,CAAC,CAAC,EAC/C,YAAY,EAAE,YAAY,EAAE,EAC5B,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,CAAC,GACL,CAAC,CA6BH"}
|
package/dist/index.cjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
"use strict";var Q=Object.create;var z=Object.defineProperty;var Z=Object.getOwnPropertyDescriptor;var tt=Object.getOwnPropertyNames;var et=Object.getPrototypeOf,rt=Object.prototype.hasOwnProperty;var it=(n,t,r,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of tt(t))!rt.call(n,a)&&a!==r&&z(n,a,{get:()=>t[a],enumerable:!(i=Z(t,a))||i.enumerable});return n};var e=(n,t,r)=>(r=n!=null?Q(et(n)):{},it(t||!n||!n.__esModule?z(r,"default",{value:n,enumerable:!0}):r,n));Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class k{constructor(t){this.livewireComponent=t}state="mounting";_beforeDestroyCallbacks=[];onBeforeDestroy(t){this._beforeDestroyCallbacks.push(t)}get canonical(){return this.livewireComponent.canonical}get element(){return this.livewireComponent.el}get $wire(){return this.livewireComponent.$wire}isBeingDestroyed(){return["destroyed","destroying"].includes(this.state)}_runBeforeDestroyCallbacks(){for(const t of this._beforeDestroyCallbacks.reverse())t();this._beforeDestroyCallbacks=[]}}function F(n,t){const r=new Map;window.Livewire?.hook("component.init",async({component:i,cleanup:a})=>{if(i.name!==n)return;const o=new t(i);r.set(i.id,o),a(async()=>{o.state="destroying",o._runBeforeDestroyCallbacks(),await o.destroyed(),o.state="destroyed",r.delete(i.id)}),await o.mounted(),o.state="mounted"}),window.Livewire?.hook("commit",async({component:i,succeed:a})=>{i.name===n&&a(()=>{const o=r.get(i.id);o?.state==="mounted"&&o?.afterCommitSynced?.()})})}class W{items=new Map;initializationErrors=new Map;pendingCallbacks=new Map;watchers=new Set;execute(t,r,i){const a=this.items.get(t),o=this.initializationErrors.get(t);return o?(i?.(o),Promise.reject(o)):a?Promise.resolve(r(a)):new Promise((s,c)=>{const u=this.getPendingCallbacks(t);u.success.push(async l=>{s(await r(l))}),i?u.error.push(i):u.error.push(c)})}register(t,r){if(this.items.has(t))throw new Error(`Item with ID "${t}" is already registered.`);this.resetErrors(t),this.items.set(t,r);const i=this.pendingCallbacks.get(t);i&&(i.success.forEach(a=>a(r)),this.pendingCallbacks.delete(t)),this.registerAsDefault(t,r),this.notifyWatchers()}error(t,r){this.items.delete(t),this.initializationErrors.set(t,r);const i=this.pendingCallbacks.get(t);i&&(i.error.forEach(a=>a(r)),this.pendingCallbacks.delete(t)),this.initializationErrors.size===1&&!this.items.size&&this.error(null,r),this.notifyWatchers()}resetErrors(t){const{initializationErrors:r}=this;r.has(null)&&r.get(null)===r.get(t)&&r.delete(null),r.delete(t)}unregister(t){if(!this.items.has(t))throw new Error(`Item with ID "${t}" is not registered.`);t&&this.items.get(null)===this.items.get(t)&&this.unregister(null),this.items.delete(t),this.pendingCallbacks.delete(t),this.notifyWatchers()}getItems(){return Array.from(this.items.values())}hasItem(t){return this.items.has(t)}waitFor(t){return new Promise((r,i)=>{this.execute(t,r,i)})}async destroyAll(){const t=Array.from(new Set(this.items.values())).map(r=>r.destroy());this.items.clear(),this.pendingCallbacks.clear(),await Promise.all(t),this.notifyWatchers()}watch(t){return this.watchers.add(t),t(new Map(this.items),new Map(this.initializationErrors)),this.unwatch.bind(this,t)}unwatch(t){this.watchers.delete(t)}notifyWatchers(){this.watchers.forEach(t=>t(new Map(this.items),new Map(this.initializationErrors)))}getPendingCallbacks(t){let r=this.pendingCallbacks.get(t);return r||(r={success:[],error:[]},this.pendingCallbacks.set(t,r)),r}registerAsDefault(t,r){this.items.size===1&&t!==null&&this.register(null,r)}}function S(n,t){let r=null;return(...i)=>{r&&clearTimeout(r),r=setTimeout(()=>{t(...i)},n)}}function nt(n,t){const r=Object.entries(n).filter(([i,a])=>t(a,i));return Object.fromEntries(r)}function V(n){return Object.keys(n).length===0&&n.constructor===Object}function H(n,t){const r=Object.entries(n).map(([i,a])=>[i,t(a,i)]);return Object.fromEntries(r)}function C(n,t){if(n===t)return!0;const r=Object.keys(n),i=Object.keys(t);if(r.length!==i.length)return!1;for(const a of r)if(n[a]!==t[a]||!Object.prototype.hasOwnProperty.call(t,a))return!1;return!0}function at(){return Math.random().toString(36).substring(2)}function ot(n,{timeOutAfter:t=500,retryAfter:r=100}={}){return new Promise((i,a)=>{const o=Date.now();let s=null;const c=setTimeout(()=>{a(s??new Error("Timeout"))},t),u=async()=>{try{const l=await n();clearTimeout(c),i(l)}catch(l){s=l,Date.now()-o>t?a(l):setTimeout(u,r)}};u()})}const T=Symbol.for("context-editor-watchdog");async function st({element:n,context:t,creator:r,config:i}){const a=at();await t.add({creator:(u,l)=>r.create(u,l),id:a,sourceElementOrData:n,type:"editor",config:i});const o=t.getItem(a),s={state:"available",editorContextId:a,context:t};o[T]=s;const c=t.destroy.bind(t);return t.destroy=async()=>(s.state="unavailable",c()),{...s,editor:o}}function ct(n){return T in n?n[T]:null}function ut(n){return n.model.document.getRootNames().reduce((r,i)=>(r[i]=n.getData({rootName:i}),r),Object.create({}))}function v(n){return["inline","classic","balloon","decoupled"].includes(n)}function B(n){let t=n;for(;t;){for(const r of t.attributes)if(r.name.startsWith("wire:model"))return!0;t=t.parentElement}return!1}async function lt(n){const t=await import("ckeditor5"),i={inline:t.InlineEditor,balloon:t.BalloonEditor,classic:t.ClassicEditor,decoupled:t.DecoupledEditor,multiroot:t.MultiRootEditor}[n];if(!i)throw new Error(`Unsupported editor type: ${n}`);return i}class I{static the=new I;plugins=new Map;constructor(){}register(t,r){if(this.plugins.has(t))throw new Error(`Plugin with name "${t}" is already registered.`);return this.plugins.set(t,r),this.unregister.bind(this,t)}unregister(t){if(!this.plugins.has(t))throw new Error(`Plugin with name "${t}" is not registered.`);this.plugins.delete(t)}unregisterAll(){this.plugins.clear()}async get(t){return this.plugins.get(t)?.()}has(t){return this.plugins.has(t)}}async function j(n){const t=await import("ckeditor5");let r=null;const i=n.map(async a=>{const o=await I.the.get(a);if(o)return o;const{[a]:s}=t;if(s)return s;if(!r)try{r=await import("ckeditor5-premium-features")}catch(u){console.error(`Failed to load premium package: ${u}`)}const{[a]:c}=r||{};if(c)return c;throw new Error(`Plugin "${a}" not found in base or premium packages.`)});return{loadedPlugins:await Promise.all(i),hasPremium:!!r}}async function N(n,t){const r=[n.ui,n.content];return await Promise.all([L("ckeditor5",r),t&&L("ckeditor5-premium-features",r)].filter(a=>!!a)).then(a=>a.flat())}async function L(n,t){return await Promise.all(t.filter(r=>r!=="en").map(async r=>{const i=await dt(n,r);return i?.default??i}).filter(Boolean))}async function dt(n,t){try{if(n==="ckeditor5")switch(t){case"af":return await import("ckeditor5/translations/af.js");case"ar":return await import("ckeditor5/translations/ar.js");case"ast":return await import("ckeditor5/translations/ast.js");case"az":return await import("ckeditor5/translations/az.js");case"bg":return await import("ckeditor5/translations/bg.js");case"bn":return await import("ckeditor5/translations/bn.js");case"bs":return await import("ckeditor5/translations/bs.js");case"ca":return await import("ckeditor5/translations/ca.js");case"cs":return await import("ckeditor5/translations/cs.js");case"da":return await import("ckeditor5/translations/da.js");case"de":return await import("ckeditor5/translations/de.js");case"de-ch":return await import("ckeditor5/translations/de-ch.js");case"el":return await import("ckeditor5/translations/el.js");case"en":return await import("ckeditor5/translations/en.js");case"en-au":return await import("ckeditor5/translations/en-au.js");case"en-gb":return await import("ckeditor5/translations/en-gb.js");case"eo":return await import("ckeditor5/translations/eo.js");case"es":return await import("ckeditor5/translations/es.js");case"es-co":return await import("ckeditor5/translations/es-co.js");case"et":return await import("ckeditor5/translations/et.js");case"eu":return await import("ckeditor5/translations/eu.js");case"fa":return await import("ckeditor5/translations/fa.js");case"fi":return await import("ckeditor5/translations/fi.js");case"fr":return await import("ckeditor5/translations/fr.js");case"gl":return await import("ckeditor5/translations/gl.js");case"gu":return await import("ckeditor5/translations/gu.js");case"he":return await import("ckeditor5/translations/he.js");case"hi":return await import("ckeditor5/translations/hi.js");case"hr":return await import("ckeditor5/translations/hr.js");case"hu":return await import("ckeditor5/translations/hu.js");case"hy":return await import("ckeditor5/translations/hy.js");case"id":return await import("ckeditor5/translations/id.js");case"it":return await import("ckeditor5/translations/it.js");case"ja":return await import("ckeditor5/translations/ja.js");case"jv":return await import("ckeditor5/translations/jv.js");case"kk":return await import("ckeditor5/translations/kk.js");case"km":return await import("ckeditor5/translations/km.js");case"kn":return await import("ckeditor5/translations/kn.js");case"ko":return await import("ckeditor5/translations/ko.js");case"ku":return await import("ckeditor5/translations/ku.js");case"lt":return await import("ckeditor5/translations/lt.js");case"lv":return await import("ckeditor5/translations/lv.js");case"ms":return await import("ckeditor5/translations/ms.js");case"nb":return await import("ckeditor5/translations/nb.js");case"ne":return await import("ckeditor5/translations/ne.js");case"nl":return await import("ckeditor5/translations/nl.js");case"no":return await import("ckeditor5/translations/no.js");case"oc":return await import("ckeditor5/translations/oc.js");case"pl":return await import("ckeditor5/translations/pl.js");case"pt":return await import("ckeditor5/translations/pt.js");case"pt-br":return await import("ckeditor5/translations/pt-br.js");case"ro":return await import("ckeditor5/translations/ro.js");case"ru":return await import("ckeditor5/translations/ru.js");case"si":return await import("ckeditor5/translations/si.js");case"sk":return await import("ckeditor5/translations/sk.js");case"sl":return await import("ckeditor5/translations/sl.js");case"sq":return await import("ckeditor5/translations/sq.js");case"sr":return await import("ckeditor5/translations/sr.js");case"sr-latn":return await import("ckeditor5/translations/sr-latn.js");case"sv":return await import("ckeditor5/translations/sv.js");case"th":return await import("ckeditor5/translations/th.js");case"tk":return await import("ckeditor5/translations/tk.js");case"tr":return await import("ckeditor5/translations/tr.js");case"tt":return await import("ckeditor5/translations/tt.js");case"ug":return await import("ckeditor5/translations/ug.js");case"uk":return await import("ckeditor5/translations/uk.js");case"ur":return await import("ckeditor5/translations/ur.js");case"uz":return await import("ckeditor5/translations/uz.js");case"vi":return await import("ckeditor5/translations/vi.js");case"zh":return await import("ckeditor5/translations/zh.js");case"zh-cn":return await import("ckeditor5/translations/zh-cn.js");default:return console.warn(`Language ${t} not found in ckeditor5 translations`),null}else switch(t){case"af":return await import("ckeditor5-premium-features/translations/af.js");case"ar":return await import("ckeditor5-premium-features/translations/ar.js");case"ast":return await import("ckeditor5-premium-features/translations/ast.js");case"az":return await import("ckeditor5-premium-features/translations/az.js");case"bg":return await import("ckeditor5-premium-features/translations/bg.js");case"bn":return await import("ckeditor5-premium-features/translations/bn.js");case"bs":return await import("ckeditor5-premium-features/translations/bs.js");case"ca":return await import("ckeditor5-premium-features/translations/ca.js");case"cs":return await import("ckeditor5-premium-features/translations/cs.js");case"da":return await import("ckeditor5-premium-features/translations/da.js");case"de":return await import("ckeditor5-premium-features/translations/de.js");case"de-ch":return await import("ckeditor5-premium-features/translations/de-ch.js");case"el":return await import("ckeditor5-premium-features/translations/el.js");case"en":return await import("ckeditor5-premium-features/translations/en.js");case"en-au":return await import("ckeditor5-premium-features/translations/en-au.js");case"en-gb":return await import("ckeditor5-premium-features/translations/en-gb.js");case"eo":return await import("ckeditor5-premium-features/translations/eo.js");case"es":return await import("ckeditor5-premium-features/translations/es.js");case"es-co":return await import("ckeditor5-premium-features/translations/es-co.js");case"et":return await import("ckeditor5-premium-features/translations/et.js");case"eu":return await import("ckeditor5-premium-features/translations/eu.js");case"fa":return await import("ckeditor5-premium-features/translations/fa.js");case"fi":return await import("ckeditor5-premium-features/translations/fi.js");case"fr":return await import("ckeditor5-premium-features/translations/fr.js");case"gl":return await import("ckeditor5-premium-features/translations/gl.js");case"gu":return await import("ckeditor5-premium-features/translations/gu.js");case"he":return await import("ckeditor5-premium-features/translations/he.js");case"hi":return await import("ckeditor5-premium-features/translations/hi.js");case"hr":return await import("ckeditor5-premium-features/translations/hr.js");case"hu":return await import("ckeditor5-premium-features/translations/hu.js");case"hy":return await import("ckeditor5-premium-features/translations/hy.js");case"id":return await import("ckeditor5-premium-features/translations/id.js");case"it":return await import("ckeditor5-premium-features/translations/it.js");case"ja":return await import("ckeditor5-premium-features/translations/ja.js");case"jv":return await import("ckeditor5-premium-features/translations/jv.js");case"kk":return await import("ckeditor5-premium-features/translations/kk.js");case"km":return await import("ckeditor5-premium-features/translations/km.js");case"kn":return await import("ckeditor5-premium-features/translations/kn.js");case"ko":return await import("ckeditor5-premium-features/translations/ko.js");case"ku":return await import("ckeditor5-premium-features/translations/ku.js");case"lt":return await import("ckeditor5-premium-features/translations/lt.js");case"lv":return await import("ckeditor5-premium-features/translations/lv.js");case"ms":return await import("ckeditor5-premium-features/translations/ms.js");case"nb":return await import("ckeditor5-premium-features/translations/nb.js");case"ne":return await import("ckeditor5-premium-features/translations/ne.js");case"nl":return await import("ckeditor5-premium-features/translations/nl.js");case"no":return await import("ckeditor5-premium-features/translations/no.js");case"oc":return await import("ckeditor5-premium-features/translations/oc.js");case"pl":return await import("ckeditor5-premium-features/translations/pl.js");case"pt":return await import("ckeditor5-premium-features/translations/pt.js");case"pt-br":return await import("ckeditor5-premium-features/translations/pt-br.js");case"ro":return await import("ckeditor5-premium-features/translations/ro.js");case"ru":return await import("ckeditor5-premium-features/translations/ru.js");case"si":return await import("ckeditor5-premium-features/translations/si.js");case"sk":return await import("ckeditor5-premium-features/translations/sk.js");case"sl":return await import("ckeditor5-premium-features/translations/sl.js");case"sq":return await import("ckeditor5-premium-features/translations/sq.js");case"sr":return await import("ckeditor5-premium-features/translations/sr.js");case"sr-latn":return await import("ckeditor5-premium-features/translations/sr-latn.js");case"sv":return await import("ckeditor5-premium-features/translations/sv.js");case"th":return await import("ckeditor5-premium-features/translations/th.js");case"tk":return await import("ckeditor5-premium-features/translations/tk.js");case"tr":return await import("ckeditor5-premium-features/translations/tr.js");case"tt":return await import("ckeditor5-premium-features/translations/tt.js");case"ug":return await import("ckeditor5-premium-features/translations/ug.js");case"uk":return await import("ckeditor5-premium-features/translations/uk.js");case"ur":return await import("ckeditor5-premium-features/translations/ur.js");case"uz":return await import("ckeditor5-premium-features/translations/uz.js");case"vi":return await import("ckeditor5-premium-features/translations/vi.js");case"zh":return await import("ckeditor5-premium-features/translations/zh.js");case"zh-cn":return await import("ckeditor5-premium-features/translations/zh-cn.js");default:return console.warn(`Language ${t} not found in premium translations`),await import("ckeditor5-premium-features/translations/en.js")}}catch(r){return console.error(`Failed to load translation for ${n}/${t}:`,r),null}}function q(n){return H(n,t=>({dictionary:t}))}function _(n){const t=U(n);return H(t,({element:r})=>r)}function U(n){const t=window.Livewire.all().filter(({name:s,canonical:c})=>s==="ckeditor5-editable"&&c.editorId===n).reduce((s,{canonical:c,el:u})=>({...s,[c.rootName]:{element:u.querySelector("[data-cke-editable-content]"),content:c.content}}),Object.create({})),i=window.Livewire.all().find(({name:s,canonical:c})=>s==="ckeditor5"&&c.editorId===n)?.canonical.content,a=document.querySelector(`#${n}_editor `),o=t.main;return o&&i?.main?{...t,main:{...o,content:o.content||i.main}}:a?{...t,main:{element:a,content:i?.main||null}}:t}function A(n){const t=U(n),r=H(t,({content:i})=>i);return nt(r,i=>typeof i=="string")}function x(n){if(!n||typeof n!="object")return n;if(Array.isArray(n))return n.map(i=>x(i));const t=n;if(t.$element&&typeof t.$element=="string"){const i=document.querySelector(t.$element);return i||console.warn(`Element not found for selector: ${t.$element}`),i||null}const r=Object.create(null);for(const[i,a]of Object.entries(n))r[i]=x(a);return r}function mt(n,t){const{editing:r}=n;r.view.change(i=>{i.setStyle("height",`${t}px`,r.view.document.getRoot())})}const O=Symbol.for("elixir-editor-watchdog");async function ht(n){const{EditorWatchdog:t}=await import("ckeditor5"),r=new t(n);return r.setCreator(async(...i)=>{const a=await n.create(...i);return a[O]=r,a}),{watchdog:r,Constructor:{create:async(...i)=>(await r.create(...i),r.editor)}}}function pt(n){return O in n?n[O]:null}class w extends W{static the=new w}class wt extends k{contextPromise=null;async mounted(){const{contextId:t,language:r,context:i}=this.canonical,{customTranslations:a,watchdogConfig:o,config:{plugins:s,...c}}=i,{loadedPlugins:u,hasPremium:l}=await j(s??[]),P=[...await N(r,l),q(a||{})].filter(g=>!V(g));this.contextPromise=(async()=>{const{ContextWatchdog:g,Context:f}=await import("ckeditor5"),p=new g(f,{crashNumberLimit:10,...o});return await p.create({...c,language:r,plugins:u,...P.length&&{translations:P}}),p.on("itemError",(...y)=>{console.error("Context item error:",...y)}),p})();const D=await this.contextPromise;this.isBeingDestroyed()||w.the.register(t,D)}async destroyed(){const{contextId:t}=this.canonical;this.element.style.display="none";try{await(await this.contextPromise)?.destroy()}finally{this.contextPromise=null,w.the.hasItem(t)&&w.the.unregister(t)}}}class m extends W{static the=new m}class K extends k{editorPromise=null;pendingContent=null;mounted(){const{editorId:t,rootName:r,content:i}=this.canonical;this.editorPromise=m.the.execute(t,a=>{if(this.isBeingDestroyed())return null;const{ui:o,editing:s,model:c}=a;if(c.document.getRoot(r)){if(i!==null){const u=a.getData({rootName:r});u&&u!==i&&a.setData({[r]:i})}}else{a.addRoot(r,{isUndoable:!1,...i!==null&&{data:i}});const u=this.element.querySelector("[data-cke-editable-content]"),l=o.view.createEditable(r,u);o.addEditable(l),s.view.forceRender()}return this.syncTypingContentPush(a),this.setupPendingReceivedContentHandlers(a),a})}syncTypingContentPush(t){const{rootName:r,saveDebounceMs:i}=this.canonical,a=this.element.querySelector("input"),o=()=>{const c=t.getData({rootName:r});a&&(a.value=c),this.$wire.set("content",c)},s=S(i,o);t.model.document.on("change:data",s),o(),this.onBeforeDestroy(()=>{t.model.document.off("change:data",s)})}setupPendingReceivedContentHandlers(t){const{ui:r,model:i}=t,{focusTracker:a}=r,{rootName:o}=this.canonical,s=()=>{this.pendingContent=null},c=()=>{!a.isFocused&&this.pendingContent!==null&&(t.setData({[o]:this.pendingContent}),this.pendingContent=null)};i.document.on("change:data",s),a.on("change:isFocused",c),this.onBeforeDestroy(()=>{i.document.off("change:data",s),a.off("change:isFocused",c)})}applyCanonicalContentToEditor(t){if(!B(this.element))return;const{content:r,rootName:i}=this.canonical,{ui:a}=t;if(t.getData({rootName:i})!==(r??"")){if(a.focusTracker.isFocused){this.pendingContent=r??"";return}t.setData({[i]:r??""})}}async afterCommitSynced(){const t=await this.editorPromise;this.applyCanonicalContentToEditor(t)}async destroyed(){const{rootName:t}=this.canonical;this.element.style.display="none";const r=await this.editorPromise;if(this.editorPromise=null,r&&r.state!=="destroyed"){const i=r.model.document.getRoot(t);i&&"detachEditable"in r&&(r.detachEditable(i),r.detachRoot(t,!1))}}}async function ft({saveDebounceMs:n,component:t}){const{Plugin:r}=await import("ckeditor5");return class extends r{static get pluginName(){return"LivewireSync"}init(){this.setupTypingContentPush(),this.setupFocusableEventPush(),this.setupAfterCommitHandler(),this.setupSetEditorContentHandler(),this.setupReadyDispatch()}setupAfterCommitHandler(){const{editor:a}=this,{model:o,ui:{focusTracker:s}}=a;let c=null;a.on("afterCommitSynced",()=>{if(!B(t.element))return;const{content:u}=t.canonical,l=this.getEditorRootsValues();if(s.isFocused){C(u,l)||(c=u);return}C(u,l)||a.setData(u)}),o.document.on("change:data",()=>{c=null}),s.on("change:isFocused",()=>{!s.isFocused&&c!==null&&(a.setData(c),c=null)})}setupReadyDispatch(){const{$wire:a}=t;this.editor.once("ready",()=>{a.dispatch("editor-ready",{editorId:t.canonical.editorId})})}setupSetEditorContentHandler(){Livewire.on("set-editor-content",({editorId:a,content:o})=>{if(a!==t.canonical.editorId)return;const s=this.getEditorRootsValues();C(s,o)||this.editor.setData(o)})}setupTypingContentPush(){const{model:a}=this.editor,{$wire:o}=t,s=()=>{const c=this.getEditorRootsValues();C(c,t.canonical.content??{})||(o.set("content",c),o.dispatch("editor-content-changed",{editorId:t.canonical.editorId,content:c}))};a.document.on("change:data",S(n,s)),this.editor.once("ready",s)}setupFocusableEventPush(){const{ui:a}=this.editor,{$wire:o}=t,s=()=>{const c=this.getEditorRootsValues();o.set("focused",a.focusTracker.isFocused),C(c,t.canonical.content??{})||o.set("content",c)};a.focusTracker.on("change:isFocused",s)}getEditorRootsValues(){return ut(this.editor)}}}async function gt(n){const{Plugin:t}=await import("ckeditor5");return class extends t{input=null;form=null;static get pluginName(){return"SyncEditorWithInput"}afterInit(){const{editor:i}=this,o=i.sourceElement.id.replace(/_editor$/,"");this.input=document.getElementById(`${o}_input`),this.input&&(i.model.document.on("change:data",S(n,()=>this.sync())),i.once("ready",this.sync),this.form=this.input.closest("form"),this.form?.addEventListener("submit",this.sync))}sync=()=>{if(this.input){const i=this.editor.getData();this.input.value=i,this.input.dispatchEvent(new Event("input",{bubbles:!0}))}};destroy(){this.form&&this.form.removeEventListener("submit",this.sync),this.input=null,this.form=null}}}class G extends k{editorPromise=null;async mounted(){const{editorId:t}=this.canonical;m.the.resetErrors(t);try{this.editorPromise=this.createEditor();const r=await this.editorPromise;this.isBeingDestroyed()||(m.the.register(t,r),r.once("destroy",()=>{m.the.hasItem(t)&&m.the.unregister(t)}))}catch(r){console.error(`Error initializing CKEditor5 instance with ID "${t}":`,r),this.editorPromise=null,m.the.error(t,r)}}async destroyed(){this.element.style.display="none";try{const t=await this.editorPromise;if(!t)return;const r=ct(t),i=pt(t);r?r.state!=="unavailable"&&await r.context.remove(r.editorContextId):i?await i.destroy():await t.destroy()}finally{this.editorPromise=null}}async afterCommitSynced(){(await this.editorPromise)?.fire("afterCommitSynced")}async createEditor(){const{preset:t,editorId:r,contextId:i,editableHeight:a,saveDebounceMs:o,language:s,watchdog:c,content:u}=this.canonical,{customTranslations:l,editorType:h,licenseKey:P,config:{plugins:D,...g}}=t;let f=await lt(h);const p=await(i?w.the.waitFor(i):null);if(c&&!p){const d=await ht(f);({Constructor:f}=d),d.watchdog.on("restart",()=>{const b=d.watchdog.editor;this.editorPromise=Promise.resolve(b),m.the.register(r,b)})}const{loadedPlugins:y,hasPremium:J}=await j(D);y.push(await ft({saveDebounceMs:o,component:this})),v(h)&&y.push(await gt(o));const R=[...await N(s,J),q(l||{})].filter(d=>!V(d));let E={...u,...A(r)};v(h)&&(E=E.main||"");const $=await(async()=>{let d=_(r);if(!(d instanceof HTMLElement)&&!("main"in d)){const M=h==="decoupled"?["main"]:Object.keys(E);Y(d,M)||(d=await yt(r,M),E={...u,...A(r)})}v(h)&&"main"in d&&(d=d.main);const b={...x(g),initialData:E,licenseKey:P,plugins:y,language:s,...R.length&&{translations:R}};return!p||!(d instanceof HTMLElement)?f.create(d,b):(await st({context:p,element:d,creator:f,config:b})).editor})();return v(h)&&a&&mt($,a),$}}function Y(n,t){return t.every(r=>n[r])}async function yt(n,t){return ot(()=>{const r=_(n);if(!Y(r,t))throw new Error(`It looks like not all required root elements are present yet.
|
|
1
|
+
"use strict";var tt=Object.create;var F=Object.defineProperty;var et=Object.getOwnPropertyDescriptor;var rt=Object.getOwnPropertyNames;var it=Object.getPrototypeOf,nt=Object.prototype.hasOwnProperty;var at=(n,t,e,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of rt(t))!nt.call(n,a)&&a!==e&&F(n,a,{get:()=>t[a],enumerable:!(i=et(t,a))||i.enumerable});return n};var r=(n,t,e)=>(e=n!=null?tt(it(n)):{},at(t||!n||!n.__esModule?F(e,"default",{value:n,enumerable:!0}):e,n));Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class v{constructor(t){this.livewireComponent=t}state="mounting";_beforeDestroyCallbacks=[];onBeforeDestroy(t){this._beforeDestroyCallbacks.push(t)}get canonical(){return this.livewireComponent.canonical}get element(){return this.livewireComponent.el}get $wire(){return this.livewireComponent.$wire}isBeingDestroyed(){return["destroyed","destroying"].includes(this.state)}_runBeforeDestroyCallbacks(){for(const t of this._beforeDestroyCallbacks.reverse())t();this._beforeDestroyCallbacks=[]}}function B(n,t){const e=new Map;window.Livewire?.hook("component.init",async({component:i,cleanup:a})=>{if(i.name!==n)return;const o=new t(i);e.set(i.id,o),a(async()=>{o.state="destroying",o._runBeforeDestroyCallbacks(),await o.destroyed(),o.state="destroyed",e.delete(i.id)}),await o.mounted(),o.state="mounted"}),window.Livewire?.hook("commit",async({component:i,succeed:a})=>{i.name===n&&a(()=>{const o=e.get(i.id);o?.state==="mounted"&&o?.afterCommitSynced?.()})})}class N{items=new Map;initializationErrors=new Map;pendingCallbacks=new Map;watchers=new Set;execute(t,e,i){const a=this.items.get(t),o=this.initializationErrors.get(t);return o?(i?.(o),Promise.reject(o)):a?Promise.resolve(e(a)):new Promise((s,c)=>{const u=this.getPendingCallbacks(t);u.success.push(async l=>{s(await e(l))}),i?u.error.push(i):u.error.push(c)})}register(t,e){if(this.items.has(t))throw new Error(`Item with ID "${t}" is already registered.`);this.resetErrors(t),this.items.set(t,e);const i=this.pendingCallbacks.get(t);i&&(i.success.forEach(a=>a(e)),this.pendingCallbacks.delete(t)),this.registerAsDefault(t,e),this.notifyWatchers()}error(t,e){this.items.delete(t),this.initializationErrors.set(t,e);const i=this.pendingCallbacks.get(t);i&&(i.error.forEach(a=>a(e)),this.pendingCallbacks.delete(t)),this.initializationErrors.size===1&&!this.items.size&&this.error(null,e),this.notifyWatchers()}resetErrors(t){const{initializationErrors:e}=this;e.has(null)&&e.get(null)===e.get(t)&&e.delete(null),e.delete(t)}unregister(t){if(!this.items.has(t))throw new Error(`Item with ID "${t}" is not registered.`);t&&this.items.get(null)===this.items.get(t)&&this.unregister(null),this.items.delete(t),this.pendingCallbacks.delete(t),this.notifyWatchers()}getItems(){return Array.from(this.items.values())}hasItem(t){return this.items.has(t)}waitFor(t){return new Promise((e,i)=>{this.execute(t,e,i)})}async destroyAll(){const t=Array.from(new Set(this.items.values())).map(e=>e.destroy());this.items.clear(),this.pendingCallbacks.clear(),await Promise.all(t),this.notifyWatchers()}watch(t){return this.watchers.add(t),t(new Map(this.items),new Map(this.initializationErrors)),this.unwatch.bind(this,t)}unwatch(t){this.watchers.delete(t)}notifyWatchers(){this.watchers.forEach(t=>t(new Map(this.items),new Map(this.initializationErrors)))}getPendingCallbacks(t){let e=this.pendingCallbacks.get(t);return e||(e={success:[],error:[]},this.pendingCallbacks.set(t,e)),e}registerAsDefault(t,e){this.items.size===1&&t!==null&&this.register(null,e)}}function R(n,t){let e=null;return(...i)=>{e&&clearTimeout(e),e=setTimeout(()=>{t(...i)},n)}}function ot(n,t){const e=Object.entries(n).filter(([i,a])=>t(a,i));return Object.fromEntries(e)}function j(n){return Object.keys(n).length===0&&n.constructor===Object}function M(n,t){const e=Object.entries(n).map(([i,a])=>[i,t(a,i)]);return Object.fromEntries(e)}function k(n,t){if(n===t)return!0;const e=Object.keys(n),i=Object.keys(t);if(e.length!==i.length)return!1;for(const a of e)if(n[a]!==t[a]||!Object.prototype.hasOwnProperty.call(t,a))return!1;return!0}function st(){return Math.random().toString(36).substring(2)}function ct(n,{timeOutAfter:t=500,retryAfter:e=100}={}){return new Promise((i,a)=>{const o=Date.now();let s=null;const c=setTimeout(()=>{a(s??new Error("Timeout"))},t),u=async()=>{try{const l=await n();clearTimeout(c),i(l)}catch(l){s=l,Date.now()-o>t?a(l):setTimeout(u,e)}};u()})}const S=Symbol.for("context-editor-watchdog");async function ut({element:n,context:t,creator:e,config:i}){const a=st();await t.add({creator:(u,l)=>e.create(u,l),id:a,sourceElementOrData:n,type:"editor",config:i});const o=t.getItem(a),s={state:"available",editorContextId:a,context:t};o[S]=s;const c=t.destroy.bind(t);return t.destroy=async()=>(s.state="unavailable",c()),{...s,editor:o}}function lt(n){return S in n?n[S]:null}function dt(n){return n.model.document.getRootNames().reduce((e,i)=>(e[i]=n.getData({rootName:i}),e),Object.create({}))}function P(n){return["inline","classic","balloon","decoupled"].includes(n)}function q(n){let t=n;for(;t;){for(const e of t.attributes)if(e.name.startsWith("wire:model"))return!0;t=t.parentElement}return!1}async function mt(n){const t=await import("ckeditor5"),i={inline:t.InlineEditor,balloon:t.BalloonEditor,classic:t.ClassicEditor,decoupled:t.DecoupledEditor,multiroot:t.MultiRootEditor}[n];if(!i)throw new Error(`Unsupported editor type: ${n}`);return i}class I{static the=new I;plugins=new Map;constructor(){}register(t,e){if(this.plugins.has(t))throw new Error(`Plugin with name "${t}" is already registered.`);return this.plugins.set(t,e),this.unregister.bind(this,t)}unregister(t){if(!this.plugins.has(t))throw new Error(`Plugin with name "${t}" is not registered.`);this.plugins.delete(t)}unregisterAll(){this.plugins.clear()}async get(t){return this.plugins.get(t)?.()}has(t){return this.plugins.has(t)}}async function _(n){const t=await import("ckeditor5");let e=null;const i=n.map(async a=>{const o=await I.the.get(a);if(o)return o;const{[a]:s}=t;if(s)return s;if(!e)try{e=await import("ckeditor5-premium-features")}catch(u){console.error(`Failed to load premium package: ${u}`)}const{[a]:c}=e||{};if(c)return c;throw new Error(`Plugin "${a}" not found in base or premium packages.`)});return{loadedPlugins:await Promise.all(i),hasPremium:!!e}}async function U(n,t){const e=[n.ui,n.content];return await Promise.all([V("ckeditor5",e),t&&V("ckeditor5-premium-features",e)].filter(a=>!!a)).then(a=>a.flat())}async function V(n,t){return await Promise.all(t.filter(e=>e!=="en").map(async e=>{const i=await pt(n,e);return i?.default??i}).filter(Boolean))}async function pt(n,t){try{if(n==="ckeditor5")switch(t){case"af":return await import("ckeditor5/translations/af.js");case"ar":return await import("ckeditor5/translations/ar.js");case"ast":return await import("ckeditor5/translations/ast.js");case"az":return await import("ckeditor5/translations/az.js");case"bg":return await import("ckeditor5/translations/bg.js");case"bn":return await import("ckeditor5/translations/bn.js");case"bs":return await import("ckeditor5/translations/bs.js");case"ca":return await import("ckeditor5/translations/ca.js");case"cs":return await import("ckeditor5/translations/cs.js");case"da":return await import("ckeditor5/translations/da.js");case"de":return await import("ckeditor5/translations/de.js");case"de-ch":return await import("ckeditor5/translations/de-ch.js");case"el":return await import("ckeditor5/translations/el.js");case"en":return await import("ckeditor5/translations/en.js");case"en-au":return await import("ckeditor5/translations/en-au.js");case"en-gb":return await import("ckeditor5/translations/en-gb.js");case"eo":return await import("ckeditor5/translations/eo.js");case"es":return await import("ckeditor5/translations/es.js");case"es-co":return await import("ckeditor5/translations/es-co.js");case"et":return await import("ckeditor5/translations/et.js");case"eu":return await import("ckeditor5/translations/eu.js");case"fa":return await import("ckeditor5/translations/fa.js");case"fi":return await import("ckeditor5/translations/fi.js");case"fr":return await import("ckeditor5/translations/fr.js");case"gl":return await import("ckeditor5/translations/gl.js");case"gu":return await import("ckeditor5/translations/gu.js");case"he":return await import("ckeditor5/translations/he.js");case"hi":return await import("ckeditor5/translations/hi.js");case"hr":return await import("ckeditor5/translations/hr.js");case"hu":return await import("ckeditor5/translations/hu.js");case"hy":return await import("ckeditor5/translations/hy.js");case"id":return await import("ckeditor5/translations/id.js");case"it":return await import("ckeditor5/translations/it.js");case"ja":return await import("ckeditor5/translations/ja.js");case"jv":return await import("ckeditor5/translations/jv.js");case"kk":return await import("ckeditor5/translations/kk.js");case"km":return await import("ckeditor5/translations/km.js");case"kn":return await import("ckeditor5/translations/kn.js");case"ko":return await import("ckeditor5/translations/ko.js");case"ku":return await import("ckeditor5/translations/ku.js");case"lt":return await import("ckeditor5/translations/lt.js");case"lv":return await import("ckeditor5/translations/lv.js");case"ms":return await import("ckeditor5/translations/ms.js");case"nb":return await import("ckeditor5/translations/nb.js");case"ne":return await import("ckeditor5/translations/ne.js");case"nl":return await import("ckeditor5/translations/nl.js");case"no":return await import("ckeditor5/translations/no.js");case"oc":return await import("ckeditor5/translations/oc.js");case"pl":return await import("ckeditor5/translations/pl.js");case"pt":return await import("ckeditor5/translations/pt.js");case"pt-br":return await import("ckeditor5/translations/pt-br.js");case"ro":return await import("ckeditor5/translations/ro.js");case"ru":return await import("ckeditor5/translations/ru.js");case"si":return await import("ckeditor5/translations/si.js");case"sk":return await import("ckeditor5/translations/sk.js");case"sl":return await import("ckeditor5/translations/sl.js");case"sq":return await import("ckeditor5/translations/sq.js");case"sr":return await import("ckeditor5/translations/sr.js");case"sr-latn":return await import("ckeditor5/translations/sr-latn.js");case"sv":return await import("ckeditor5/translations/sv.js");case"th":return await import("ckeditor5/translations/th.js");case"tk":return await import("ckeditor5/translations/tk.js");case"tr":return await import("ckeditor5/translations/tr.js");case"tt":return await import("ckeditor5/translations/tt.js");case"ug":return await import("ckeditor5/translations/ug.js");case"uk":return await import("ckeditor5/translations/uk.js");case"ur":return await import("ckeditor5/translations/ur.js");case"uz":return await import("ckeditor5/translations/uz.js");case"vi":return await import("ckeditor5/translations/vi.js");case"zh":return await import("ckeditor5/translations/zh.js");case"zh-cn":return await import("ckeditor5/translations/zh-cn.js");default:return console.warn(`Language ${t} not found in ckeditor5 translations`),null}else switch(t){case"af":return await import("ckeditor5-premium-features/translations/af.js");case"ar":return await import("ckeditor5-premium-features/translations/ar.js");case"ast":return await import("ckeditor5-premium-features/translations/ast.js");case"az":return await import("ckeditor5-premium-features/translations/az.js");case"bg":return await import("ckeditor5-premium-features/translations/bg.js");case"bn":return await import("ckeditor5-premium-features/translations/bn.js");case"bs":return await import("ckeditor5-premium-features/translations/bs.js");case"ca":return await import("ckeditor5-premium-features/translations/ca.js");case"cs":return await import("ckeditor5-premium-features/translations/cs.js");case"da":return await import("ckeditor5-premium-features/translations/da.js");case"de":return await import("ckeditor5-premium-features/translations/de.js");case"de-ch":return await import("ckeditor5-premium-features/translations/de-ch.js");case"el":return await import("ckeditor5-premium-features/translations/el.js");case"en":return await import("ckeditor5-premium-features/translations/en.js");case"en-au":return await import("ckeditor5-premium-features/translations/en-au.js");case"en-gb":return await import("ckeditor5-premium-features/translations/en-gb.js");case"eo":return await import("ckeditor5-premium-features/translations/eo.js");case"es":return await import("ckeditor5-premium-features/translations/es.js");case"es-co":return await import("ckeditor5-premium-features/translations/es-co.js");case"et":return await import("ckeditor5-premium-features/translations/et.js");case"eu":return await import("ckeditor5-premium-features/translations/eu.js");case"fa":return await import("ckeditor5-premium-features/translations/fa.js");case"fi":return await import("ckeditor5-premium-features/translations/fi.js");case"fr":return await import("ckeditor5-premium-features/translations/fr.js");case"gl":return await import("ckeditor5-premium-features/translations/gl.js");case"gu":return await import("ckeditor5-premium-features/translations/gu.js");case"he":return await import("ckeditor5-premium-features/translations/he.js");case"hi":return await import("ckeditor5-premium-features/translations/hi.js");case"hr":return await import("ckeditor5-premium-features/translations/hr.js");case"hu":return await import("ckeditor5-premium-features/translations/hu.js");case"hy":return await import("ckeditor5-premium-features/translations/hy.js");case"id":return await import("ckeditor5-premium-features/translations/id.js");case"it":return await import("ckeditor5-premium-features/translations/it.js");case"ja":return await import("ckeditor5-premium-features/translations/ja.js");case"jv":return await import("ckeditor5-premium-features/translations/jv.js");case"kk":return await import("ckeditor5-premium-features/translations/kk.js");case"km":return await import("ckeditor5-premium-features/translations/km.js");case"kn":return await import("ckeditor5-premium-features/translations/kn.js");case"ko":return await import("ckeditor5-premium-features/translations/ko.js");case"ku":return await import("ckeditor5-premium-features/translations/ku.js");case"lt":return await import("ckeditor5-premium-features/translations/lt.js");case"lv":return await import("ckeditor5-premium-features/translations/lv.js");case"ms":return await import("ckeditor5-premium-features/translations/ms.js");case"nb":return await import("ckeditor5-premium-features/translations/nb.js");case"ne":return await import("ckeditor5-premium-features/translations/ne.js");case"nl":return await import("ckeditor5-premium-features/translations/nl.js");case"no":return await import("ckeditor5-premium-features/translations/no.js");case"oc":return await import("ckeditor5-premium-features/translations/oc.js");case"pl":return await import("ckeditor5-premium-features/translations/pl.js");case"pt":return await import("ckeditor5-premium-features/translations/pt.js");case"pt-br":return await import("ckeditor5-premium-features/translations/pt-br.js");case"ro":return await import("ckeditor5-premium-features/translations/ro.js");case"ru":return await import("ckeditor5-premium-features/translations/ru.js");case"si":return await import("ckeditor5-premium-features/translations/si.js");case"sk":return await import("ckeditor5-premium-features/translations/sk.js");case"sl":return await import("ckeditor5-premium-features/translations/sl.js");case"sq":return await import("ckeditor5-premium-features/translations/sq.js");case"sr":return await import("ckeditor5-premium-features/translations/sr.js");case"sr-latn":return await import("ckeditor5-premium-features/translations/sr-latn.js");case"sv":return await import("ckeditor5-premium-features/translations/sv.js");case"th":return await import("ckeditor5-premium-features/translations/th.js");case"tk":return await import("ckeditor5-premium-features/translations/tk.js");case"tr":return await import("ckeditor5-premium-features/translations/tr.js");case"tt":return await import("ckeditor5-premium-features/translations/tt.js");case"ug":return await import("ckeditor5-premium-features/translations/ug.js");case"uk":return await import("ckeditor5-premium-features/translations/uk.js");case"ur":return await import("ckeditor5-premium-features/translations/ur.js");case"uz":return await import("ckeditor5-premium-features/translations/uz.js");case"vi":return await import("ckeditor5-premium-features/translations/vi.js");case"zh":return await import("ckeditor5-premium-features/translations/zh.js");case"zh-cn":return await import("ckeditor5-premium-features/translations/zh-cn.js");default:return console.warn(`Language ${t} not found in premium translations`),await import("ckeditor5-premium-features/translations/en.js")}}catch(e){return console.error(`Failed to load translation for ${n}/${t}:`,e),null}}function K(n){return M(n,t=>({dictionary:t}))}function G(n){const t=Y(n);return M(t,({element:e})=>e)}function Y(n){const t=window.Livewire.all().filter(({name:s,canonical:c})=>s==="ckeditor5-editable"&&c.editorId===n).reduce((s,{canonical:c,el:u})=>({...s,[c.rootName]:{element:u.querySelector("[data-cke-editable-content]"),content:c.content}}),Object.create({})),i=window.Livewire.all().find(({name:s,canonical:c})=>s==="ckeditor5"&&c.editorId===n)?.canonical.content,a=document.querySelector(`#${n}_editor `),o=t.main;return o&&i?.main?{...t,main:{...o,content:o.content||i.main}}:a?{...t,main:{element:a,content:i?.main||null}}:t}function W(n){const t=Y(n),e=M(t,({content:i})=>i);return ot(e,i=>typeof i=="string")}function T(n){if(!n||typeof n!="object")return n;if(Array.isArray(n))return n.map(i=>T(i));const t=n;if(t.$element&&typeof t.$element=="string"){const i=document.querySelector(t.$element);return i||console.warn(`Element not found for selector: ${t.$element}`),i||null}const e=Object.create(null);for(const[i,a]of Object.entries(n))e[i]=T(a);return e}function D(n,t,e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(o=>D(n,t,o));const i=e;if(i.$translation&&typeof i.$translation=="string"){const o=i.$translation,s=ht(n,o,t);return s===void 0&&console.warn(`Translation not found for key: ${o}`),s!==void 0?s:null}const a=Object.create(null);for(const[o,s]of Object.entries(e))a[o]=D(n,t,s);return a}function ht(n,t,e){for(const i of n){const a=i[e];if(a?.dictionary&&t in a.dictionary)return a.dictionary[t]}}function wt(n,t){const{editing:e}=n;e.view.change(i=>{i.setStyle("height",`${t}px`,e.view.document.getRoot())})}const H=Symbol.for("elixir-editor-watchdog");async function ft(n){const{EditorWatchdog:t}=await import("ckeditor5"),e=new t(n);return e.setCreator(async(...i)=>{const a=await n.create(...i);return a[H]=e,a}),{watchdog:e,Constructor:{create:async(...i)=>(await e.create(...i),e.editor)}}}function gt(n){return H in n?n[H]:null}class f extends N{static the=new f}class yt extends v{contextPromise=null;async mounted(){const{contextId:t,language:e,context:i}=this.canonical,{customTranslations:a,watchdogConfig:o,config:{plugins:s,...c}}=i,{loadedPlugins:u,hasPremium:l}=await _(s??[]),E=[...await U(e,l),K(a||{})].filter(b=>!j(b));this.contextPromise=(async()=>{const{ContextWatchdog:b,Context:g}=await import("ckeditor5"),h=new b(g,{crashNumberLimit:10,...o});let w=T(c);return w=D([...E].reverse(),e.ui,w),await h.create({...w,language:e,plugins:u,...E.length&&{translations:E}}),h.on("itemError",(...O)=>{console.error("Context item error:",...O)}),h})();const x=await this.contextPromise;this.isBeingDestroyed()||f.the.register(t,x)}async destroyed(){const{contextId:t}=this.canonical;this.element.style.display="none";try{await(await this.contextPromise)?.destroy()}finally{this.contextPromise=null,f.the.hasItem(t)&&f.the.unregister(t)}}}class m extends N{static the=new m}class X extends v{editorPromise=null;pendingContent=null;mounted(){const{editorId:t,rootName:e,content:i}=this.canonical;this.editorPromise=m.the.execute(t,a=>{if(this.isBeingDestroyed())return null;const{ui:o,editing:s,model:c}=a;if(c.document.getRoot(e)){if(i!==null){const u=a.getData({rootName:e});u&&u!==i&&a.setData({[e]:i})}}else{a.addRoot(e,{isUndoable:!1,...i!==null&&{data:i}});const u=this.element.querySelector("[data-cke-editable-content]"),l=o.view.createEditable(e,u);o.addEditable(l),s.view.forceRender()}return this.syncTypingContentPush(a),this.setupPendingReceivedContentHandlers(a),a})}syncTypingContentPush(t){const{rootName:e,saveDebounceMs:i}=this.canonical,a=this.element.querySelector("input"),o=()=>{const c=t.getData({rootName:e});a&&(a.value=c),this.$wire.set("content",c)},s=R(i,o);t.model.document.on("change:data",s),o(),this.onBeforeDestroy(()=>{t.model.document.off("change:data",s)})}setupPendingReceivedContentHandlers(t){const{ui:e,model:i}=t,{focusTracker:a}=e,{rootName:o}=this.canonical,s=()=>{this.pendingContent=null},c=()=>{!a.isFocused&&this.pendingContent!==null&&(t.setData({[o]:this.pendingContent}),this.pendingContent=null)};i.document.on("change:data",s),a.on("change:isFocused",c),this.onBeforeDestroy(()=>{i.document.off("change:data",s),a.off("change:isFocused",c)})}applyCanonicalContentToEditor(t){if(!q(this.element))return;const{content:e,rootName:i}=this.canonical,{ui:a}=t;if(t.getData({rootName:i})!==(e??"")){if(a.focusTracker.isFocused){this.pendingContent=e??"";return}t.setData({[i]:e??""})}}async afterCommitSynced(){const t=await this.editorPromise;this.applyCanonicalContentToEditor(t)}async destroyed(){const{rootName:t}=this.canonical;this.element.style.display="none";const e=await this.editorPromise;if(this.editorPromise=null,e&&e.state!=="destroyed"){const i=e.model.document.getRoot(t);i&&"detachEditable"in e&&(e.detachEditable(i),e.detachRoot(t,!1))}}}async function Et({saveDebounceMs:n,component:t}){const{Plugin:e}=await import("ckeditor5");return class extends e{static get pluginName(){return"LivewireSync"}init(){this.setupTypingContentPush(),this.setupFocusableEventPush(),this.setupAfterCommitHandler(),this.setupSetEditorContentHandler(),this.setupReadyDispatch()}setupAfterCommitHandler(){const{editor:a}=this,{model:o,ui:{focusTracker:s}}=a;let c=null;a.on("afterCommitSynced",()=>{if(!q(t.element))return;const{content:u}=t.canonical,l=this.getEditorRootsValues();if(s.isFocused){k(u,l)||(c=u);return}k(u,l)||a.setData(u)}),o.document.on("change:data",()=>{c=null}),s.on("change:isFocused",()=>{!s.isFocused&&c!==null&&(a.setData(c),c=null)})}setupReadyDispatch(){const{$wire:a}=t;this.editor.once("ready",()=>{a.dispatch("editor-ready",{editorId:t.canonical.editorId})})}setupSetEditorContentHandler(){Livewire.on("set-editor-content",({editorId:a,content:o})=>{if(a!==t.canonical.editorId)return;const s=this.getEditorRootsValues();k(s,o)||this.editor.setData(o)})}setupTypingContentPush(){const{model:a}=this.editor,{$wire:o}=t,s=()=>{const c=this.getEditorRootsValues();k(c,t.canonical.content??{})||(o.set("content",c),o.dispatch("editor-content-changed",{editorId:t.canonical.editorId,content:c}))};a.document.on("change:data",R(n,s)),this.editor.once("ready",s)}setupFocusableEventPush(){const{ui:a}=this.editor,{$wire:o}=t,s=()=>{const c=this.getEditorRootsValues();o.set("focused",a.focusTracker.isFocused),k(c,t.canonical.content??{})||o.set("content",c)};a.focusTracker.on("change:isFocused",s)}getEditorRootsValues(){return dt(this.editor)}}}async function bt(n){const{Plugin:t}=await import("ckeditor5");return class extends t{input=null;form=null;static get pluginName(){return"SyncEditorWithInput"}afterInit(){const{editor:i}=this,o=i.sourceElement.id.replace(/_editor$/,"");this.input=document.getElementById(`${o}_input`),this.input&&(i.model.document.on("change:data",R(n,()=>this.sync())),i.once("ready",this.sync),this.form=this.input.closest("form"),this.form?.addEventListener("submit",this.sync))}sync=()=>{if(this.input){const i=this.editor.getData();this.input.value=i,this.input.dispatchEvent(new Event("input",{bubbles:!0}))}};destroy(){this.form&&this.form.removeEventListener("submit",this.sync),this.input=null,this.form=null}}}class J extends v{editorPromise=null;async mounted(){const{editorId:t}=this.canonical;m.the.resetErrors(t);try{this.editorPromise=this.createEditor();const e=await this.editorPromise;this.isBeingDestroyed()||(m.the.register(t,e),e.once("destroy",()=>{m.the.hasItem(t)&&m.the.unregister(t)}))}catch(e){console.error(`Error initializing CKEditor5 instance with ID "${t}":`,e),this.editorPromise=null,m.the.error(t,e)}}async destroyed(){this.element.style.display="none";try{const t=await this.editorPromise;if(!t)return;const e=lt(t),i=gt(t);e?e.state!=="unavailable"&&await e.context.remove(e.editorContextId):i?await i.destroy():await t.destroy()}finally{this.editorPromise=null}}async afterCommitSynced(){(await this.editorPromise)?.fire("afterCommitSynced")}async createEditor(){const{preset:t,editorId:e,contextId:i,editableHeight:a,saveDebounceMs:o,language:s,watchdog:c,content:u}=this.canonical,{customTranslations:l,editorType:p,licenseKey:E,config:{plugins:x,...b}}=t;let g=await mt(p);const h=await(i?f.the.waitFor(i):null);if(c&&!h){const d=await ft(g);({Constructor:g}=d),d.watchdog.on("restart",()=>{const y=d.watchdog.editor;this.editorPromise=Promise.resolve(y),m.the.register(e,y)})}const{loadedPlugins:w,hasPremium:O}=await _(x);w.push(await Et({saveDebounceMs:o,component:this})),P(p)&&w.push(await bt(o));const $=[...await U(s,O),K(l||{})].filter(d=>!j(d));let C={...u,...W(e)};P(p)&&(C=C.main||"");const z=await(async()=>{let d=G(e);if(!(d instanceof HTMLElement)&&!("main"in d)){const A=p==="decoupled"?["main"]:Object.keys(C);Q(d,A)||(d=await Ct(e,A),C={...u,...W(e)})}P(p)&&"main"in d&&(d=d.main);let y=T(b);y=D([...$].reverse(),s.ui,y);const L={...y,initialData:C,licenseKey:E,plugins:w,language:s,...$.length&&{translations:$}};return!h||!(d instanceof HTMLElement)?g.create(d,L):(await ut({context:h,element:d,creator:g,config:L})).editor})();return P(p)&&a&&wt(z,a),z}}function Q(n,t){return t.every(e=>n[e])}async function Ct(n,t){return ct(()=>{const e=G(n);if(!Q(e,t))throw new Error(`It looks like not all required root elements are present yet.
|
|
2
2
|
* If you want to wait for them, ensure they are registered before editor initialization.
|
|
3
3
|
* If you want lazy initialize roots, consider removing root values from the \`initialData\` config and assign initial data in editable components.
|
|
4
|
-
Missing roots: ${t.filter(i=>!
|
|
4
|
+
Missing roots: ${t.filter(i=>!e[i]).join(", ")}.`);return e},{timeOutAfter:2e3,retryAfter:100})}class Z extends v{mountedPromise=null;async mounted(){const{editorId:t,name:e}=this.canonical;this.mountedPromise=m.the.execute(t,i=>{if(this.isBeingDestroyed())return;const{ui:a}=i,o=kt(e),s=a.view[o];if(!s){console.error(`Unknown UI part name: "${e}". Supported names are "toolbar" and "menubar".`);return}this.element.appendChild(s.element)})}async destroyed(){this.element.style.display="none",await this.mountedPromise,this.mountedPromise=null,this.element.innerHTML=""}}function kt(n){switch(n){case"toolbar":return"toolbar";case"menubar":return"menuBarView";default:return null}}const vt={ckeditor5:J,"ckeditor5-context":yt,"ckeditor5-ui-part":Z,"ckeditor5-editable":X};function Pt(){for(const[n,t]of Object.entries(vt))B(n,t)}Pt();exports.ClassHook=v;exports.ContextsRegistry=f;exports.CustomEditorPluginsRegistry=I;exports.EditableComponentHook=X;exports.EditorComponentHook=J;exports.EditorsRegistry=m;exports.UIPartComponentHook=Z;exports.registerLivewireComponentHook=B;
|
|
5
5
|
//# sourceMappingURL=index.cjs.map
|