@klippa/ngx-enhancy-forms 18.33.20 → 18.33.21
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.
|
@@ -71,7 +71,8 @@ export class SelectComponent extends ValueAccessorBase {
|
|
|
71
71
|
return;
|
|
72
72
|
}
|
|
73
73
|
this.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');
|
|
74
|
-
const
|
|
74
|
+
const paddingForScrollbar = this.getScrollbarWidth();
|
|
75
|
+
const maxWidth = this.elRef.nativeElement.querySelector('.scrollable-content').getBoundingClientRect().width + paddingForScrollbar;
|
|
75
76
|
this.elRef.nativeElement.querySelector('.scrollable-content').classList.remove('calculatingWidths');
|
|
76
77
|
const dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');
|
|
77
78
|
if (dropdownPanel) {
|
|
@@ -280,6 +281,23 @@ export class SelectComponent extends ValueAccessorBase {
|
|
|
280
281
|
singleValueInputElement.style.left = `0px`;
|
|
281
282
|
}
|
|
282
283
|
}
|
|
284
|
+
getScrollbarWidth() {
|
|
285
|
+
// Create a temporary div element
|
|
286
|
+
const div = document.createElement('div');
|
|
287
|
+
// Set the style to measure the scrollbar
|
|
288
|
+
div.style.overflow = 'scroll'; // Enable scrollbar
|
|
289
|
+
div.style.width = '100px'; // Set a fixed width
|
|
290
|
+
div.style.height = '100px'; // Set a fixed height
|
|
291
|
+
div.style.position = 'absolute'; // Prevent the element from taking space in the layout
|
|
292
|
+
div.style.top = '-9999px'; // Position it out of the viewport
|
|
293
|
+
// Append the element to the body
|
|
294
|
+
document.body.appendChild(div);
|
|
295
|
+
// Get the width of the scrollbar
|
|
296
|
+
const scrollbarWidth = div.offsetWidth - div.clientWidth;
|
|
297
|
+
// Remove the temporary element from the DOM
|
|
298
|
+
document.body.removeChild(div);
|
|
299
|
+
return scrollbarWidth;
|
|
300
|
+
}
|
|
283
301
|
ngOnDestroy() {
|
|
284
302
|
super.ngOnDestroy();
|
|
285
303
|
this.elRef.nativeElement?.querySelector('input')?.removeEventListener('keydown', this.keyListener);
|
|
@@ -362,4 +380,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
362
380
|
type: ContentChild,
|
|
363
381
|
args: [KlpSelectOptionTemplateDirective, { read: TemplateRef }]
|
|
364
382
|
}] } });
|
|
365
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEN,SAAS,EACT,YAAY,EACZ,SAAS,EAET,YAAY,EACZ,IAAI,EACJ,MAAM,EACN,cAAc,EACd,KAAK,EAGL,QAAQ,EACR,MAAM,EAEN,WAAW,EACX,SAAS,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAC,iBAAiB,EAAC,MAAM,sDAAsD,CAAC;AAEvF,OAAO,EAAC,UAAU,EAAE,oBAAoB,EAAC,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAC,qBAAqB,EAAC,MAAM,oBAAoB,CAAC;;;;;;AAWzD,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,cAAc,CAAM,8BAA8B,CAAC,CAAC;AAG3F,MAAM,OAAO,gCAAgC;8GAAhC,gCAAgC;kGAAhC,gCAAgC;;2FAAhC,gCAAgC;kBAD5C,SAAS;mBAAC,EAAC,QAAQ,EAAE,sBAAsB,EAAC;;AAU7C,MAAM,OAAO,eAAgB,SAAQ,iBAAoC;IAqCxE,YAC+B,MAA4B,EAC5B,gBAAkC,EACf,YAAiB,EAC1D,KAAiB,EACjB,MAAc;QAEtB,KAAK,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QANF,WAAM,GAAN,MAAM,CAAsB;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QACf,iBAAY,GAAZ,YAAY,CAAK;QAC1D,UAAK,GAAL,KAAK,CAAY;QACjB,WAAM,GAAN,MAAM,CAAQ;QAvCd,gBAAW,GAA8B,YAAY,CAAC;QAEtD,aAAQ,GAAG,KAAK,CAAC;QACjB,8BAAyB,GAAG,KAAK,CAAC;QAClC,cAAS,GAAG,IAAI,CAAC;QACjB,oBAAe,GAAG,IAAI,CAAC;QACvB,uBAAkB,GAAG,KAAK,CAAC;QAC3B,eAAU,GAAG,IAAI,CAAC;QAClB,kBAAa,GAAG,IAAI,CAAC;QACrB,mBAAc,GAAG,IAAI,CAAC;QACf,qBAAgB,GAAiD,IAAI,CAAC;QACtE,sBAAiB,GAAqB,MAAM,CAAC;QAG5C,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QACtC,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QACxC,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAC;QACpC,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAC;QACpC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAClC,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;QACnC,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAMjD,yBAAoB,GAAG,CAAC,CAAC,CAAC;QAC3B,0BAAqB,GAAiD,QAAQ,CAAC;QAC9E,WAAM,GAAY,KAAK,CAAC;QACxB,yBAAoB,GAAG,CAAC,CAAC;QACzB,yBAAoB,GAAG,CAAC,CAAC;QAoBzB,gBAAW,GAAG,CAAC,CAAC,EAAE,EAAE;YAC3B,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;gBACvB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAEtC,CAAC;QACF,CAAC,CAAA;QA4GO,kCAA6B,GAAG,GAAG,EAAE;YAC5C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;YAClF,aAAa,CAAC,KAAK,CAAC,UAAU,GAAG,SAAS,CAAC;YAC3C,IAAI,IAAI,CAAC,WAAW,KAAK,UAAU,EAAE,CAAC;gBACrC,OAAO;YACR,CAAC;YACD,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,qBAAqB,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;YAClH,IAAI,CAAC,oBAAoB,GAAG,UAAU,CAAC;YAEvC,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YACvC,IAAI,CAAC,eAAe,EAAE,CAAC;QACxB,CAAC,CAAC;QAEM,iCAA4B,GAAG,KAAK,IAAmB,EAAE;YAChE,IAAI,IAAI,CAAC,eAAe,KAAK,KAAK,EAAE,CAAC;gBACpC,MAAM,qBAAqB,EAAE,CAAC;gBAC9B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC,EAAE,CAAC;oBAChF,OAAO;gBACR,CAAC;gBACD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;gBACjG,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;gBAC7G,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;gBACpG,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;gBAClF,IAAI,aAAa,EAAE,CAAC;oBACnB,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,IAAI,CAAC;oBAC3E,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,EAAE,QAAQ,EAAE,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC;oBACzI,MAAM,qBAAqB,EAAE,CAAC;oBAC9B,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;oBAC3E,MAAM,kBAAkB,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;oBAEvE,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC;oBAC/E,MAAM,iBAAiB,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,GAAG,gBAAgB,CAAC,CAAC;oBAC1H,MAAM,gBAAgB,GAAG,kBAAkB,GAAG,WAAW,CAAC;oBAC1D,IAAI,IAAI,CAAC,iBAAiB,KAAK,OAAO,EAAE,CAAC;wBACxC,IAAI,gBAAgB,GAAG,gBAAgB,EAAE,CAAC;4BACzC,IAAI,CAAC,oBAAoB,GAAG,CAAC,gBAAgB,GAAG,EAAE,CAAC;wBACpD,CAAC;6BAAM,CAAC;4BACP,IAAI,CAAC,oBAAoB,GAAG,CAAC,gBAAgB,CAAC;wBAC/C,CAAC;oBACF,CAAC;yBAAM,IAAI,gBAAgB,GAAG,iBAAiB,EAAE,CAAC;wBACjD,IAAI,CAAC,oBAAoB,GAAG,CAAC,gBAAgB,GAAG,iBAAiB,GAAG,EAAE,CAAC;oBACxE,CAAC;oBACD,IAAI,CAAC,eAAe,EAAE,CAAC;gBACxB,CAAC;YACF,CAAC;QACF,CAAC,CAAC;QAuDK,UAAK,GAAG,GAAS,EAAE;YACzB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QACvB,CAAC,CAAA;QAEM,SAAI,GAAG,GAAS,EAAE;YACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtB,CAAC,CAAA;QAEM,UAAK,GAAG,GAAS,EAAE;YACzB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QACvB,CAAC,CAAA;IAvOD,CAAC;IAED,eAAe;QACd,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IAC/F,CAAC;IASO,OAAO;QACd,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;YACjF,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;YACjF,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QACtE,CAAC;IACF,CAAC;IAEO,SAAS;QAChB,IAAI,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YACvC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;YACjF,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC7B,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC;YAChC,SAAS,CAAC,YAAY,CAAC,OAAO,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QACxD,CAAC;IACF,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAsB;QACvC,IAAI,IAAI,CAAC,MAAM,IAAI,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YAChD,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC,CAAC;YAC/B,0DAA0D;YAC1D,MAAM,qBAAqB,EAAE,CAAC;YAC9B,MAAM,IAAI,CAAC,4BAA4B,EAAE,CAAC;QAC3C,CAAC;QACD,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;YAC9B,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,CAAC;QACpD,CAAC;QACD,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACpB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,EAAE,aAAa,EAAE,aAAa,CAAC,8BAA8B,CAAC,CAAC;YAC3F,IAAI,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC3B,SAAS,CAAC,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC;YACnD,CAAC;QACF,CAAC;IACF,CAAC;IAED,qBAAqB,CAAC,GAAW;QAChC,QAAQ,GAAG,EAAE,CAAC;YACb,KAAK,aAAa;gBACjB,OAAO,GAAG,EAAE,CAAC,gBAAgB,CAAC;YAC/B,KAAK,gBAAgB;gBACpB,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,MAAM,WAAW,CAAC;QAC1C,CAAC;IACF,CAAC;IAED,cAAc,CAAC,GAAW,EAAE,SAAc,IAAI;QAC7C,IAAI,GAAG,KAAK,aAAa,IAAI,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;YACrE,OAAO,IAAI,CAAC,WAAW,CAAC;QACzB,CAAC;QACD,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;IACtF,CAAC;IAED,QAAQ,CAAC,aAAqB;QAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC,CAAC;QAC1E,IAAI,IAAI,CAAC,oBAAoB,GAAG,aAAa,IAAI,aAAa,KAAK,YAAY,EAAE,CAAC;YACjF,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC1B,CAAC;QACD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC/E,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACrC,CAAC;IAED,kBAAkB,CAAC,WAAmB;QACrC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,MAAM;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QAEnB,IAAI,IAAI,CAAC,WAAW,KAAK,YAAY,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC;YAC7E,IAAI,CAAC,yBAAyB,EAAE,CAAC;QAClC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;QACtB,CAAC;QACD,0DAA0D;QAC1D,MAAM,qBAAqB,EAAE,CAAC;QAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAErB,MAAM,IAAI,CAAC,4BAA4B,EAAE,CAAC;QAC1C,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC3B,IAAI,CAAC,6BAA6B,EAAE,CAAC;YACrC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAClC,CAAC,GAAG,IAAI,CAAC,wBAAwB,EAAE,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,CAAC,CAAC;YAC7H,CAAC,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAEO,aAAa;QACpB,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACpD,IAAI,IAAI,CAAC,qBAAqB,KAAK,KAAK,EAAE,CAAC;YAC1C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACvD,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3D,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;QAC1C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACxD,CAAC;IAEO,aAAa;QACpB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1D,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACxD,CAAC;IAiDO,wBAAwB;QAC/B,MAAM,MAAM,GAAG,EAAE,CAAC;QAClB,IAAI,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;QACvC,OAAO,OAAO,CAAC,aAAa,EAAE,CAAC;YAC9B,IAAI,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;gBACrD,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;YACpC,CAAC;YACD,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC;QACjC,CAAC;QACD,OAAO,MAAM,CAAC;IACf,CAAC;IAEO,eAAe;QACtB,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;QAClF,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;YAChC,OAAO;QACR,CAAC;QACD,MAAM,oBAAoB,GAAG,aAAa,IAAI,CAAC,oBAAoB,OAAO,IAAI,CAAC,oBAAoB,KAAK,CAAC;QACzG,MAAM,sBAAsB,GAAG,IAAI,CAAC,qBAAqB,KAAK,KAAK,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/G,IAAI,IAAI,CAAC,WAAW,KAAK,UAAU,EAAE,CAAC;YACrC,aAAa,CAAC,KAAK,CAAC,eAAe,GAAG,UAAU,CAAC;YACjD,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,6BAA6B,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,KAAK,CAAC;QAC1H,CAAC;aAAM,CAAC;YACP,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,oBAAoB,EAAE,sBAAsB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1F,CAAC;IACF,CAAC;IAEO,yBAAyB;QAChC,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;QAC9F,IAAI,WAAW,IAAI,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC;QACvC,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;QACpC,CAAC;IACF,CAAC;IAEO,mBAAmB,CAAC,OAAgB;QAC3C,MAAM,KAAK,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;QACxC,IAAI,KAAK,CAAC,SAAS,KAAK,MAAM,EAAE,CAAC;YAChC,OAAO,IAAI,CAAC;QACb,CAAC;QACD,IAAI,KAAK,CAAC,QAAQ,KAAK,MAAM,EAAE,CAAC;YAC/B,OAAO,IAAI,CAAC;QACb,CAAC;QACD,IAAI,KAAK,CAAC,SAAS,KAAK,QAAQ,EAAE,CAAC;YAClC,OAAO,IAAI,CAAC;QACb,CAAC;QACD,IAAI,KAAK,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC;QACb,CAAC;QACD,OAAO,KAAK,CAAC;IACd,CAAC;IAcM,OAAO;QACb,CAAC,GAAG,IAAI,CAAC,wBAAwB,EAAE,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,CAAC,CAAC;QAC/H,uFAAuF;QACvF,UAAU,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;gBAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;YACtB,CAAC;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,OAAO;QACN,MAAM,uBAAuB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,6BAA6B,CAAC,CAAC;QACtG,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,2BAA2B,CAAC,CAAC;QAC1F,IAAI,UAAU,CAAC,uBAAuB,CAAC,IAAI,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;YACtE,MAAM,WAAW,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;YAChE,MAAM,OAAO,GAAG,QAAQ,CAAC;YACzB,uBAAuB,CAAC,KAAK,CAAC,IAAI,GAAG,QAAQ,WAAW,QAAQ,OAAO,GAAG,CAAC;QAC5E,CAAC;aAAM,IAAI,UAAU,CAAC,uBAAuB,CAAC,EAAE,CAAC;YAChD,uBAAuB,CAAC,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC;QAC5C,CAAC;IACF,CAAC;IAED,WAAW;QACV,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,CAAC,OAAO,CAAC,EAAE,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IACpG,CAAC;8GAjTW,eAAe,8IAwClB,mBAAmB;kGAxChB,eAAe,iuBAFhB,CAAC,EAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,eAAe,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,uEA6BtE,gCAAgC,2BAAS,WAAW,iWCzEnE,muEAsDA;;2FDRa,eAAe;kBAN3B,SAAS;+BACC,iBAAiB,aAGhB,CAAC,EAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,iBAAiB,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC;;0BAwClF,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BAAI,IAAI;;0BAChB,MAAM;2BAAC,mBAAmB;;0BAAG,QAAQ;uFAvC9B,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACW,QAAQ;sBAAxB,MAAM;gBACU,YAAY;sBAA5B,MAAM;gBACU,QAAQ;sBAAxB,MAAM;gBACU,QAAQ;sBAAxB,MAAM;gBACU,MAAM;sBAAtB,MAAM;gBACU,OAAO;sBAAvB,MAAM;gBACU,UAAU;sBAA1B,MAAM;gBACgB,QAAQ;sBAA9B,SAAS;uBAAC,UAAU;gBACC,OAAO;sBAA5B,SAAS;uBAAC,SAAS;gBACM,WAAW;sBAApC,SAAS;uBAAC,aAAa;gBAC6C,eAAe;sBAAnF,YAAY;uBAAC,gCAAgC,EAAE,EAAC,IAAI,EAAE,WAAW,EAAC","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tHost,\n\tInject,\n\tInjectionToken,\n\tInput, NgZone,\n\tOnChanges,\n\tOnDestroy,\n\tOptional,\n\tOutput,\n\tSimpleChanges,\n\tTemplateRef,\n\tViewChild\n} from '@angular/core';\nimport {ControlContainer, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {ValueAccessorBase} from '../value-accessor-base/value-accessor-base.component';\nimport {FormElementComponent} from '../../form/form-element/form-element.component';\nimport {isValueSet, stringIsSetAndFilled} from '../../util/values';\nimport {awaitableForNextCycle} from \"../../util/angular\";\n\nexport type AppSelectOptions = Array<AppSelectOption>;\nexport type AppSelectOption = {\n\tid: any;\n\tname: string;\n\tdescription?: string;\n\tactive?: boolean;\n\tdisabled?: boolean;\n};\n\nexport const SELECT_TRANSLATIONS = new InjectionToken<any>('klp.form.select.translations');\n\n@Directive({selector: '[klpSelectOptionTpl]'})\nexport class KlpSelectOptionTemplateDirective {\n}\n\n@Component({\n\tselector: 'klp-form-select',\n\ttemplateUrl: './select.component.html',\n\tstyleUrls: ['./select.component.scss'],\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: SelectComponent, multi: true}],\n})\nexport class SelectComponent extends ValueAccessorBase<string | string[]> implements OnChanges, AfterViewInit, OnDestroy {\n\t@Input() placeholder: string;\n\t@Input() prefix: string;\n\t@Input() orientation: 'vertical' | 'horizontal' = 'horizontal';\n\t@Input() options: AppSelectOptions;\n\t@Input() multiple = false;\n\t@Input() multipleDisplayedAsAmount = false;\n\t@Input() clearable = true;\n\t@Input() truncateOptions = true;\n\t@Input() withSeparatingLine = false;\n\t@Input() searchable = true;\n\t@Input() hasBorderLeft = true;\n\t@Input() hasBorderRight = true;\n\t@Input() public dropdownPosition: 'auto' | 'bottom' | 'top' | 'left' | 'right' = null;\n\t@Input() public dropdownAlignment: 'left' | 'right' = 'left';\n\t@Input() public customSearchFn: (term: string, item: { id: string; name: string; description: string }) => boolean;\n\t@Input() public footerElement: TemplateRef<any>;\n\t@Output() public onSearch = new EventEmitter<string>();\n\t@Output() public onEndReached = new EventEmitter<void>();\n\t@Output() public onOpened = new EventEmitter<void>();\n\t@Output() public onClosed = new EventEmitter<void>();\n\t@Output() public onBlur = new EventEmitter<void>();\n\t@Output() public onClear = new EventEmitter<void>();\n\t@Output() public onEnterKey = new EventEmitter<string>();\n\t@ViewChild('ngSelect') ngSelect;\n\t@ViewChild('tailRef') tailRef: ElementRef;\n\t@ViewChild('tailMockRef') tailMockRef: ElementRef;\n\t@ContentChild(KlpSelectOptionTemplateDirective, {read: TemplateRef}) customOptionTpl: TemplateRef<any>;\n\n\tprivate lastItemIndexReached = -1;\n\tpublic dropdownPositionToUse: 'auto' | 'bottom' | 'top' | 'left' | 'right' = 'bottom';\n\tprivate isOpen: boolean = false;\n\tprivate dropdownPanelOffsetX = 0;\n\tprivate dropdownPanelOffsetY = 0;\n\tprivate anchorAbsolute: HTMLDivElement;\n\tprivate anchorFixed: HTMLDivElement;\n\n\tconstructor(\n\t\t@Optional() @Host() protected parent: FormElementComponent,\n\t\t@Optional() @Host() protected controlContainer: ControlContainer,\n\t\t@Inject(SELECT_TRANSLATIONS) @Optional() private translations: any,\n\t\tprivate elRef: ElementRef,\n\t\tprivate ngZone: NgZone,\n\t) {\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.addPrefix();\n\t\tthis.addTail();\n\t\tthis.elRef.nativeElement.querySelector('input').addEventListener('keydown', this.keyListener);\n\t}\n\n\tprivate keyListener = (e) => {\n\t\tif (e.key === 'Enter') {\n\t\t\tthis.onEnterKey.emit(e.target.value);\n\n\t\t}\n\t}\n\n\tprivate addTail(): void {\n\t\tif (this.tailMockRef) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst arrowWrapper = this.elRef.nativeElement.querySelector('.ng-arrow-wrapper');\n\t\t\tcontainer.insertBefore(this.tailMockRef.nativeElement, arrowWrapper);\n\t\t}\n\t}\n\n\tprivate addPrefix(): void {\n\t\tif (stringIsSetAndFilled(this.prefix)) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst newNode = document.createElement('div');\n\t\t\tnewNode.className = 'prefix';\n\t\t\tnewNode.innerText = this.prefix;\n\t\t\tcontainer.insertBefore(newNode, container.children[0]);\n\t\t}\n\t}\n\n\tasync ngOnChanges(changes: SimpleChanges): Promise<void> {\n\t\tif (this.isOpen && isValueSet(changes.options)) {\n\t\t\tthis.lastItemIndexReached = -1;\n\t\t\t// waiting for the thing to render until we fire the event\n\t\t\tawait awaitableForNextCycle();\n\t\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\t}\n\t\tif (changes.dropdownPosition) {\n\t\t\tthis.dropdownPositionToUse = this.dropdownPosition;\n\t\t}\n\t\tif (changes.prefix) {\n\t\t\tconst container = this.elRef?.nativeElement?.querySelector('.ng-select-container .prefix');\n\t\t\tif (isValueSet(container)) {\n\t\t\t\tcontainer.innerText = changes.prefix.currentValue;\n\t\t\t}\n\t\t}\n\t}\n\n\tgetDefaultTranslation(key: string): (x: any) => string {\n\t\tswitch (key) {\n\t\t\tcase 'placeholder':\n\t\t\t\treturn () => 'Pick an option';\n\t\t\tcase 'amountSelected':\n\t\t\t\treturn (amount) => `${amount} selected`;\n\t\t}\n\t}\n\n\tgetTranslation(key: string, params: any = null): string {\n\t\tif (key === 'placeholder' && stringIsSetAndFilled(this.placeholder)) {\n\t\t\treturn this.placeholder;\n\t\t}\n\t\treturn this.translations?.[key]?.(params) ?? this.getDefaultTranslation(key)(params);\n\t}\n\n\tonScroll(lastItemIndex: number): void {\n\t\tconst visibleItems = this.ngSelect?.itemsList?.filteredItems?.length ?? 0;\n\t\tif (this.lastItemIndexReached < lastItemIndex && lastItemIndex === visibleItems) {\n\t\t\tthis.onEndReached.emit();\n\t\t}\n\t\tthis.lastItemIndexReached = Math.max(lastItemIndex, this.lastItemIndexReached);\n\t\tthis.setWidthBasedOnOptionsWidths();\n\t}\n\n\tsearchQueryChanged(searchQuery: string): void {\n\t\tthis.onSearch.emit(searchQuery);\n\t}\n\n\tasync onOpen(): Promise<void> {\n\t\tthis.isOpen = true;\n\n\t\tif (this.orientation === 'horizontal' && !isValueSet(this.dropdownPosition)) {\n\t\t\tthis.determineDropdownPosition();\n\t\t}\n\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.createAnchors();\n\t\t}\n\t\t// waiting for the thing to render until we fire the event\n\t\tawait awaitableForNextCycle();\n\t\tthis.onOpened.emit();\n\n\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.setFixedDropdownPanelPosition();\n\t\t\tthis.ngZone.runOutsideAngular(() => {\n\t\t\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.addEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate createAnchors(): void {\n\t\tthis.anchorAbsolute = document.createElement('div');\n\t\tif (this.dropdownPositionToUse === 'top') {\n\t\t\tthis.elRef.nativeElement.prepend(this.anchorAbsolute);\n\t\t} else {\n\t\t\tthis.elRef.nativeElement.appendChild(this.anchorAbsolute);\n\t\t}\n\n\t\tthis.anchorFixed = document.createElement('div');\n\t\tthis.anchorFixed.style.position = 'fixed';\n\t\tthis.elRef.nativeElement.appendChild(this.anchorFixed);\n\t}\n\n\tprivate removeAnchors(): void {\n\t\tthis.elRef.nativeElement.removeChild(this.anchorAbsolute);\n\t\tthis.elRef.nativeElement.removeChild(this.anchorFixed);\n\t}\n\n\tprivate setFixedDropdownPanelPosition = () => {\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tdropdownPanel.style.visibility = 'initial';\n\t\tif (this.orientation === 'vertical') {\n\t\t\treturn;\n\t\t}\n\t\tconst difference = this.anchorAbsolute.getBoundingClientRect().top - this.anchorFixed.getBoundingClientRect().top;\n\t\tthis.dropdownPanelOffsetY = difference;\n\n\t\tdropdownPanel.style.position = 'fixed';\n\t\tthis.setPanelOffsets();\n\t};\n\n\tprivate setWidthBasedOnOptionsWidths = async (): Promise<void> => {\n\t\tif (this.truncateOptions === false) {\n\t\t\tawait awaitableForNextCycle();\n\t\t\tif (!isValueSet(this.elRef.nativeElement.querySelector('.scrollable-content'))) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');\n\t\t\tconst maxWidth = this.elRef.nativeElement.querySelector('.scrollable-content').getBoundingClientRect().width;\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.remove('calculatingWidths');\n\t\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\t\tif (dropdownPanel) {\n\t\t\t\tdropdownPanel.style.minWidth = `${this.elRef.nativeElement.clientWidth}px`;\n\t\t\t\tdropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth, dropdownPanel.getBoundingClientRect().width)}px`;\n\t\t\t\tawait awaitableForNextCycle();\n\t\t\t\tconst pickerWidth = this.elRef.nativeElement.getBoundingClientRect().width;\n\t\t\t\tconst dropdownPanelWidth = dropdownPanel.getBoundingClientRect().width;\n\n\t\t\t\tconst spaceLeftOfElRef = this.elRef.nativeElement.getBoundingClientRect().left;\n\t\t\t\tconst spaceRightOfElRef = window.innerWidth - (this.elRef.nativeElement.getBoundingClientRect().width + spaceLeftOfElRef);\n\t\t\t\tconst extraNeededSpace = dropdownPanelWidth - pickerWidth;\n\t\t\t\tif (this.dropdownAlignment === 'right') {\n\t\t\t\t\tif (extraNeededSpace > spaceLeftOfElRef) {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -spaceLeftOfElRef + 10;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace;\n\t\t\t\t\t}\n\t\t\t\t} else if (extraNeededSpace > spaceRightOfElRef) {\n\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace + spaceRightOfElRef - 20;\n\t\t\t\t}\n\t\t\t\tthis.setPanelOffsets();\n\t\t\t}\n\t\t}\n\t};\n\n\tprivate getAllLimitingContainers(): Array<HTMLElement> {\n\t\tconst result = [];\n\t\tlet current = this.elRef.nativeElement;\n\t\twhile (current.parentElement) {\n\t\t\tif (this.isLimitingContainer(current.parentElement)) {\n\t\t\t\tresult.push(current.parentElement);\n\t\t\t}\n\t\t\tcurrent = current.parentElement;\n\t\t}\n\t\treturn result;\n\t}\n\n\tprivate setPanelOffsets(): void {\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tif (!isValueSet(dropdownPanel)) {\n\t\t\treturn;\n\t\t}\n\t\tconst scrollPositionOffset = `translate(${this.dropdownPanelOffsetX}px, ${this.dropdownPanelOffsetY}px)`;\n\t\tconst dropdownPositionOffset = this.dropdownPositionToUse === 'top' ? `translateY(-100%) translateY(1px)` : '';\n\t\tif (this.orientation === 'vertical') {\n\t\t\tdropdownPanel.style.transformOrigin = 'top left';\n\t\t\tdropdownPanel.style.transform = `rotate(90deg) translateY(-${this.elRef.nativeElement.getBoundingClientRect().width}px)`;\n\t\t} else {\n\t\t\tdropdownPanel.style.transform = [scrollPositionOffset, dropdownPositionOffset].join(' ');\n\t\t}\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tconst bottomSpace = window.innerHeight - this.elRef.nativeElement.getBoundingClientRect().top;\n\t\tif (bottomSpace >= 330) {\n\t\t\tthis.dropdownPositionToUse = 'bottom';\n\t\t} else {\n\t\t\tthis.dropdownPositionToUse = 'top';\n\t\t}\n\t}\n\n\tprivate isLimitingContainer(element: Element): boolean {\n\t\tconst style = getComputedStyle(element);\n\t\tif (style.overflowY === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflowY === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpublic focus = (): void => {\n\t\tthis.ngSelect.focus();\n\t}\n\n\tpublic open = (): void => {\n\t\tthis.ngSelect.open();\n\t}\n\n\tpublic close = (): void => {\n\t\tthis.ngSelect.close();\n\t}\n\n\tpublic onClose(): void {\n\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.removeEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t// Give angular a second to render the closed situation before emitting the close event\n\t\tsetTimeout(() => {\n\t\t\tthis.isOpen = false;\n\t\t\tif (!this.truncateOptions) {\n\t\t\t\tthis.removeAnchors();\n\t\t\t}\n\t\t\tthis.onClosed.emit();\n\t\t});\n\t}\n\n\tonFocus(): void {\n\t\tconst singleValueInputElement = this.elRef.nativeElement.querySelector('.ng-select-single .ng-input');\n\t\tconst prefixElement = this.elRef.nativeElement.querySelector('.ng-select-single .prefix');\n\t\tif (isValueSet(singleValueInputElement) && isValueSet(prefixElement)) {\n\t\t\tconst prefixWidth = prefixElement.getBoundingClientRect().width;\n\t\t\tconst spacing = '0.4rem';\n\t\t\tsingleValueInputElement.style.left = `calc(${prefixWidth}px + ${spacing})`;\n\t\t} else if (isValueSet(singleValueInputElement)) {\n\t\t\tsingleValueInputElement.style.left = `0px`;\n\t\t}\n\t}\n\n\tngOnDestroy(): void {\n\t\tsuper.ngOnDestroy();\n\t\tthis.elRef.nativeElement?.querySelector('input')?.removeEventListener('keydown', this.keyListener);\n\t}\n}\n","<ng-select\n\t#ngSelect\n\t[placeholder]=\"getTranslation('placeholder')\"\n\tbindLabel=\"name\"\n\tbindValue=\"id\"\n\t[items]=\"options\"\n\t[clearable]=\"clearable\"\n\t[(ngModel)]=\"innerValue\"\n\t[ngClass]=\"{showErrors: isInErrorState(), verticalOrientation: orientation === 'vertical', truncateOptions: truncateOptions, nonTruncatedOptions: !truncateOptions, withSeparatingLine: withSeparatingLine, noBorderLeft: !hasBorderLeft, noBorderRight: !hasBorderRight}\"\n\t(change)=\"setInnerValueAndNotify(innerValue)\"\n\t[multiple]=\"multiple\"\n\t[disabled]=\"disabled\"\n\t(blur)=\"touch(); onBlur.emit()\"\n\t(clear)=\"onClear.emit()\"\n\t(search)=\"searchQueryChanged($event.term)\"\n\t[searchable]=\"searchable\"\n\t[dropdownPosition]=\"dropdownPositionToUse\"\n\t[searchFn]=\"customSearchFn\"\n\t[selectOnTab]=\"true\"\n\t[virtualScroll]=\"true\"\n\t(scroll)=\"onScroll($event.end)\"\n\t(open)=\"onOpen()\"\n\t(close)=\"onClose()\"\n\t(focus)=\"onFocus()\"\n>\n\t<ng-template let-item=\"item\" ng-option-tmp>\n\t\t<ng-container *ngIf=\"customOptionTpl\" [ngTemplateOutlet]=\"customOptionTpl\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n\t\t<div [attr.data-cy]=\"item.id\" *ngIf=\"!customOptionTpl\">\n\t\t\t{{ item.name }}\n\t\t\t<div *ngIf=\"item.description\" class=\"dropdown-item-description\">\n\t\t\t\t{{ item.description }}\n\t\t\t</div>\n\t\t</div>\n\t</ng-template>\n\t<ng-container *ngIf=\"multiple && multipleDisplayedAsAmount && innerValue?.length > 1\">\n\t\t<ng-template ng-multi-label-tmp>\n\t\t\t<div class=\"ng-value\">\n\t\t\t\t<span class=\"ng-value-label\">{{getTranslation('amountSelected', innerValue?.length)}}</span>\n\t\t\t</div>\n\t\t</ng-template>\n\t</ng-container>\n\t<ng-template ng-footer-tmp *ngIf=\"footerElement\">\n\t\t<ng-container [ngTemplateOutlet]=\"footerElement\"></ng-container>\n\t</ng-template>\n</ng-select>\n\n<div class=\"tail\" #tailRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n<!-- I need this mock to reserve the space. I cant use the normal tail because that opens the dropdown from ng-select -->\n<!-- I have no idea how to avoid that -->\n<div class=\"tailMock\" #tailMockRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n"]}
|
|
383
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tHost,\n\tInject,\n\tInjectionToken,\n\tInput, NgZone,\n\tOnChanges,\n\tOnDestroy,\n\tOptional,\n\tOutput,\n\tSimpleChanges,\n\tTemplateRef,\n\tViewChild\n} from '@angular/core';\nimport {ControlContainer, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {ValueAccessorBase} from '../value-accessor-base/value-accessor-base.component';\nimport {FormElementComponent} from '../../form/form-element/form-element.component';\nimport {isValueSet, stringIsSetAndFilled} from '../../util/values';\nimport {awaitableForNextCycle} from \"../../util/angular\";\n\nexport type AppSelectOptions = Array<AppSelectOption>;\nexport type AppSelectOption = {\n\tid: any;\n\tname: string;\n\tdescription?: string;\n\tactive?: boolean;\n\tdisabled?: boolean;\n};\n\nexport const SELECT_TRANSLATIONS = new InjectionToken<any>('klp.form.select.translations');\n\n@Directive({selector: '[klpSelectOptionTpl]'})\nexport class KlpSelectOptionTemplateDirective {\n}\n\n@Component({\n\tselector: 'klp-form-select',\n\ttemplateUrl: './select.component.html',\n\tstyleUrls: ['./select.component.scss'],\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: SelectComponent, multi: true}],\n})\nexport class SelectComponent extends ValueAccessorBase<string | string[]> implements OnChanges, AfterViewInit, OnDestroy {\n\t@Input() placeholder: string;\n\t@Input() prefix: string;\n\t@Input() orientation: 'vertical' | 'horizontal' = 'horizontal';\n\t@Input() options: AppSelectOptions;\n\t@Input() multiple = false;\n\t@Input() multipleDisplayedAsAmount = false;\n\t@Input() clearable = true;\n\t@Input() truncateOptions = true;\n\t@Input() withSeparatingLine = false;\n\t@Input() searchable = true;\n\t@Input() hasBorderLeft = true;\n\t@Input() hasBorderRight = true;\n\t@Input() public dropdownPosition: 'auto' | 'bottom' | 'top' | 'left' | 'right' = null;\n\t@Input() public dropdownAlignment: 'left' | 'right' = 'left';\n\t@Input() public customSearchFn: (term: string, item: { id: string; name: string; description: string }) => boolean;\n\t@Input() public footerElement: TemplateRef<any>;\n\t@Output() public onSearch = new EventEmitter<string>();\n\t@Output() public onEndReached = new EventEmitter<void>();\n\t@Output() public onOpened = new EventEmitter<void>();\n\t@Output() public onClosed = new EventEmitter<void>();\n\t@Output() public onBlur = new EventEmitter<void>();\n\t@Output() public onClear = new EventEmitter<void>();\n\t@Output() public onEnterKey = new EventEmitter<string>();\n\t@ViewChild('ngSelect') ngSelect;\n\t@ViewChild('tailRef') tailRef: ElementRef;\n\t@ViewChild('tailMockRef') tailMockRef: ElementRef;\n\t@ContentChild(KlpSelectOptionTemplateDirective, {read: TemplateRef}) customOptionTpl: TemplateRef<any>;\n\n\tprivate lastItemIndexReached = -1;\n\tpublic dropdownPositionToUse: 'auto' | 'bottom' | 'top' | 'left' | 'right' = 'bottom';\n\tprivate isOpen: boolean = false;\n\tprivate dropdownPanelOffsetX = 0;\n\tprivate dropdownPanelOffsetY = 0;\n\tprivate anchorAbsolute: HTMLDivElement;\n\tprivate anchorFixed: HTMLDivElement;\n\n\tconstructor(\n\t\t@Optional() @Host() protected parent: FormElementComponent,\n\t\t@Optional() @Host() protected controlContainer: ControlContainer,\n\t\t@Inject(SELECT_TRANSLATIONS) @Optional() private translations: any,\n\t\tprivate elRef: ElementRef,\n\t\tprivate ngZone: NgZone,\n\t) {\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.addPrefix();\n\t\tthis.addTail();\n\t\tthis.elRef.nativeElement.querySelector('input').addEventListener('keydown', this.keyListener);\n\t}\n\n\tprivate keyListener = (e) => {\n\t\tif (e.key === 'Enter') {\n\t\t\tthis.onEnterKey.emit(e.target.value);\n\n\t\t}\n\t}\n\n\tprivate addTail(): void {\n\t\tif (this.tailMockRef) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst arrowWrapper = this.elRef.nativeElement.querySelector('.ng-arrow-wrapper');\n\t\t\tcontainer.insertBefore(this.tailMockRef.nativeElement, arrowWrapper);\n\t\t}\n\t}\n\n\tprivate addPrefix(): void {\n\t\tif (stringIsSetAndFilled(this.prefix)) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst newNode = document.createElement('div');\n\t\t\tnewNode.className = 'prefix';\n\t\t\tnewNode.innerText = this.prefix;\n\t\t\tcontainer.insertBefore(newNode, container.children[0]);\n\t\t}\n\t}\n\n\tasync ngOnChanges(changes: SimpleChanges): Promise<void> {\n\t\tif (this.isOpen && isValueSet(changes.options)) {\n\t\t\tthis.lastItemIndexReached = -1;\n\t\t\t// waiting for the thing to render until we fire the event\n\t\t\tawait awaitableForNextCycle();\n\t\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\t}\n\t\tif (changes.dropdownPosition) {\n\t\t\tthis.dropdownPositionToUse = this.dropdownPosition;\n\t\t}\n\t\tif (changes.prefix) {\n\t\t\tconst container = this.elRef?.nativeElement?.querySelector('.ng-select-container .prefix');\n\t\t\tif (isValueSet(container)) {\n\t\t\t\tcontainer.innerText = changes.prefix.currentValue;\n\t\t\t}\n\t\t}\n\t}\n\n\tgetDefaultTranslation(key: string): (x: any) => string {\n\t\tswitch (key) {\n\t\t\tcase 'placeholder':\n\t\t\t\treturn () => 'Pick an option';\n\t\t\tcase 'amountSelected':\n\t\t\t\treturn (amount) => `${amount} selected`;\n\t\t}\n\t}\n\n\tgetTranslation(key: string, params: any = null): string {\n\t\tif (key === 'placeholder' && stringIsSetAndFilled(this.placeholder)) {\n\t\t\treturn this.placeholder;\n\t\t}\n\t\treturn this.translations?.[key]?.(params) ?? this.getDefaultTranslation(key)(params);\n\t}\n\n\tonScroll(lastItemIndex: number): void {\n\t\tconst visibleItems = this.ngSelect?.itemsList?.filteredItems?.length ?? 0;\n\t\tif (this.lastItemIndexReached < lastItemIndex && lastItemIndex === visibleItems) {\n\t\t\tthis.onEndReached.emit();\n\t\t}\n\t\tthis.lastItemIndexReached = Math.max(lastItemIndex, this.lastItemIndexReached);\n\t\tthis.setWidthBasedOnOptionsWidths();\n\t}\n\n\tsearchQueryChanged(searchQuery: string): void {\n\t\tthis.onSearch.emit(searchQuery);\n\t}\n\n\tasync onOpen(): Promise<void> {\n\t\tthis.isOpen = true;\n\n\t\tif (this.orientation === 'horizontal' && !isValueSet(this.dropdownPosition)) {\n\t\t\tthis.determineDropdownPosition();\n\t\t}\n\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.createAnchors();\n\t\t}\n\t\t// waiting for the thing to render until we fire the event\n\t\tawait awaitableForNextCycle();\n\t\tthis.onOpened.emit();\n\n\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.setFixedDropdownPanelPosition();\n\t\t\tthis.ngZone.runOutsideAngular(() => {\n\t\t\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.addEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate createAnchors(): void {\n\t\tthis.anchorAbsolute = document.createElement('div');\n\t\tif (this.dropdownPositionToUse === 'top') {\n\t\t\tthis.elRef.nativeElement.prepend(this.anchorAbsolute);\n\t\t} else {\n\t\t\tthis.elRef.nativeElement.appendChild(this.anchorAbsolute);\n\t\t}\n\n\t\tthis.anchorFixed = document.createElement('div');\n\t\tthis.anchorFixed.style.position = 'fixed';\n\t\tthis.elRef.nativeElement.appendChild(this.anchorFixed);\n\t}\n\n\tprivate removeAnchors(): void {\n\t\tthis.elRef.nativeElement.removeChild(this.anchorAbsolute);\n\t\tthis.elRef.nativeElement.removeChild(this.anchorFixed);\n\t}\n\n\tprivate setFixedDropdownPanelPosition = () => {\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tdropdownPanel.style.visibility = 'initial';\n\t\tif (this.orientation === 'vertical') {\n\t\t\treturn;\n\t\t}\n\t\tconst difference = this.anchorAbsolute.getBoundingClientRect().top - this.anchorFixed.getBoundingClientRect().top;\n\t\tthis.dropdownPanelOffsetY = difference;\n\n\t\tdropdownPanel.style.position = 'fixed';\n\t\tthis.setPanelOffsets();\n\t};\n\n\tprivate setWidthBasedOnOptionsWidths = async (): Promise<void> => {\n\t\tif (this.truncateOptions === false) {\n\t\t\tawait awaitableForNextCycle();\n\t\t\tif (!isValueSet(this.elRef.nativeElement.querySelector('.scrollable-content'))) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');\n\t\t\tconst paddingForScrollbar = this.getScrollbarWidth();\n\t\t\tconst maxWidth = this.elRef.nativeElement.querySelector('.scrollable-content').getBoundingClientRect().width + paddingForScrollbar;\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.remove('calculatingWidths');\n\t\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\t\tif (dropdownPanel) {\n\t\t\t\tdropdownPanel.style.minWidth = `${this.elRef.nativeElement.clientWidth}px`;\n\t\t\t\tdropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth, dropdownPanel.getBoundingClientRect().width)}px`;\n\t\t\t\tawait awaitableForNextCycle();\n\t\t\t\tconst pickerWidth = this.elRef.nativeElement.getBoundingClientRect().width;\n\t\t\t\tconst dropdownPanelWidth = dropdownPanel.getBoundingClientRect().width;\n\n\t\t\t\tconst spaceLeftOfElRef = this.elRef.nativeElement.getBoundingClientRect().left;\n\t\t\t\tconst spaceRightOfElRef = window.innerWidth - (this.elRef.nativeElement.getBoundingClientRect().width + spaceLeftOfElRef);\n\t\t\t\tconst extraNeededSpace = dropdownPanelWidth - pickerWidth;\n\t\t\t\tif (this.dropdownAlignment === 'right') {\n\t\t\t\t\tif (extraNeededSpace > spaceLeftOfElRef) {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -spaceLeftOfElRef + 10;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace;\n\t\t\t\t\t}\n\t\t\t\t} else if (extraNeededSpace > spaceRightOfElRef) {\n\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace + spaceRightOfElRef - 20;\n\t\t\t\t}\n\t\t\t\tthis.setPanelOffsets();\n\t\t\t}\n\t\t}\n\t};\n\n\tprivate getAllLimitingContainers(): Array<HTMLElement> {\n\t\tconst result = [];\n\t\tlet current = this.elRef.nativeElement;\n\t\twhile (current.parentElement) {\n\t\t\tif (this.isLimitingContainer(current.parentElement)) {\n\t\t\t\tresult.push(current.parentElement);\n\t\t\t}\n\t\t\tcurrent = current.parentElement;\n\t\t}\n\t\treturn result;\n\t}\n\n\tprivate setPanelOffsets(): void {\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tif (!isValueSet(dropdownPanel)) {\n\t\t\treturn;\n\t\t}\n\t\tconst scrollPositionOffset = `translate(${this.dropdownPanelOffsetX}px, ${this.dropdownPanelOffsetY}px)`;\n\t\tconst dropdownPositionOffset = this.dropdownPositionToUse === 'top' ? `translateY(-100%) translateY(1px)` : '';\n\t\tif (this.orientation === 'vertical') {\n\t\t\tdropdownPanel.style.transformOrigin = 'top left';\n\t\t\tdropdownPanel.style.transform = `rotate(90deg) translateY(-${this.elRef.nativeElement.getBoundingClientRect().width}px)`;\n\t\t} else {\n\t\t\tdropdownPanel.style.transform = [scrollPositionOffset, dropdownPositionOffset].join(' ');\n\t\t}\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tconst bottomSpace = window.innerHeight - this.elRef.nativeElement.getBoundingClientRect().top;\n\t\tif (bottomSpace >= 330) {\n\t\t\tthis.dropdownPositionToUse = 'bottom';\n\t\t} else {\n\t\t\tthis.dropdownPositionToUse = 'top';\n\t\t}\n\t}\n\n\tprivate isLimitingContainer(element: Element): boolean {\n\t\tconst style = getComputedStyle(element);\n\t\tif (style.overflowY === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflowY === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpublic focus = (): void => {\n\t\tthis.ngSelect.focus();\n\t}\n\n\tpublic open = (): void => {\n\t\tthis.ngSelect.open();\n\t}\n\n\tpublic close = (): void => {\n\t\tthis.ngSelect.close();\n\t}\n\n\tpublic onClose(): void {\n\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.removeEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t// Give angular a second to render the closed situation before emitting the close event\n\t\tsetTimeout(() => {\n\t\t\tthis.isOpen = false;\n\t\t\tif (!this.truncateOptions) {\n\t\t\t\tthis.removeAnchors();\n\t\t\t}\n\t\t\tthis.onClosed.emit();\n\t\t});\n\t}\n\n\tonFocus(): void {\n\t\tconst singleValueInputElement = this.elRef.nativeElement.querySelector('.ng-select-single .ng-input');\n\t\tconst prefixElement = this.elRef.nativeElement.querySelector('.ng-select-single .prefix');\n\t\tif (isValueSet(singleValueInputElement) && isValueSet(prefixElement)) {\n\t\t\tconst prefixWidth = prefixElement.getBoundingClientRect().width;\n\t\t\tconst spacing = '0.4rem';\n\t\t\tsingleValueInputElement.style.left = `calc(${prefixWidth}px + ${spacing})`;\n\t\t} else if (isValueSet(singleValueInputElement)) {\n\t\t\tsingleValueInputElement.style.left = `0px`;\n\t\t}\n\t}\n\n\tprivate getScrollbarWidth(): number {\n\t\t// Create a temporary div element\n\t\tconst div = document.createElement('div');\n\n\t\t// Set the style to measure the scrollbar\n\t\tdiv.style.overflow = 'scroll'; // Enable scrollbar\n\t\tdiv.style.width = '100px';      // Set a fixed width\n\t\tdiv.style.height = '100px';     // Set a fixed height\n\t\tdiv.style.position = 'absolute'; // Prevent the element from taking space in the layout\n\t\tdiv.style.top = '-9999px';      // Position it out of the viewport\n\n\t\t// Append the element to the body\n\t\tdocument.body.appendChild(div);\n\n\t\t// Get the width of the scrollbar\n\t\tconst scrollbarWidth = div.offsetWidth - div.clientWidth;\n\n\t\t// Remove the temporary element from the DOM\n\t\tdocument.body.removeChild(div);\n\n\t\treturn scrollbarWidth;\n\t}\n\n\tngOnDestroy(): void {\n\t\tsuper.ngOnDestroy();\n\t\tthis.elRef.nativeElement?.querySelector('input')?.removeEventListener('keydown', this.keyListener);\n\t}\n}\n","<ng-select\n\t#ngSelect\n\t[placeholder]=\"getTranslation('placeholder')\"\n\tbindLabel=\"name\"\n\tbindValue=\"id\"\n\t[items]=\"options\"\n\t[clearable]=\"clearable\"\n\t[(ngModel)]=\"innerValue\"\n\t[ngClass]=\"{showErrors: isInErrorState(), verticalOrientation: orientation === 'vertical', truncateOptions: truncateOptions, nonTruncatedOptions: !truncateOptions, withSeparatingLine: withSeparatingLine, noBorderLeft: !hasBorderLeft, noBorderRight: !hasBorderRight}\"\n\t(change)=\"setInnerValueAndNotify(innerValue)\"\n\t[multiple]=\"multiple\"\n\t[disabled]=\"disabled\"\n\t(blur)=\"touch(); onBlur.emit()\"\n\t(clear)=\"onClear.emit()\"\n\t(search)=\"searchQueryChanged($event.term)\"\n\t[searchable]=\"searchable\"\n\t[dropdownPosition]=\"dropdownPositionToUse\"\n\t[searchFn]=\"customSearchFn\"\n\t[selectOnTab]=\"true\"\n\t[virtualScroll]=\"true\"\n\t(scroll)=\"onScroll($event.end)\"\n\t(open)=\"onOpen()\"\n\t(close)=\"onClose()\"\n\t(focus)=\"onFocus()\"\n>\n\t<ng-template let-item=\"item\" ng-option-tmp>\n\t\t<ng-container *ngIf=\"customOptionTpl\" [ngTemplateOutlet]=\"customOptionTpl\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n\t\t<div [attr.data-cy]=\"item.id\" *ngIf=\"!customOptionTpl\">\n\t\t\t{{ item.name }}\n\t\t\t<div *ngIf=\"item.description\" class=\"dropdown-item-description\">\n\t\t\t\t{{ item.description }}\n\t\t\t</div>\n\t\t</div>\n\t</ng-template>\n\t<ng-container *ngIf=\"multiple && multipleDisplayedAsAmount && innerValue?.length > 1\">\n\t\t<ng-template ng-multi-label-tmp>\n\t\t\t<div class=\"ng-value\">\n\t\t\t\t<span class=\"ng-value-label\">{{getTranslation('amountSelected', innerValue?.length)}}</span>\n\t\t\t</div>\n\t\t</ng-template>\n\t</ng-container>\n\t<ng-template ng-footer-tmp *ngIf=\"footerElement\">\n\t\t<ng-container [ngTemplateOutlet]=\"footerElement\"></ng-container>\n\t</ng-template>\n</ng-select>\n\n<div class=\"tail\" #tailRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n<!-- I need this mock to reserve the space. I cant use the normal tail because that opens the dropdown from ng-select -->\n<!-- I have no idea how to avoid that -->\n<div class=\"tailMock\" #tailMockRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n"]}
|
|
@@ -1341,7 +1341,8 @@ class SelectComponent extends ValueAccessorBase {
|
|
|
1341
1341
|
return;
|
|
1342
1342
|
}
|
|
1343
1343
|
this.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');
|
|
1344
|
-
const
|
|
1344
|
+
const paddingForScrollbar = this.getScrollbarWidth();
|
|
1345
|
+
const maxWidth = this.elRef.nativeElement.querySelector('.scrollable-content').getBoundingClientRect().width + paddingForScrollbar;
|
|
1345
1346
|
this.elRef.nativeElement.querySelector('.scrollable-content').classList.remove('calculatingWidths');
|
|
1346
1347
|
const dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');
|
|
1347
1348
|
if (dropdownPanel) {
|
|
@@ -1550,6 +1551,23 @@ class SelectComponent extends ValueAccessorBase {
|
|
|
1550
1551
|
singleValueInputElement.style.left = `0px`;
|
|
1551
1552
|
}
|
|
1552
1553
|
}
|
|
1554
|
+
getScrollbarWidth() {
|
|
1555
|
+
// Create a temporary div element
|
|
1556
|
+
const div = document.createElement('div');
|
|
1557
|
+
// Set the style to measure the scrollbar
|
|
1558
|
+
div.style.overflow = 'scroll'; // Enable scrollbar
|
|
1559
|
+
div.style.width = '100px'; // Set a fixed width
|
|
1560
|
+
div.style.height = '100px'; // Set a fixed height
|
|
1561
|
+
div.style.position = 'absolute'; // Prevent the element from taking space in the layout
|
|
1562
|
+
div.style.top = '-9999px'; // Position it out of the viewport
|
|
1563
|
+
// Append the element to the body
|
|
1564
|
+
document.body.appendChild(div);
|
|
1565
|
+
// Get the width of the scrollbar
|
|
1566
|
+
const scrollbarWidth = div.offsetWidth - div.clientWidth;
|
|
1567
|
+
// Remove the temporary element from the DOM
|
|
1568
|
+
document.body.removeChild(div);
|
|
1569
|
+
return scrollbarWidth;
|
|
1570
|
+
}
|
|
1553
1571
|
ngOnDestroy() {
|
|
1554
1572
|
super.ngOnDestroy();
|
|
1555
1573
|
this.elRef.nativeElement?.querySelector('input')?.removeEventListener('keydown', this.keyListener);
|