@edm-sdui/sdui 1.0.53 → 1.0.54
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/edm-sdui-sdui-1.0.54.tgz +0 -0
- package/esm2022/lib/components/uicomponent/tags-row/tag/tag.component.mjs +28 -3
- package/fesm2022/edm-sdui-sdui.mjs +27 -2
- package/fesm2022/edm-sdui-sdui.mjs.map +1 -1
- package/lib/components/uicomponent/tags-row/tag/tag.component.d.ts +2 -0
- package/lib/components/uicomponent/tags-row/tag/tag.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/edm-sdui-sdui-1.0.53.tgz +0 -0
|
Binary file
|
|
@@ -61,6 +61,31 @@ export class TagsRowTagComponent {
|
|
|
61
61
|
active.classList.add('row-tag--selected');
|
|
62
62
|
this.ensureTagVisible(active);
|
|
63
63
|
}
|
|
64
|
+
onTagClick() {
|
|
65
|
+
const actionParam = this.tagElementRef?.nativeElement?.getAttribute('data-tag');
|
|
66
|
+
if (!actionParam)
|
|
67
|
+
return;
|
|
68
|
+
this.markSelectedTag(actionParam);
|
|
69
|
+
this.scrollToSection(actionParam);
|
|
70
|
+
}
|
|
71
|
+
scrollToSection(id) {
|
|
72
|
+
const sectionEl = document.getElementById(id);
|
|
73
|
+
if (!sectionEl)
|
|
74
|
+
return;
|
|
75
|
+
const container = this.resolveScrollContainer();
|
|
76
|
+
const offset = document.querySelector('.tags-row--can-fix') ? 140 : 180;
|
|
77
|
+
const isPage = container === document.documentElement ||
|
|
78
|
+
container === document.body ||
|
|
79
|
+
container === document.scrollingElement;
|
|
80
|
+
if (isPage) {
|
|
81
|
+
const top = sectionEl.getBoundingClientRect().top + window.scrollY - offset;
|
|
82
|
+
window.scrollTo({ top, behavior: 'smooth' });
|
|
83
|
+
}
|
|
84
|
+
else if (container) {
|
|
85
|
+
const top = sectionEl.getBoundingClientRect().top - container.getBoundingClientRect().top + container.scrollTop - offset;
|
|
86
|
+
container.scrollTo({ top, behavior: 'smooth' });
|
|
87
|
+
}
|
|
88
|
+
}
|
|
64
89
|
selectFirstTagAsDefault() {
|
|
65
90
|
requestAnimationFrame(() => {
|
|
66
91
|
if (TagsRowTagComponent.activeId)
|
|
@@ -194,11 +219,11 @@ export class TagsRowTagComponent {
|
|
|
194
219
|
this.destroy$.complete();
|
|
195
220
|
}
|
|
196
221
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowTagComponent, deps: [{ token: 'uiComponent' }, { token: i0.Renderer2 }, { token: i1.FontSizeMappingService }, { token: i2.ScrollSpyService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
197
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowTagComponent, isStandalone: false, selector: "edm-sdui-tags-row-tag", viewQueries: [{ propertyName: "tagElementRef", first: true, predicate: ["tagElement"], descendants: true }, { propertyName: "tagNameElementRef", first: true, predicate: ["tagNameElement"], descendants: true }], ngImport: i0, template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
|
|
222
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowTagComponent, isStandalone: false, selector: "edm-sdui-tags-row-tag", viewQueries: [{ propertyName: "tagElementRef", first: true, predicate: ["tagElement"], descendants: true }, { propertyName: "tagNameElementRef", first: true, predicate: ["tagNameElement"], descendants: true }], ngImport: i0, template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\" (click)=\"onTagClick()\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
|
|
198
223
|
}
|
|
199
224
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowTagComponent, decorators: [{
|
|
200
225
|
type: Component,
|
|
201
|
-
args: [{ standalone: false, selector: 'edm-sdui-tags-row-tag', template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"] }]
|
|
226
|
+
args: [{ standalone: false, selector: 'edm-sdui-tags-row-tag', template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\" (click)=\"onTagClick()\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"] }]
|
|
202
227
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
203
228
|
type: Inject,
|
|
204
229
|
args: ['uiComponent']
|
|
@@ -209,4 +234,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
209
234
|
type: ViewChild,
|
|
210
235
|
args: ['tagNameElement']
|
|
211
236
|
}] } });
|
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tag/tag.component.ts","../../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tag/tag.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,UAAU,EAAE,MAAM,EAAqB,SAAS,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAGtH,OAAO,EAAE,YAAY,EAAE,MAAM,gDAAgD,CAAC;AAC9E,OAAO,EAA+B,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;AAC9H,OAAO,EAAE,sBAAsB,EAAE,MAAM,qDAAqD,CAAC;AAG7F,OAAO,EAAE,gBAAgB,EAAE,MAAM,8CAA8C,CAAC;AAChF,OAAO,EAAc,OAAO,EAA2B,MAAM,MAAM,CAAC;;;;;;AAQpE,MAAM,OAAO,mBAAmB;aAIf,yBAAoB,GAAG,KAAK,AAAR,CAAS;aAC7B,eAAU,GAAqC,IAAI,AAAzC,CAA0C;aACpD,iBAAY,GAAwB,IAAI,AAA5B,CAA6B;aACzC,uBAAkB,GAAG,CAAC,AAAJ,CAAK;aACvB,uBAAkB,GAAuB,IAAI,AAA3B,CAA4B;aAC9C,aAAQ,GAAkB,IAAI,AAAtB,CAAuB;IAE9C,YACgC,WAAwB,EAC9C,QAAmB,EACnB,sBAA8C,EAC9C,SAA2B;QAHL,gBAAW,GAAX,WAAW,CAAa;QAC9C,aAAQ,GAAR,QAAQ,CAAW;QACnB,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,cAAS,GAAT,SAAS,CAAkB;QAZ7B,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAanC,CAAC;IAEL,QAAQ;IAER,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC5C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAEjD,0CAA0C;YAC1C,MAAM,WAAW,GAAI,IAAI,CAAC,WAAW,EAAE,OAAe,EAAE,MAAM,EAAE,KAAK,CAAC;YACtE,IAAI,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,aAAa,EAAE,aAAa,EAAE,CAAC;gBAC7D,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,UAAU,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;YAChG,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,yCAAyC,EAAE,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YACrF,CAAC;YAED,2DAA2D;YAC3D,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAE1B,uDAAuD;YACvD,uGAAuG;YACvG,8FAA8F;YAC9F,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAEO,YAAY,CAAC,OAAkB;IACvC,CAAC;IAEO,eAAe,CAAC,EAAU;QAChC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAc,UAAU,CAAC,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC;QAC3D,mBAAmB,CAAC,QAAQ,GAAG,EAAE,CAAC;QAClC,KAAK,MAAM,CAAC,IAAI,IAAI;YAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAC9D,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAc,sBAAsB,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAC7F,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,CAAC,IAAI,CAAC,4CAA4C,EAAE,EAAE,CAAC,CAAC;YAC/D,OAAO;QACT,CAAC;QACD,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QAC1C,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAEO,uBAAuB;QAC7B,qBAAqB,CAAC,GAAG,EAAE;YACzB,IAAI,mBAAmB,CAAC,QAAQ;gBAAE,OAAO;YACzC,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAc,oBAAoB,CAAC,CAAC;YAC3E,MAAM,UAAU,GAAG,QAAQ,EAAE,YAAY,CAAC,UAAU,CAAC,CAAC;YACtD,IAAI,UAAU,EAAE,CAAC;gBACf,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YACnC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB;QACxB,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,aAAa,EAAE,YAAY,CAAC,UAAU,CAAC,CAAC;QAC5E,IAAI,CAAC,OAAO;YAAE,OAAO;QACrB,IAAI,mBAAmB,CAAC,QAAQ,IAAI,mBAAmB,CAAC,QAAQ,KAAK,OAAO,EAAE,CAAC;YAC7E,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACtE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;IAEO,iBAAiB,CAAC,OAAkB;QAC1C,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAC9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QAC/E,CAAC;QAED,MAAM,wBAAwB,GAAG,IAAI,CAAC,sBAAsB,CAAC,UAAU,EAAE,CAAC;QAE1E,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,MAAM,QAAQ,GAAG,wBAAwB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAC7D,MAAM,UAAU,GAAG,0BAA0B,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACjE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,IAAI,CAAC,iBAAiB,CAAC,aAAa,EACpC,WAAW,EACX,QAAQ,CACT,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC;QAC1F,CAAC;IACH,CAAC;IAEO,iBAAiB;QACvB,qBAAqB;QACrB,IAAI,mBAAmB,CAAC,YAAY,EAAE,CAAC;YACrC,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;YACvD,MAAM,KAAK,GAAG,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,WAAW,IAAI,CAAC,gBAAgB,IAAI,mBAAmB,CAAC,kBAAkB,KAAK,gBAAgB,CAAC,CAAC;YACxJ,IAAI,CAAC,KAAK;gBAAE,OAAO;YAEnB,IAAI,CAAC;gBACH,mBAAmB,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;YACjD,CAAC;YAAC,MAAM,CAAC,CAAA,CAAC;YACV,mBAAmB,CAAC,YAAY,GAAG,IAAI,CAAC;YACxC,mBAAmB,CAAC,UAAU,GAAG,IAAI,CAAC;YACtC,mBAAmB,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC9C,mBAAmB,CAAC,oBAAoB,GAAG,KAAK,CAAC;QACnD,CAAC;QAED,8FAA8F;QAC9F,MAAM,eAAe,GAAG,CAAC,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;QACxD,IAAI,CAAC,eAAe,EAAE,CAAC;YACrB,mBAAmB,CAAC,kBAAkB,EAAE,CAAC;YACzC,IAAI,mBAAmB,CAAC,kBAAkB,IAAI,EAAE,EAAE,CAAC;gBACjD,qBAAqB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;YACxD,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,yEAAyE,CAAC,CAAC;YAC1F,CAAC;YACD,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,mBAAmB,CAAC,oBAAoB,GAAG,IAAI,CAAC;YAEhD,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB,EAAG,CAAC;YAExD,mBAAmB,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC;gBAC9D,SAAS,EAAE,gBAAiB;gBAC5B,cAAc,EAAE,mCAAmC;gBACnD,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;gBAC9E,SAAS,EAAE,CAAC,MAAM,EAAE,EAAE;oBACpB,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAc,sBAAsB,CAAC,CAAC;oBACpE,IAAI,OAAO,EAAE,EAAE;wBAAE,OAAO,OAAO,CAAC,EAAE,CAAC;oBACnC,IAAI,MAAM,CAAC,EAAE;wBAAE,OAAO,MAAM,CAAC,EAAE,CAAC;oBAChC,OAAO,MAAM,CAAC,OAAO,CAAc,MAAM,CAAC,EAAE,EAAE,IAAI,IAAI,CAAC;gBACzD,CAAC;gBACD,KAAK,EAAE,KAAK;aACb,CAAC,CAAC;YAEH,mBAAmB,CAAC,kBAAkB,GAAG,gBAAiB,CAAC;YAE3D,mBAAmB,CAAC,YAAY,GAAG,mBAAmB,CAAC,UAAU,CAAC,SAAS,CAAC;gBAC1E,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE;oBACjB,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACd,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,CAAC;4BAClC,IAAI,CAAC,uBAAuB,EAAE,CAAC;wBACjC,CAAC;wBACD,OAAO;oBACT,CAAC;oBACD,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBACjC,CAAC;gBACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;oBACb,OAAO,CAAC,KAAK,CAAC,6CAA6C,EAAE,GAAG,CAAC,CAAC;gBACpE,CAAC;aACF,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,CAAC,CAAC,CAAC;QAC3D,CAAC;IACH,CAAC;IAEO,sBAAsB;QAC5B,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,uBAAuB,CAAuB,CAAC;QACvF,IAAI,QAAQ,IAAI,QAAQ,CAAC,YAAY,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC;YAC9D,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,MAAM,YAAY,GACf,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAwB;YAC5D,QAAQ,CAAC,aAAa,CAAC,sBAAsB,CAAwB,CAAC;QAEzE,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;QACtD,CAAC;QAED,OAAQ,QAAQ,CAAC,gBAAgC,IAAI,QAAQ,CAAC,eAAe,CAAC;IAChF,CAAC;IAEO,gBAAgB,CAAC,KAAkB;QACzC,MAAM,SAAS,GAAG,KAAK,CAAC,OAAO,CAAc,WAAW,CAAC,CAAC;QAC1D,IAAI,CAAC,SAAS;YAAE,OAAO;QAEvB,MAAM,aAAa,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC;QACxD,MAAM,OAAO,GAAG,KAAK,CAAC,qBAAqB,EAAE,CAAC;QAC9C,MAAM,OAAO,GAAG,EAAE,CAAC,CAAC,mCAAmC;QAEvD,IAAI,OAAO,CAAC,IAAI,GAAG,aAAa,CAAC,IAAI,GAAG,OAAO,EAAE,CAAC;YAChD,MAAM,KAAK,GAAG,OAAO,CAAC,IAAI,GAAG,aAAa,CAAC,IAAI,GAAG,OAAO,CAAC;YAC1D,SAAS,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC1D,CAAC;aAAM,IAAI,OAAO,CAAC,KAAK,GAAG,aAAa,CAAC,KAAK,GAAG,OAAO,EAAE,CAAC;YACzD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,GAAG,aAAa,CAAC,KAAK,GAAG,OAAO,CAAC;YAC5D,SAAS,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;+GA/MU,mBAAmB,kBAYpB,aAAa;mGAZZ,mBAAmB,qSCjBhC,uMAGA;;4FDca,mBAAmB;kBAN/B,SAAS;iCAGI,KAAK,YACP,uBAAuB;;0BAc9B,MAAM;2BAAC,aAAa;qIAXE,aAAa;sBAArC,SAAS;uBAAC,YAAY;gBACM,iBAAiB;sBAA7C,SAAS;uBAAC,gBAAgB","sourcesContent":["import { AfterViewInit, Component, ElementRef, Inject, OnDestroy, OnInit, Renderer2, ViewChild } from \"@angular/core\";\nimport { UIComponent } from \"../../../../core/uicomposition/models/uicomponent\";\nimport { UIElement } from \"../../../../core/uicomposition/models/uielement\";\nimport { colorMapping } from \"../../../../core/uitheme/mapping/color-mapping\";\nimport { getTextStyleMappingFontSize, textStyleMappingLineHeight } from \"../../../../core/uitheme/mapping/text-style-mapping\";\nimport { FontSizeMappingService } from \"../../../../core/services/font-size-mapping.service\";\nimport { UISize } from \"../../../../core/uitheme/enums/uisize\";\nimport { sizeMappingHeight } from \"../../../../core/uitheme/mapping/size-mapping\";\nimport { ScrollSpyService } from \"../../../../core/services/scroll-spy.service\";\nimport { Observable, Subject, Subscription, takeUntil } from \"rxjs\";\n\n@Component({\n  styleUrl: './tag.component.scss',\n  templateUrl: './tag.component.html',\n  standalone: false,\n  selector: 'edm-sdui-tags-row-tag',\n})\nexport class TagsRowTagComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ViewChild('tagElement') tagElementRef!: ElementRef<HTMLElement>;\n  @ViewChild('tagNameElement') tagNameElementRef!: ElementRef<HTMLElement>;\n  private destroy$ = new Subject<void>();\n  private static scrollSpyInitialized = false;\n  private static scrollSpy$: Observable<string | null> | null = null;\n  private static scrollSpySub: Subscription | null = null;\n  private static scrollSpyInitTries = 0;\n  private static scrollSpyContainer: HTMLElement | null = null;\n  private static activeId: string | null = null;\n\n  constructor(\n    @Inject('uiComponent') public uiComponent: UIComponent,\n    private renderer: Renderer2,\n    private fontSizeMappingService: FontSizeMappingService,\n    private scrollSpy: ScrollSpyService\n  ) { }\n\n  ngOnInit(): void {\n\n  }\n\n  ngAfterViewInit(): void {\n    if (this.uiComponent.element) {\n      this.applyElement(this.uiComponent.element);\n      this.applyLabelElement(this.uiComponent.element);\n\n      // Map: tag.action.param -> section div id\n      const actionParam = (this.uiComponent?.element as any)?.action?.param;\n      if (actionParam != null && this.tagElementRef?.nativeElement) {\n        this.renderer.setAttribute(this.tagElementRef.nativeElement, 'data-tag', String(actionParam));\n      } else {\n        console.warn('[TagComponent] tag without action.param', this.uiComponent?.element);\n      }\n\n      // Reaplica seleção se este tag corresponde ao ativo atual.\n      this.syncSelectionState();\n\n      // IMPORTANT: TagsRowTagComponent renders once per tag.\n      // We initialize the scroll observer only once, but we MUST NOT tie it to the first instance lifecycle,\n      // because the first instance may be destroyed (e.g. rerender) and the subscription would die.\n      this.initScrollSpyOnce();\n    }\n  }\n\n  private applyElement(element: UIElement) {\n  }\n\n  private markSelectedTag(id: string): void {\n    const tags = Array.from(document.querySelectorAll<HTMLElement>('.row-tag'));\n    const dataTags = tags.map(t => t.getAttribute('data-tag'));\n    TagsRowTagComponent.activeId = id;\n    for (const t of tags) t.classList.remove('row-tag--selected');\n    const active = document.querySelector<HTMLElement>(`.row-tag[data-tag=\"${CSS.escape(id)}\"]`);\n    if (!active) {\n      console.warn('[TagComponent] active tag not found for id', id);\n      return;\n    }\n    active.classList.add('row-tag--selected');\n    this.ensureTagVisible(active);\n  }\n\n  private selectFirstTagAsDefault(): void {\n    requestAnimationFrame(() => {\n      if (TagsRowTagComponent.activeId) return;\n      const firstTag = document.querySelector<HTMLElement>('.row-tag[data-tag]');\n      const firstTagId = firstTag?.getAttribute('data-tag');\n      if (firstTagId) {\n        this.markSelectedTag(firstTagId);\n      }\n    });\n  }\n\n  private syncSelectionState(): void {\n    const dataTag = this.tagElementRef?.nativeElement?.getAttribute('data-tag');\n    if (!dataTag) return;\n    if (TagsRowTagComponent.activeId && TagsRowTagComponent.activeId === dataTag) {\n      this.tagElementRef.nativeElement.classList.add('row-tag--selected');\n    } else {\n      this.tagElementRef.nativeElement.classList.remove('row-tag--selected');\n    }\n  }\n\n  private applyLabelElement(element: UIElement) {\n    if (element.textColor) {\n      const color = colorMapping[element.textColor];\n      this.renderer.setStyle(this.tagNameElementRef.nativeElement, 'color', color);\n    }\n\n    const textStyleMappingFontSize = this.fontSizeMappingService.getMapping();\n\n    if (element.textStyle) {\n      const fontSize = textStyleMappingFontSize[element.textStyle];\n      const lineHeight = textStyleMappingLineHeight[element.textStyle];\n      this.renderer.setStyle(\n        this.tagNameElementRef.nativeElement,\n        'font-size',\n        fontSize\n      );\n      this.renderer.setStyle(this.tagNameElementRef.nativeElement, 'line-height', lineHeight);\n    }\n  }\n\n  private initScrollSpyOnce(): void {\n    // Already subscribed\n    if (TagsRowTagComponent.scrollSpySub) {\n      const currentContainer = this.resolveScrollContainer();\n      const stale = !TagsRowTagComponent.scrollSpyContainer?.isConnected || (currentContainer && TagsRowTagComponent.scrollSpyContainer !== currentContainer);\n      if (!stale) return;\n\n      try {\n        TagsRowTagComponent.scrollSpySub.unsubscribe();\n      } catch {}\n      TagsRowTagComponent.scrollSpySub = null;\n      TagsRowTagComponent.scrollSpy$ = null;\n      TagsRowTagComponent.scrollSpyContainer = null;\n      TagsRowTagComponent.scrollSpyInitialized = false;\n    }\n\n    // Ensure container exists; TagComponent can render before the scroll container is in the DOM.\n    const containerExists = !!this.resolveScrollContainer();\n    if (!containerExists) {\n      TagsRowTagComponent.scrollSpyInitTries++;\n      if (TagsRowTagComponent.scrollSpyInitTries <= 30) {\n        requestAnimationFrame(() => this.initScrollSpyOnce());\n      } else {\n        console.warn('[TagComponent] ScrollSpy: .scrollable-container not found after retries');\n      }\n      return;\n    }\n\n    try {\n      TagsRowTagComponent.scrollSpyInitialized = true;\n\n      const currentContainer = this.resolveScrollContainer()!;\n\n      TagsRowTagComponent.scrollSpy$ = this.scrollSpy.observeActiveId({\n        container: currentContainer!,\n        anchorSelector: '[data-anchor-target], .column[id]',\n        getOffsetTop: () => (document.querySelector('.tags-row--can-fix') ? 140 : 180),\n        resolveId: (anchor) => {\n          const section = anchor.closest<HTMLElement>('[data-anchor-target]');\n          if (section?.id) return section.id;\n          if (anchor.id) return anchor.id;\n          return anchor.closest<HTMLElement>('[id]')?.id || null;\n        },\n        debug: false,\n      });\n\n      TagsRowTagComponent.scrollSpyContainer = currentContainer!;\n\n      TagsRowTagComponent.scrollSpySub = TagsRowTagComponent.scrollSpy$.subscribe({\n        next: (activeId) => {\n          if (!activeId) {\n            if (!TagsRowTagComponent.activeId) {\n              this.selectFirstTagAsDefault();\n            }\n            return;\n          }\n          this.markSelectedTag(activeId);\n        },\n        error: (err) => {\n          console.error('[TagComponent] ScrollSpy subscription error', err);\n        },\n      });\n    } catch (e) {\n      console.error('[TagComponent] ScrollSpy init failed', e);\n    }\n  }\n\n  private resolveScrollContainer(): HTMLElement | null {\n    const explicit = document.querySelector('.scrollable-container') as HTMLElement | null;\n    if (explicit && explicit.scrollHeight > explicit.clientHeight) {\n      return explicit;\n    }\n\n    const anchorSample =\n      (document.querySelector('.column[id]') as HTMLElement | null) ||\n      (document.querySelector('[data-anchor-target]') as HTMLElement | null);\n\n    if (anchorSample) {\n      return this.scrollSpy.getScrollParent(anchorSample);\n    }\n\n    return (document.scrollingElement as HTMLElement) || document.documentElement;\n  }\n\n  private ensureTagVisible(tagEl: HTMLElement): void {\n    const container = tagEl.closest<HTMLElement>('.tags-row');\n    if (!container) return;\n\n    const containerRect = container.getBoundingClientRect();\n    const tagRect = tagEl.getBoundingClientRect();\n    const padding = 12; // keep a small side breathing room\n\n    if (tagRect.left < containerRect.left + padding) {\n      const delta = tagRect.left - containerRect.left - padding;\n      container.scrollBy({ left: delta, behavior: 'smooth' });\n    } else if (tagRect.right > containerRect.right - padding) {\n      const delta = tagRect.right - containerRect.right + padding;\n      container.scrollBy({ left: delta, behavior: 'smooth' });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n    <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n"]}
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tag/tag.component.ts","../../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tag/tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Inject, OnDestroy, OnInit, Renderer2, ViewChild } from \"@angular/core\";\nimport { UIComponent } from \"../../../../core/uicomposition/models/uicomponent\";\nimport { UIElement } from \"../../../../core/uicomposition/models/uielement\";\nimport { colorMapping } from \"../../../../core/uitheme/mapping/color-mapping\";\nimport { getTextStyleMappingFontSize, textStyleMappingLineHeight } from \"../../../../core/uitheme/mapping/text-style-mapping\";\nimport { FontSizeMappingService } from \"../../../../core/services/font-size-mapping.service\";\nimport { UISize } from \"../../../../core/uitheme/enums/uisize\";\nimport { sizeMappingHeight } from \"../../../../core/uitheme/mapping/size-mapping\";\nimport { ScrollSpyService } from \"../../../../core/services/scroll-spy.service\";\nimport { Observable, Subject, Subscription, takeUntil } from \"rxjs\";\n\n@Component({\n  styleUrl: './tag.component.scss',\n  templateUrl: './tag.component.html',\n  standalone: false,\n  selector: 'edm-sdui-tags-row-tag',\n})\nexport class TagsRowTagComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ViewChild('tagElement') tagElementRef!: ElementRef<HTMLElement>;\n  @ViewChild('tagNameElement') tagNameElementRef!: ElementRef<HTMLElement>;\n  private destroy$ = new Subject<void>();\n  private static scrollSpyInitialized = false;\n  private static scrollSpy$: Observable<string | null> | null = null;\n  private static scrollSpySub: Subscription | null = null;\n  private static scrollSpyInitTries = 0;\n  private static scrollSpyContainer: HTMLElement | null = null;\n  private static activeId: string | null = null;\n\n  constructor(\n    @Inject('uiComponent') public uiComponent: UIComponent,\n    private renderer: Renderer2,\n    private fontSizeMappingService: FontSizeMappingService,\n    private scrollSpy: ScrollSpyService\n  ) { }\n\n  ngOnInit(): void {\n\n  }\n\n  ngAfterViewInit(): void {\n    if (this.uiComponent.element) {\n      this.applyElement(this.uiComponent.element);\n      this.applyLabelElement(this.uiComponent.element);\n\n      // Map: tag.action.param -> section div id\n      const actionParam = (this.uiComponent?.element as any)?.action?.param;\n      if (actionParam != null && this.tagElementRef?.nativeElement) {\n        this.renderer.setAttribute(this.tagElementRef.nativeElement, 'data-tag', String(actionParam));\n      } else {\n        console.warn('[TagComponent] tag without action.param', this.uiComponent?.element);\n      }\n\n      // Reaplica seleção se este tag corresponde ao ativo atual.\n      this.syncSelectionState();\n\n      // IMPORTANT: TagsRowTagComponent renders once per tag.\n      // We initialize the scroll observer only once, but we MUST NOT tie it to the first instance lifecycle,\n      // because the first instance may be destroyed (e.g. rerender) and the subscription would die.\n      this.initScrollSpyOnce();\n    }\n  }\n\n  private applyElement(element: UIElement) {\n  }\n\n  private markSelectedTag(id: string): void {\n    const tags = Array.from(document.querySelectorAll<HTMLElement>('.row-tag'));\n    const dataTags = tags.map(t => t.getAttribute('data-tag'));\n    TagsRowTagComponent.activeId = id;\n    for (const t of tags) t.classList.remove('row-tag--selected');\n    const active = document.querySelector<HTMLElement>(`.row-tag[data-tag=\"${CSS.escape(id)}\"]`);\n    if (!active) {\n      console.warn('[TagComponent] active tag not found for id', id);\n      return;\n    }\n    active.classList.add('row-tag--selected');\n    this.ensureTagVisible(active);\n  }\n\n  onTagClick(): void {\n    const actionParam = this.tagElementRef?.nativeElement?.getAttribute('data-tag');\n    if (!actionParam) return;\n\n    this.markSelectedTag(actionParam);\n    this.scrollToSection(actionParam);\n  }\n\n  private scrollToSection(id: string): void {\n    const sectionEl = document.getElementById(id);\n    if (!sectionEl) return;\n\n    const container = this.resolveScrollContainer();\n    const offset = document.querySelector('.tags-row--can-fix') ? 140 : 180;\n    const isPage =\n      container === document.documentElement ||\n      container === document.body ||\n      container === document.scrollingElement;\n\n    if (isPage) {\n      const top = sectionEl.getBoundingClientRect().top + window.scrollY - offset;\n      window.scrollTo({ top, behavior: 'smooth' });\n    } else if (container) {\n      const top = sectionEl.getBoundingClientRect().top - container.getBoundingClientRect().top + container.scrollTop - offset;\n      container.scrollTo({ top, behavior: 'smooth' });\n    }\n  }\n\n  private selectFirstTagAsDefault(): void {\n    requestAnimationFrame(() => {\n      if (TagsRowTagComponent.activeId) return;\n      const firstTag = document.querySelector<HTMLElement>('.row-tag[data-tag]');\n      const firstTagId = firstTag?.getAttribute('data-tag');\n      if (firstTagId) {\n        this.markSelectedTag(firstTagId);\n      }\n    });\n  }\n\n  private syncSelectionState(): void {\n    const dataTag = this.tagElementRef?.nativeElement?.getAttribute('data-tag');\n    if (!dataTag) return;\n    if (TagsRowTagComponent.activeId && TagsRowTagComponent.activeId === dataTag) {\n      this.tagElementRef.nativeElement.classList.add('row-tag--selected');\n    } else {\n      this.tagElementRef.nativeElement.classList.remove('row-tag--selected');\n    }\n  }\n\n  private applyLabelElement(element: UIElement) {\n    if (element.textColor) {\n      const color = colorMapping[element.textColor];\n      this.renderer.setStyle(this.tagNameElementRef.nativeElement, 'color', color);\n    }\n\n    const textStyleMappingFontSize = this.fontSizeMappingService.getMapping();\n\n    if (element.textStyle) {\n      const fontSize = textStyleMappingFontSize[element.textStyle];\n      const lineHeight = textStyleMappingLineHeight[element.textStyle];\n      this.renderer.setStyle(\n        this.tagNameElementRef.nativeElement,\n        'font-size',\n        fontSize\n      );\n      this.renderer.setStyle(this.tagNameElementRef.nativeElement, 'line-height', lineHeight);\n    }\n  }\n\n  private initScrollSpyOnce(): void {\n    // Already subscribed\n    if (TagsRowTagComponent.scrollSpySub) {\n      const currentContainer = this.resolveScrollContainer();\n      const stale = !TagsRowTagComponent.scrollSpyContainer?.isConnected || (currentContainer && TagsRowTagComponent.scrollSpyContainer !== currentContainer);\n      if (!stale) return;\n\n      try {\n        TagsRowTagComponent.scrollSpySub.unsubscribe();\n      } catch {}\n      TagsRowTagComponent.scrollSpySub = null;\n      TagsRowTagComponent.scrollSpy$ = null;\n      TagsRowTagComponent.scrollSpyContainer = null;\n      TagsRowTagComponent.scrollSpyInitialized = false;\n    }\n\n    // Ensure container exists; TagComponent can render before the scroll container is in the DOM.\n    const containerExists = !!this.resolveScrollContainer();\n    if (!containerExists) {\n      TagsRowTagComponent.scrollSpyInitTries++;\n      if (TagsRowTagComponent.scrollSpyInitTries <= 30) {\n        requestAnimationFrame(() => this.initScrollSpyOnce());\n      } else {\n        console.warn('[TagComponent] ScrollSpy: .scrollable-container not found after retries');\n      }\n      return;\n    }\n\n    try {\n      TagsRowTagComponent.scrollSpyInitialized = true;\n\n      const currentContainer = this.resolveScrollContainer()!;\n\n      TagsRowTagComponent.scrollSpy$ = this.scrollSpy.observeActiveId({\n        container: currentContainer!,\n        anchorSelector: '[data-anchor-target], .column[id]',\n        getOffsetTop: () => (document.querySelector('.tags-row--can-fix') ? 140 : 180),\n        resolveId: (anchor) => {\n          const section = anchor.closest<HTMLElement>('[data-anchor-target]');\n          if (section?.id) return section.id;\n          if (anchor.id) return anchor.id;\n          return anchor.closest<HTMLElement>('[id]')?.id || null;\n        },\n        debug: false,\n      });\n\n      TagsRowTagComponent.scrollSpyContainer = currentContainer!;\n\n      TagsRowTagComponent.scrollSpySub = TagsRowTagComponent.scrollSpy$.subscribe({\n        next: (activeId) => {\n          if (!activeId) {\n            if (!TagsRowTagComponent.activeId) {\n              this.selectFirstTagAsDefault();\n            }\n            return;\n          }\n          this.markSelectedTag(activeId);\n        },\n        error: (err) => {\n          console.error('[TagComponent] ScrollSpy subscription error', err);\n        },\n      });\n    } catch (e) {\n      console.error('[TagComponent] ScrollSpy init failed', e);\n    }\n  }\n\n  private resolveScrollContainer(): HTMLElement | null {\n    const explicit = document.querySelector('.scrollable-container') as HTMLElement | null;\n    if (explicit && explicit.scrollHeight > explicit.clientHeight) {\n      return explicit;\n    }\n\n    const anchorSample =\n      (document.querySelector('.column[id]') as HTMLElement | null) ||\n      (document.querySelector('[data-anchor-target]') as HTMLElement | null);\n\n    if (anchorSample) {\n      return this.scrollSpy.getScrollParent(anchorSample);\n    }\n\n    return (document.scrollingElement as HTMLElement) || document.documentElement;\n  }\n\n  private ensureTagVisible(tagEl: HTMLElement): void {\n    const container = tagEl.closest<HTMLElement>('.tags-row');\n    if (!container) return;\n\n    const containerRect = container.getBoundingClientRect();\n    const tagRect = tagEl.getBoundingClientRect();\n    const padding = 12; // keep a small side breathing room\n\n    if (tagRect.left < containerRect.left + padding) {\n      const delta = tagRect.left - containerRect.left - padding;\n      container.scrollBy({ left: delta, behavior: 'smooth' });\n    } else if (tagRect.right > containerRect.right - padding) {\n      const delta = tagRect.right - containerRect.right + padding;\n      container.scrollBy({ left: delta, behavior: 'smooth' });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\" (click)=\"onTagClick()\">\n    <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n"]}
|
|
@@ -3288,6 +3288,31 @@ class TagsRowTagComponent {
|
|
|
3288
3288
|
active.classList.add('row-tag--selected');
|
|
3289
3289
|
this.ensureTagVisible(active);
|
|
3290
3290
|
}
|
|
3291
|
+
onTagClick() {
|
|
3292
|
+
const actionParam = this.tagElementRef?.nativeElement?.getAttribute('data-tag');
|
|
3293
|
+
if (!actionParam)
|
|
3294
|
+
return;
|
|
3295
|
+
this.markSelectedTag(actionParam);
|
|
3296
|
+
this.scrollToSection(actionParam);
|
|
3297
|
+
}
|
|
3298
|
+
scrollToSection(id) {
|
|
3299
|
+
const sectionEl = document.getElementById(id);
|
|
3300
|
+
if (!sectionEl)
|
|
3301
|
+
return;
|
|
3302
|
+
const container = this.resolveScrollContainer();
|
|
3303
|
+
const offset = document.querySelector('.tags-row--can-fix') ? 140 : 180;
|
|
3304
|
+
const isPage = container === document.documentElement ||
|
|
3305
|
+
container === document.body ||
|
|
3306
|
+
container === document.scrollingElement;
|
|
3307
|
+
if (isPage) {
|
|
3308
|
+
const top = sectionEl.getBoundingClientRect().top + window.scrollY - offset;
|
|
3309
|
+
window.scrollTo({ top, behavior: 'smooth' });
|
|
3310
|
+
}
|
|
3311
|
+
else if (container) {
|
|
3312
|
+
const top = sectionEl.getBoundingClientRect().top - container.getBoundingClientRect().top + container.scrollTop - offset;
|
|
3313
|
+
container.scrollTo({ top, behavior: 'smooth' });
|
|
3314
|
+
}
|
|
3315
|
+
}
|
|
3291
3316
|
selectFirstTagAsDefault() {
|
|
3292
3317
|
requestAnimationFrame(() => {
|
|
3293
3318
|
if (TagsRowTagComponent.activeId)
|
|
@@ -3421,11 +3446,11 @@ class TagsRowTagComponent {
|
|
|
3421
3446
|
this.destroy$.complete();
|
|
3422
3447
|
}
|
|
3423
3448
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowTagComponent, deps: [{ token: 'uiComponent' }, { token: i0.Renderer2 }, { token: FontSizeMappingService }, { token: ScrollSpyService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3424
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowTagComponent, isStandalone: false, selector: "edm-sdui-tags-row-tag", viewQueries: [{ propertyName: "tagElementRef", first: true, predicate: ["tagElement"], descendants: true }, { propertyName: "tagNameElementRef", first: true, predicate: ["tagNameElement"], descendants: true }], ngImport: i0, template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
|
|
3449
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowTagComponent, isStandalone: false, selector: "edm-sdui-tags-row-tag", viewQueries: [{ propertyName: "tagElementRef", first: true, predicate: ["tagElement"], descendants: true }, { propertyName: "tagNameElementRef", first: true, predicate: ["tagNameElement"], descendants: true }], ngImport: i0, template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\" (click)=\"onTagClick()\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
|
|
3425
3450
|
}
|
|
3426
3451
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowTagComponent, decorators: [{
|
|
3427
3452
|
type: Component,
|
|
3428
|
-
args: [{ standalone: false, selector: 'edm-sdui-tags-row-tag', template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"] }]
|
|
3453
|
+
args: [{ standalone: false, selector: 'edm-sdui-tags-row-tag', template: "<div class=\"row-tag\" #tagElement *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\" (click)=\"onTagClick()\">\n <span class=\"tag-name\" #tagNameElement>{{ uiComponent.element?.label ?? '' }}</span>\n</div>\n", styles: [":host{display:contents}.row-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:.85px solid var(--tag-explorer-aux);cursor:pointer;font-size:16px;flex-shrink:0}.row-tag:hover{background-color:var(--bt-tag-explorer-on)}.row-tag--selected{border-color:var(--tag-explorer-highlight);background-color:var(--bt-tag-explorer-on);background-origin:border-box}.tag-name{font-weight:600;color:var(--font-bt-tag-explorer-on);font-size:15px;line-height:17.25px}\n"] }]
|
|
3429
3454
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
3430
3455
|
type: Inject,
|
|
3431
3456
|
args: ['uiComponent']
|