slate-angular 1.9.3 → 13.0.2

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 (63) hide show
  1. package/components/descendant/descendant.component.d.ts +2 -3
  2. package/{esm2015/components/block-card/block-card.component.js → esm2020/components/block-card/block-card.component.mjs} +5 -8
  3. package/{esm2015/components/children/children.component.js → esm2020/components/children/children.component.mjs} +3 -3
  4. package/esm2020/components/descendant/descendant.component.mjs +183 -0
  5. package/esm2020/components/editable/editable.component.mjs +1057 -0
  6. package/{esm2015/components/element/default-element.component.js → esm2020/components/element/default-element.component.mjs} +3 -3
  7. package/{esm2015/components/element/default-element.component.token.js → esm2020/components/element/default-element.component.token.mjs} +0 -0
  8. package/{esm2015/components/element/element.component.js → esm2020/components/element/element.component.mjs} +3 -3
  9. package/{esm2015/components/leaf/default-leaf.component.js → esm2020/components/leaf/default-leaf.component.mjs} +3 -3
  10. package/{esm2015/components/leaf/leaf.component.js → esm2020/components/leaf/leaf.component.mjs} +3 -3
  11. package/{esm2015/components/leaves/leaves.component.js → esm2020/components/leaves/leaves.component.mjs} +3 -3
  12. package/esm2020/components/string/string.component.mjs +73 -0
  13. package/esm2020/components/string/template.component.mjs +26 -0
  14. package/{esm2015/components/text/default-text.component.js → esm2020/components/text/default-text.component.mjs} +3 -3
  15. package/{esm2015/components/text/void-text.component.js → esm2020/components/text/void-text.component.mjs} +3 -3
  16. package/{esm2015/custom-event/BeforeInputEventPlugin.js → esm2020/custom-event/BeforeInputEventPlugin.mjs} +0 -0
  17. package/{esm2015/custom-event/DOMTopLevelEventTypes.js → esm2020/custom-event/DOMTopLevelEventTypes.mjs} +0 -0
  18. package/{esm2015/custom-event/FallbackCompositionState.js → esm2020/custom-event/FallbackCompositionState.mjs} +0 -0
  19. package/{esm2015/custom-event/before-input-polyfill.js → esm2020/custom-event/before-input-polyfill.mjs} +0 -0
  20. package/{esm2015/module.js → esm2020/module.mjs} +5 -6
  21. package/esm2020/plugins/angular-editor.mjs +565 -0
  22. package/{esm2015/plugins/with-angular.js → esm2020/plugins/with-angular.mjs} +0 -0
  23. package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
  24. package/{esm2015/slate-angular.js → esm2020/slate-angular.mjs} +0 -0
  25. package/{esm2015/types/error.js → esm2020/types/error.mjs} +0 -0
  26. package/{esm2015/types/feature.js → esm2020/types/feature.mjs} +0 -0
  27. package/{esm2015/types/index.js → esm2020/types/index.mjs} +1 -1
  28. package/{esm2015/types/view.js → esm2020/types/view.mjs} +0 -0
  29. package/esm2020/utils/block-card.mjs +25 -0
  30. package/{esm2015/utils/dom.js → esm2020/utils/dom.mjs} +0 -0
  31. package/{esm2015/utils/environment.js → esm2020/utils/environment.mjs} +0 -0
  32. package/{esm2015/utils/global-normalize.js → esm2020/utils/global-normalize.mjs} +0 -0
  33. package/{esm2015/utils/hotkeys.js → esm2020/utils/hotkeys.mjs} +0 -0
  34. package/{esm2015/utils/index.js → esm2020/utils/index.mjs} +0 -0
  35. package/{esm2015/utils/key.js → esm2020/utils/key.mjs} +0 -0
  36. package/{esm2015/utils/lines.js → esm2020/utils/lines.mjs} +0 -0
  37. package/esm2020/utils/range-list.mjs +29 -0
  38. package/{esm2015/utils/view.js → esm2020/utils/view.mjs} +0 -0
  39. package/{esm2015/utils/weak-maps.js → esm2020/utils/weak-maps.mjs} +0 -0
  40. package/{esm2015/view/base.js → esm2020/view/base.mjs} +12 -12
  41. package/{esm2015/view/before-context-change.js → esm2020/view/before-context-change.mjs} +0 -0
  42. package/esm2020/view/container-item.mjs +102 -0
  43. package/{esm2015/view/container.js → esm2020/view/container.mjs} +3 -3
  44. package/{esm2015/view/context.js → esm2020/view/context.mjs} +0 -0
  45. package/fesm2015/{slate-angular.js → slate-angular.mjs} +83 -100
  46. package/fesm2015/slate-angular.mjs.map +1 -0
  47. package/fesm2020/slate-angular.mjs +3643 -0
  48. package/fesm2020/slate-angular.mjs.map +1 -0
  49. package/package.json +30 -6
  50. package/styles/index.scss +1 -1
  51. package/types/index.d.ts +1 -0
  52. package/view/container-item.d.ts +2 -3
  53. package/bundles/slate-angular.umd.js +0 -4298
  54. package/bundles/slate-angular.umd.js.map +0 -1
  55. package/esm2015/components/descendant/descendant.component.js +0 -179
  56. package/esm2015/components/editable/editable.component.js +0 -1063
  57. package/esm2015/components/string/string.component.js +0 -73
  58. package/esm2015/components/string/template.component.js +0 -30
  59. package/esm2015/plugins/angular-editor.js +0 -565
  60. package/esm2015/utils/block-card.js +0 -25
  61. package/esm2015/utils/range-list.js +0 -30
  62. package/esm2015/view/container-item.js +0 -105
  63. package/fesm2015/slate-angular.js.map +0 -1
@@ -1,25 +0,0 @@
1
- export const FAKE_LEFT_BLOCK_CARD_OFFSET = -1;
2
- export const FAKE_RIGHT_BLOCK_CARD_OFFSET = -2;
3
- export function hasBlockCardWithNode(node) {
4
- return node && (node.parentElement.hasAttribute('card-target') || (node instanceof HTMLElement && node.hasAttribute('card-target')));
5
- }
6
- export function hasBlockCard(selection) {
7
- return hasBlockCardWithNode(selection === null || selection === void 0 ? void 0 : selection.anchorNode) || hasBlockCardWithNode(selection === null || selection === void 0 ? void 0 : selection.focusNode);
8
- }
9
- export function getCardTargetAttribute(node) {
10
- return node.parentElement.attributes['card-target'] || (node instanceof HTMLElement && node.attributes['card-target']);
11
- }
12
- export function isCardLeft(node) {
13
- const cardTarget = getCardTargetAttribute(node);
14
- return cardTarget && cardTarget.nodeValue === 'card-left';
15
- }
16
- export function isCardLeftByTargetAttr(targetAttr) {
17
- return targetAttr && targetAttr.nodeValue === 'card-left';
18
- }
19
- export function isCardRightByTargetAttr(targetAttr) {
20
- return targetAttr && targetAttr.nodeValue === 'card-right';
21
- }
22
- export function isCardCenterByTargetAttr(targetAttr) {
23
- return targetAttr && targetAttr.nodeValue === 'card-center';
24
- }
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2stY2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy91dGlscy9ibG9jay1jYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHLENBQUMsQ0FBQyxDQUFDO0FBRTlDLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLENBQUMsQ0FBQyxDQUFDO0FBRS9DLE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxJQUFhO0lBQzlDLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLFlBQVksV0FBVyxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3pJLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLFNBQXVCO0lBQ2hELE9BQU8sb0JBQW9CLENBQUMsU0FBUyxhQUFULFNBQVMsdUJBQVQsU0FBUyxDQUFFLFVBQVUsQ0FBQyxJQUFJLG9CQUFvQixDQUFDLFNBQVMsYUFBVCxTQUFTLHVCQUFULFNBQVMsQ0FBRSxTQUFTLENBQUMsQ0FBQztBQUNyRyxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUFDLElBQWE7SUFDaEQsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksWUFBWSxXQUFXLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO0FBQzNILENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLElBQWE7SUFDcEMsTUFBTSxVQUFVLEdBQUcsc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEQsT0FBTyxVQUFVLElBQUksVUFBVSxDQUFDLFNBQVMsS0FBSyxXQUFXLENBQUM7QUFDOUQsQ0FBQztBQUVELE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxVQUFlO0lBQ2xELE9BQU8sVUFBVSxJQUFJLFVBQVUsQ0FBQyxTQUFTLEtBQUssV0FBVyxDQUFDO0FBQzlELENBQUM7QUFFRCxNQUFNLFVBQVUsdUJBQXVCLENBQUMsVUFBZTtJQUNuRCxPQUFPLFVBQVUsSUFBSSxVQUFVLENBQUMsU0FBUyxLQUFLLFlBQVksQ0FBQztBQUMvRCxDQUFDO0FBRUQsTUFBTSxVQUFVLHdCQUF3QixDQUFDLFVBQWU7SUFDcEQsT0FBTyxVQUFVLElBQUksVUFBVSxDQUFDLFNBQVMsS0FBSyxhQUFhLENBQUM7QUFDaEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPTU5vZGUsIERPTVNlbGVjdGlvbiB9IGZyb20gXCIuL2RvbVwiO1xuXG5leHBvcnQgY29uc3QgRkFLRV9MRUZUX0JMT0NLX0NBUkRfT0ZGU0VUID0gLTE7XG5cbmV4cG9ydCBjb25zdCBGQUtFX1JJR0hUX0JMT0NLX0NBUkRfT0ZGU0VUID0gLTI7XG5cbmV4cG9ydCBmdW5jdGlvbiBoYXNCbG9ja0NhcmRXaXRoTm9kZShub2RlOiBET01Ob2RlKSB7XG4gICAgcmV0dXJuIG5vZGUgJiYgKG5vZGUucGFyZW50RWxlbWVudC5oYXNBdHRyaWJ1dGUoJ2NhcmQtdGFyZ2V0JykgfHwgKG5vZGUgaW5zdGFuY2VvZiBIVE1MRWxlbWVudCAmJiBub2RlLmhhc0F0dHJpYnV0ZSgnY2FyZC10YXJnZXQnKSkpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGFzQmxvY2tDYXJkKHNlbGVjdGlvbjogRE9NU2VsZWN0aW9uKSB7XG4gICAgcmV0dXJuIGhhc0Jsb2NrQ2FyZFdpdGhOb2RlKHNlbGVjdGlvbj8uYW5jaG9yTm9kZSkgfHwgaGFzQmxvY2tDYXJkV2l0aE5vZGUoc2VsZWN0aW9uPy5mb2N1c05vZGUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q2FyZFRhcmdldEF0dHJpYnV0ZShub2RlOiBET01Ob2RlKSB7XG4gICAgcmV0dXJuIG5vZGUucGFyZW50RWxlbWVudC5hdHRyaWJ1dGVzWydjYXJkLXRhcmdldCddIHx8IChub2RlIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQgJiYgbm9kZS5hdHRyaWJ1dGVzWydjYXJkLXRhcmdldCddKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FyZExlZnQobm9kZTogRE9NTm9kZSkge1xuICAgIGNvbnN0IGNhcmRUYXJnZXQgPSBnZXRDYXJkVGFyZ2V0QXR0cmlidXRlKG5vZGUpO1xuICAgIHJldHVybiBjYXJkVGFyZ2V0ICYmIGNhcmRUYXJnZXQubm9kZVZhbHVlID09PSAnY2FyZC1sZWZ0Jztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FyZExlZnRCeVRhcmdldEF0dHIodGFyZ2V0QXR0cjogYW55KSB7XG4gICAgcmV0dXJuIHRhcmdldEF0dHIgJiYgdGFyZ2V0QXR0ci5ub2RlVmFsdWUgPT09ICdjYXJkLWxlZnQnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNDYXJkUmlnaHRCeVRhcmdldEF0dHIodGFyZ2V0QXR0cjogYW55KSB7XG4gICAgcmV0dXJuIHRhcmdldEF0dHIgJiYgdGFyZ2V0QXR0ci5ub2RlVmFsdWUgPT09ICdjYXJkLXJpZ2h0Jztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FyZENlbnRlckJ5VGFyZ2V0QXR0cih0YXJnZXRBdHRyOiBhbnkpIHtcbiAgICByZXR1cm4gdGFyZ2V0QXR0ciAmJiB0YXJnZXRBdHRyLm5vZGVWYWx1ZSA9PT0gJ2NhcmQtY2VudGVyJztcbn1cbiJdfQ==
@@ -1,30 +0,0 @@
1
- import { __rest } from "tslib";
2
- import { Range } from 'slate';
3
- import { PLACEHOLDER_SYMBOL } from './weak-maps';
4
- export const shallowCompare = (obj1, obj2) => Object.keys(obj1).length === Object.keys(obj2).length &&
5
- Object.keys(obj1).every(key => obj2.hasOwnProperty(key) && obj1[key] === obj2[key]);
6
- /**
7
- * Check if a list of decorator ranges are equal to another.
8
- *
9
- * PERF: this requires the two lists to also have the ranges inside them in the
10
- * same order, but this is an okay constraint for us since decorations are
11
- * kept in order, and the odd case where they aren't is okay to re-render for.
12
- */
13
- export const isDecoratorRangeListEqual = (list, another) => {
14
- if (list.length !== another.length) {
15
- return false;
16
- }
17
- for (let i = 0; i < list.length; i++) {
18
- const range = list[i];
19
- const other = another[i];
20
- const { anchor: rangeAnchor, focus: rangeFocus } = range, rangeOwnProps = __rest(range, ["anchor", "focus"]);
21
- const { anchor: otherAnchor, focus: otherFocus } = other, otherOwnProps = __rest(other, ["anchor", "focus"]);
22
- if (!Range.equals(range, other) ||
23
- range[PLACEHOLDER_SYMBOL] !== other[PLACEHOLDER_SYMBOL] ||
24
- !shallowCompare(rangeOwnProps, otherOwnProps)) {
25
- return false;
26
- }
27
- }
28
- return true;
29
- };
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtbGlzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy91dGlscy9yYW5nZS1saXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sT0FBTyxDQUFBO0FBQzdCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUVoRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsQ0FBQyxJQUFRLEVBQUUsSUFBUSxFQUFFLEVBQUUsQ0FDakQsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNO0lBQ3JELE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUNuQixHQUFHLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FDN0QsQ0FBQTtBQUVMOzs7Ozs7R0FNRztBQUVILE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLENBQ3JDLElBQWEsRUFDYixPQUFnQixFQUNULEVBQUU7SUFDVCxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssT0FBTyxDQUFDLE1BQU0sRUFBRTtRQUNoQyxPQUFPLEtBQUssQ0FBQTtLQUNmO0lBRUQsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDbEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQ3JCLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUV4QixNQUFNLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsVUFBVSxLQUF1QixLQUFLLEVBQXZCLGFBQWEsVUFBSyxLQUFLLEVBQXBFLG1CQUE0RCxDQUFRLENBQUE7UUFDMUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLFVBQVUsS0FBdUIsS0FBSyxFQUF2QixhQUFhLFVBQUssS0FBSyxFQUFwRSxtQkFBNEQsQ0FBUSxDQUFBO1FBRTFFLElBQ0ksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUM7WUFDM0IsS0FBSyxDQUFDLGtCQUFrQixDQUFDLEtBQUssS0FBSyxDQUFDLGtCQUFrQixDQUFDO1lBQ3ZELENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxhQUFhLENBQUMsRUFDL0M7WUFDRSxPQUFPLEtBQUssQ0FBQTtTQUNmO0tBQ0o7SUFFRCxPQUFPLElBQUksQ0FBQTtBQUNmLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJhbmdlIH0gZnJvbSAnc2xhdGUnXG5pbXBvcnQgeyBQTEFDRUhPTERFUl9TWU1CT0wgfSBmcm9tICcuL3dlYWstbWFwcydcblxuZXhwb3J0IGNvbnN0IHNoYWxsb3dDb21wYXJlID0gKG9iajE6IHt9LCBvYmoyOiB7fSkgPT5cbiAgICBPYmplY3Qua2V5cyhvYmoxKS5sZW5ndGggPT09IE9iamVjdC5rZXlzKG9iajIpLmxlbmd0aCAmJlxuICAgIE9iamVjdC5rZXlzKG9iajEpLmV2ZXJ5KFxuICAgICAgICBrZXkgPT4gb2JqMi5oYXNPd25Qcm9wZXJ0eShrZXkpICYmIG9iajFba2V5XSA9PT0gb2JqMltrZXldXG4gICAgKVxuXG4vKipcbiAqIENoZWNrIGlmIGEgbGlzdCBvZiBkZWNvcmF0b3IgcmFuZ2VzIGFyZSBlcXVhbCB0byBhbm90aGVyLlxuICpcbiAqIFBFUkY6IHRoaXMgcmVxdWlyZXMgdGhlIHR3byBsaXN0cyB0byBhbHNvIGhhdmUgdGhlIHJhbmdlcyBpbnNpZGUgdGhlbSBpbiB0aGVcbiAqIHNhbWUgb3JkZXIsIGJ1dCB0aGlzIGlzIGFuIG9rYXkgY29uc3RyYWludCBmb3IgdXMgc2luY2UgZGVjb3JhdGlvbnMgYXJlXG4gKiBrZXB0IGluIG9yZGVyLCBhbmQgdGhlIG9kZCBjYXNlIHdoZXJlIHRoZXkgYXJlbid0IGlzIG9rYXkgdG8gcmUtcmVuZGVyIGZvci5cbiAqL1xuXG5leHBvcnQgY29uc3QgaXNEZWNvcmF0b3JSYW5nZUxpc3RFcXVhbCA9IChcbiAgICBsaXN0OiBSYW5nZVtdLFxuICAgIGFub3RoZXI6IFJhbmdlW11cbik6IGJvb2xlYW4gPT4ge1xuICAgIGlmIChsaXN0Lmxlbmd0aCAhPT0gYW5vdGhlci5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlXG4gICAgfVxuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBsaXN0Lmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIGNvbnN0IHJhbmdlID0gbGlzdFtpXVxuICAgICAgICBjb25zdCBvdGhlciA9IGFub3RoZXJbaV1cblxuICAgICAgICBjb25zdCB7IGFuY2hvcjogcmFuZ2VBbmNob3IsIGZvY3VzOiByYW5nZUZvY3VzLCAuLi5yYW5nZU93blByb3BzIH0gPSByYW5nZVxuICAgICAgICBjb25zdCB7IGFuY2hvcjogb3RoZXJBbmNob3IsIGZvY3VzOiBvdGhlckZvY3VzLCAuLi5vdGhlck93blByb3BzIH0gPSBvdGhlclxuXG4gICAgICAgIGlmIChcbiAgICAgICAgICAgICFSYW5nZS5lcXVhbHMocmFuZ2UsIG90aGVyKSB8fFxuICAgICAgICAgICAgcmFuZ2VbUExBQ0VIT0xERVJfU1lNQk9MXSAhPT0gb3RoZXJbUExBQ0VIT0xERVJfU1lNQk9MXSB8fFxuICAgICAgICAgICAgIXNoYWxsb3dDb21wYXJlKHJhbmdlT3duUHJvcHMsIG90aGVyT3duUHJvcHMpXG4gICAgICAgICkge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlXG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZVxufVxuIl19
@@ -1,105 +0,0 @@
1
- import { Directive, Input } from "@angular/core";
2
- import { isComponentType, isDOMElement, isTemplateRef } from "../utils";
3
- import * as i0 from "@angular/core";
4
- /**
5
- * Dynamically create/update components or templates
6
- * Provide rootNodes for the view container
7
- * If the dynamically created component uses onpush mode, then it must call markForCheck when setting the context
8
- */
9
- export class ViewContainerItem {
10
- constructor(viewContainerRef, componentFactoryResolver) {
11
- this.viewContainerRef = viewContainerRef;
12
- this.componentFactoryResolver = componentFactoryResolver;
13
- this.initialized = false;
14
- }
15
- get rootNodes() {
16
- return this.getRootNodes();
17
- }
18
- getRootNodes() {
19
- if (this.embeddedViewRef) {
20
- return this.embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode));
21
- }
22
- if (this.componentRef) {
23
- return [this.componentRef.instance.nativeElement];
24
- }
25
- return [];
26
- }
27
- destroyView() {
28
- if (this.embeddedViewRef) {
29
- this.embeddedViewRef.destroy();
30
- this.embeddedViewRef = null;
31
- }
32
- if (this.componentRef) {
33
- this.componentRef.destroy();
34
- this.componentRef = null;
35
- }
36
- }
37
- createView() {
38
- this.initialized = true;
39
- this.viewType = this.getViewType();
40
- const context = this.getContext();
41
- if (isTemplateRef(this.viewType)) {
42
- this.embeddedViewContext = { context, viewContext: this.viewContext };
43
- const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.viewType, this.embeddedViewContext);
44
- this.embeddedViewRef = embeddedViewRef;
45
- }
46
- if (isComponentType(this.viewType)) {
47
- const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.viewType);
48
- const componentRef = this.viewContainerRef.createComponent(componentFactory);
49
- componentRef.instance.context = context;
50
- componentRef.instance.viewContext = this.viewContext;
51
- this.componentRef = componentRef;
52
- }
53
- }
54
- updateView() {
55
- const viewType = this.getViewType();
56
- const context = this.getContext();
57
- if (this.viewType === viewType) {
58
- if (this.componentRef) {
59
- if (this.memoizedContext(this.componentRef.instance.context, context)) {
60
- return;
61
- }
62
- this.componentRef.instance.context = context;
63
- }
64
- if (this.embeddedViewRef) {
65
- if (this.memoizedContext(this.embeddedViewContext.context, context)) {
66
- return;
67
- }
68
- this.embeddedViewContext.context = context;
69
- }
70
- }
71
- else {
72
- this.viewType = viewType;
73
- const firstRootNode = this.rootNodes[0];
74
- if (isTemplateRef(this.viewType)) {
75
- this.embeddedViewContext = { context, viewContext: this.viewContext };
76
- const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.viewType, this.embeddedViewContext);
77
- firstRootNode.replaceWith(...embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode)));
78
- this.destroyView();
79
- this.embeddedViewRef = embeddedViewRef;
80
- }
81
- if (isComponentType(this.viewType)) {
82
- const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.viewType);
83
- const componentRef = this.viewContainerRef.createComponent(componentFactory);
84
- componentRef.instance.context = context;
85
- componentRef.instance.viewContext = this.viewContext;
86
- firstRootNode.replaceWith(componentRef.instance.nativeElement);
87
- this.destroyView();
88
- this.componentRef = componentRef;
89
- }
90
- }
91
- }
92
- appendBlockCardElement() {
93
- if (this.blockCardComponentRef) {
94
- this.blockCardComponentRef.instance.append();
95
- }
96
- }
97
- }
98
- ViewContainerItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainerItem, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
99
- ViewContainerItem.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.7", type: ViewContainerItem, inputs: { viewContext: "viewContext" }, ngImport: i0 });
100
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainerItem, decorators: [{
101
- type: Directive
102
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { viewContext: [{
103
- type: Input
104
- }] } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container-item.js","sourceRoot":"","sources":["../../../packages/src/view/container-item.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, EmbeddedViewRef, Input, ViewContainerRef } from \"@angular/core\";\nimport { SlateBlockCardComponent } from \"../components/block-card/block-card.component\";\nimport { ViewType } from \"../types/view\";\nimport { isComponentType, isDOMElement, isTemplateRef } from \"../utils\";\nimport { BaseComponent, BaseEmbeddedView } from \"./base\";\nimport { SlateElementContext, SlateLeafContext, SlateStringContext, SlateTextContext, SlateViewContext } from \"./context\";\n\n/**\n * Dynamically create/update components or templates\n * Provide rootNodes for the view container\n * If the dynamically created component uses onpush mode, then it must call markForCheck when setting the context\n */\n@Directive()\nexport abstract class ViewContainerItem<T = SlateElementContext | SlateTextContext | SlateLeafContext | SlateStringContext, K extends BaseComponent<T> = BaseComponent<T>> {\n    initialized = false;\n    embeddedViewRef: EmbeddedViewRef<BaseEmbeddedView<T>>;\n    embeddedViewContext: BaseEmbeddedView<T>;\n    blockCardComponentRef: ComponentRef<SlateBlockCardComponent>;\n    componentRef: ComponentRef<K>;\n    viewType: ViewType;\n\n    @Input() viewContext: SlateViewContext;\n\n    get rootNodes() {\n        return this.getRootNodes();\n    }\n\n    getRootNodes(): HTMLElement[] {\n        if (this.embeddedViewRef) {\n            return this.embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode));\n        }\n        if (this.componentRef) {\n            return [this.componentRef.instance.nativeElement];\n        }\n        return [];\n    }\n\n    constructor(\n        protected viewContainerRef: ViewContainerRef,\n        protected componentFactoryResolver: ComponentFactoryResolver\n    ) { }\n\n    destroyView() {\n        if (this.embeddedViewRef) {\n            this.embeddedViewRef.destroy();\n            this.embeddedViewRef = null;\n        }\n        if (this.componentRef) {\n            this.componentRef.destroy();\n            this.componentRef = null;\n        }\n    }\n\n    abstract getContext(): T;\n\n    abstract getViewType(): ViewType;\n\n    abstract memoizedContext(prev: T, next: T): boolean;\n\n    createView() {\n        this.initialized = true;\n        this.viewType = this.getViewType();\n        const context = this.getContext();\n        if (isTemplateRef(this.viewType)) {\n            this.embeddedViewContext = { context, viewContext: this.viewContext };\n            const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n            this.embeddedViewRef = embeddedViewRef;\n        }\n        if (isComponentType(this.viewType)) {\n            const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n            const componentRef = this.viewContainerRef.createComponent(componentFactory);\n            componentRef.instance.context = context;\n            componentRef.instance.viewContext = this.viewContext;\n            this.componentRef = componentRef;\n        }\n    }\n\n    updateView() {\n        const viewType = this.getViewType();\n        const context = this.getContext();\n        if (this.viewType === viewType) {\n            if (this.componentRef) {\n                if (this.memoizedContext(this.componentRef.instance.context, context)) {\n                    return;\n                }\n                this.componentRef.instance.context = context;\n            }\n            if (this.embeddedViewRef) {\n                if (this.memoizedContext(this.embeddedViewContext.context, context)) {\n                    return;\n                }\n                this.embeddedViewContext.context = context;\n            }\n        } else {\n            this.viewType = viewType;\n            const firstRootNode = this.rootNodes[0];\n            if (isTemplateRef(this.viewType)) {\n                this.embeddedViewContext = { context, viewContext: this.viewContext };\n                const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n                firstRootNode.replaceWith(...embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode)));\n                this.destroyView();\n                this.embeddedViewRef = embeddedViewRef;\n            }\n            if (isComponentType(this.viewType)) {\n                const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n                const componentRef = this.viewContainerRef.createComponent(componentFactory);\n                componentRef.instance.context = context;\n                componentRef.instance.viewContext = this.viewContext;\n                firstRootNode.replaceWith(componentRef.instance.nativeElement);\n                this.destroyView();\n                this.componentRef = componentRef;\n            }\n        }\n    }\n\n    appendBlockCardElement() {\n        if (this.blockCardComponentRef) {\n            this.blockCardComponentRef.instance.append();\n        }\n    }\n}"]}