@edm-sdui/sdui 1.0.45 → 1.0.46
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/lib/components/uicomponent/tags-row/tags-row.component.mjs +47 -17
- package/fesm2022/edm-sdui-sdui.mjs +46 -16
- package/fesm2022/edm-sdui-sdui.mjs.map +1 -1
- package/lib/components/uicomponent/tags-row/tags-row.component.d.ts +7 -3
- package/lib/components/uicomponent/tags-row/tags-row.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/edm-sdui-sdui-1.0.45.tgz +0 -0
|
@@ -43,25 +43,57 @@ export class TagsRowComponent {
|
|
|
43
43
|
}
|
|
44
44
|
ngAfterViewInit() {
|
|
45
45
|
requestAnimationFrame(() => {
|
|
46
|
+
this.measureLayout();
|
|
46
47
|
this.updateFixedState();
|
|
47
48
|
this.cdr.detectChanges();
|
|
49
|
+
// In production, fonts/images/header can change heights after initial paint,
|
|
50
|
+
// which shifts the trigger point and causes a visible "jump".
|
|
51
|
+
// Observe size changes and re-measure.
|
|
52
|
+
const el = this.tagsRowRef?.nativeElement;
|
|
53
|
+
if (el && typeof ResizeObserver !== 'undefined') {
|
|
54
|
+
this.resizeObserver = new ResizeObserver(() => {
|
|
55
|
+
this.measureLayout(true);
|
|
56
|
+
this.updateFixedState();
|
|
57
|
+
this.cdr.detectChanges();
|
|
58
|
+
});
|
|
59
|
+
this.resizeObserver.observe(el);
|
|
60
|
+
}
|
|
48
61
|
});
|
|
49
62
|
}
|
|
63
|
+
ngOnDestroy() {
|
|
64
|
+
this.resizeObserver?.disconnect();
|
|
65
|
+
this.resizeObserver = undefined;
|
|
66
|
+
}
|
|
50
67
|
onWindowScroll() {
|
|
51
68
|
this.updateFixedState();
|
|
52
|
-
console.log('versao 4433');
|
|
53
69
|
}
|
|
54
|
-
|
|
55
|
-
const
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
if (
|
|
59
|
-
|
|
70
|
+
measureLayout(force = false) {
|
|
71
|
+
const hostEl = this.hostRef.nativeElement;
|
|
72
|
+
const tagsEl = this.tagsRowRef?.nativeElement;
|
|
73
|
+
// Height spacer: keep the host reserving space so the content below doesn’t jump
|
|
74
|
+
if (tagsEl) {
|
|
75
|
+
const h = tagsEl.getBoundingClientRect().height;
|
|
76
|
+
if (force || !this.lastMeasuredHeight || Math.abs(h - this.lastMeasuredHeight) > 0.5) {
|
|
77
|
+
this.lastMeasuredHeight = h;
|
|
78
|
+
this.hostMinHeight = h;
|
|
79
|
+
}
|
|
60
80
|
}
|
|
61
|
-
|
|
62
|
-
|
|
81
|
+
// Trigger position: only capture/refresh when not fixed, because fixed changes the rect
|
|
82
|
+
if (!this.isFixed) {
|
|
83
|
+
const rect = hostEl.getBoundingClientRect();
|
|
84
|
+
const docTop = rect.top + window.scrollY;
|
|
85
|
+
if (force || !this.lastMeasuredDocTop || Math.abs(docTop - this.lastMeasuredDocTop) > 0.5) {
|
|
86
|
+
this.lastMeasuredDocTop = docTop;
|
|
87
|
+
this.initialTop = docTop;
|
|
88
|
+
}
|
|
63
89
|
}
|
|
64
|
-
|
|
90
|
+
}
|
|
91
|
+
updateFixedState() {
|
|
92
|
+
this.measureLayout();
|
|
93
|
+
const offset = this.getStickyOffset();
|
|
94
|
+
const isMobile = window.matchMedia('(max-width: 565px)').matches;
|
|
95
|
+
const targetTop = isMobile ? 60 : offset;
|
|
96
|
+
const triggerPoint = (this.initialTop ?? 0) - offset;
|
|
65
97
|
const shouldFix = window.scrollY >= triggerPoint;
|
|
66
98
|
this.canFix = shouldFix;
|
|
67
99
|
if (shouldFix) {
|
|
@@ -83,6 +115,7 @@ export class TagsRowComponent {
|
|
|
83
115
|
else {
|
|
84
116
|
this.isFixed = false;
|
|
85
117
|
this.setTagsRowTop(undefined);
|
|
118
|
+
this.measureLayout(true);
|
|
86
119
|
}
|
|
87
120
|
}
|
|
88
121
|
getStickyOffset() {
|
|
@@ -90,10 +123,7 @@ export class TagsRowComponent {
|
|
|
90
123
|
const parsed = parseInt(variable || '', 10);
|
|
91
124
|
if (!isNaN(parsed))
|
|
92
125
|
return parsed;
|
|
93
|
-
return
|
|
94
|
-
}
|
|
95
|
-
getStickyTop() {
|
|
96
|
-
return window.matchMedia('(max-width: 565px)').matches ? 58 : 78;
|
|
126
|
+
return 74; // fallback to navbar height
|
|
97
127
|
}
|
|
98
128
|
setTagsRowTop(value) {
|
|
99
129
|
const el = this.tagsRowRef?.nativeElement;
|
|
@@ -106,11 +136,11 @@ export class TagsRowComponent {
|
|
|
106
136
|
this.renderer.setStyle(el, 'top', `${value}px`);
|
|
107
137
|
}
|
|
108
138
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowComponent, deps: [{ token: 'uiComponent' }, { token: i0.Injector }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
109
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowComponent, isStandalone: false, selector: "edm-sdui-tags-row", host: { listeners: { "window:scroll": "onWindowScroll()" }, properties: { "class.tags-row--fixed": "this.isFixed", "class.tags-row--can-fix": "this.canFix", "style.min-height.px": "this.hostMinHeight" } }, viewQueries: [{ propertyName: "tagsRowRef", first: true, predicate: ["tagsRowElement"], descendants: true }], ngImport: i0, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:78px;left:32px;right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{
|
|
139
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowComponent, isStandalone: false, selector: "edm-sdui-tags-row", host: { listeners: { "window:scroll": "onWindowScroll()" }, properties: { "class.tags-row--fixed": "this.isFixed", "class.tags-row--can-fix": "this.canFix", "style.min-height.px": "this.hostMinHeight" } }, viewQueries: [{ propertyName: "tagsRowRef", first: true, predicate: ["tagsRowElement"], descendants: true }], ngImport: i0, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:var(--sdui-tags-row-top, 78px);left:var(--sdui-tags-row-left, 32px);right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{left:var(--sdui-tags-row-left-mobile, 0);top:var(--sdui-tags-row-top-mobile, var(--sdui-tags-row-top, 78px))}}:host.tags-row--can-fix .tags-row{background:var(--bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0003}\n"], dependencies: [{ kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"], exportAs: ["ngComponentOutlet"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
|
|
110
140
|
}
|
|
111
141
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowComponent, decorators: [{
|
|
112
142
|
type: Component,
|
|
113
|
-
args: [{ selector: 'edm-sdui-tags-row', standalone: false, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:78px;left:32px;right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{
|
|
143
|
+
args: [{ selector: 'edm-sdui-tags-row', standalone: false, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:var(--sdui-tags-row-top, 78px);left:var(--sdui-tags-row-left, 32px);right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{left:var(--sdui-tags-row-left-mobile, 0);top:var(--sdui-tags-row-top-mobile, var(--sdui-tags-row-top, 78px))}}:host.tags-row--can-fix .tags-row{background:var(--bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0003}\n"] }]
|
|
114
144
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
115
145
|
type: Inject,
|
|
116
146
|
args: ['uiComponent']
|
|
@@ -130,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
130
160
|
type: HostListener,
|
|
131
161
|
args: ['window:scroll']
|
|
132
162
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tags-row.component.js","sourceRoot":"","sources":["../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tags-row.component.ts","../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tags-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Inject, Injector, Renderer2, ViewChild } from '@angular/core';\nimport { UIComponent } from '../../../core/uicomposition/models/uicomponent';\n\n\nimport { UIComponentType } from '../../../core/uicomposition/enums/uicomponent-type';\nimport { UITag } from '../../../core/uicomposition/models/uitag';\nimport { TagsRowTagComponent } from './tag/tag.component';\n\n@Component({\n  selector: 'edm-sdui-tags-row',\n  styleUrl: './tags-row.component.scss',\n  templateUrl: './tags-row.component.html',\n  standalone: false,\n})\nexport class TagsRowComponent {\n  @HostBinding('class.tags-row--fixed') isFixed = false;\n  @HostBinding('class.tags-row--can-fix') canFix = false;\n  @HostBinding('style.min-height.px') hostMinHeight?: number;\n  @ViewChild('tagsRowElement') tagsRowRef?: ElementRef<HTMLElement>;\n  tagComponent = TagsRowTagComponent;\n  private injectorCache = new Map<string | number, Injector>();\n  private initialTop?: number;\n\n  constructor(\n    @Inject('uiComponent') public uiComponent: UIComponent,\n    private injector: Injector,\n    private hostRef: ElementRef<HTMLElement>,\n    private cdr: ChangeDetectorRef,\n    private renderer: Renderer2\n  ) {}\n\n  get tags(): UITag[] {\n    return this.uiComponent.tags ?? [];\n  }\n\n  trackByLabel(index: number, tag: UITag): string | number {\n    return tag.label ?? index;\n  }\n\n  createInjector(tag: UITag, index: number): Injector {\n    const key = this.getTagKey(tag, index);\n    const cached = this.injectorCache.get(key);\n    if (cached) return cached;\n\n    const component: UIComponent = {\n      type: UIComponentType.TAG,\n      element: tag,\n    };\n\n    const injector = Injector.create({\n      providers: [{ provide: 'uiComponent', useValue: component }],\n      parent: this.injector,\n    });\n    this.injectorCache.set(key, injector);\n    return injector;\n  }\n\n  private getTagKey(tag: UITag, index: number): string | number {\n    return tag.label ?? (tag as any)?.action?.param ?? index;\n  }\n\n  ngAfterViewInit(): void {\n    requestAnimationFrame(() => {\n      this.updateFixedState();\n      this.cdr.detectChanges();\n    });\n  }\n\n  @HostListener('window:scroll')\n  onWindowScroll(): void {\n    this.updateFixedState();\n    console.log('versao 4433')\n  }\n\n  private updateFixedState(): void {\n    const offset = this.getStickyOffset();\n    const rect = this.hostRef.nativeElement.getBoundingClientRect();\n    const targetTop = this.getStickyTop();\n\n    if (!this.initialTop) {\n      this.initialTop = rect.top + window.scrollY;\n    }\n\n    if (!this.hostMinHeight) {\n      this.hostMinHeight = rect.height;\n    }\n\n    const triggerPoint = (this.initialTop ?? 0) - offset + 8;\n    const shouldFix = window.scrollY >= triggerPoint;\n    this.canFix = shouldFix;\n    if (shouldFix) {\n      if (!this.isFixed) {\n        this.isFixed = true;\n        this.setTagsRowTop(targetTop);\n        this.cdr.detectChanges();\n        requestAnimationFrame(() => {\n          if (this.isFixed) {\n            this.setTagsRowTop(targetTop);\n            this.cdr.detectChanges();\n          }\n        });\n      } else {\n        this.setTagsRowTop(targetTop);\n      }\n    } else {\n      this.isFixed = false;\n      this.setTagsRowTop(undefined);\n    }\n  }\n\n  private getStickyOffset(): number {\n    const variable = getComputedStyle(document.documentElement).getPropertyValue('--sdui-sticky-offset');\n    const parsed = parseInt(variable || '', 10);\n    if (!isNaN(parsed)) return parsed;\n    return 72; // fallback to navbar height\n  }\n\n  private getStickyTop(): number {\n    return window.matchMedia('(max-width: 565px)').matches ? 58 : 78;\n  }\n\n  private setTagsRowTop(value?: number): void {\n    const el = this.tagsRowRef?.nativeElement;\n    if (!el) return;\n    if (value === undefined || value === null) {\n      this.renderer.removeStyle(el, 'top');\n      return;\n    }\n    this.renderer.setStyle(el, 'top', `${value}px`);\n  }\n}\n","<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n  <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n    <ng-container\n      *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n    ></ng-container>\n  </ng-container>\n</div>\n"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tags-row.component.js","sourceRoot":"","sources":["../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tags-row.component.ts","../../../../../../../../libs/sdui/src/lib/components/uicomponent/tags-row/tags-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Inject, Injector, OnDestroy, Renderer2, ViewChild } from '@angular/core';\nimport { UIComponent } from '../../../core/uicomposition/models/uicomponent';\n\n\nimport { UIComponentType } from '../../../core/uicomposition/enums/uicomponent-type';\nimport { UITag } from '../../../core/uicomposition/models/uitag';\nimport { TagsRowTagComponent } from './tag/tag.component';\n\n@Component({\n  selector: 'edm-sdui-tags-row',\n  styleUrl: './tags-row.component.scss',\n  templateUrl: './tags-row.component.html',\n  standalone: false,\n})\nexport class TagsRowComponent implements OnDestroy {\n  @HostBinding('class.tags-row--fixed') isFixed = false;\n  @HostBinding('class.tags-row--can-fix') canFix = false;\n  @HostBinding('style.min-height.px') hostMinHeight?: number;\n  @ViewChild('tagsRowElement') tagsRowRef?: ElementRef<HTMLElement>;\n  tagComponent = TagsRowTagComponent;\n  private injectorCache = new Map<string | number, Injector>();\n  private initialTop?: number;\n  private resizeObserver?: ResizeObserver;\n  private lastMeasuredHeight?: number;\n  private lastMeasuredDocTop?: number;\n\n  constructor(\n    @Inject('uiComponent') public uiComponent: UIComponent,\n    private injector: Injector,\n    private hostRef: ElementRef<HTMLElement>,\n    private cdr: ChangeDetectorRef,\n    private renderer: Renderer2\n  ) {}\n\n  get tags(): UITag[] {\n    return this.uiComponent.tags ?? [];\n  }\n\n  trackByLabel(index: number, tag: UITag): string | number {\n    return tag.label ?? index;\n  }\n\n  createInjector(tag: UITag, index: number): Injector {\n    const key = this.getTagKey(tag, index);\n    const cached = this.injectorCache.get(key);\n    if (cached) return cached;\n\n    const component: UIComponent = {\n      type: UIComponentType.TAG,\n      element: tag,\n    };\n\n    const injector = Injector.create({\n      providers: [{ provide: 'uiComponent', useValue: component }],\n      parent: this.injector,\n    });\n    this.injectorCache.set(key, injector);\n    return injector;\n  }\n\n  private getTagKey(tag: UITag, index: number): string | number {\n    return tag.label ?? (tag as any)?.action?.param ?? index;\n  }\n\n  ngAfterViewInit(): void {\n    requestAnimationFrame(() => {\n      this.measureLayout();\n      this.updateFixedState();\n      this.cdr.detectChanges();\n\n      // In production, fonts/images/header can change heights after initial paint,\n      // which shifts the trigger point and causes a visible \"jump\".\n      // Observe size changes and re-measure.\n      const el = this.tagsRowRef?.nativeElement;\n      if (el && typeof ResizeObserver !== 'undefined') {\n        this.resizeObserver = new ResizeObserver(() => {\n          this.measureLayout(true);\n          this.updateFixedState();\n          this.cdr.detectChanges();\n        });\n        this.resizeObserver.observe(el);\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.resizeObserver?.disconnect();\n    this.resizeObserver = undefined;\n  }\n\n  @HostListener('window:scroll')\n  onWindowScroll(): void {\n    this.updateFixedState();\n  }\n\n  private measureLayout(force = false): void {\n    const hostEl = this.hostRef.nativeElement;\n    const tagsEl = this.tagsRowRef?.nativeElement;\n\n    // Height spacer: keep the host reserving space so the content below doesn’t jump\n    if (tagsEl) {\n      const h = tagsEl.getBoundingClientRect().height;\n      if (force || !this.lastMeasuredHeight || Math.abs(h - this.lastMeasuredHeight) > 0.5) {\n        this.lastMeasuredHeight = h;\n        this.hostMinHeight = h;\n      }\n    }\n\n    // Trigger position: only capture/refresh when not fixed, because fixed changes the rect\n    if (!this.isFixed) {\n      const rect = hostEl.getBoundingClientRect();\n      const docTop = rect.top + window.scrollY;\n      if (force || !this.lastMeasuredDocTop || Math.abs(docTop - this.lastMeasuredDocTop) > 0.5) {\n        this.lastMeasuredDocTop = docTop;\n        this.initialTop = docTop;\n      }\n    }\n  }\n\n  private updateFixedState(): void {\n    this.measureLayout();\n\n    const offset = this.getStickyOffset();\n    const isMobile = window.matchMedia('(max-width: 565px)').matches;\n    const targetTop = isMobile ? 60 : offset;\n\n    const triggerPoint = (this.initialTop ?? 0) - offset;\n    const shouldFix = window.scrollY >= triggerPoint;\n    this.canFix = shouldFix;\n    if (shouldFix) {\n      if (!this.isFixed) {\n        this.isFixed = true;\n        this.setTagsRowTop(targetTop);\n        this.cdr.detectChanges();\n        requestAnimationFrame(() => {\n          if (this.isFixed) {\n            this.setTagsRowTop(targetTop);\n            this.cdr.detectChanges();\n          }\n        });\n      } else {\n        this.setTagsRowTop(targetTop);\n      }\n    } else {\n      this.isFixed = false;\n      this.setTagsRowTop(undefined);\n      this.measureLayout(true);\n    }\n  }\n\n  private getStickyOffset(): number {\n    const variable = getComputedStyle(document.documentElement).getPropertyValue('--sdui-sticky-offset');\n    const parsed = parseInt(variable || '', 10);\n    if (!isNaN(parsed)) return parsed;\n    return 74; // fallback to navbar height\n  }\n\n  private setTagsRowTop(value?: number): void {\n    const el = this.tagsRowRef?.nativeElement;\n    if (!el) return;\n    if (value === undefined || value === null) {\n      this.renderer.removeStyle(el, 'top');\n      return;\n    }\n    this.renderer.setStyle(el, 'top', `${value}px`);\n  }\n}\n","<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n  <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n    <ng-container\n      *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n    ></ng-container>\n  </ng-container>\n</div>\n"]}
|
|
@@ -3918,25 +3918,57 @@ class TagsRowComponent {
|
|
|
3918
3918
|
}
|
|
3919
3919
|
ngAfterViewInit() {
|
|
3920
3920
|
requestAnimationFrame(() => {
|
|
3921
|
+
this.measureLayout();
|
|
3921
3922
|
this.updateFixedState();
|
|
3922
3923
|
this.cdr.detectChanges();
|
|
3924
|
+
// In production, fonts/images/header can change heights after initial paint,
|
|
3925
|
+
// which shifts the trigger point and causes a visible "jump".
|
|
3926
|
+
// Observe size changes and re-measure.
|
|
3927
|
+
const el = this.tagsRowRef?.nativeElement;
|
|
3928
|
+
if (el && typeof ResizeObserver !== 'undefined') {
|
|
3929
|
+
this.resizeObserver = new ResizeObserver(() => {
|
|
3930
|
+
this.measureLayout(true);
|
|
3931
|
+
this.updateFixedState();
|
|
3932
|
+
this.cdr.detectChanges();
|
|
3933
|
+
});
|
|
3934
|
+
this.resizeObserver.observe(el);
|
|
3935
|
+
}
|
|
3923
3936
|
});
|
|
3924
3937
|
}
|
|
3938
|
+
ngOnDestroy() {
|
|
3939
|
+
this.resizeObserver?.disconnect();
|
|
3940
|
+
this.resizeObserver = undefined;
|
|
3941
|
+
}
|
|
3925
3942
|
onWindowScroll() {
|
|
3926
3943
|
this.updateFixedState();
|
|
3927
|
-
console.log('versao 4433');
|
|
3928
3944
|
}
|
|
3929
|
-
|
|
3930
|
-
const
|
|
3931
|
-
const
|
|
3932
|
-
|
|
3933
|
-
if (
|
|
3934
|
-
|
|
3945
|
+
measureLayout(force = false) {
|
|
3946
|
+
const hostEl = this.hostRef.nativeElement;
|
|
3947
|
+
const tagsEl = this.tagsRowRef?.nativeElement;
|
|
3948
|
+
// Height spacer: keep the host reserving space so the content below doesn’t jump
|
|
3949
|
+
if (tagsEl) {
|
|
3950
|
+
const h = tagsEl.getBoundingClientRect().height;
|
|
3951
|
+
if (force || !this.lastMeasuredHeight || Math.abs(h - this.lastMeasuredHeight) > 0.5) {
|
|
3952
|
+
this.lastMeasuredHeight = h;
|
|
3953
|
+
this.hostMinHeight = h;
|
|
3954
|
+
}
|
|
3935
3955
|
}
|
|
3936
|
-
|
|
3937
|
-
|
|
3956
|
+
// Trigger position: only capture/refresh when not fixed, because fixed changes the rect
|
|
3957
|
+
if (!this.isFixed) {
|
|
3958
|
+
const rect = hostEl.getBoundingClientRect();
|
|
3959
|
+
const docTop = rect.top + window.scrollY;
|
|
3960
|
+
if (force || !this.lastMeasuredDocTop || Math.abs(docTop - this.lastMeasuredDocTop) > 0.5) {
|
|
3961
|
+
this.lastMeasuredDocTop = docTop;
|
|
3962
|
+
this.initialTop = docTop;
|
|
3963
|
+
}
|
|
3938
3964
|
}
|
|
3939
|
-
|
|
3965
|
+
}
|
|
3966
|
+
updateFixedState() {
|
|
3967
|
+
this.measureLayout();
|
|
3968
|
+
const offset = this.getStickyOffset();
|
|
3969
|
+
const isMobile = window.matchMedia('(max-width: 565px)').matches;
|
|
3970
|
+
const targetTop = isMobile ? 60 : offset;
|
|
3971
|
+
const triggerPoint = (this.initialTop ?? 0) - offset;
|
|
3940
3972
|
const shouldFix = window.scrollY >= triggerPoint;
|
|
3941
3973
|
this.canFix = shouldFix;
|
|
3942
3974
|
if (shouldFix) {
|
|
@@ -3958,6 +3990,7 @@ class TagsRowComponent {
|
|
|
3958
3990
|
else {
|
|
3959
3991
|
this.isFixed = false;
|
|
3960
3992
|
this.setTagsRowTop(undefined);
|
|
3993
|
+
this.measureLayout(true);
|
|
3961
3994
|
}
|
|
3962
3995
|
}
|
|
3963
3996
|
getStickyOffset() {
|
|
@@ -3965,10 +3998,7 @@ class TagsRowComponent {
|
|
|
3965
3998
|
const parsed = parseInt(variable || '', 10);
|
|
3966
3999
|
if (!isNaN(parsed))
|
|
3967
4000
|
return parsed;
|
|
3968
|
-
return
|
|
3969
|
-
}
|
|
3970
|
-
getStickyTop() {
|
|
3971
|
-
return window.matchMedia('(max-width: 565px)').matches ? 58 : 78;
|
|
4001
|
+
return 74; // fallback to navbar height
|
|
3972
4002
|
}
|
|
3973
4003
|
setTagsRowTop(value) {
|
|
3974
4004
|
const el = this.tagsRowRef?.nativeElement;
|
|
@@ -3981,11 +4011,11 @@ class TagsRowComponent {
|
|
|
3981
4011
|
this.renderer.setStyle(el, 'top', `${value}px`);
|
|
3982
4012
|
}
|
|
3983
4013
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowComponent, deps: [{ token: 'uiComponent' }, { token: i0.Injector }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3984
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowComponent, isStandalone: false, selector: "edm-sdui-tags-row", host: { listeners: { "window:scroll": "onWindowScroll()" }, properties: { "class.tags-row--fixed": "this.isFixed", "class.tags-row--can-fix": "this.canFix", "style.min-height.px": "this.hostMinHeight" } }, viewQueries: [{ propertyName: "tagsRowRef", first: true, predicate: ["tagsRowElement"], descendants: true }], ngImport: i0, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:78px;left:32px;right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{
|
|
4014
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: TagsRowComponent, isStandalone: false, selector: "edm-sdui-tags-row", host: { listeners: { "window:scroll": "onWindowScroll()" }, properties: { "class.tags-row--fixed": "this.isFixed", "class.tags-row--can-fix": "this.canFix", "style.min-height.px": "this.hostMinHeight" } }, viewQueries: [{ propertyName: "tagsRowRef", first: true, predicate: ["tagsRowElement"], descendants: true }], ngImport: i0, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:var(--sdui-tags-row-top, 78px);left:var(--sdui-tags-row-left, 32px);right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{left:var(--sdui-tags-row-left-mobile, 0);top:var(--sdui-tags-row-top-mobile, var(--sdui-tags-row-top, 78px))}}:host.tags-row--can-fix .tags-row{background:var(--bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0003}\n"], dependencies: [{ kind: "directive", type: i1$1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"], exportAs: ["ngComponentOutlet"] }, { kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: UIViewDirective, selector: "[edmSduiView]", inputs: ["edmSduiView", "disableClick"] }] }); }
|
|
3985
4015
|
}
|
|
3986
4016
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TagsRowComponent, decorators: [{
|
|
3987
4017
|
type: Component,
|
|
3988
|
-
args: [{ selector: 'edm-sdui-tags-row', standalone: false, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:78px;left:32px;right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{
|
|
4018
|
+
args: [{ selector: 'edm-sdui-tags-row', standalone: false, template: "<div class=\"tags-row\" #tagsRowElement [class.tags-row-fixed]=\"isFixed\" *ngIf=\"uiComponent\" [edmSduiView]=\"uiComponent.element\">\n <ng-container *ngFor=\"let tag of tags; let i = index; trackBy: trackByLabel\">\n <ng-container\n *ngComponentOutlet=\"tagComponent; injector: createInjector(tag, i)\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:block;width:100%;box-sizing:border-box;margin-top:var(--sdui-header-margin-top, 12px)}.tags-row{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:6px 0 6px 16px;background-color:inherit;justify-content:flex-start;box-sizing:border-box;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:16px;scroll-padding-right:16px}:host .tags-row>*{flex:0 0 auto}:host.tags-row--fixed{box-sizing:border-box}:host.tags-row--fixed .tags-row{position:fixed;top:var(--sdui-tags-row-top, 78px);left:var(--sdui-tags-row-left, 32px);right:0;z-index:120;transition:top .16s ease;will-change:top;padding:6px 0 6px 16px}@media (max-width: 565px){:host.tags-row--fixed .tags-row{left:var(--sdui-tags-row-left-mobile, 0);top:var(--sdui-tags-row-top-mobile, var(--sdui-tags-row-top, 78px))}}:host.tags-row--can-fix .tags-row{background:var(--bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0003}\n"] }]
|
|
3989
4019
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
3990
4020
|
type: Inject,
|
|
3991
4021
|
args: ['uiComponent']
|