slate-angular 16.1.0-next.2 → 16.1.0-next.20

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.
Files changed (42) hide show
  1. package/components/children/children-outlet.component.d.ts +9 -0
  2. package/components/editable/editable.component.d.ts +1 -1
  3. package/components/string/default-string.component.d.ts +1 -1
  4. package/components/text/void-text.component.d.ts +0 -1
  5. package/esm2022/components/block-card/block-card.component.mjs +2 -2
  6. package/esm2022/components/children/children-outlet.component.mjs +22 -0
  7. package/esm2022/components/children/children.component.mjs +2 -4
  8. package/esm2022/components/editable/editable.component.mjs +36 -20
  9. package/esm2022/components/leaf/token.mjs +1 -1
  10. package/esm2022/components/string/default-string.component.mjs +1 -1
  11. package/esm2022/components/string/string.component.mjs +1 -1
  12. package/esm2022/components/text/token.mjs +1 -1
  13. package/esm2022/components/text/void-text.component.mjs +2 -6
  14. package/esm2022/module.mjs +7 -16
  15. package/esm2022/plugins/angular-editor.mjs +61 -17
  16. package/esm2022/plugins/with-angular.mjs +5 -4
  17. package/esm2022/public-api.mjs +3 -2
  18. package/esm2022/utils/constants.mjs +2 -0
  19. package/esm2022/utils/index.mjs +2 -1
  20. package/esm2022/utils/throttle.mjs +1 -1
  21. package/esm2022/view/base.mjs +59 -22
  22. package/esm2022/view/container.mjs +1 -1
  23. package/esm2022/view/context-change.mjs +13 -0
  24. package/esm2022/view/context.mjs +1 -1
  25. package/esm2022/view/render/leaves-render.mjs +8 -6
  26. package/esm2022/view/render/list-render.mjs +57 -15
  27. package/esm2022/view/render/utils.mjs +25 -14
  28. package/fesm2022/slate-angular.mjs +294 -111
  29. package/fesm2022/slate-angular.mjs.map +1 -1
  30. package/module.d.ts +2 -1
  31. package/package.json +7 -7
  32. package/plugins/angular-editor.d.ts +17 -6
  33. package/public-api.d.ts +2 -1
  34. package/utils/constants.d.ts +1 -0
  35. package/utils/index.d.ts +1 -0
  36. package/view/base.d.ts +11 -7
  37. package/view/{before-context-change.d.ts → context-change.d.ts} +4 -0
  38. package/view/context.d.ts +2 -3
  39. package/view/render/leaves-render.d.ts +2 -1
  40. package/view/render/list-render.d.ts +7 -3
  41. package/view/render/utils.d.ts +3 -3
  42. package/esm2022/view/before-context-change.mjs +0 -7
@@ -8,12 +8,13 @@ export * from './components/element/element.component';
8
8
  export * from './components/string/string.component';
9
9
  export * from './components/string/default-string.component';
10
10
  export * from './components/children/children.component';
11
+ export * from './components/children/children-outlet.component';
11
12
  export * from './components/leaves/leaves.component';
12
13
  export * from './module';
13
14
  export * from './types/error';
14
15
  export * from './view/base';
15
16
  export * from './view/context';
16
- export * from './view/before-context-change';
17
+ export * from './view/context-change';
17
18
  export * from './utils';
18
19
  export * from './types';
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3BhY2thZ2VzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygc2xhdGUtYW5ndWxhclxuICovXG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMvYW5ndWxhci1lZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9wbHVnaW5zL3dpdGgtYW5ndWxhcic7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZWRpdGFibGUvZWRpdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9lbGVtZW50L2VsZW1lbnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9zdHJpbmcvc3RyaW5nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvc3RyaW5nL2RlZmF1bHQtc3RyaW5nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvY2hpbGRyZW4vY2hpbGRyZW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9sZWF2ZXMvbGVhdmVzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzL2Vycm9yJztcbmV4cG9ydCAqIGZyb20gJy4vdmlldy9iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vdmlldy9jb250ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vdmlldy9iZWZvcmUtY29udGV4dC1jaGFuZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3BhY2thZ2VzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBzbGF0ZS1hbmd1bGFyXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2lucy9hbmd1bGFyLWVkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMvd2l0aC1hbmd1bGFyJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9lZGl0YWJsZS9lZGl0YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2VsZW1lbnQvZWxlbWVudC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3N0cmluZy9zdHJpbmcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9zdHJpbmcvZGVmYXVsdC1zdHJpbmcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9jaGlsZHJlbi9jaGlsZHJlbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2NoaWxkcmVuL2NoaWxkcmVuLW91dGxldC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2xlYXZlcy9sZWF2ZXMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMvZXJyb3InO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3L2Jhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3L2NvbnRleHQnO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3L2NvbnRleHQtY2hhbmdlJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export const TRIPLE_CLICK = 3;
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvc3JjL3V0aWxzL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFRSSVBMRV9DTElDSyA9IDM7XG4iXX0=
@@ -7,4 +7,5 @@ export * from './key';
7
7
  export * from './range-list';
8
8
  export * from './block-card';
9
9
  export * from './global-normalize';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vd2Vhay1tYXBzJztcbmV4cG9ydCAqIGZyb20gJy4vaG90a2V5cyc7XG5leHBvcnQgKiBmcm9tICcuL2RvbSc7XG5leHBvcnQgKiBmcm9tICcuL3ZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9lbnZpcm9ubWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2tleSc7XG5leHBvcnQgKiBmcm9tICcuL3JhbmdlLWxpc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9ibG9jay1jYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vZ2xvYmFsLW5vcm1hbGl6ZSc7XG4iXX0=
10
+ export * from './throttle';
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLFlBQVksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vd2Vhay1tYXBzJztcbmV4cG9ydCAqIGZyb20gJy4vaG90a2V5cyc7XG5leHBvcnQgKiBmcm9tICcuL2RvbSc7XG5leHBvcnQgKiBmcm9tICcuL3ZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9lbnZpcm9ubWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2tleSc7XG5leHBvcnQgKiBmcm9tICcuL3JhbmdlLWxpc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9ibG9jay1jYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vZ2xvYmFsLW5vcm1hbGl6ZSc7XG5leHBvcnQgKiBmcm9tICcuL3Rocm90dGxlJztcbiJdfQ==
@@ -15,4 +15,4 @@ export const createThrottleRAF = () => {
15
15
  };
16
16
  return throttleRAF;
17
17
  };
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyb3R0bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvdGhyb3R0bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsR0FBRyxFQUFFO0lBQ2xDLElBQUksT0FBTyxHQUFrQixJQUFJLENBQUM7SUFDbEMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxFQUFjLEVBQUUsRUFBRTtRQUNuQyxNQUFNLFlBQVksR0FBRyxHQUFHLEVBQUU7WUFDdEIsT0FBTyxHQUFHLHFCQUFxQixDQUFDLEdBQUcsRUFBRTtnQkFDakMsT0FBTyxHQUFHLElBQUksQ0FBQztnQkFDZixFQUFFLEVBQUUsQ0FBQztZQUNULENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxPQUFPLEtBQUssSUFBSSxFQUFFO1lBQ2xCLG9CQUFvQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzlCLE9BQU8sR0FBRyxJQUFJLENBQUM7U0FDbEI7UUFDRCxZQUFZLEVBQUUsQ0FBQztJQUNuQixDQUFDLENBQUM7SUFDRixPQUFPLFdBQVcsQ0FBQztBQUN2QixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgY3JlYXRlVGhyb3R0bGVSQUYgPSAoKSA9PiB7XG4gICAgbGV0IHRpbWVySWQ6IG51bWJlciB8IG51bGwgPSBudWxsO1xuICAgIGNvbnN0IHRocm90dGxlUkFGID0gKGZuOiAoKSA9PiB2b2lkKSA9PiB7XG4gICAgICAgIGNvbnN0IHNjaGVkdWxlRnVuYyA9ICgpID0+IHtcbiAgICAgICAgICAgIHRpbWVySWQgPSByZXF1ZXN0QW5pbWF0aW9uRnJhbWUoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRpbWVySWQgPSBudWxsO1xuICAgICAgICAgICAgICAgIGZuKCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfTtcbiAgICAgICAgaWYgKHRpbWVySWQgIT09IG51bGwpIHtcbiAgICAgICAgICAgIGNhbmNlbEFuaW1hdGlvbkZyYW1lKHRpbWVySWQpO1xuICAgICAgICAgICAgdGltZXJJZCA9IG51bGw7XG4gICAgICAgIH1cbiAgICAgICAgc2NoZWR1bGVGdW5jKCk7XG4gICAgfTtcbiAgICByZXR1cm4gdGhyb3R0bGVSQUY7XG59O1xuXG5leHBvcnQgdHlwZSBUaHJvdHRsZVJBRiA9IChmbjogKCkgPT4gdm9pZCkgPT4gdm9pZCJdfQ==
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyb3R0bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvdGhyb3R0bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsR0FBRyxFQUFFO0lBQ2xDLElBQUksT0FBTyxHQUFrQixJQUFJLENBQUM7SUFDbEMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxFQUFjLEVBQUUsRUFBRTtRQUNuQyxNQUFNLFlBQVksR0FBRyxHQUFHLEVBQUU7WUFDdEIsT0FBTyxHQUFHLHFCQUFxQixDQUFDLEdBQUcsRUFBRTtnQkFDakMsT0FBTyxHQUFHLElBQUksQ0FBQztnQkFDZixFQUFFLEVBQUUsQ0FBQztZQUNULENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxPQUFPLEtBQUssSUFBSSxFQUFFO1lBQ2xCLG9CQUFvQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzlCLE9BQU8sR0FBRyxJQUFJLENBQUM7U0FDbEI7UUFDRCxZQUFZLEVBQUUsQ0FBQztJQUNuQixDQUFDLENBQUM7SUFDRixPQUFPLFdBQVcsQ0FBQztBQUN2QixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgY3JlYXRlVGhyb3R0bGVSQUYgPSAoKSA9PiB7XG4gICAgbGV0IHRpbWVySWQ6IG51bWJlciB8IG51bGwgPSBudWxsO1xuICAgIGNvbnN0IHRocm90dGxlUkFGID0gKGZuOiAoKSA9PiB2b2lkKSA9PiB7XG4gICAgICAgIGNvbnN0IHNjaGVkdWxlRnVuYyA9ICgpID0+IHtcbiAgICAgICAgICAgIHRpbWVySWQgPSByZXF1ZXN0QW5pbWF0aW9uRnJhbWUoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRpbWVySWQgPSBudWxsO1xuICAgICAgICAgICAgICAgIGZuKCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfTtcbiAgICAgICAgaWYgKHRpbWVySWQgIT09IG51bGwpIHtcbiAgICAgICAgICAgIGNhbmNlbEFuaW1hdGlvbkZyYW1lKHRpbWVySWQpO1xuICAgICAgICAgICAgdGltZXJJZCA9IG51bGw7XG4gICAgICAgIH1cbiAgICAgICAgc2NoZWR1bGVGdW5jKCk7XG4gICAgfTtcbiAgICByZXR1cm4gdGhyb3R0bGVSQUY7XG59O1xuXG5leHBvcnQgdHlwZSBUaHJvdHRsZVJBRiA9IChmbjogKCkgPT4gdm9pZCkgPT4gdm9pZDtcbiJdfQ==
@@ -1,9 +1,10 @@
1
- import { Directive, HostBinding, Input, ViewContainerRef, inject } from '@angular/core';
1
+ import { Directive, HostBinding, Input, ViewChild, ViewContainerRef, inject } from '@angular/core';
2
2
  import { ELEMENT_TO_COMPONENT, ELEMENT_TO_NODE, NODE_TO_ELEMENT } from '../utils/weak-maps';
3
3
  import { Range } from 'slate';
4
- import { hasBeforeContextChange } from './before-context-change';
4
+ import { hasAfterContextChange, hasBeforeContextChange } from './context-change';
5
5
  import { ListRender } from './render/list-render';
6
6
  import { LeavesRender } from './render/leaves-render';
7
+ import { SlateChildrenOutlet } from '../components/children/children-outlet.component';
7
8
  import * as i0 from "@angular/core";
8
9
  /**
9
10
  * base class for custom element component or text component
@@ -15,6 +16,12 @@ export class BaseComponent {
15
16
  }
16
17
  this._context = value;
17
18
  this.onContextChange();
19
+ if (this.initialized) {
20
+ this.cdr.detectChanges();
21
+ }
22
+ if (hasAfterContextChange(this)) {
23
+ this.afterContextChange();
24
+ }
18
25
  }
19
26
  get context() {
20
27
  return this._context;
@@ -28,6 +35,7 @@ export class BaseComponent {
28
35
  constructor(elementRef, cdr) {
29
36
  this.elementRef = elementRef;
30
37
  this.cdr = cdr;
38
+ this.initialized = false;
31
39
  }
32
40
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: BaseComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
33
41
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: BaseComponent, inputs: { context: "context", viewContext: "viewContext" }, ngImport: i0 }); }
@@ -45,7 +53,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
45
53
  export class BaseLeafComponent extends BaseComponent {
46
54
  constructor() {
47
55
  super(...arguments);
48
- this.initialized = false;
49
56
  this.isSlateLeaf = true;
50
57
  }
51
58
  get text() {
@@ -61,7 +68,6 @@ export class BaseLeafComponent extends BaseComponent {
61
68
  if (!this.initialized) {
62
69
  return;
63
70
  }
64
- this.cdr.detectChanges();
65
71
  }
66
72
  renderPlaceholder() {
67
73
  // issue-1: IME input was interrupted
@@ -114,10 +120,15 @@ export class BaseElementComponent extends BaseComponent {
114
120
  constructor() {
115
121
  super(...arguments);
116
122
  this.viewContainerRef = inject(ViewContainerRef);
117
- this.initialized = false;
118
- this.getOutletElement = () => {
123
+ this.getOutletParent = () => {
119
124
  return this.elementRef.nativeElement;
120
125
  };
126
+ this.getOutletElement = () => {
127
+ if (this.childrenOutletInstance) {
128
+ return this.childrenOutletInstance.getNativeElement();
129
+ }
130
+ return null;
131
+ };
121
132
  }
122
133
  get element() {
123
134
  return this._context && this._context.element;
@@ -125,9 +136,6 @@ export class BaseElementComponent extends BaseComponent {
125
136
  get selection() {
126
137
  return this._context && this._context.selection;
127
138
  }
128
- get path() {
129
- return this._context && this._context.path;
130
- }
131
139
  get decorations() {
132
140
  return this._context && this._context.decorations;
133
141
  }
@@ -148,8 +156,16 @@ export class BaseElementComponent extends BaseComponent {
148
156
  this.nativeElement.setAttribute(key, this._context.attributes[key]);
149
157
  }
150
158
  this.initialized = true;
151
- this.listRender = new ListRender(this.viewContext, this.viewContainerRef, this.getOutletElement);
152
- this.listRender.initialize(this.children, this.element, this.path, this.childrenContext);
159
+ this.listRender = new ListRender(this.viewContext, this.viewContainerRef, this.getOutletParent, this.getOutletElement);
160
+ if (this.editor.isExpanded(this.element)) {
161
+ this.listRender.initialize(this.children, this.element, this.childrenContext);
162
+ }
163
+ }
164
+ afterViewInit() {
165
+ if (this._context.contentEditable !== undefined) {
166
+ this.nativeElement.setAttribute('contenteditable', this._context.contentEditable + '');
167
+ }
168
+ this.listRender.afterViewInit();
153
169
  }
154
170
  updateWeakMap() {
155
171
  NODE_TO_ELEMENT.set(this.element, this.nativeElement);
@@ -160,6 +176,7 @@ export class BaseElementComponent extends BaseComponent {
160
176
  if (NODE_TO_ELEMENT.get(this.element) === this.nativeElement) {
161
177
  NODE_TO_ELEMENT.delete(this.element);
162
178
  }
179
+ ELEMENT_TO_NODE.delete(this.nativeElement);
163
180
  if (ELEMENT_TO_COMPONENT.get(this.element) === this) {
164
181
  ELEMENT_TO_COMPONENT.delete(this.element);
165
182
  }
@@ -170,8 +187,17 @@ export class BaseElementComponent extends BaseComponent {
170
187
  if (!this.initialized) {
171
188
  return;
172
189
  }
173
- this.listRender.update(this.children, this.element, this.path, this.childrenContext);
174
- this.cdr.detectChanges();
190
+ this.updateChildrenView();
191
+ }
192
+ updateChildrenView() {
193
+ if (this.editor.isExpanded(this.element)) {
194
+ this.listRender.update(this.children, this.element, this.childrenContext);
195
+ }
196
+ else {
197
+ if (this.listRender.initialized) {
198
+ this.listRender.destroy();
199
+ }
200
+ }
175
201
  }
176
202
  getChildrenContext() {
177
203
  return {
@@ -183,29 +209,37 @@ export class BaseElementComponent extends BaseComponent {
183
209
  };
184
210
  }
185
211
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: BaseElementComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
186
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: BaseElementComponent, usesInheritance: true, ngImport: i0 }); }
212
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: BaseElementComponent, viewQueries: [{ propertyName: "childrenOutletInstance", first: true, predicate: SlateChildrenOutlet, descendants: true, static: true }], usesInheritance: true, ngImport: i0 }); }
187
213
  }
188
214
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: BaseElementComponent, decorators: [{
189
215
  type: Directive
190
- }] });
216
+ }], propDecorators: { childrenOutletInstance: [{
217
+ type: ViewChild,
218
+ args: [SlateChildrenOutlet, { static: true }]
219
+ }] } });
191
220
  /**
192
221
  * base class for custom text component
193
222
  */
194
223
  export class BaseTextComponent extends BaseComponent {
195
224
  constructor() {
196
225
  super(...arguments);
197
- this.initialized = false;
198
226
  this.viewContainerRef = inject(ViewContainerRef);
199
- this.getOutletElement = () => {
227
+ this.getOutletParent = () => {
200
228
  return this.elementRef.nativeElement;
201
229
  };
230
+ this.getOutletElement = () => {
231
+ if (this.childrenOutletInstance) {
232
+ return this.childrenOutletInstance.getNativeElement();
233
+ }
234
+ return null;
235
+ };
202
236
  }
203
237
  get text() {
204
238
  return this._context && this._context.text;
205
239
  }
206
240
  ngOnInit() {
207
241
  this.initialized = true;
208
- this.leavesRender = new LeavesRender(this.viewContext, this.viewContainerRef, this.getOutletElement);
242
+ this.leavesRender = new LeavesRender(this.viewContext, this.viewContainerRef, this.getOutletParent, this.getOutletElement);
209
243
  this.leavesRender.initialize(this.context);
210
244
  }
211
245
  updateWeakMap() {
@@ -216,6 +250,7 @@ export class BaseTextComponent extends BaseComponent {
216
250
  if (NODE_TO_ELEMENT.get(this.text) === this.nativeElement) {
217
251
  NODE_TO_ELEMENT.delete(this.text);
218
252
  }
253
+ ELEMENT_TO_NODE.delete(this.nativeElement);
219
254
  }
220
255
  onContextChange() {
221
256
  this.updateWeakMap();
@@ -223,12 +258,14 @@ export class BaseTextComponent extends BaseComponent {
223
258
  return;
224
259
  }
225
260
  this.leavesRender.update(this.context);
226
- this.cdr.detectChanges();
227
261
  }
228
262
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: BaseTextComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
229
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: BaseTextComponent, usesInheritance: true, ngImport: i0 }); }
263
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: BaseTextComponent, viewQueries: [{ propertyName: "childrenOutletInstance", first: true, predicate: SlateChildrenOutlet, descendants: true, static: true }], usesInheritance: true, ngImport: i0 }); }
230
264
  }
231
265
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: BaseTextComponent, decorators: [{
232
266
  type: Directive
233
- }] });
234
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../packages/src/view/base.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, HostBinding, Input, OnDestroy, OnInit, ViewContainerRef, inject } from '@angular/core';\nimport { AngularEditor } from '../plugins/angular-editor';\nimport { ELEMENT_TO_COMPONENT, ELEMENT_TO_NODE, NODE_TO_ELEMENT } from '../utils/weak-maps';\nimport { SlateViewContext, SlateElementContext, SlateTextContext, SlateLeafContext } from './context';\nimport { Descendant, Element, Path, Range, Text } from 'slate';\nimport { SlateChildrenContext } from './context';\nimport { hasBeforeContextChange } from './before-context-change';\nimport { ListRender } from './render/list-render';\nimport { LeavesRender } from './render/leaves-render';\n\n/**\n * base class for template\n */\nexport interface BaseEmbeddedView<T, K extends AngularEditor = AngularEditor> {\n    context: T;\n    viewContext: SlateViewContext<K>;\n}\n\n/**\n * base class for custom element component or text component\n */\n@Directive()\nexport abstract class BaseComponent<\n    T = SlateTextContext | SlateLeafContext | SlateElementContext,\n    K extends AngularEditor = AngularEditor\n> {\n    protected _context: T;\n\n    @Input()\n    set context(value: T) {\n        if (hasBeforeContextChange<T>(this)) {\n            this.beforeContextChange(value);\n        }\n        this._context = value;\n        this.onContextChange();\n    }\n\n    get context() {\n        return this._context;\n    }\n\n    @Input() viewContext: SlateViewContext<K>;\n\n    get editor() {\n        return this.viewContext && this.viewContext.editor;\n    }\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef) {}\n\n    abstract onContextChange();\n}\n\n/**\n * base class for custom leaf component\n */\n@Directive()\nexport class BaseLeafComponent extends BaseComponent<SlateLeafContext> implements OnInit {\n    initialized = false;\n\n    placeholderElement: HTMLSpanElement;\n\n    @HostBinding('attr.data-slate-leaf') isSlateLeaf = true;\n\n    get text(): Text {\n        return this.context && this.context.text;\n    }\n\n    get leaf(): Text {\n        return this.context && this.context.leaf;\n    }\n\n    ngOnInit() {\n        this.initialized = true;\n    }\n\n    onContextChange() {\n        if (!this.initialized) {\n            return;\n        }\n        this.cdr.detectChanges();\n    }\n\n    renderPlaceholder() {\n        // issue-1: IME input was interrupted\n        // issue-2: IME input focus jumping\n        // Issue occurs when the span node of the placeholder is before the slateString span node\n        if (this.context.leaf['placeholder']) {\n            if (!this.placeholderElement) {\n                this.createPlaceholder();\n            }\n            this.updatePlaceholder();\n        } else {\n            this.destroyPlaceholder();\n        }\n    }\n\n    createPlaceholder() {\n        const placeholderElement = document.createElement('span');\n        placeholderElement.innerText = this.context.leaf['placeholder'];\n        placeholderElement.contentEditable = 'false';\n        placeholderElement.setAttribute('data-slate-placeholder', 'true');\n        this.placeholderElement = placeholderElement;\n        this.nativeElement.classList.add('leaf-with-placeholder');\n        this.nativeElement.appendChild(placeholderElement);\n    }\n\n    updatePlaceholder() {\n        if (this.placeholderElement.innerText !== this.context.leaf['placeholder']) {\n            this.placeholderElement.innerText = this.context.leaf['placeholder'];\n        }\n    }\n\n    destroyPlaceholder() {\n        if (this.placeholderElement) {\n            this.placeholderElement.remove();\n            this.placeholderElement = null;\n            this.nativeElement.classList.remove('leaf-with-placeholder');\n        }\n    }\n}\n\n/**\n * base class for custom element component\n */\n@Directive()\nexport class BaseElementComponent<T extends Element = Element, K extends AngularEditor = AngularEditor>\n    extends BaseComponent<SlateElementContext<T>, K>\n    implements OnInit, OnDestroy\n{\n    viewContainerRef = inject(ViewContainerRef);\n\n    initialized = false;\n\n    childrenContext: SlateChildrenContext;\n\n    get element(): T {\n        return this._context && this._context.element;\n    }\n\n    get selection(): Range {\n        return this._context && this._context.selection;\n    }\n\n    get path(): Path {\n        return this._context && this._context.path;\n    }\n\n    get decorations(): Range[] {\n        return this._context && this._context.decorations;\n    }\n\n    get children(): Descendant[] {\n        return this._context && this._context.element.children;\n    }\n\n    get isCollapsed() {\n        return this.selection && Range.isCollapsed(this.selection);\n    }\n\n    get isCollapsedAndNonReadonly() {\n        return this.selection && Range.isCollapsed(this.selection) && !this.readonly;\n    }\n\n    get readonly() {\n        return this._context && this._context.readonly;\n    }\n\n    getOutletElement = () => {\n        return this.elementRef.nativeElement;\n    };\n\n    listRender: ListRender;\n\n    ngOnInit() {\n        for (const key in this._context.attributes) {\n            this.nativeElement.setAttribute(key, this._context.attributes[key]);\n        }\n        this.initialized = true;\n        this.listRender = new ListRender(this.viewContext, this.viewContainerRef, this.getOutletElement);\n        this.listRender.initialize(this.children, this.element, this.path, this.childrenContext);\n    }\n\n    updateWeakMap() {\n        NODE_TO_ELEMENT.set(this.element, this.nativeElement);\n        ELEMENT_TO_NODE.set(this.nativeElement, this.element);\n        ELEMENT_TO_COMPONENT.set(this.element, this);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.element) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.element);\n        }\n        if (ELEMENT_TO_COMPONENT.get(this.element) === this) {\n            ELEMENT_TO_COMPONENT.delete(this.element);\n        }\n    }\n\n    onContextChange() {\n        this.childrenContext = this.getChildrenContext();\n        this.updateWeakMap();\n        if (!this.initialized) {\n            return;\n        }\n        this.listRender.update(this.children, this.element, this.path, this.childrenContext);\n        this.cdr.detectChanges();\n    }\n\n    getChildrenContext(): SlateChildrenContext {\n        return {\n            parent: this._context.element,\n            selection: this._context.selection,\n            decorations: this._context.decorations,\n            decorate: this._context.decorate,\n            readonly: this._context.readonly\n        };\n    }\n}\n\n/**\n * base class for custom text component\n */\n@Directive()\nexport class BaseTextComponent<T extends Text = Text> extends BaseComponent<SlateTextContext<T>> implements OnInit, OnDestroy {\n    initialized = false;\n\n    viewContainerRef = inject(ViewContainerRef);\n\n    get text(): T {\n        return this._context && this._context.text;\n    }\n\n    leavesRender: LeavesRender;\n\n    getOutletElement = () => {\n        return this.elementRef.nativeElement;\n    };\n\n    ngOnInit() {\n        this.initialized = true;\n        this.leavesRender = new LeavesRender(this.viewContext, this.viewContainerRef, this.getOutletElement);\n        this.leavesRender.initialize(this.context);\n    }\n\n    updateWeakMap() {\n        ELEMENT_TO_NODE.set(this.nativeElement, this.text);\n        NODE_TO_ELEMENT.set(this.text, this.nativeElement);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.text) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.text);\n        }\n    }\n\n    onContextChange() {\n        this.updateWeakMap();\n        if (!this.initialized) {\n            return;\n        }\n        this.leavesRender.update(this.context);\n        this.cdr.detectChanges();\n    }\n}\n"]}
267
+ }], propDecorators: { childrenOutletInstance: [{
268
+ type: ViewChild,
269
+ args: [SlateChildrenOutlet, { static: true }]
270
+ }] } });
271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../packages/src/view/base.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n    ViewChild,\n    ViewContainerRef,\n    inject\n} from '@angular/core';\nimport { AngularEditor } from '../plugins/angular-editor';\nimport { ELEMENT_TO_COMPONENT, ELEMENT_TO_NODE, NODE_TO_ELEMENT } from '../utils/weak-maps';\nimport { SlateViewContext, SlateElementContext, SlateTextContext, SlateLeafContext } from './context';\nimport { Descendant, Element, Path, Range, Text } from 'slate';\nimport { SlateChildrenContext } from './context';\nimport { hasAfterContextChange, hasBeforeContextChange } from './context-change';\nimport { ListRender } from './render/list-render';\nimport { LeavesRender } from './render/leaves-render';\nimport { SlateChildrenOutlet } from '../components/children/children-outlet.component';\n\n/**\n * base class for template\n */\nexport interface BaseEmbeddedView<T, K extends AngularEditor = AngularEditor> {\n    context: T;\n    viewContext: SlateViewContext<K>;\n}\n\n/**\n * base class for custom element component or text component\n */\n@Directive()\nexport abstract class BaseComponent<\n    T = SlateTextContext | SlateLeafContext | SlateElementContext,\n    K extends AngularEditor = AngularEditor\n> {\n    initialized = false;\n\n    protected _context: T;\n\n    @Input()\n    set context(value: T) {\n        if (hasBeforeContextChange<T>(this)) {\n            this.beforeContextChange(value);\n        }\n        this._context = value;\n        this.onContextChange();\n        if (this.initialized) {\n            this.cdr.detectChanges();\n        }\n        if (hasAfterContextChange<T>(this)) {\n            this.afterContextChange();\n        }\n    }\n\n    get context() {\n        return this._context;\n    }\n\n    @Input() viewContext: SlateViewContext<K>;\n\n    get editor() {\n        return this.viewContext && this.viewContext.editor;\n    }\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        public cdr: ChangeDetectorRef\n    ) {}\n\n    abstract onContextChange();\n}\n\n/**\n * base class for custom leaf component\n */\n@Directive()\nexport class BaseLeafComponent extends BaseComponent<SlateLeafContext> implements OnInit {\n    placeholderElement: HTMLSpanElement;\n\n    @HostBinding('attr.data-slate-leaf') isSlateLeaf = true;\n\n    get text(): Text {\n        return this.context && this.context.text;\n    }\n\n    get leaf(): Text {\n        return this.context && this.context.leaf;\n    }\n\n    ngOnInit() {\n        this.initialized = true;\n    }\n\n    onContextChange() {\n        if (!this.initialized) {\n            return;\n        }\n    }\n\n    renderPlaceholder() {\n        // issue-1: IME input was interrupted\n        // issue-2: IME input focus jumping\n        // Issue occurs when the span node of the placeholder is before the slateString span node\n        if (this.context.leaf['placeholder']) {\n            if (!this.placeholderElement) {\n                this.createPlaceholder();\n            }\n            this.updatePlaceholder();\n        } else {\n            this.destroyPlaceholder();\n        }\n    }\n\n    createPlaceholder() {\n        const placeholderElement = document.createElement('span');\n        placeholderElement.innerText = this.context.leaf['placeholder'];\n        placeholderElement.contentEditable = 'false';\n        placeholderElement.setAttribute('data-slate-placeholder', 'true');\n        this.placeholderElement = placeholderElement;\n        this.nativeElement.classList.add('leaf-with-placeholder');\n        this.nativeElement.appendChild(placeholderElement);\n    }\n\n    updatePlaceholder() {\n        if (this.placeholderElement.innerText !== this.context.leaf['placeholder']) {\n            this.placeholderElement.innerText = this.context.leaf['placeholder'];\n        }\n    }\n\n    destroyPlaceholder() {\n        if (this.placeholderElement) {\n            this.placeholderElement.remove();\n            this.placeholderElement = null;\n            this.nativeElement.classList.remove('leaf-with-placeholder');\n        }\n    }\n}\n\n/**\n * base class for custom element component\n */\n@Directive()\nexport class BaseElementComponent<T extends Element = Element, K extends AngularEditor = AngularEditor>\n    extends BaseComponent<SlateElementContext<T>, K>\n    implements OnInit, OnDestroy\n{\n    viewContainerRef = inject(ViewContainerRef);\n\n    childrenContext: SlateChildrenContext;\n\n    @ViewChild(SlateChildrenOutlet, { static: true })\n    childrenOutletInstance?: SlateChildrenOutlet;\n\n    get element(): T {\n        return this._context && this._context.element;\n    }\n\n    get selection(): Range {\n        return this._context && this._context.selection;\n    }\n\n    get decorations(): Range[] {\n        return this._context && this._context.decorations;\n    }\n\n    get children(): Descendant[] {\n        return this._context && this._context.element.children;\n    }\n\n    get isCollapsed() {\n        return this.selection && Range.isCollapsed(this.selection);\n    }\n\n    get isCollapsedAndNonReadonly() {\n        return this.selection && Range.isCollapsed(this.selection) && !this.readonly;\n    }\n\n    get readonly() {\n        return this._context && this._context.readonly;\n    }\n\n    getOutletParent = () => {\n        return this.elementRef.nativeElement;\n    };\n\n    getOutletElement = () => {\n        if (this.childrenOutletInstance) {\n            return this.childrenOutletInstance.getNativeElement();\n        }\n        return null;\n    };\n\n    listRender: ListRender;\n\n    ngOnInit() {\n        for (const key in this._context.attributes) {\n            this.nativeElement.setAttribute(key, this._context.attributes[key]);\n        }\n        this.initialized = true;\n        this.listRender = new ListRender(this.viewContext, this.viewContainerRef, this.getOutletParent, this.getOutletElement);\n        if (this.editor.isExpanded(this.element)) {\n            this.listRender.initialize(this.children, this.element, this.childrenContext);\n        }\n    }\n\n    afterViewInit() {\n        if (this._context.contentEditable !== undefined) {\n            this.nativeElement.setAttribute('contenteditable', this._context.contentEditable + '');\n        }\n        this.listRender.afterViewInit();\n    }\n\n    updateWeakMap() {\n        NODE_TO_ELEMENT.set(this.element, this.nativeElement);\n        ELEMENT_TO_NODE.set(this.nativeElement, this.element);\n        ELEMENT_TO_COMPONENT.set(this.element, this);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.element) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.element);\n        }\n        ELEMENT_TO_NODE.delete(this.nativeElement);\n        if (ELEMENT_TO_COMPONENT.get(this.element) === this) {\n            ELEMENT_TO_COMPONENT.delete(this.element);\n        }\n    }\n\n    onContextChange() {\n        this.childrenContext = this.getChildrenContext();\n        this.updateWeakMap();\n        if (!this.initialized) {\n            return;\n        }\n        this.updateChildrenView();\n    }\n\n    updateChildrenView() {\n        if (this.editor.isExpanded(this.element)) {\n            this.listRender.update(this.children, this.element, this.childrenContext);\n        } else {\n            if (this.listRender.initialized) {\n                this.listRender.destroy();\n            }\n        }\n    }\n\n    getChildrenContext(): SlateChildrenContext {\n        return {\n            parent: this._context.element,\n            selection: this._context.selection,\n            decorations: this._context.decorations,\n            decorate: this._context.decorate,\n            readonly: this._context.readonly\n        };\n    }\n}\n\n/**\n * base class for custom text component\n */\n@Directive()\nexport class BaseTextComponent<T extends Text = Text> extends BaseComponent<SlateTextContext<T>> implements OnInit, OnDestroy {\n    viewContainerRef = inject(ViewContainerRef);\n\n    get text(): T {\n        return this._context && this._context.text;\n    }\n\n    leavesRender: LeavesRender;\n\n    @ViewChild(SlateChildrenOutlet, { static: true })\n    childrenOutletInstance?: SlateChildrenOutlet;\n\n    getOutletParent = () => {\n        return this.elementRef.nativeElement;\n    };\n\n    getOutletElement = () => {\n        if (this.childrenOutletInstance) {\n            return this.childrenOutletInstance.getNativeElement();\n        }\n        return null;\n    };\n\n    ngOnInit() {\n        this.initialized = true;\n        this.leavesRender = new LeavesRender(this.viewContext, this.viewContainerRef, this.getOutletParent, this.getOutletElement);\n        this.leavesRender.initialize(this.context);\n    }\n\n    updateWeakMap() {\n        ELEMENT_TO_NODE.set(this.nativeElement, this.text);\n        NODE_TO_ELEMENT.set(this.text, this.nativeElement);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.text) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.text);\n        }\n        ELEMENT_TO_NODE.delete(this.nativeElement);\n    }\n\n    onContextChange() {\n        this.updateWeakMap();\n        if (!this.initialized) {\n            return;\n        }\n        this.leavesRender.update(this.context);\n    }\n}\n"]}
@@ -19,4 +19,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
19
19
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.IterableDiffers }]; }, propDecorators: { viewContext: [{
20
20
  type: Input
21
21
  }] } });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvc3JjL3ZpZXcvY29udGFpbmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFtQixNQUFNLGVBQWUsQ0FBQzs7QUFJOUU7Ozs7O0dBS0c7QUFFSCxNQUFNLE9BQWdCLGFBQWE7SUFHL0IsWUFBc0IsVUFBMkIsRUFBWSxPQUF3QjtRQUEvRCxlQUFVLEdBQVYsVUFBVSxDQUFpQjtRQUFZLFlBQU8sR0FBUCxPQUFPLENBQWlCO0lBQUcsQ0FBQzs4R0FIdkUsYUFBYTtrR0FBYixhQUFhOzsyRkFBYixhQUFhO2tCQURsQyxTQUFTOytIQUVHLFdBQVc7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBJdGVyYWJsZURpZmZlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNsYXRlVmlld0NvbnRleHQgfSBmcm9tICcuL2NvbnRleHQnO1xuaW1wb3J0IHsgVmlld0NvbnRhaW5lckl0ZW0gfSBmcm9tICcuL2NvbnRhaW5lci1pdGVtJztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZFxuICogdGhlIHNwZWNpYWwgY29udGFpbmVyIGZvciBhbmd1bGFyIHRlbXBsYXRlXG4gKiBBZGQgdGhlIHJvb3ROb2RlcyBvZiBlYWNoIGNoaWxkIGNvbXBvbmVudCB0byB0aGUgcGFyZW50RWxlbWVudFxuICogUmVtb3ZlIHVzZWxlc3MgRE9NIGVsZW1lbnRzLCBlZzogY29tbWVudC4uLlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBWaWV3Q29udGFpbmVyPFQgZXh0ZW5kcyBWaWV3Q29udGFpbmVySXRlbT4ge1xuICAgIEBJbnB1dCgpIHZpZXdDb250ZXh0OiBTbGF0ZVZpZXdDb250ZXh0O1xuXG4gICAgY29uc3RydWN0b3IocHJvdGVjdGVkIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8YW55PiwgcHJvdGVjdGVkIGRpZmZlcnM6IEl0ZXJhYmxlRGlmZmVycykge31cbn1cbiJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvc3JjL3ZpZXcvY29udGFpbmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFtQixNQUFNLGVBQWUsQ0FBQzs7QUFJOUU7Ozs7O0dBS0c7QUFFSCxNQUFNLE9BQWdCLGFBQWE7SUFHL0IsWUFDYyxVQUEyQixFQUMzQixPQUF3QjtRQUR4QixlQUFVLEdBQVYsVUFBVSxDQUFpQjtRQUMzQixZQUFPLEdBQVAsT0FBTyxDQUFpQjtJQUNuQyxDQUFDOzhHQU5jLGFBQWE7a0dBQWIsYUFBYTs7MkZBQWIsYUFBYTtrQkFEbEMsU0FBUzsrSEFFRyxXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCwgSXRlcmFibGVEaWZmZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTbGF0ZVZpZXdDb250ZXh0IH0gZnJvbSAnLi9jb250ZXh0JztcbmltcG9ydCB7IFZpZXdDb250YWluZXJJdGVtIH0gZnJvbSAnLi9jb250YWluZXItaXRlbSc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWRcbiAqIHRoZSBzcGVjaWFsIGNvbnRhaW5lciBmb3IgYW5ndWxhciB0ZW1wbGF0ZVxuICogQWRkIHRoZSByb290Tm9kZXMgb2YgZWFjaCBjaGlsZCBjb21wb25lbnQgdG8gdGhlIHBhcmVudEVsZW1lbnRcbiAqIFJlbW92ZSB1c2VsZXNzIERPTSBlbGVtZW50cywgZWc6IGNvbW1lbnQuLi5cbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgVmlld0NvbnRhaW5lcjxUIGV4dGVuZHMgVmlld0NvbnRhaW5lckl0ZW0+IHtcbiAgICBASW5wdXQoKSB2aWV3Q29udGV4dDogU2xhdGVWaWV3Q29udGV4dDtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcm90ZWN0ZWQgZWxlbWVudFJlZjogRWxlbWVudFJlZjxhbnk+LFxuICAgICAgICBwcm90ZWN0ZWQgZGlmZmVyczogSXRlcmFibGVEaWZmZXJzXG4gICAgKSB7fVxufVxuIl19
@@ -0,0 +1,13 @@
1
+ export function hasBeforeContextChange(value) {
2
+ if (value.beforeContextChange) {
3
+ return true;
4
+ }
5
+ return false;
6
+ }
7
+ export function hasAfterContextChange(value) {
8
+ if (value.afterContextChange) {
9
+ return true;
10
+ }
11
+ return false;
12
+ }
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1jaGFuZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdmlldy9jb250ZXh0LWNoYW5nZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSxNQUFNLFVBQVUsc0JBQXNCLENBQUksS0FBSztJQUMzQyxJQUFJLEtBQUssQ0FBQyxtQkFBbUIsRUFBRTtRQUMzQixPQUFPLElBQUksQ0FBQztLQUNmO0lBQ0QsT0FBTyxLQUFLLENBQUM7QUFDakIsQ0FBQztBQUVELE1BQU0sVUFBVSxxQkFBcUIsQ0FBSSxLQUFLO0lBQzFDLElBQUksS0FBSyxDQUFDLGtCQUFrQixFQUFFO1FBQzFCLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBCZWZvcmVDb250ZXh0Q2hhbmdlPFQ+IHtcbiAgICBiZWZvcmVDb250ZXh0Q2hhbmdlOiAodmFsdWU6IFQpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWZ0ZXJDb250ZXh0Q2hhbmdlPD4ge1xuICAgIGFmdGVyQ29udGV4dENoYW5nZTogKCkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGhhc0JlZm9yZUNvbnRleHRDaGFuZ2U8VD4odmFsdWUpOiB2YWx1ZSBpcyBCZWZvcmVDb250ZXh0Q2hhbmdlPFQ+IHtcbiAgICBpZiAodmFsdWUuYmVmb3JlQ29udGV4dENoYW5nZSkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGFzQWZ0ZXJDb250ZXh0Q2hhbmdlPFQ+KHZhbHVlKTogdmFsdWUgaXMgQWZ0ZXJDb250ZXh0Q2hhbmdlIHtcbiAgICBpZiAodmFsdWUuYWZ0ZXJDb250ZXh0Q2hhbmdlKSB7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgICByZXR1cm4gZmFsc2U7XG59XG4iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy92aWV3L2NvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vZGVFbnRyeSwgUmFuZ2UsIEVsZW1lbnQsIEFuY2VzdG9yLCBUZXh0LCBQYXRoIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgU2xhdGVTdHJpbmdUZW1wbGF0ZSB9IGZyb20gJy4uL2NvbXBvbmVudHMvc3RyaW5nL3RlbXBsYXRlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBbmd1bGFyRWRpdG9yIH0gZnJvbSAnLi4vcGx1Z2lucy9hbmd1bGFyLWVkaXRvcic7XG5pbXBvcnQgeyBDb21wb25lbnRUeXBlLCBWaWV3VHlwZSB9IGZyb20gJy4uL3R5cGVzL3ZpZXcnO1xuaW1wb3J0IHsgQmFzZUVsZW1lbnRDb21wb25lbnQsIEJhc2VMZWFmQ29tcG9uZW50LCBCYXNlVGV4dENvbXBvbmVudCB9IGZyb20gJy4vYmFzZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVWaWV3Q29udGV4dDxUIGV4dGVuZHMgQW5ndWxhckVkaXRvciA9IEFuZ3VsYXJFZGl0b3I+IHtcbiAgICBlZGl0b3I6IFQ7XG4gICAgdGVtcGxhdGVDb21wb25lbnQ6IFNsYXRlU3RyaW5nVGVtcGxhdGU7XG4gICAgZGVmYXVsdEVsZW1lbnQ6IENvbXBvbmVudFR5cGU8QmFzZUVsZW1lbnRDb21wb25lbnQ+O1xuICAgIGRlZmF1bHRUZXh0OiBDb21wb25lbnRUeXBlPEJhc2VUZXh0Q29tcG9uZW50PjtcbiAgICBkZWZhdWx0Vm9pZFRleHQ6IENvbXBvbmVudFR5cGU8QmFzZVRleHRDb21wb25lbnQ+O1xuICAgIGRlZmF1bHRMZWFmOiBDb21wb25lbnRUeXBlPEJhc2VMZWFmQ29tcG9uZW50PjtcbiAgICB0cmFja0J5OiAoZWxlbWVudDogRWxlbWVudCkgPT4gYW55O1xuICAgIHJlbmRlckVsZW1lbnQ/OiAoZWxlbWVudDogRWxlbWVudCkgPT4gVmlld1R5cGU7XG4gICAgcmVuZGVyTGVhZj86ICh0ZXh0OiBUZXh0KSA9PiBWaWV3VHlwZTtcbiAgICByZW5kZXJUZXh0PzogKHRleHQ6IFRleHQpID0+IFZpZXdUeXBlO1xuICAgIGlzU3RyaWN0RGVjb3JhdGU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVDaGlsZHJlbkNvbnRleHQge1xuICAgIHBhcmVudDogQW5jZXN0b3I7XG4gICAgc2VsZWN0aW9uOiBSYW5nZTtcbiAgICBkZWNvcmF0aW9uczogUmFuZ2VbXTtcbiAgICBkZWNvcmF0ZTogKGVudHJ5OiBOb2RlRW50cnkpID0+IFJhbmdlW107XG4gICAgcmVhZG9ubHk6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVFbGVtZW50Q29udGV4dDxUIGV4dGVuZHMgRWxlbWVudCA9IEVsZW1lbnQ+IHtcbiAgICBlbGVtZW50OiBUO1xuICAgIHNlbGVjdGlvbjogUmFuZ2UgfCBudWxsO1xuICAgIHBhdGg6IFBhdGg7XG4gICAgZGVjb3JhdGlvbnM6IFJhbmdlW107XG4gICAgYXR0cmlidXRlczogU2xhdGVFbGVtZW50QXR0cmlidXRlcztcbiAgICBkZWNvcmF0ZTogKGVudHJ5OiBOb2RlRW50cnkpID0+IFJhbmdlW107XG4gICAgcmVhZG9ubHk6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVUZXh0Q29udGV4dDxUIGV4dGVuZHMgVGV4dCA9IFRleHQ+IHtcbiAgICB0ZXh0OiBUO1xuICAgIGRlY29yYXRpb25zOiBSYW5nZVtdO1xuICAgIGlzTGFzdDogYm9vbGVhbjtcbiAgICBwYXJlbnQ6IEVsZW1lbnQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVMZWFmQ29udGV4dCB7XG4gICAgbGVhZjogVGV4dDtcbiAgICB0ZXh0OiBUZXh0O1xuICAgIHBhcmVudDogRWxlbWVudDtcbiAgICBpc0xhc3Q6IGJvb2xlYW47XG4gICAgaW5kZXg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTbGF0ZUVsZW1lbnRBdHRyaWJ1dGVzIHtcbiAgICAnZGF0YS1zbGF0ZS1ub2RlJzogJ2VsZW1lbnQnO1xuICAgICdkYXRhLXNsYXRlLXZvaWQnPzogYm9vbGVhbjtcbiAgICAnZGF0YS1zbGF0ZS1pbmxpbmUnPzogYm9vbGVhbjtcbiAgICBjb250ZW50ZWRpdGFibGU/OiBib29sZWFuO1xuICAgICdkYXRhLXNsYXRlLWtleSc/OiBzdHJpbmc7XG4gICAgZGlyPzogJ3J0bCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVTdHJpbmdDb250ZXh0IHtcbiAgICB0ZXh0OiBzdHJpbmc7XG4gICAgZWxlbWVudFN0cmluZ0xlbmd0aDogbnVtYmVyO1xuICAgIHR5cGU6ICdzdHJpbmcnIHwgJ2xpbmVCcmVha0VtcHR5U3RyaW5nJztcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy92aWV3L2NvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vZGVFbnRyeSwgUmFuZ2UsIEVsZW1lbnQsIEFuY2VzdG9yLCBUZXh0LCBQYXRoIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgU2xhdGVTdHJpbmdUZW1wbGF0ZSB9IGZyb20gJy4uL2NvbXBvbmVudHMvc3RyaW5nL3RlbXBsYXRlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBbmd1bGFyRWRpdG9yIH0gZnJvbSAnLi4vcGx1Z2lucy9hbmd1bGFyLWVkaXRvcic7XG5pbXBvcnQgeyBDb21wb25lbnRUeXBlLCBWaWV3VHlwZSB9IGZyb20gJy4uL3R5cGVzL3ZpZXcnO1xuaW1wb3J0IHsgQmFzZUVsZW1lbnRDb21wb25lbnQsIEJhc2VMZWFmQ29tcG9uZW50LCBCYXNlVGV4dENvbXBvbmVudCB9IGZyb20gJy4vYmFzZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVWaWV3Q29udGV4dDxUIGV4dGVuZHMgQW5ndWxhckVkaXRvciA9IEFuZ3VsYXJFZGl0b3I+IHtcbiAgICBlZGl0b3I6IFQ7XG4gICAgdGVtcGxhdGVDb21wb25lbnQ6IFNsYXRlU3RyaW5nVGVtcGxhdGU7XG4gICAgZGVmYXVsdEVsZW1lbnQ6IENvbXBvbmVudFR5cGU8QmFzZUVsZW1lbnRDb21wb25lbnQ+O1xuICAgIGRlZmF1bHRUZXh0OiBDb21wb25lbnRUeXBlPEJhc2VUZXh0Q29tcG9uZW50PjtcbiAgICBkZWZhdWx0Vm9pZFRleHQ6IENvbXBvbmVudFR5cGU8QmFzZVRleHRDb21wb25lbnQ+O1xuICAgIGRlZmF1bHRMZWFmOiBDb21wb25lbnRUeXBlPEJhc2VMZWFmQ29tcG9uZW50PjtcbiAgICB0cmFja0J5OiAoZWxlbWVudDogRWxlbWVudCkgPT4gYW55O1xuICAgIHJlbmRlckVsZW1lbnQ/OiAoZWxlbWVudDogRWxlbWVudCkgPT4gVmlld1R5cGU7XG4gICAgcmVuZGVyTGVhZj86ICh0ZXh0OiBUZXh0KSA9PiBWaWV3VHlwZTtcbiAgICByZW5kZXJUZXh0PzogKHRleHQ6IFRleHQpID0+IFZpZXdUeXBlO1xuICAgIGlzU3RyaWN0RGVjb3JhdGU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVDaGlsZHJlbkNvbnRleHQge1xuICAgIHBhcmVudDogQW5jZXN0b3I7XG4gICAgc2VsZWN0aW9uOiBSYW5nZTtcbiAgICBkZWNvcmF0aW9uczogUmFuZ2VbXTtcbiAgICBkZWNvcmF0ZTogKGVudHJ5OiBOb2RlRW50cnkpID0+IFJhbmdlW107XG4gICAgcmVhZG9ubHk6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVFbGVtZW50Q29udGV4dDxUIGV4dGVuZHMgRWxlbWVudCA9IEVsZW1lbnQ+IHtcbiAgICBlbGVtZW50OiBUO1xuICAgIHNlbGVjdGlvbjogUmFuZ2UgfCBudWxsO1xuICAgIGRlY29yYXRpb25zOiBSYW5nZVtdO1xuICAgIGF0dHJpYnV0ZXM6IFNsYXRlRWxlbWVudEF0dHJpYnV0ZXM7XG4gICAgY29udGVudEVkaXRhYmxlPzogYm9vbGVhbjtcbiAgICBkZWNvcmF0ZTogKGVudHJ5OiBOb2RlRW50cnkpID0+IFJhbmdlW107XG4gICAgcmVhZG9ubHk6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVUZXh0Q29udGV4dDxUIGV4dGVuZHMgVGV4dCA9IFRleHQ+IHtcbiAgICB0ZXh0OiBUO1xuICAgIGRlY29yYXRpb25zOiBSYW5nZVtdO1xuICAgIGlzTGFzdDogYm9vbGVhbjtcbiAgICBwYXJlbnQ6IEVsZW1lbnQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVMZWFmQ29udGV4dCB7XG4gICAgbGVhZjogVGV4dDtcbiAgICB0ZXh0OiBUZXh0O1xuICAgIHBhcmVudDogRWxlbWVudDtcbiAgICBpc0xhc3Q6IGJvb2xlYW47XG4gICAgaW5kZXg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTbGF0ZUVsZW1lbnRBdHRyaWJ1dGVzIHtcbiAgICAnZGF0YS1zbGF0ZS1ub2RlJzogJ2VsZW1lbnQnO1xuICAgICdkYXRhLXNsYXRlLXZvaWQnPzogYm9vbGVhbjtcbiAgICAnZGF0YS1zbGF0ZS1pbmxpbmUnPzogYm9vbGVhbjtcbiAgICAnZGF0YS1zbGF0ZS1rZXknPzogc3RyaW5nO1xuICAgIGRpcj86ICdydGwnO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNsYXRlU3RyaW5nQ29udGV4dCB7XG4gICAgdGV4dDogc3RyaW5nO1xuICAgIGVsZW1lbnRTdHJpbmdMZW5ndGg6IG51bWJlcjtcbiAgICB0eXBlOiAnc3RyaW5nJyB8ICdsaW5lQnJlYWtFbXB0eVN0cmluZyc7XG59XG4iXX0=
@@ -2,9 +2,10 @@ import { Text } from 'slate';
2
2
  import { IterableDiffers } from '@angular/core';
3
3
  import { createEmbeddedViewOrComponent, getRootNodes, mount, mountOnItemChange, updateContext } from './utils';
4
4
  export class LeavesRender {
5
- constructor(viewContext, viewContainerRef, getOutletElement) {
5
+ constructor(viewContext, viewContainerRef, getOutletParent, getOutletElement) {
6
6
  this.viewContext = viewContext;
7
7
  this.viewContainerRef = viewContainerRef;
8
+ this.getOutletParent = getOutletParent;
8
9
  this.getOutletElement = getOutletElement;
9
10
  this.views = [];
10
11
  this.contexts = [];
@@ -22,16 +23,17 @@ export class LeavesRender {
22
23
  this.contexts.push(context);
23
24
  this.viewTypes.push(viewType);
24
25
  });
25
- mount(this.views, null, this.getOutletElement());
26
+ mount(this.views, null, this.getOutletParent(), this.getOutletElement());
26
27
  const newDiffers = this.viewContainerRef.injector.get(IterableDiffers);
27
28
  this.differ = newDiffers.find(this.leaves).create(trackBy(this.viewContext));
28
29
  this.differ.diff(this.leaves);
29
30
  }
30
31
  update(context) {
31
32
  const { leaves, contexts } = this.getLeaves(context);
32
- const outletElement = this.getOutletElement();
33
+ const outletParent = this.getOutletParent();
33
34
  const diffResult = this.differ.diff(leaves);
34
35
  if (diffResult) {
36
+ let firstRootNode = getRootNodes(this.views[0])[0];
35
37
  const newContexts = [];
36
38
  const newViewTypes = [];
37
39
  const newViews = [];
@@ -44,7 +46,7 @@ export class LeavesRender {
44
46
  view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);
45
47
  newContexts.push(context);
46
48
  newViews.push(view);
47
- mountOnItemChange(record.currentIndex, record.item, newViews, null, outletElement, this.viewContext);
49
+ mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);
48
50
  }
49
51
  else {
50
52
  const previousView = this.views[record.previousIndex];
@@ -69,7 +71,7 @@ export class LeavesRender {
69
71
  view.destroy();
70
72
  });
71
73
  diffResult.forEachMovedItem(record => {
72
- mountOnItemChange(record.currentIndex, record.item, newViews, null, outletElement, this.viewContext);
74
+ mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);
73
75
  });
74
76
  this.viewTypes = newViewTypes;
75
77
  this.views = newViews;
@@ -102,4 +104,4 @@ export function trackBy(viewContext) {
102
104
  return index;
103
105
  };
104
106
  }
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaves-render.js","sourceRoot":"","sources":["../../../../packages/src/view/render/leaves-render.ts"],"names":[],"mappings":"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","sourcesContent":["import { Text } from 'slate';\nimport { ComponentRef, EmbeddedViewRef, IterableDiffer, IterableDiffers, ViewContainerRef } from '@angular/core';\nimport { ViewType } from '../../types/view';\nimport { SlateLeafContext, SlateTextContext, SlateViewContext } from '../context';\nimport { createEmbeddedViewOrComponent, getRootNodes, mount, mountOnItemChange, updateContext } from './utils';\n\nexport class LeavesRender {\n    private leaves: Text[];\n    private views: (EmbeddedViewRef<any> | ComponentRef<any>)[] = [];\n    private contexts: SlateLeafContext[] = [];\n    private viewTypes: ViewType[] = [];\n    private differ: IterableDiffer<any>;\n\n    constructor(\n        private viewContext: SlateViewContext,\n        private viewContainerRef: ViewContainerRef,\n        private getOutletElement: () => HTMLElement\n    ) {}\n\n    public initialize(context: SlateTextContext) {\n        const { leaves, contexts } = this.getLeaves(context);\n        this.leaves = leaves;\n        this.contexts = contexts;\n        this.leaves.forEach((leaf, index) => {\n            const context = getContext(index, this.contexts);\n            const viewType = getViewType(context, this.viewContext);\n            const view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n            this.views.push(view);\n            this.contexts.push(context);\n            this.viewTypes.push(viewType);\n        });\n        mount(this.views, null, this.getOutletElement());\n        const newDiffers = this.viewContainerRef.injector.get(IterableDiffers);\n        this.differ = newDiffers.find(this.leaves).create(trackBy(this.viewContext));\n        this.differ.diff(this.leaves);\n    }\n\n    public update(context: SlateTextContext) {\n        const { leaves, contexts } = this.getLeaves(context);\n        const outletElement = this.getOutletElement();\n        const diffResult = this.differ.diff(leaves);\n        if (diffResult) {\n            const newContexts = [];\n            const newViewTypes = [];\n            const newViews = [];\n            diffResult.forEachItem(record => {\n                let context = getContext(record.currentIndex, contexts);\n                const viewType = getViewType(context, this.viewContext);\n                newViewTypes.push(viewType);\n                let view: EmbeddedViewRef<any> | ComponentRef<any>;\n                if (record.previousIndex === null) {\n                    view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                    newContexts.push(context);\n                    newViews.push(view);\n                    mountOnItemChange(record.currentIndex, record.item, newViews, null, outletElement, this.viewContext);\n                } else {\n                    const previousView = this.views[record.previousIndex];\n                    const previousViewType = this.viewTypes[record.previousIndex];\n                    if (previousViewType !== viewType) {\n                        view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                        const firstRootNode = getRootNodes(previousView, null)[0];\n                        const newRootNodes = getRootNodes(view, null);\n                        firstRootNode.replaceWith(...newRootNodes);\n                        previousView.destroy();\n                    } else {\n                        view = previousView;\n                        updateContext(previousView, context, this.viewContext);\n                    }\n                    newContexts.push(context);\n                    newViews.push(view);\n                }\n            });\n            diffResult.forEachRemovedItem(record => {\n                const view = this.views[record.previousIndex];\n                view.destroy();\n            });\n            diffResult.forEachMovedItem(record => {\n                mountOnItemChange(record.currentIndex, record.item, newViews, null, outletElement, this.viewContext);\n            });\n            this.viewTypes = newViewTypes;\n            this.views = newViews;\n            this.contexts = newContexts;\n            this.leaves = leaves;\n        }\n    }\n\n    private getLeaves(context: SlateTextContext) {\n        const leaves = Text.decorations(context.text, context.decorations);\n        const contexts = leaves.map((leaf, index) => {\n            return {\n                leaf,\n                text: context.text,\n                parent: context.parent,\n                index,\n                isLast: context.isLast && index === leaves.length - 1\n            };\n        });\n        return { leaves, contexts };\n    }\n}\n\nexport function getContext(index: number, leafContexts: SlateLeafContext[]): SlateLeafContext {\n    return leafContexts[index];\n}\n\nexport function getViewType(leafContext: SlateLeafContext, viewContext: SlateViewContext) {\n    return (viewContext.renderLeaf && viewContext.renderLeaf(leafContext.leaf)) || viewContext.defaultLeaf;\n}\n\nexport function trackBy(viewContext: SlateViewContext) {\n    return (index, node) => {\n        return index;\n    };\n}\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaves-render.js","sourceRoot":"","sources":["../../../../packages/src/view/render/leaves-render.ts"],"names":[],"mappings":"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","sourcesContent":["import { Text } from 'slate';\nimport { ComponentRef, EmbeddedViewRef, IterableDiffer, IterableDiffers, ViewContainerRef } from '@angular/core';\nimport { ViewType } from '../../types/view';\nimport { SlateLeafContext, SlateTextContext, SlateViewContext } from '../context';\nimport { createEmbeddedViewOrComponent, getRootNodes, mount, mountOnItemChange, updateContext } from './utils';\n\nexport class LeavesRender {\n    private leaves: Text[];\n    private views: (EmbeddedViewRef<any> | ComponentRef<any>)[] = [];\n    private contexts: SlateLeafContext[] = [];\n    private viewTypes: ViewType[] = [];\n    private differ: IterableDiffer<any>;\n\n    constructor(\n        private viewContext: SlateViewContext,\n        private viewContainerRef: ViewContainerRef,\n        private getOutletParent: () => HTMLElement,\n        private getOutletElement: () => HTMLElement\n    ) {}\n\n    public initialize(context: SlateTextContext) {\n        const { leaves, contexts } = this.getLeaves(context);\n        this.leaves = leaves;\n        this.contexts = contexts;\n        this.leaves.forEach((leaf, index) => {\n            const context = getContext(index, this.contexts);\n            const viewType = getViewType(context, this.viewContext);\n            const view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n            this.views.push(view);\n            this.contexts.push(context);\n            this.viewTypes.push(viewType);\n        });\n        mount(this.views, null, this.getOutletParent(), this.getOutletElement());\n        const newDiffers = this.viewContainerRef.injector.get(IterableDiffers);\n        this.differ = newDiffers.find(this.leaves).create(trackBy(this.viewContext));\n        this.differ.diff(this.leaves);\n    }\n\n    public update(context: SlateTextContext) {\n        const { leaves, contexts } = this.getLeaves(context);\n        const outletParent = this.getOutletParent();\n        const diffResult = this.differ.diff(leaves);\n        if (diffResult) {\n            let firstRootNode = getRootNodes(this.views[0])[0];\n            const newContexts = [];\n            const newViewTypes = [];\n            const newViews = [];\n            diffResult.forEachItem(record => {\n                let context = getContext(record.currentIndex, contexts);\n                const viewType = getViewType(context, this.viewContext);\n                newViewTypes.push(viewType);\n                let view: EmbeddedViewRef<any> | ComponentRef<any>;\n                if (record.previousIndex === null) {\n                    view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                    newContexts.push(context);\n                    newViews.push(view);\n                    mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);\n                } else {\n                    const previousView = this.views[record.previousIndex];\n                    const previousViewType = this.viewTypes[record.previousIndex];\n                    if (previousViewType !== viewType) {\n                        view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                        const firstRootNode = getRootNodes(previousView, null)[0];\n                        const newRootNodes = getRootNodes(view, null);\n                        firstRootNode.replaceWith(...newRootNodes);\n                        previousView.destroy();\n                    } else {\n                        view = previousView;\n                        updateContext(previousView, context, this.viewContext);\n                    }\n                    newContexts.push(context);\n                    newViews.push(view);\n                }\n            });\n            diffResult.forEachRemovedItem(record => {\n                const view = this.views[record.previousIndex];\n                view.destroy();\n            });\n            diffResult.forEachMovedItem(record => {\n                mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);\n            });\n            this.viewTypes = newViewTypes;\n            this.views = newViews;\n            this.contexts = newContexts;\n            this.leaves = leaves;\n        }\n    }\n\n    private getLeaves(context: SlateTextContext) {\n        const leaves = Text.decorations(context.text, context.decorations);\n        const contexts = leaves.map((leaf, index) => {\n            return {\n                leaf,\n                text: context.text,\n                parent: context.parent,\n                index,\n                isLast: context.isLast && index === leaves.length - 1\n            };\n        });\n        return { leaves, contexts };\n    }\n}\n\nexport function getContext(index: number, leafContexts: SlateLeafContext[]): SlateLeafContext {\n    return leafContexts[index];\n}\n\nexport function getViewType(leafContext: SlateLeafContext, viewContext: SlateViewContext) {\n    return (viewContext.renderLeaf && viewContext.renderLeaf(leafContext.leaf)) || viewContext.defaultLeaf;\n}\n\nexport function trackBy(viewContext: SlateViewContext) {\n    return (index, node) => {\n        return index;\n    };\n}\n"]}