@worktile/theia 2.2.10 → 2.3.0-next.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.
Files changed (55) hide show
  1. package/bundles/worktile-theia.umd.js +768 -184
  2. package/bundles/worktile-theia.umd.js.map +1 -1
  3. package/constants/default.d.ts +3 -0
  4. package/constants/node-types.d.ts +4 -0
  5. package/custom-types.d.ts +3 -1
  6. package/editor.component.d.ts +3 -1
  7. package/editor.module.d.ts +26 -24
  8. package/esm2015/constants/default.js +2 -1
  9. package/esm2015/constants/node-types.js +6 -1
  10. package/esm2015/custom-types.js +1 -1
  11. package/esm2015/editor.component.js +12 -6
  12. package/esm2015/editor.module.js +6 -3
  13. package/esm2015/interfaces/editor.js +1 -1
  14. package/esm2015/interfaces/image.js +1 -1
  15. package/esm2015/interfaces/valid-children-types.js +2 -1
  16. package/esm2015/plugins/align/align.editor.js +10 -2
  17. package/esm2015/plugins/align/options.js +3 -2
  18. package/esm2015/plugins/common/auto-insert-data..js +2 -18
  19. package/esm2015/plugins/dnd/component/dnd.component.js +260 -0
  20. package/esm2015/plugins/dnd/utils/get-current-target.js +19 -0
  21. package/esm2015/plugins/dnd/utils/get-hover-direction.js +13 -0
  22. package/esm2015/plugins/dnd/utils/is-valid-drag.js +38 -0
  23. package/esm2015/plugins/dnd/utils/move-drag-node.js +30 -0
  24. package/esm2015/plugins/dnd/utils/remove-drop-thumb-line.js +10 -0
  25. package/esm2015/plugins/image/image.component.js +167 -14
  26. package/esm2015/plugins/image/image.editor.js +4 -1
  27. package/esm2015/plugins/quick-insert/components/quick-insert.component.js +13 -2
  28. package/esm2015/services/context.service.js +5 -1
  29. package/esm2015/utils/dom.js +39 -1
  30. package/esm2015/utils/merge-element-options.js +20 -0
  31. package/fesm2015/worktile-theia.js +719 -153
  32. package/fesm2015/worktile-theia.js.map +1 -1
  33. package/interfaces/editor.d.ts +9 -1
  34. package/interfaces/image.d.ts +7 -1
  35. package/interfaces/valid-children-types.d.ts +1 -0
  36. package/package.json +1 -1
  37. package/plugins/align/align.editor.d.ts +1 -0
  38. package/plugins/dnd/component/dnd.component.d.ts +42 -0
  39. package/plugins/dnd/component/dnd.component.scss +61 -0
  40. package/plugins/dnd/utils/get-current-target.d.ts +2 -0
  41. package/plugins/dnd/utils/get-hover-direction.d.ts +3 -0
  42. package/plugins/dnd/utils/is-valid-drag.d.ts +3 -0
  43. package/plugins/dnd/utils/move-drag-node.d.ts +2 -0
  44. package/plugins/dnd/utils/remove-drop-thumb-line.d.ts +2 -0
  45. package/plugins/image/image.component.d.ts +27 -3
  46. package/plugins/image/image.component.scss +9 -2
  47. package/plugins/image/image.editor.d.ts +6 -1
  48. package/plugins/quick-insert/components/quick-insert.component.d.ts +1 -0
  49. package/plugins/table/components/table.component.scss +1 -0
  50. package/services/context.service.d.ts +1 -0
  51. package/styles/editor.scss +4 -0
  52. package/styles/index.scss +1 -0
  53. package/styles/typo.scss +44 -0
  54. package/utils/dom.d.ts +5 -1
  55. package/utils/merge-element-options.d.ts +2 -0
@@ -1,3 +1,4 @@
1
+ import { AngularEditor, EDITOR_TO_ELEMENT } from 'slate-angular';
1
2
  import { Alignment } from '../constants';
2
3
  /** Converts CSS pixel values to numbers, eg "123px" to 123. Returns NaN for non pixel values. */
3
4
  export function coercePixelsFromCssValue(cssValue) {
@@ -44,4 +45,41 @@ export function getElementClassByPrefix(el, prefix) {
44
45
  });
45
46
  return matchClass;
46
47
  }
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9tLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3V0aWxzL2RvbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXpDLGlHQUFpRztBQUNqRyxNQUFNLFVBQVUsd0JBQXdCLENBQUMsUUFBZ0I7SUFDckQsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN4QyxJQUFJLEtBQUssRUFBRTtRQUNQLE9BQU8sTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQzNCO0FBQ0wsQ0FBQztBQUVELE1BQU0sVUFBVSxlQUFlLENBQUMsT0FBb0I7SUFDaEQscUZBQXFGO0lBQ3JGLHFDQUFxQztJQUNyQyxPQUFPLHdCQUF3QixDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLFdBQVcsQ0FBQztBQUNoRixDQUFDO0FBRUQsTUFBTSxVQUFVLGdCQUFnQixDQUFDLE9BQW9CO0lBQ2pELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUM5RCxDQUFDO0FBRUQsTUFBTSxVQUFVLGlCQUFpQixDQUFDLElBQTJCO0lBQ3pELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxHQUFHLEVBQUUsRUFBRTtRQUM5QixPQUFPLEtBQUssR0FBRyxlQUFlLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDeEMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ1YsQ0FBQztBQUVELE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxJQUEyQjtJQUMxRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFLEVBQUU7UUFDOUIsT0FBTyxLQUFLLEdBQUcsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDekMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ1YsQ0FBQztBQUVELE1BQU0sVUFBVSxlQUFlLENBQUMsRUFBZSxFQUFFLE9BQWdCO0lBQzdELElBQUksT0FBTyxDQUFDLEtBQUssRUFBRTtRQUNmLEVBQUUsQ0FBQyxLQUFLLENBQUMsU0FBUyxHQUFJLE9BQU8sQ0FBQyxLQUFnQixJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUM7S0FDcEU7SUFFRCxJQUFJLE9BQU8sQ0FBQyxVQUFVLEVBQUU7UUFDcEIsRUFBRSxDQUFDLEtBQUssQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7S0FDbkQ7SUFFRCxJQUFJLE9BQU8sQ0FBQyxhQUFhLEVBQUU7UUFDdkIsRUFBRSxDQUFDLEtBQUssQ0FBQyxhQUFhLEdBQUcsT0FBTyxDQUFDLGFBQWEsQ0FBQztLQUNsRDtBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsdUJBQXVCLENBQUMsRUFBYyxFQUFFLE1BQWM7SUFDbEUsSUFBSSxVQUFVLEdBQUcsSUFBSSxDQUFDO0lBQ3RCLEVBQUUsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRSxFQUFFO1FBQ2hDLElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN4QixVQUFVLEdBQUcsS0FBSyxDQUFDO1NBQ3RCO0lBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDSCxPQUFPLFVBQVUsQ0FBQztBQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudCB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IERPTUVsZW1lbnQgfSBmcm9tICdzbGF0ZS1hbmd1bGFyJztcbmltcG9ydCB7IEFsaWdubWVudCB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5cbi8qKiBDb252ZXJ0cyBDU1MgcGl4ZWwgdmFsdWVzIHRvIG51bWJlcnMsIGVnIFwiMTIzcHhcIiB0byAxMjMuIFJldHVybnMgTmFOIGZvciBub24gcGl4ZWwgdmFsdWVzLiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvZXJjZVBpeGVsc0Zyb21Dc3NWYWx1ZShjc3NWYWx1ZTogc3RyaW5nKTogbnVtYmVyIHtcbiAgICBjb25zdCBtYXRjaCA9IGNzc1ZhbHVlLm1hdGNoKC8oXFxkKylweC8pO1xuICAgIGlmIChtYXRjaCkge1xuICAgICAgICByZXR1cm4gTnVtYmVyKG1hdGNoWzFdKTtcbiAgICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRFbGVtZW50V2lkdGgoZWxlbWVudDogSFRNTEVsZW1lbnQpIHtcbiAgICAvLyBPcHRpbWl6YXRpb246IENoZWNrIHN0eWxlLndpZHRoIGZpcnN0IGFzIHdlIHByb2JhYmx5IHNldCBpdCBhbHJlYWR5IGJlZm9yZSByZWFkaW5nXG4gICAgLy8gb2Zmc2V0V2lkdGggd2hpY2ggdHJpZ2dlcnMgbGF5b3V0LlxuICAgIHJldHVybiBjb2VyY2VQaXhlbHNGcm9tQ3NzVmFsdWUoZWxlbWVudC5zdHlsZS53aWR0aCkgfHwgZWxlbWVudC5vZmZzZXRXaWR0aDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEVsZW1lbnRIZWlnaHQoZWxlbWVudDogSFRNTEVsZW1lbnQpIHtcbiAgICByZXR1cm4gTWF0aC5yb3VuZChlbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpLmhlaWdodCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb2xzVG90YWxXaWR0aChjb2xzOiBIVE1MVGFibGVDb2xFbGVtZW50W10pIHtcbiAgICByZXR1cm4gY29scy5yZWR1Y2UoKHRvdGFsLCBjb2wpID0+IHtcbiAgICAgICAgcmV0dXJuIHRvdGFsICsgZ2V0RWxlbWVudFdpZHRoKGNvbCk7XG4gICAgfSwgMCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRSb3dzVG90YWxIZWlnaHQocm93czogSFRNTFRhYmxlUm93RWxlbWVudFtdKSB7XG4gICAgcmV0dXJuIHJvd3MucmVkdWNlKCh0b3RhbCwgcm93KSA9PiB7XG4gICAgICAgIHJldHVybiB0b3RhbCArIGdldEVsZW1lbnRIZWlnaHQocm93KTtcbiAgICB9LCAwKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUVsZW1lbnRTdHlsZShlbDogSFRNTEVsZW1lbnQsIGVsZW1lbnQ6IEVsZW1lbnQpIHtcbiAgICBpZiAoZWxlbWVudC5hbGlnbikge1xuICAgICAgICBlbC5zdHlsZS50ZXh0QWxpZ24gPSAoZWxlbWVudC5hbGlnbiBhcyBzdHJpbmcpIHx8IEFsaWdubWVudC5sZWZ0O1xuICAgIH1cblxuICAgIGlmIChlbGVtZW50LnRleHRJbmRlbnQpIHtcbiAgICAgICAgZWwuc3R5bGUudGV4dEluZGVudCA9IGVsZW1lbnQudGV4dEluZGVudCArICdlbSc7XG4gICAgfVxuXG4gICAgaWYgKGVsZW1lbnQudmVydGljYWxBbGlnbikge1xuICAgICAgICBlbC5zdHlsZS52ZXJ0aWNhbEFsaWduID0gZWxlbWVudC52ZXJ0aWNhbEFsaWduO1xuICAgIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEVsZW1lbnRDbGFzc0J5UHJlZml4KGVsOiBET01FbGVtZW50LCBwcmVmaXg6IHN0cmluZykge1xuICAgIGxldCBtYXRjaENsYXNzID0gbnVsbDtcbiAgICBlbC5jbGFzc0xpc3QuZm9yRWFjaCgodmFsdWUsIGtleSkgPT4ge1xuICAgICAgICBpZiAodmFsdWUuaW5jbHVkZXMocHJlZml4KSkge1xuICAgICAgICAgICAgbWF0Y2hDbGFzcyA9IHZhbHVlO1xuICAgICAgICB9XG4gICAgfSk7XG4gICAgcmV0dXJuIG1hdGNoQ2xhc3M7XG59XG4iXX0=
48
+ export function findRelativeElementByPoint(editor, x, y, mode) {
49
+ const editableElement = EDITOR_TO_ELEMENT.get(editor);
50
+ const rectEditable = editableElement.getBoundingClientRect();
51
+ if (x > rectEditable.x && x < rectEditable.x + rectEditable.width) {
52
+ const centerX = rectEditable.x + rectEditable.width / 2;
53
+ let relativeElement = document.elementFromPoint(mode === 'highest' ? centerX : x, y);
54
+ return relativeElement;
55
+ }
56
+ return null;
57
+ }
58
+ export function findNodeEntryByPoint(editor, x, y, mode) {
59
+ const editableElement = EDITOR_TO_ELEMENT.get(editor);
60
+ let rootElement = null;
61
+ let relativeElement = findRelativeElementByPoint(editor, x, y, mode);
62
+ // 获取最顶层的DOM
63
+ if (mode === 'highest') {
64
+ while (relativeElement && editableElement.contains(relativeElement)) {
65
+ relativeElement = relativeElement.closest('[data-slate-node="element"]');
66
+ if (relativeElement) {
67
+ rootElement = relativeElement;
68
+ relativeElement = relativeElement.parentElement;
69
+ }
70
+ }
71
+ }
72
+ if (!mode) {
73
+ if (relativeElement && editableElement.contains(relativeElement)) {
74
+ relativeElement = relativeElement.closest('[data-slate-node="element"]');
75
+ rootElement = relativeElement;
76
+ }
77
+ }
78
+ if (rootElement) {
79
+ const node = AngularEditor.toSlateNode(editor, rootElement);
80
+ const path = AngularEditor.findPath(editor, node);
81
+ return [node, path];
82
+ }
83
+ return null;
84
+ }
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../../../packages/src/utils/dom.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Element, NodeEntry } from 'slate';\nimport { AngularEditor, DOMElement, EDITOR_TO_ELEMENT } from 'slate-angular';\nimport { TheEditor } from '../interfaces/editor';\nimport { Alignment, NodeLevel } from '../constants';\n\n/** Converts CSS pixel values to numbers, eg \"123px\" to 123. Returns NaN for non pixel values. */\nexport function coercePixelsFromCssValue(cssValue: string): number {\n    const match = cssValue.match(/(\\d+)px/);\n    if (match) {\n        return Number(match[1]);\n    }\n}\n\nexport function getElementWidth(element: HTMLElement) {\n    // Optimization: Check style.width first as we probably set it already before reading\n    // offsetWidth which triggers layout.\n    return coercePixelsFromCssValue(element.style.width) || element.offsetWidth;\n}\n\nexport function getElementHeight(element: HTMLElement) {\n    return Math.round(element.getBoundingClientRect().height);\n}\n\nexport function getColsTotalWidth(cols: HTMLTableColElement[]) {\n    return cols.reduce((total, col) => {\n        return total + getElementWidth(col);\n    }, 0);\n}\n\nexport function getRowsTotalHeight(rows: HTMLTableRowElement[]) {\n    return rows.reduce((total, row) => {\n        return total + getElementHeight(row);\n    }, 0);\n}\n\nexport function useElementStyle(el: HTMLElement, element: Element) {\n    if (element.align) {\n        el.style.textAlign = (element.align as string) || Alignment.left;\n    }\n\n    if (element.textIndent) {\n        el.style.textIndent = element.textIndent + 'em';\n    }\n\n    if (element.verticalAlign) {\n        el.style.verticalAlign = element.verticalAlign;\n    }\n}\n\nexport function getElementClassByPrefix(el: DOMElement, prefix: string) {\n    let matchClass = null;\n    el.classList.forEach((value, key) => {\n        if (value.includes(prefix)) {\n            matchClass = value;\n        }\n    });\n    return matchClass;\n}\n\nexport function findRelativeElementByPoint(editor: TheEditor, x: number, y: number, mode?: NodeLevel) {\n    const editableElement = EDITOR_TO_ELEMENT.get(editor);\n    const rectEditable = editableElement.getBoundingClientRect();\n    if (x > rectEditable.x && x < rectEditable.x + rectEditable.width) {\n        const centerX = rectEditable.x + rectEditable.width / 2;\n        let relativeElement = document.elementFromPoint(mode === 'highest' ? centerX : x, y);\n        return relativeElement;\n    }\n    return null;\n}\n\nexport function findNodeEntryByPoint(editor: TheEditor, x: number, y: number, mode?: NodeLevel): NodeEntry<Element> | null {\n    const editableElement = EDITOR_TO_ELEMENT.get(editor);\n    let rootElement: DOMElement = null;\n    let relativeElement = findRelativeElementByPoint(editor, x, y, mode);\n    // 获取最顶层的DOM\n    if (mode === 'highest') {\n        while (relativeElement && editableElement.contains(relativeElement)) {\n            relativeElement = relativeElement.closest('[data-slate-node=\"element\"]');\n            if (relativeElement) {\n                rootElement = relativeElement;\n                relativeElement = relativeElement.parentElement;\n            }\n        }\n    }\n\n    if (!mode) {\n        if (relativeElement && editableElement.contains(relativeElement)) {\n            relativeElement = relativeElement.closest('[data-slate-node=\"element\"]');\n            rootElement = relativeElement;\n        }\n    }\n\n    if (rootElement) {\n        const node = AngularEditor.toSlateNode(editor, rootElement) as Element;\n        const path = AngularEditor.findPath(editor, node);\n        return [node, path];\n    }\n    return null;\n}\n"]}
@@ -0,0 +1,20 @@
1
+ import { DefaultElementOptions } from '../interfaces';
2
+ export const mergeElementOptions = (elementOptions) => {
3
+ elementOptions = elementOptions.filter(item => item.inValidChildrenTypes.length > 0);
4
+ const combinationData = [...DefaultElementOptions, ...elementOptions];
5
+ const dataInfo = {};
6
+ combinationData.forEach(item => {
7
+ const { type, inValidChildrenTypes, isIndivisible, isSecondaryContainer } = item;
8
+ if (!dataInfo[type]) {
9
+ dataInfo[type] = {
10
+ type,
11
+ inValidChildrenTypes,
12
+ isIndivisible,
13
+ isSecondaryContainer
14
+ };
15
+ }
16
+ dataInfo[type].inValidChildrenTypes = Array.from(new Set([...inValidChildrenTypes, ...dataInfo[type].inValidChildrenTypes]));
17
+ });
18
+ return dataInfo;
19
+ };
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtZWxlbWVudC1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3V0aWxzL21lcmdlLWVsZW1lbnQtb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQXNCLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsY0FBb0MsRUFBRSxFQUFFO0lBQ3hFLGNBQWMsR0FBRyxjQUFjLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUNyRixNQUFNLGVBQWUsR0FBRyxDQUFDLEdBQUcscUJBQXFCLEVBQUUsR0FBRyxjQUFjLENBQUMsQ0FBQztJQUN0RSxNQUFNLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDcEIsZUFBZSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUMzQixNQUFNLEVBQUUsSUFBSSxFQUFFLG9CQUFvQixFQUFFLGFBQWEsRUFBRSxvQkFBb0IsRUFBRSxHQUFHLElBQUksQ0FBQztRQUNqRixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2pCLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRztnQkFDYixJQUFJO2dCQUNKLG9CQUFvQjtnQkFDcEIsYUFBYTtnQkFDYixvQkFBb0I7YUFDdkIsQ0FBQztTQUNMO1FBQ0QsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLG9CQUFvQixHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxHQUFHLG9CQUFvQixFQUFFLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2pJLENBQUMsQ0FBQyxDQUFDO0lBQ0gsT0FBTyxRQUFRLENBQUM7QUFDcEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVmYXVsdEVsZW1lbnRPcHRpb25zLCBFbGVtZW50T3B0aW9uc0luZm8gfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcblxuZXhwb3J0IGNvbnN0IG1lcmdlRWxlbWVudE9wdGlvbnMgPSAoZWxlbWVudE9wdGlvbnM6IEVsZW1lbnRPcHRpb25zSW5mb1tdKSA9PiB7XG4gICAgZWxlbWVudE9wdGlvbnMgPSBlbGVtZW50T3B0aW9ucy5maWx0ZXIoaXRlbSA9PiBpdGVtLmluVmFsaWRDaGlsZHJlblR5cGVzLmxlbmd0aCA+IDApO1xuICAgIGNvbnN0IGNvbWJpbmF0aW9uRGF0YSA9IFsuLi5EZWZhdWx0RWxlbWVudE9wdGlvbnMsIC4uLmVsZW1lbnRPcHRpb25zXTtcbiAgICBjb25zdCBkYXRhSW5mbyA9IHt9O1xuICAgIGNvbWJpbmF0aW9uRGF0YS5mb3JFYWNoKGl0ZW0gPT4ge1xuICAgICAgICBjb25zdCB7IHR5cGUsIGluVmFsaWRDaGlsZHJlblR5cGVzLCBpc0luZGl2aXNpYmxlLCBpc1NlY29uZGFyeUNvbnRhaW5lciB9ID0gaXRlbTtcbiAgICAgICAgaWYgKCFkYXRhSW5mb1t0eXBlXSkge1xuICAgICAgICAgICAgZGF0YUluZm9bdHlwZV0gPSB7XG4gICAgICAgICAgICAgICAgdHlwZSxcbiAgICAgICAgICAgICAgICBpblZhbGlkQ2hpbGRyZW5UeXBlcyxcbiAgICAgICAgICAgICAgICBpc0luZGl2aXNpYmxlLFxuICAgICAgICAgICAgICAgIGlzU2Vjb25kYXJ5Q29udGFpbmVyXG4gICAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgICAgIGRhdGFJbmZvW3R5cGVdLmluVmFsaWRDaGlsZHJlblR5cGVzID0gQXJyYXkuZnJvbShuZXcgU2V0KFsuLi5pblZhbGlkQ2hpbGRyZW5UeXBlcywgLi4uZGF0YUluZm9bdHlwZV0uaW5WYWxpZENoaWxkcmVuVHlwZXNdKSk7XG4gICAgfSk7XG4gICAgcmV0dXJuIGRhdGFJbmZvO1xufTtcbiJdfQ==