@ai-table/grid 0.0.35 → 0.0.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/components/cell-editors/link/link-editor.component.mjs +3 -3
- package/esm2022/renderer/components/cells/cells.mjs +6 -0
- package/esm2022/renderer/components/cells/index.mjs +2 -0
- package/esm2022/renderer/components/cells/link.component.mjs +90 -0
- package/esm2022/renderer/components/field-head.component.mjs +2 -2
- package/esm2022/renderer/components/hover-cell.component.mjs +103 -0
- package/esm2022/renderer/components/index.mjs +2 -1
- package/esm2022/renderer/components/text.component.mjs +13 -4
- package/esm2022/renderer/creations/create-cells.mjs +9 -3
- package/esm2022/renderer/drawers/cell-drawer.mjs +22 -6
- package/esm2022/renderer/interfaces/hover-cell.mjs +4 -0
- package/esm2022/renderer/interfaces/index.mjs +2 -0
- package/esm2022/renderer/renderer.component.mjs +8 -4
- package/esm2022/types/cell.mjs +1 -1
- package/esm2022/types/component-config.mjs +1 -1
- package/esm2022/utils/get-placeholder-cells.mjs +5 -5
- package/esm2022/utils/hover-cell.mjs +31 -0
- package/esm2022/utils/index.mjs +2 -1
- package/fesm2022/ai-table-grid.mjs +1187 -942
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/package.json +1 -1
- package/renderer/components/cells/cells.d.ts +5 -0
- package/renderer/components/cells/cells.d.ts.map +1 -0
- package/renderer/components/cells/index.d.ts +2 -0
- package/renderer/components/cells/index.d.ts.map +1 -0
- package/renderer/components/cells/link.component.d.ts +23 -0
- package/renderer/components/cells/link.component.d.ts.map +1 -0
- package/renderer/components/hover-cell.component.d.ts +23 -0
- package/renderer/components/hover-cell.component.d.ts.map +1 -0
- package/renderer/components/index.d.ts +1 -0
- package/renderer/components/index.d.ts.map +1 -1
- package/renderer/components/text.component.d.ts +6 -1
- package/renderer/components/text.component.d.ts.map +1 -1
- package/renderer/creations/create-cells.d.ts +2 -0
- package/renderer/creations/create-cells.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/renderer/interfaces/hover-cell.d.ts +8 -0
- package/renderer/interfaces/hover-cell.d.ts.map +1 -0
- package/renderer/interfaces/index.d.ts +2 -0
- package/renderer/interfaces/index.d.ts.map +1 -0
- package/renderer/renderer.component.d.ts.map +1 -1
- package/types/cell.d.ts +1 -0
- package/types/cell.d.ts.map +1 -1
- package/types/component-config.d.ts +10 -0
- package/types/component-config.d.ts.map +1 -1
- package/utils/hover-cell.d.ts +8 -0
- package/utils/hover-cell.d.ts.map +1 -0
- package/utils/index.d.ts +1 -0
- package/utils/index.d.ts.map +1 -1
@@ -53,8 +53,8 @@ export class LinkCellEditorComponent extends AbstractEditCellEditor {
|
|
53
53
|
ngOnInit() {
|
54
54
|
super.ngOnInit();
|
55
55
|
this.originValue = this.modelValue;
|
56
|
-
this.text = this.modelValue
|
57
|
-
this.url = this.modelValue
|
56
|
+
this.text = this.modelValue?.text ?? '';
|
57
|
+
this.url = this.modelValue?.url ?? '';
|
58
58
|
}
|
59
59
|
updateValue() {
|
60
60
|
if (!this.isValidLink({ text: this.text, url: this.url ?? '' })) {
|
@@ -114,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
114
114
|
type: ViewChild,
|
115
115
|
args: ['inputElement', { static: false }]
|
116
116
|
}] } });
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-editor.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/components/cell-editors/link/link-editor.component.ts","../../../../../../packages/grid/src/components/cell-editors/link/link-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, ElementRef, inject, OnInit, ViewChild } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyAutofocusDirective, ThyEnterDirective } from 'ngx-tethys/shared';\nimport { AbstractEditCellEditor } from '../abstract-cell-editor.component';\nimport { ThyInputGroup, ThyInputModule } from 'ngx-tethys/input';\nimport { ThyTooltipModule } from 'ngx-tethys/tooltip';\nimport { ThyAction } from 'ngx-tethys/action';\nimport { ThyFlexibleTextModule } from 'ngx-tethys/flexible-text';\nimport { ThyPopover } from 'ngx-tethys/popover';\nimport { LINK_URL_REGEX, LinkEditComponent } from './edit-link/edit-link.component';\nimport * as _ from 'lodash';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\n\n@Component({\n    selector: 'link-cell-editor',\n    templateUrl: `./link-editor.component.html`,\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        FormsModule,\n        ThyAutofocusDirective,\n        ThyEnterDirective,\n        ThyInputGroup,\n        ThyTooltipModule,\n        ThyAction,\n        ThyInputModule,\n        ThyFlexibleTextModule,\n        LinkEditComponent\n    ],\n    host: {\n        class: 'ai-table-link-editor'\n    }\n})\nexport class LinkCellEditorComponent extends AbstractEditCellEditor<{ text: string; url: string }> implements OnInit {\n    @ViewChild('inputElement', { static: false })\n    inputElement!: ElementRef;\n\n    text = '';\n\n    url = '';\n\n    originValue = {};\n\n    thyPopover = inject(ThyPopover);\n\n    cdr = inject(ChangeDetectorRef);\n\n    notifyService = inject(ThyNotifyService);\n\n    isOpened = false;\n\n    isValidLink(link: { text: string; url: string }) {\n        if (!link?.text?.trim()) {\n            return true;\n        }\n        if (!link.url) {\n            return LINK_URL_REGEX.test(link.text);\n        }\n        return true;\n    }\n\n    createLinkValue(link: { text: string; url: string }) {\n        const text = link?.text?.trim();\n        if (!text) {\n            return { url: '', text: '' };\n        } else {\n            const url = link.url?.trim();\n            return { url: url || text, text: text || url };\n        }\n    }\n\n    public blur(event: FocusEvent) {\n        const action = this.elementRef.nativeElement.querySelector('.edit-icon');\n        if (!(event.relatedTarget as HTMLElement)?.contains(action)) {\n            this.updateValue();\n        }\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.originValue = this.modelValue;\n        this.text = this.modelValue.text ?? '';\n        this.url = this.modelValue.url ?? '';\n    }\n\n    updateValue() {\n        if (!this.isValidLink({ text: this.text, url: this.url ?? '' })) {\n            this.notifyService.error(undefined, '链接格式不正确');\n            return;\n        }\n        this.modelValue = this.createLinkValue({ text: this.text, url: this.url ?? '' });\n        if (!_.isEqual(this.originValue, this.modelValue)) {\n            super.update()\n            this.originValue = this.modelValue;\n        }\n    }\n\n    openEdit() {\n        this.isOpened = true;\n        const popoverRef = this.thyPopover.open(LinkEditComponent, {\n            origin: this.elementRef.nativeElement,\n            originActiveClass: 'editing',\n            placement: 'bottomLeft',\n            minWidth: '320px',\n            width: this.elementRef.nativeElement.clientWidth + 'px',\n            initialState: {\n                url: this.url ?? '',\n                text: this.text ?? ''\n            }\n        });\n\n        if (popoverRef) {\n            popoverRef.componentInstance.confirm.subscribe((value: { url: string; text: string }) => {\n                this.text = value.text;\n                this.url = value.url;\n                this.updateValue();\n            });\n\n            popoverRef.beforeClosed().subscribe(() => {\n                this.isOpened = false;\n                this.cdr.markForCheck();\n            });\n        }\n    }\n}\n","<thy-input-group class=\"link-input-group h-100\" thySize=\"lg\">\n    <input\n        #inputElement\n        class=\"h-100\"\n        class=\"link-input\"\n        thyInput\n        thySize=\"md\"\n        [thyAutofocus]=\"true\"\n        [(ngModel)]=\"text\"\n        (blur)=\"blur($event)\"\n        (thyEnter)=\"updateValue()\"\n    />\n    <ng-template #suffix>\n        <a\n            thyAction\n            thyIcon=\"link-insert\"\n            thyTooltip=\"链接\"\n            class=\"font-size-base edit-icon\"\n            [class.active]=\"isOpened\"\n            href=\"javascript:;\"\n            (click)=\"openEdit()\"\n        ></a>\n    </ng-template>\n</thy-input-group>\n"]}
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-editor.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/components/cell-editors/link/link-editor.component.ts","../../../../../../packages/grid/src/components/cell-editors/link/link-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, ElementRef, inject, OnInit, ViewChild } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyAutofocusDirective, ThyEnterDirective } from 'ngx-tethys/shared';\nimport { AbstractEditCellEditor } from '../abstract-cell-editor.component';\nimport { ThyInputGroup, ThyInputModule } from 'ngx-tethys/input';\nimport { ThyTooltipModule } from 'ngx-tethys/tooltip';\nimport { ThyAction } from 'ngx-tethys/action';\nimport { ThyFlexibleTextModule } from 'ngx-tethys/flexible-text';\nimport { ThyPopover } from 'ngx-tethys/popover';\nimport { LINK_URL_REGEX, LinkEditComponent } from './edit-link/edit-link.component';\nimport * as _ from 'lodash';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\n\n@Component({\n    selector: 'link-cell-editor',\n    templateUrl: `./link-editor.component.html`,\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        FormsModule,\n        ThyAutofocusDirective,\n        ThyEnterDirective,\n        ThyInputGroup,\n        ThyTooltipModule,\n        ThyAction,\n        ThyInputModule,\n        ThyFlexibleTextModule,\n        LinkEditComponent\n    ],\n    host: {\n        class: 'ai-table-link-editor'\n    }\n})\nexport class LinkCellEditorComponent extends AbstractEditCellEditor<{ text: string; url: string }> implements OnInit {\n    @ViewChild('inputElement', { static: false })\n    inputElement!: ElementRef;\n\n    text = '';\n\n    url = '';\n\n    originValue = {};\n\n    thyPopover = inject(ThyPopover);\n\n    cdr = inject(ChangeDetectorRef);\n\n    notifyService = inject(ThyNotifyService);\n\n    isOpened = false;\n\n    isValidLink(link: { text: string; url: string }) {\n        if (!link?.text?.trim()) {\n            return true;\n        }\n        if (!link.url) {\n            return LINK_URL_REGEX.test(link.text);\n        }\n        return true;\n    }\n\n    createLinkValue(link: { text: string; url: string }) {\n        const text = link?.text?.trim();\n        if (!text) {\n            return { url: '', text: '' };\n        } else {\n            const url = link.url?.trim();\n            return { url: url || text, text: text || url };\n        }\n    }\n\n    public blur(event: FocusEvent) {\n        const action = this.elementRef.nativeElement.querySelector('.edit-icon');\n        if (!(event.relatedTarget as HTMLElement)?.contains(action)) {\n            this.updateValue();\n        }\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.originValue = this.modelValue;\n        this.text = this.modelValue?.text ?? '';\n        this.url = this.modelValue?.url ?? '';\n    }\n\n    updateValue() {\n        if (!this.isValidLink({ text: this.text, url: this.url ?? '' })) {\n            this.notifyService.error(undefined, '链接格式不正确');\n            return;\n        }\n        this.modelValue = this.createLinkValue({ text: this.text, url: this.url ?? '' });\n        if (!_.isEqual(this.originValue, this.modelValue)) {\n            super.update();\n            this.originValue = this.modelValue;\n        }\n    }\n\n    openEdit() {\n        this.isOpened = true;\n        const popoverRef = this.thyPopover.open(LinkEditComponent, {\n            origin: this.elementRef.nativeElement,\n            originActiveClass: 'editing',\n            placement: 'bottomLeft',\n            minWidth: '320px',\n            width: this.elementRef.nativeElement.clientWidth + 'px',\n            initialState: {\n                url: this.url ?? '',\n                text: this.text ?? ''\n            }\n        });\n\n        if (popoverRef) {\n            popoverRef.componentInstance.confirm.subscribe((value: { url: string; text: string }) => {\n                this.text = value.text;\n                this.url = value.url;\n                this.updateValue();\n            });\n\n            popoverRef.beforeClosed().subscribe(() => {\n                this.isOpened = false;\n                this.cdr.markForCheck();\n            });\n        }\n    }\n}\n","<thy-input-group class=\"link-input-group h-100\" thySize=\"lg\">\n    <input\n        #inputElement\n        class=\"h-100\"\n        class=\"link-input\"\n        thyInput\n        thySize=\"md\"\n        [thyAutofocus]=\"true\"\n        [(ngModel)]=\"text\"\n        (blur)=\"blur($event)\"\n        (thyEnter)=\"updateValue()\"\n    />\n    <ng-template #suffix>\n        <a\n            thyAction\n            thyIcon=\"link-insert\"\n            thyTooltip=\"链接\"\n            class=\"font-size-base edit-icon\"\n            [class.active]=\"isOpened\"\n            href=\"javascript:;\"\n            (click)=\"openEdit()\"\n        ></a>\n    </ng-template>\n</thy-input-group>\n"]}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import * as cellComponents from '.';
|
2
|
+
export const componentMap = {};
|
3
|
+
Object.values(cellComponents).forEach((cellComponent) => {
|
4
|
+
componentMap[cellComponent.fieldType] = cellComponent;
|
5
|
+
});
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2NlbGxzL2NlbGxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sS0FBSyxjQUFjLE1BQU0sR0FBRyxDQUFDO0FBRXBDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBdUUsRUFBRSxDQUFDO0FBRW5HLE1BQU0sQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsYUFBYSxFQUFFLEVBQUU7SUFDcEQsWUFBWSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxhQUFhLENBQUM7QUFDMUQsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3RvciB9IGZyb20gJ25neC10ZXRoeXMvY29yZSc7XG5pbXBvcnQgeyBBSVRhYmxlRmllbGRUeXBlIH0gZnJvbSAnLi4vLi4vLi4vY29yZSc7XG5pbXBvcnQgeyBIb3ZlckNlbGxDb21wb25lbnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuaW1wb3J0ICogYXMgY2VsbENvbXBvbmVudHMgZnJvbSAnLic7XG5cbmV4cG9ydCBjb25zdCBjb21wb25lbnRNYXA6IFBhcnRpYWw8UmVjb3JkPEFJVGFibGVGaWVsZFR5cGUsIENvbnN0cnVjdG9yPEhvdmVyQ2VsbENvbXBvbmVudD4+PiA9IHt9O1xuXG5PYmplY3QudmFsdWVzKGNlbGxDb21wb25lbnRzKS5mb3JFYWNoKChjZWxsQ29tcG9uZW50KSA9PiB7XG4gICAgY29tcG9uZW50TWFwW2NlbGxDb21wb25lbnQuZmllbGRUeXBlXSA9IGNlbGxDb21wb25lbnQ7XG59KTtcbiJdfQ==
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export * from './link.component';
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2NlbGxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpbmsuY29tcG9uZW50JztcbiJdfQ==
|
@@ -0,0 +1,90 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
|
+
import { KoShape } from '../../../angular-konva/components/shape.component';
|
3
|
+
import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';
|
4
|
+
import { KoContainer } from '../../../angular-konva/components/container.component';
|
5
|
+
import { getMousePosition, handleMouseStyle } from '../../../utils';
|
6
|
+
import { AITableText } from '../text.component';
|
7
|
+
import { AITable, AITableFieldType } from '../../../core';
|
8
|
+
import { drawer } from '../../drawers/drawer';
|
9
|
+
import * as i0 from "@angular/core";
|
10
|
+
export class AITableCellLink {
|
11
|
+
constructor() {
|
12
|
+
this.config = input();
|
13
|
+
this.textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;
|
14
|
+
this.render = computed(() => this.config()?.render);
|
15
|
+
this.transformValue = computed(() => this.render()?.transformValue);
|
16
|
+
this.showLink = computed(() => !!this.transformValue()?.text);
|
17
|
+
this.textConfig = computed(() => {
|
18
|
+
const render = this.config()?.render;
|
19
|
+
if (render) {
|
20
|
+
const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;
|
21
|
+
let textRender = transformValue.text;
|
22
|
+
if (textRender == null) {
|
23
|
+
return;
|
24
|
+
}
|
25
|
+
textRender = textRender.replace(/\r|\n/g, ' ');
|
26
|
+
const fontWeight = style?.fontWeight;
|
27
|
+
const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
|
28
|
+
const { text, textWidth } = drawer.textEllipsis({
|
29
|
+
text: textRender,
|
30
|
+
maxWidth: textMaxWidth,
|
31
|
+
fontWeight
|
32
|
+
});
|
33
|
+
return {
|
34
|
+
x,
|
35
|
+
y,
|
36
|
+
text,
|
37
|
+
wrap: 'none',
|
38
|
+
width: textWidth,
|
39
|
+
fillStyle: Colors.primary,
|
40
|
+
fill: Colors.primary,
|
41
|
+
height: rowHeight + 2,
|
42
|
+
lineHeight: 1.84,
|
43
|
+
listening: true,
|
44
|
+
ellipsis: true,
|
45
|
+
zIndex
|
46
|
+
};
|
47
|
+
}
|
48
|
+
return;
|
49
|
+
});
|
50
|
+
}
|
51
|
+
static { this.fieldType = AITableFieldType.link; }
|
52
|
+
linkClick(e) {
|
53
|
+
e.event.cancelBubble = true;
|
54
|
+
window.open(this.transformValue().url, '_blank', 'noopener,noreferrer');
|
55
|
+
}
|
56
|
+
linkMouseMove(e) {
|
57
|
+
e.event.cancelBubble = true;
|
58
|
+
const { aiTable, coordinate } = this.config();
|
59
|
+
const targetName = e.event.target.name();
|
60
|
+
const gridStage = e.event.currentTarget.getStage();
|
61
|
+
const pos = gridStage?.getPointerPosition();
|
62
|
+
if (pos == null)
|
63
|
+
return;
|
64
|
+
const { context } = aiTable;
|
65
|
+
const { x, y } = pos;
|
66
|
+
const curMousePosition = getMousePosition(x, y, coordinate, AITable.getVisibleFields(aiTable), context, targetName);
|
67
|
+
handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);
|
68
|
+
}
|
69
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellLink, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
70
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableCellLink, isStandalone: true, selector: "ai-table-link", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
71
|
+
@if (showLink()) {
|
72
|
+
<ai-table-text [config]="textConfig()!" (koClick)="linkClick($event)" (koMouseMove)="linkMouseMove($event)"></ai-table-text>
|
73
|
+
}
|
74
|
+
`, isInline: true, dependencies: [{ kind: "component", type: AITableText, selector: "ai-table-text", inputs: ["config"], outputs: ["koClick", "koMouseMove"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
75
|
+
}
|
76
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellLink, decorators: [{
|
77
|
+
type: Component,
|
78
|
+
args: [{
|
79
|
+
selector: 'ai-table-link',
|
80
|
+
template: `
|
81
|
+
@if (showLink()) {
|
82
|
+
<ai-table-text [config]="textConfig()!" (koClick)="linkClick($event)" (koMouseMove)="linkMouseMove($event)"></ai-table-text>
|
83
|
+
}
|
84
|
+
`,
|
85
|
+
standalone: true,
|
86
|
+
imports: [KoContainer, KoShape, AITableText],
|
87
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
88
|
+
}]
|
89
|
+
}] });
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoShape } from '../../../angular-konva/components/shape.component';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';\nimport { KoContainer } from '../../../angular-konva/components/container.component';\nimport { getMousePosition, getTextWidth, handleMouseStyle, TextMeasure } from '../../../utils';\nimport { AITableText } from '../text.component';\nimport { AITableHoverCellConfig, AITableRender } from '../../../types';\nimport { KoEventObject } from '../../../angular-konva';\nimport { AITable, AITableFieldType } from '../../../core';\nimport { TextConfig } from 'konva/lib/shapes/Text';\nimport { drawer } from '../../drawers/drawer';\nimport { HoverCellComponent } from '../../interfaces';\n\n@Component({\n    selector: 'ai-table-link',\n    template: `\n        @if (showLink()) {\n            <ai-table-text [config]=\"textConfig()!\" (koClick)=\"linkClick($event)\" (koMouseMove)=\"linkMouseMove($event)\"></ai-table-text>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableText],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellLink implements HoverCellComponent {\n    static fieldType = AITableFieldType.link;\n\n    config = input<AITableHoverCellConfig | undefined>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    render = computed<AITableRender | undefined>(() => this.config()?.render);\n\n    transformValue = computed<{ text: string; url: string }>(() => this.render()?.transformValue);\n\n    showLink = computed<boolean>(() => !!this.transformValue()?.text);\n\n    textConfig = computed<TextConfig | undefined>(() => {\n        const render = this.config()?.render;\n        if (render) {\n            const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;\n            let textRender: string | null = transformValue.text;\n            if (textRender == null) {\n                return;\n            }\n\n            textRender = textRender.replace(/\\r|\\n/g, ' ');\n            const fontWeight = style?.fontWeight;\n            const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n            const { text, textWidth } = drawer.textEllipsis({\n                text: textRender,\n                maxWidth: textMaxWidth,\n                fontWeight\n            });\n\n            return {\n                x,\n                y,\n                text,\n                wrap: 'none',\n                width: textWidth,\n                fillStyle: Colors.primary,\n                fill: Colors.primary,\n                height: rowHeight + 2,\n                lineHeight: 1.84,\n                listening: true,\n                ellipsis: true,\n                zIndex\n            };\n        }\n        return;\n    });\n\n    linkClick(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        window.open(this.transformValue().url, '_blank', 'noopener,noreferrer');\n    }\n\n    linkMouseMove(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        const { aiTable, coordinate } = this.config()!;\n        const targetName = e.event.target.name();\n        const gridStage = e.event.currentTarget.getStage();\n        const pos = gridStage?.getPointerPosition();\n        if (pos == null) return;\n        const { context } = aiTable;\n        const { x, y } = pos;\n        const curMousePosition = getMousePosition(x, y, coordinate, AITable.getVisibleFields(aiTable), context!, targetName);\n        handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);\n    }\n}\n"]}
|
@@ -104,7 +104,7 @@ export class AITableFieldHead {
|
|
104
104
|
}
|
105
105
|
</ko-group>
|
106
106
|
</ko-group>
|
107
|
-
`, isInline: true, dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: AITableFieldIcon, selector: "ai-table-field-icon", inputs: ["config"] }, { kind: "component", type: AITableText, selector: "ai-table-text", inputs: ["config"] }, { kind: "component", type: AITableIcon, selector: "ai-table-icon", inputs: ["config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
107
|
+
`, isInline: true, dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: AITableFieldIcon, selector: "ai-table-field-icon", inputs: ["config"] }, { kind: "component", type: AITableText, selector: "ai-table-text", inputs: ["config"], outputs: ["koClick", "koMouseMove"] }, { kind: "component", type: AITableIcon, selector: "ai-table-icon", inputs: ["config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
108
108
|
}
|
109
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldHead, decorators: [{
|
110
110
|
type: Component,
|
@@ -127,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
127
127
|
changeDetection: ChangeDetectionStrategy.OnPush
|
128
128
|
}]
|
129
129
|
}] });
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-head.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/field-head.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoContainer, KoShape, KoStage } from '../../angular-konva';\nimport {\n    AI_TABLE_ACTION_COMMON_SIZE,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE,\n    AI_TABLE_FIELD_HEAD_MORE,\n    AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    Colors,\n    DEFAULT_FONT_SIZE,\n    MoreStandOutlinedPath\n} from '../../constants';\nimport { AITableFieldHeadConfig } from '../../types';\nimport { generateTargetName, TextMeasure } from '../../utils';\nimport { AITableFieldIcon } from './field-icon.component';\nimport { AITableIcon } from './icon.component';\nimport { AITableText } from './text.component';\n\n@Component({\n    selector: 'ai-table-field-head',\n    template: `\n        <ko-group [config]=\"groupConfig()\">\n            <ko-rect [config]=\"bgConfig()\"></ko-rect>\n            <ko-group>\n                <ai-table-field-icon [config]=\"fieldIconConfig()\"></ai-table-field-icon>\n                <ai-table-text [config]=\"textConfig()\"></ai-table-text>\n                @if (config().iconVisible) {\n                    <ai-table-icon [config]=\"moreIconConfig()\"></ai-table-icon>\n                }\n            </ko-group>\n        </ko-group>\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableFieldIcon, AITableText, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFieldHead {\n    config = input.required<AITableFieldHeadConfig>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    textMeasure = TextMeasure();\n\n    availableTextWidth = computed(() => {\n        const { width, iconVisible } = this.config();\n        return (\n            width -\n            (iconVisible\n                ? 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n                : 2 * AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n        );\n    });\n\n    textData = computed(() => {\n        const fieldName = this.config().field.name.replace(/\\r|\\n/g, ' ');\n        this.textMeasure.setFont({ fontSize: DEFAULT_FONT_SIZE });\n        const { width, height, isOverflow } = this.textMeasure.measureText(fieldName, this.availableTextWidth(), 1);\n        return {\n            width: Math.min(width, this.availableTextWidth()),\n            height,\n            isOverflow\n        };\n    });\n\n    groupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: this.config().x,\n            y: this.config().y\n        };\n    });\n\n    bgConfig = computed(() => {\n        const { field, width, height, stroke, isSelected, iconVisible } = this.config();\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD,\n                fieldId: field._id\n            }),\n            width: width,\n            height: height,\n            fill: isSelected ? Colors.headSelectedBgColor : iconVisible ? Colors.gray80 : Colors.white,\n            stroke: stroke || Colors.gray200,\n            strokeWidth: 1,\n            opacity: 1\n        };\n    });\n\n    fieldIconConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            field: field,\n            x: AI_TABLE_CELL_PADDING,\n            y: (height - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            width: AI_TABLE_ICON_COMMON_SIZE,\n            height: AI_TABLE_ICON_COMMON_SIZE,\n            fill: Colors.gray600\n        };\n    });\n\n    textConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            x: this.textOffset,\n            y: undefined,\n            width: Math.max(this.textData().width, AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH),\n            height: height + 2,\n            text: field.name,\n            lineHeight: 1.84\n        };\n    });\n\n    moreIconConfig = computed(() => {\n        const { field, width, height, isHoverIcon, isSelected } = this.config();\n        const commonIconOffsetY = (height - AI_TABLE_ACTION_COMMON_SIZE) / 2;\n        return {\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD_MORE,\n                fieldId: field._id\n            }),\n            x: width - AI_TABLE_ACTION_COMMON_SIZE,\n            y: commonIconOffsetY,\n            data: MoreStandOutlinedPath,\n            fill: isHoverIcon ? Colors.primary : Colors.gray600,\n            background: Colors.transparent,\n            backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,\n            backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,\n            cornerRadius: 4\n        };\n    });\n}\n"]}
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-head.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/field-head.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoContainer, KoShape, KoStage } from '../../angular-konva';\nimport {\n    AI_TABLE_ACTION_COMMON_SIZE,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE,\n    AI_TABLE_FIELD_HEAD_MORE,\n    AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    Colors,\n    DEFAULT_FONT_SIZE,\n    MoreStandOutlinedPath\n} from '../../constants';\nimport { AITableFieldHeadConfig } from '../../types';\nimport { generateTargetName, TextMeasure } from '../../utils';\nimport { AITableFieldIcon } from './field-icon.component';\nimport { AITableIcon } from './icon.component';\nimport { AITableText } from './text.component';\n\n@Component({\n    selector: 'ai-table-field-head',\n    template: `\n        <ko-group [config]=\"groupConfig()\">\n            <ko-rect [config]=\"bgConfig()\"></ko-rect>\n            <ko-group>\n                <ai-table-field-icon [config]=\"fieldIconConfig()\"></ai-table-field-icon>\n                <ai-table-text [config]=\"textConfig()\"></ai-table-text>\n                @if (config().iconVisible) {\n                    <ai-table-icon [config]=\"moreIconConfig()\"></ai-table-icon>\n                }\n            </ko-group>\n        </ko-group>\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableFieldIcon, AITableText, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFieldHead {\n    config = input.required<AITableFieldHeadConfig>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    textMeasure = TextMeasure();\n\n    availableTextWidth = computed(() => {\n        const { width, iconVisible } = this.config();\n        return (\n            width -\n            (iconVisible\n                ? 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n                : 2 * AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n        );\n    });\n\n    textData = computed(() => {\n        const fieldName = this.config().field.name.replace(/\\r|\\n/g, ' ');\n        this.textMeasure.setFont({ fontSize: DEFAULT_FONT_SIZE });\n        const { width, height, isOverflow } = this.textMeasure.measureText(fieldName, this.availableTextWidth(), 1);\n        return {\n            width: Math.min(width, this.availableTextWidth()),\n            height,\n            isOverflow\n        };\n    });\n\n    groupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: this.config().x,\n            y: this.config().y\n        };\n    });\n\n    bgConfig = computed(() => {\n        const { field, width, height, stroke, isSelected, iconVisible } = this.config();\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD,\n                fieldId: field._id\n            }),\n            width: width,\n            height: height,\n            fill: isSelected ? Colors.headSelectedBgColor : iconVisible ? Colors.gray80 : Colors.white,\n            stroke: stroke || Colors.gray200,\n            strokeWidth: 1,\n            opacity: 1\n        };\n    });\n\n    fieldIconConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            field: field,\n            x: AI_TABLE_CELL_PADDING,\n            y: (height - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            width: AI_TABLE_ICON_COMMON_SIZE,\n            height: AI_TABLE_ICON_COMMON_SIZE,\n            fill: Colors.gray600\n        };\n    });\n\n    textConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            x: this.textOffset,\n            y: undefined,\n            width: Math.max(this.textData().width, AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH),\n            height: height + 2,\n            text: field.name,\n            lineHeight: 1.84\n        };\n    });\n\n    moreIconConfig = computed(() => {\n        const { field, width, height, isHoverIcon, isSelected } = this.config();\n        const commonIconOffsetY = (height - AI_TABLE_ACTION_COMMON_SIZE) / 2;\n        return {\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD_MORE,\n                fieldId: field._id\n            }),\n            x: width - AI_TABLE_ACTION_COMMON_SIZE,\n            y: commonIconOffsetY,\n            data: MoreStandOutlinedPath,\n            fill: isHoverIcon ? Colors.primary : Colors.gray600,\n            background: Colors.transparent,\n            backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,\n            backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,\n            cornerRadius: 4\n        };\n    });\n}\n"]}
|
@@ -0,0 +1,103 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
|
+
import { KoContainer, KoShape } from '../../angular-konva';
|
3
|
+
import { AITableQueries } from '../../core';
|
4
|
+
import { CommonModule } from '@angular/common';
|
5
|
+
import { AI_TABLE_CELL_PADDING, AI_TABLE_OFFSET, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT } from '../../constants';
|
6
|
+
import { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';
|
7
|
+
import { isSelectedField } from '../creations/create-cells';
|
8
|
+
import * as i0 from "@angular/core";
|
9
|
+
import * as i1 from "@angular/common";
|
10
|
+
export class AITableHoverCells {
|
11
|
+
constructor() {
|
12
|
+
this.config = input.required();
|
13
|
+
this.componentMap = {};
|
14
|
+
this.groupConfig = computed(() => {
|
15
|
+
return {
|
16
|
+
x: this.hoverCellConfig()?.x,
|
17
|
+
y: this.hoverCellConfig()?.y
|
18
|
+
};
|
19
|
+
});
|
20
|
+
this.hoverCellConfig = computed(() => {
|
21
|
+
const { aiTable, coordinate } = this.config();
|
22
|
+
const pointPosition = aiTable.context.pointPosition();
|
23
|
+
const hoverCell = this.hoverCell();
|
24
|
+
if (!hoverCell) {
|
25
|
+
return;
|
26
|
+
}
|
27
|
+
const { field, recordId, fieldId, renderComponentDefinition } = hoverCell;
|
28
|
+
const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);
|
29
|
+
const transformValue = transformCellValue(aiTable, field, cellValue) || {};
|
30
|
+
if (Object.keys(transformValue).length === 0) {
|
31
|
+
return;
|
32
|
+
}
|
33
|
+
const { rowHeight, columnCount, rowCount } = coordinate;
|
34
|
+
const columnIndex = pointPosition.columnIndex;
|
35
|
+
const rowIndex = pointPosition.rowIndex;
|
36
|
+
const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;
|
37
|
+
const columnWidth = coordinate.getColumnWidth(columnIndex);
|
38
|
+
const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;
|
39
|
+
const { width } = getCellHorizontalPosition({
|
40
|
+
columnWidth,
|
41
|
+
columnIndex,
|
42
|
+
columnCount
|
43
|
+
});
|
44
|
+
const style = {
|
45
|
+
textAlign: DEFAULT_TEXT_ALIGN_LEFT
|
46
|
+
};
|
47
|
+
const textAlign = style.textAlign;
|
48
|
+
const renderX = textAlign === DEFAULT_TEXT_ALIGN_RIGHT
|
49
|
+
? columnWidth - AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET
|
50
|
+
: AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET;
|
51
|
+
const renderY = 0 - AI_TABLE_OFFSET * 2;
|
52
|
+
const result = {
|
53
|
+
field,
|
54
|
+
aiTable,
|
55
|
+
coordinate,
|
56
|
+
x,
|
57
|
+
y,
|
58
|
+
render: {
|
59
|
+
aiTable,
|
60
|
+
recordId,
|
61
|
+
field,
|
62
|
+
isActive: isSelectedField(field._id, aiTable),
|
63
|
+
x: renderX,
|
64
|
+
y: renderY,
|
65
|
+
columnWidth: width,
|
66
|
+
rowHeight,
|
67
|
+
cellValue,
|
68
|
+
transformValue,
|
69
|
+
style
|
70
|
+
}
|
71
|
+
};
|
72
|
+
return result;
|
73
|
+
});
|
74
|
+
this.hoverCell = computed(() => getHoverCell(this.config().aiTable));
|
75
|
+
}
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableHoverCells, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableHoverCells, isStandalone: true, selector: "ai-table-hover-cell", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
|
78
|
+
@if (hoverCell()) {
|
79
|
+
<ko-group [config]="groupConfig()">
|
80
|
+
<ng-container *ngComponentOutlet="hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }">
|
81
|
+
</ng-container>
|
82
|
+
</ko-group>
|
83
|
+
}
|
84
|
+
`, isInline: true, dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
85
|
+
}
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableHoverCells, decorators: [{
|
87
|
+
type: Component,
|
88
|
+
args: [{
|
89
|
+
selector: 'ai-table-hover-cell',
|
90
|
+
template: `
|
91
|
+
@if (hoverCell()) {
|
92
|
+
<ko-group [config]="groupConfig()">
|
93
|
+
<ng-container *ngComponentOutlet="hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }">
|
94
|
+
</ng-container>
|
95
|
+
</ko-group>
|
96
|
+
}
|
97
|
+
`,
|
98
|
+
standalone: true,
|
99
|
+
imports: [KoShape, KoContainer, CommonModule],
|
100
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
101
|
+
}]
|
102
|
+
}] });
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-cell.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, input, SimpleChanges } from '@angular/core';\nimport { KoContainer, KoShape } from '../../angular-konva';\nimport { AITableCellsConfig, AITableHoverCellConfig } from '../../types';\nimport { AITableField, AITableFieldType, AITableQueries } from '../../core';\nimport { AITableCellLink } from './cells/link.component';\nimport { CommonModule } from '@angular/common';\nimport {\n    AI_TABLE_CELL_BORDER,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_OFFSET,\n    Colors,\n    DEFAULT_TEXT_ALIGN_LEFT,\n    DEFAULT_TEXT_ALIGN_RIGHT\n} from '../../constants';\nimport { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { isSelectedField } from '../creations/create-cells';\nimport _ from 'lodash';\n\nimport * as cellComponents from './cells';\nimport { HoverCellComponent } from '../interfaces';\nimport { Constructor } from 'ngx-tethys/core';\n\n@Component({\n    selector: 'ai-table-hover-cell',\n    template: `\n        @if (hoverCell()) {\n            <ko-group [config]=\"groupConfig()\">\n                <ng-container *ngComponentOutlet=\"hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }\">\n                </ng-container>\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoShape, KoContainer, CommonModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverCells {\n    config = input.required<AITableCellsConfig>();\n\n    componentMap: Partial<Record<AITableFieldType, Constructor<HoverCellComponent>>> = {};\n\n    groupConfig = computed(() => {\n        return {\n            x: this.hoverCellConfig()?.x,\n            y: this.hoverCellConfig()?.y\n        };\n    });\n\n    hoverCellConfig = computed(() => {\n        const { aiTable, coordinate } = this.config();\n        const pointPosition = aiTable.context!.pointPosition();\n        const hoverCell = this.hoverCell();\n        if (!hoverCell) {\n            return;\n        }\n        const { field, recordId, fieldId, renderComponentDefinition } = hoverCell;\n        const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);\n        const transformValue = transformCellValue(aiTable, field, cellValue) || {};\n        if (Object.keys(transformValue).length === 0) {\n            return;\n        }\n\n        const { rowHeight, columnCount, rowCount } = coordinate;\n        const columnIndex = pointPosition.columnIndex;\n        const rowIndex = pointPosition.rowIndex;\n\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n        const { width } = getCellHorizontalPosition({\n            columnWidth,\n            columnIndex,\n            columnCount\n        });\n\n        const style = {\n            textAlign: DEFAULT_TEXT_ALIGN_LEFT\n        } as any;\n        const textAlign = style.textAlign;\n        const renderX =\n            textAlign === DEFAULT_TEXT_ALIGN_RIGHT\n                ? columnWidth - AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET\n                : AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET;\n        const renderY = 0 - AI_TABLE_OFFSET * 2;\n\n        const result: AITableHoverCellConfig = {\n            field,\n            aiTable,\n            coordinate,\n            x,\n            y,\n            render: {\n                aiTable,\n                recordId,\n                field,\n                isActive: isSelectedField(field._id, aiTable),\n                x: renderX,\n                y: renderY,\n                columnWidth: width,\n                rowHeight,\n                cellValue,\n                transformValue,\n                style\n            }\n        };\n\n        return result;\n    });\n\n    hoverCell = computed(() => getHoverCell(this.config().aiTable));\n}\n"]}
|
@@ -11,4 +11,5 @@ export * from './icon.component';
|
|
11
11
|
export * from './other-rows.component';
|
12
12
|
export * from './placeholder-cells.component';
|
13
13
|
export * from './text.component';
|
14
|
-
|
14
|
+
export * from './cells';
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FkZC1maWVsZC1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2VsbHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmllbGQtaGVhZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9maWVsZC1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Zyb3plbi1jZWxscy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9mcm96ZW4taGVhZHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZnJvemVuLXBsYWNlaG9sZGVyLWNlbGxzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hlYWRzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hvdmVyLXJvdy1oZWFkcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL290aGVyLXJvd3MuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcGxhY2Vob2xkZXItY2VsbHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jZWxscyc7XG4iXX0=
|
@@ -1,10 +1,13 @@
|
|
1
|
-
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
|
2
2
|
import { KoShape } from '../../angular-konva/components/shape.component';
|
3
3
|
import { DEFAULT_FONT_FAMILY, DEFAULT_FONT_SIZE, DEFAULT_FONT_STYLE, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ELLIPSIS, DEFAULT_TEXT_FILL, DEFAULT_TEXT_LISTENING, DEFAULT_TEXT_TRANSFORMS_ENABLED, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE, DEFAULT_TEXT_WRAP } from '../../constants';
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
export class AITableText {
|
6
6
|
constructor() {
|
7
7
|
this.config = input.required();
|
8
|
+
// @Output() koClick = new EventEmitter<KoEventObject<MouseEvent>>();
|
9
|
+
this.koClick = output();
|
10
|
+
this.koMouseMove = output();
|
8
11
|
this.textConfig = computed(() => {
|
9
12
|
const { x, y, width, height, text, padding, align = DEFAULT_TEXT_ALIGN_LEFT, verticalAlign = DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE, fill = DEFAULT_TEXT_FILL, textDecoration, fontSize = DEFAULT_FONT_SIZE, fontStyle = DEFAULT_FONT_STYLE, ellipsis = DEFAULT_TEXT_ELLIPSIS, wrap = DEFAULT_TEXT_WRAP, transformsEnabled = DEFAULT_TEXT_TRANSFORMS_ENABLED, listening = DEFAULT_TEXT_LISTENING, fontFamily = DEFAULT_FONT_FAMILY, ...rest } = this.config();
|
10
13
|
return {
|
@@ -29,17 +32,23 @@ export class AITableText {
|
|
29
32
|
};
|
30
33
|
});
|
31
34
|
}
|
35
|
+
onClick(e) {
|
36
|
+
this.koClick.emit(e);
|
37
|
+
}
|
38
|
+
onMousemove(e) {
|
39
|
+
this.koMouseMove.emit(e);
|
40
|
+
}
|
32
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
33
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableText, isStandalone: true, selector: "ai-table-text", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: ` <ko-text [config]="textConfig()"></ko-text> `, isInline: true, dependencies: [{ kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableText, isStandalone: true, selector: "ai-table-text", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { koClick: "koClick", koMouseMove: "koMouseMove" }, ngImport: i0, template: ` <ko-text [config]="textConfig()" (koClick)="onClick($event)" (koMousemove)="onMousemove($event)"></ko-text> `, isInline: true, dependencies: [{ kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
34
43
|
}
|
35
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableText, decorators: [{
|
36
45
|
type: Component,
|
37
46
|
args: [{
|
38
47
|
selector: 'ai-table-text',
|
39
|
-
template: ` <ko-text [config]="textConfig()"></ko-text> `,
|
48
|
+
template: ` <ko-text [config]="textConfig()" (koClick)="onClick($event)" (koMousemove)="onMousemove($event)"></ko-text> `,
|
40
49
|
standalone: true,
|
41
50
|
imports: [KoShape],
|
42
51
|
changeDetection: ChangeDetectionStrategy.OnPush
|
43
52
|
}]
|
44
53
|
}] });
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL3RleHQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFnQixLQUFLLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRWxILE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN6RSxPQUFPLEVBQ0gsbUJBQW1CLEVBQ25CLGlCQUFpQixFQUNqQixrQkFBa0IsRUFDbEIsdUJBQXVCLEVBQ3ZCLHFCQUFxQixFQUNyQixpQkFBaUIsRUFDakIsc0JBQXNCLEVBQ3RCLCtCQUErQixFQUMvQixrQ0FBa0MsRUFDbEMsaUJBQWlCLEVBQ3BCLE1BQU0saUJBQWlCLENBQUM7O0FBVXpCLE1BQU0sT0FBTyxXQUFXO0lBUHhCO1FBUUksV0FBTSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXFCLENBQUM7UUFFN0MscUVBQXFFO1FBQ3JFLFlBQU8sR0FBRyxNQUFNLEVBQTZCLENBQUM7UUFFOUMsZ0JBQVcsR0FBRyxNQUFNLEVBQTZCLENBQUM7UUFFbEQsZUFBVSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDdkIsTUFBTSxFQUNGLENBQUMsRUFDRCxDQUFDLEVBQ0QsS0FBSyxFQUNMLE1BQU0sRUFDTixJQUFJLEVBQ0osT0FBTyxFQUNQLEtBQUssR0FBRyx1QkFBdUIsRUFDL0IsYUFBYSxHQUFHLGtDQUFrQyxFQUNsRCxJQUFJLEdBQUcsaUJBQWlCLEVBQ3hCLGNBQWMsRUFDZCxRQUFRLEdBQUcsaUJBQWlCLEVBQzVCLFNBQVMsR0FBRyxrQkFBa0IsRUFDOUIsUUFBUSxHQUFHLHFCQUFxQixFQUNoQyxJQUFJLEdBQUcsaUJBQWlCLEVBQ3hCLGlCQUFpQixHQUFHLCtCQUErQixFQUNuRCxTQUFTLEdBQUcsc0JBQXNCLEVBQ2xDLFVBQVUsR0FBRyxtQkFBbUIsRUFDaEMsR0FBRyxJQUFJLEVBQ1YsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDbEIsT0FBTztnQkFDSCxDQUFDO2dCQUNELENBQUM7Z0JBQ0QsS0FBSztnQkFDTCxNQUFNO2dCQUNOLElBQUk7Z0JBQ0osT0FBTztnQkFDUCxLQUFLO2dCQUNMLGFBQWE7Z0JBQ2IsSUFBSTtnQkFDSixjQUFjO2dCQUNkLFFBQVE7Z0JBQ1IsU0FBUztnQkFDVCxRQUFRO2dCQUNSLElBQUk7Z0JBQ0osaUJBQWlCO2dCQUNqQixTQUFTO2dCQUNULFVBQVU7Z0JBQ1YsR0FBRyxJQUFJO2FBQ1YsQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO0tBUU47SUFORyxPQUFPLENBQUMsQ0FBNEI7UUFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUNELFdBQVcsQ0FBQyxDQUE0QjtRQUNwQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM3QixDQUFDOytHQXhEUSxXQUFXO21HQUFYLFdBQVcsNFFBTFYsK0dBQStHLDREQUUvRyxPQUFPOzs0RkFHUixXQUFXO2tCQVB2QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxlQUFlO29CQUN6QixRQUFRLEVBQUUsK0dBQStHO29CQUN6SCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgRXZlbnRFbWl0dGVyLCBpbnB1dCwgb3V0cHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCBLb252YSBmcm9tICdrb252YSc7XG5pbXBvcnQgeyBLb1NoYXBlIH0gZnJvbSAnLi4vLi4vYW5ndWxhci1rb252YS9jb21wb25lbnRzL3NoYXBlLmNvbXBvbmVudCc7XG5pbXBvcnQge1xuICAgIERFRkFVTFRfRk9OVF9GQU1JTFksXG4gICAgREVGQVVMVF9GT05UX1NJWkUsXG4gICAgREVGQVVMVF9GT05UX1NUWUxFLFxuICAgIERFRkFVTFRfVEVYVF9BTElHTl9MRUZULFxuICAgIERFRkFVTFRfVEVYVF9FTExJUFNJUyxcbiAgICBERUZBVUxUX1RFWFRfRklMTCxcbiAgICBERUZBVUxUX1RFWFRfTElTVEVOSU5HLFxuICAgIERFRkFVTFRfVEVYVF9UUkFOU0ZPUk1TX0VOQUJMRUQsXG4gICAgREVGQVVMVF9URVhUX1ZFUlRJQ0FMX0FMSUdOX01JRERMRSxcbiAgICBERUZBVUxUX1RFWFRfV1JBUFxufSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgS29FdmVudE9iamVjdCB9IGZyb20gJy4uLy4uL2FuZ3VsYXIta29udmEnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FpLXRhYmxlLXRleHQnLFxuICAgIHRlbXBsYXRlOiBgIDxrby10ZXh0IFtjb25maWddPVwidGV4dENvbmZpZygpXCIgKGtvQ2xpY2spPVwib25DbGljaygkZXZlbnQpXCIgKGtvTW91c2Vtb3ZlKT1cIm9uTW91c2Vtb3ZlKCRldmVudClcIj48L2tvLXRleHQ+IGAsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbS29TaGFwZV0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQUlUYWJsZVRleHQge1xuICAgIGNvbmZpZyA9IGlucHV0LnJlcXVpcmVkPEtvbnZhLlNoYXBlQ29uZmlnPigpO1xuXG4gICAgLy8gQE91dHB1dCgpIGtvQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPEtvRXZlbnRPYmplY3Q8TW91c2VFdmVudD4+KCk7XG4gICAga29DbGljayA9IG91dHB1dDxLb0V2ZW50T2JqZWN0PE1vdXNlRXZlbnQ+PigpO1xuXG4gICAga29Nb3VzZU1vdmUgPSBvdXRwdXQ8S29FdmVudE9iamVjdDxNb3VzZUV2ZW50Pj4oKTtcblxuICAgIHRleHRDb25maWcgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgICAgIGNvbnN0IHtcbiAgICAgICAgICAgIHgsXG4gICAgICAgICAgICB5LFxuICAgICAgICAgICAgd2lkdGgsXG4gICAgICAgICAgICBoZWlnaHQsXG4gICAgICAgICAgICB0ZXh0LFxuICAgICAgICAgICAgcGFkZGluZyxcbiAgICAgICAgICAgIGFsaWduID0gREVGQVVMVF9URVhUX0FMSUdOX0xFRlQsXG4gICAgICAgICAgICB2ZXJ0aWNhbEFsaWduID0gREVGQVVMVF9URVhUX1ZFUlRJQ0FMX0FMSUdOX01JRERMRSxcbiAgICAgICAgICAgIGZpbGwgPSBERUZBVUxUX1RFWFRfRklMTCxcbiAgICAgICAgICAgIHRleHREZWNvcmF0aW9uLFxuICAgICAgICAgICAgZm9udFNpemUgPSBERUZBVUxUX0ZPTlRfU0laRSxcbiAgICAgICAgICAgIGZvbnRTdHlsZSA9IERFRkFVTFRfRk9OVF9TVFlMRSxcbiAgICAgICAgICAgIGVsbGlwc2lzID0gREVGQVVMVF9URVhUX0VMTElQU0lTLFxuICAgICAgICAgICAgd3JhcCA9IERFRkFVTFRfVEVYVF9XUkFQLFxuICAgICAgICAgICAgdHJhbnNmb3Jtc0VuYWJsZWQgPSBERUZBVUxUX1RFWFRfVFJBTlNGT1JNU19FTkFCTEVELFxuICAgICAgICAgICAgbGlzdGVuaW5nID0gREVGQVVMVF9URVhUX0xJU1RFTklORyxcbiAgICAgICAgICAgIGZvbnRGYW1pbHkgPSBERUZBVUxUX0ZPTlRfRkFNSUxZLFxuICAgICAgICAgICAgLi4ucmVzdFxuICAgICAgICB9ID0gdGhpcy5jb25maWcoKTtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHgsXG4gICAgICAgICAgICB5LFxuICAgICAgICAgICAgd2lkdGgsXG4gICAgICAgICAgICBoZWlnaHQsXG4gICAgICAgICAgICB0ZXh0LFxuICAgICAgICAgICAgcGFkZGluZyxcbiAgICAgICAgICAgIGFsaWduLFxuICAgICAgICAgICAgdmVydGljYWxBbGlnbixcbiAgICAgICAgICAgIGZpbGwsXG4gICAgICAgICAgICB0ZXh0RGVjb3JhdGlvbixcbiAgICAgICAgICAgIGZvbnRTaXplLFxuICAgICAgICAgICAgZm9udFN0eWxlLFxuICAgICAgICAgICAgZWxsaXBzaXMsXG4gICAgICAgICAgICB3cmFwLFxuICAgICAgICAgICAgdHJhbnNmb3Jtc0VuYWJsZWQsXG4gICAgICAgICAgICBsaXN0ZW5pbmcsXG4gICAgICAgICAgICBmb250RmFtaWx5LFxuICAgICAgICAgICAgLi4ucmVzdFxuICAgICAgICB9O1xuICAgIH0pO1xuXG4gICAgb25DbGljayhlOiBLb0V2ZW50T2JqZWN0PE1vdXNlRXZlbnQ+KSB7XG4gICAgICAgIHRoaXMua29DbGljay5lbWl0KGUpO1xuICAgIH1cbiAgICBvbk1vdXNlbW92ZShlOiBLb0V2ZW50T2JqZWN0PE1vdXNlRXZlbnQ+KSB7XG4gICAgICAgIHRoaXMua29Nb3VzZU1vdmUuZW1pdChlKTtcbiAgICB9XG59XG4iXX0=
|