mis-crystal-design-system 18.1.3 → 18.1.4-test-1
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/async-search-dropdown/async-dropdown.component.d.ts +5 -3
- package/esm2022/async-search-dropdown/async-dropdown.component.mjs +62 -36
- package/esm2022/input/mis-input.component.mjs +2 -2
- package/esm2022/table/sort-icons.directive.mjs +13 -2
- package/esm2022/table/table.component.mjs +21 -17
- package/esm2022/timepicker/timepicker.component.mjs +26 -5
- package/esm2022/timerangepicker/timerangepicker.component.mjs +22 -16
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +61 -35
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-input.mjs +2 -2
- package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +31 -16
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timepicker.mjs +25 -4
- package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +21 -15
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
- package/input/mis-input.component.scss +2 -3
- package/package.json +7 -7
- package/styles/mis-old-icon-styles.scss +0 -498
- package/table/table.component.d.ts +1 -0
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { ElementRef, Injector, NgZone, TemplateRef, ViewContainerRef } from '@angular/core';
|
|
1
|
+
import { ElementRef, Injector, NgZone, OnInit, OnDestroy, TemplateRef, ViewContainerRef } from '@angular/core';
|
|
2
2
|
import { AbstractControl, UntypedFormControl } from '@angular/forms';
|
|
3
3
|
import { Overlay } from '@angular/cdk/overlay';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
type IListData = any;
|
|
6
|
-
export declare class AsyncDropdownComponent {
|
|
6
|
+
export declare class AsyncDropdownComponent implements OnInit, OnDestroy {
|
|
7
7
|
private overlay;
|
|
8
8
|
private viewContainerRef;
|
|
9
9
|
private _ngZone;
|
|
@@ -42,12 +42,14 @@ export declare class AsyncDropdownComponent {
|
|
|
42
42
|
searchInput: UntypedFormControl;
|
|
43
43
|
private httpStreamTrigger;
|
|
44
44
|
private overlayRef?;
|
|
45
|
+
private searchSubscription?;
|
|
46
|
+
private controlSubscription?;
|
|
45
47
|
opened: import("@angular/core").WritableSignal<boolean>;
|
|
46
48
|
loading: import("@angular/core").WritableSignal<boolean>;
|
|
47
49
|
error: import("@angular/core").WritableSignal<boolean>;
|
|
48
50
|
openPopUpOnTab: import("@angular/core").WritableSignal<boolean>;
|
|
49
51
|
data: import("@angular/core").WritableSignal<any[]>;
|
|
50
|
-
private
|
|
52
|
+
private isSelecting;
|
|
51
53
|
ngOnInit(): void;
|
|
52
54
|
ngOnChanges(): void;
|
|
53
55
|
ngOnDestroy(): void;
|
|
@@ -2,7 +2,7 @@ import { Component, ContentChild, HostListener, ViewChild, } from '@angular/core
|
|
|
2
2
|
import { UntypedFormControl } from '@angular/forms';
|
|
3
3
|
import { OverlayConfig, ConnectionPositionPair, } from '@angular/cdk/overlay';
|
|
4
4
|
import { TemplatePortal } from '@angular/cdk/portal';
|
|
5
|
-
import { signal,
|
|
5
|
+
import { signal, input, output } from '@angular/core';
|
|
6
6
|
import { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators';
|
|
7
7
|
import { merge, Subject } from 'rxjs';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
@@ -227,34 +227,7 @@ export class AsyncDropdownComponent {
|
|
|
227
227
|
this.error = signal(false);
|
|
228
228
|
this.openPopUpOnTab = signal(false);
|
|
229
229
|
this.data = signal([]);
|
|
230
|
-
//
|
|
231
|
-
this.searchEffect = effect(() => {
|
|
232
|
-
// Merge form control changes and manual triggers
|
|
233
|
-
merge(this.searchInput.valueChanges.pipe(tap((val) => this.searchQueryChange.emit(val)), debounceTime(this.debounceTime()), distinctUntilChanged()), this.httpStreamTrigger).subscribe((query) => {
|
|
234
|
-
const q = query?.trim() ?? '';
|
|
235
|
-
if (!q || q.length < this.minInputLength()) {
|
|
236
|
-
this.closeDropdown();
|
|
237
|
-
return;
|
|
238
|
-
}
|
|
239
|
-
this.loading.set(true);
|
|
240
|
-
this.error.set(false);
|
|
241
|
-
// Open overlay if not yet open
|
|
242
|
-
if (!this.overlayRef?.hasAttached()) {
|
|
243
|
-
this.openDropdown(this.dd, this.origin.nativeElement);
|
|
244
|
-
}
|
|
245
|
-
// Call HTTP stream
|
|
246
|
-
this.httpStream()(q).subscribe({
|
|
247
|
-
next: (list) => {
|
|
248
|
-
this.loading.set(false);
|
|
249
|
-
this.data.set(list);
|
|
250
|
-
},
|
|
251
|
-
error: () => {
|
|
252
|
-
this.loading.set(false);
|
|
253
|
-
this.error.set(true);
|
|
254
|
-
},
|
|
255
|
-
});
|
|
256
|
-
});
|
|
257
|
-
});
|
|
230
|
+
this.isSelecting = signal(false); // Flag to prevent reopening after selection
|
|
258
231
|
this.handleControlChanges = (values) => {
|
|
259
232
|
values.forEach((el) => this.selectData(el, true));
|
|
260
233
|
};
|
|
@@ -264,17 +237,58 @@ export class AsyncDropdownComponent {
|
|
|
264
237
|
if (this.multi() && !this.uniqueKey()) {
|
|
265
238
|
throw new Error('[uniqueKey] required in multi mode.');
|
|
266
239
|
}
|
|
267
|
-
if (this.disabled())
|
|
240
|
+
if (this.disabled()) {
|
|
268
241
|
this.searchInput.disable();
|
|
242
|
+
}
|
|
243
|
+
// Set up search subscription in ngOnInit (proper lifecycle, not in effect)
|
|
244
|
+
const searchObservable = this.searchInput.valueChanges.pipe(tap((val) => this.searchQueryChange.emit(val)), debounceTime(this.debounceTime()), distinctUntilChanged());
|
|
245
|
+
this.searchSubscription = merge(searchObservable, this.httpStreamTrigger)
|
|
246
|
+
.subscribe((query) => {
|
|
247
|
+
// Don't process if we're in the middle of selecting
|
|
248
|
+
if (this.isSelecting()) {
|
|
249
|
+
return;
|
|
250
|
+
}
|
|
251
|
+
const q = query?.trim() ?? '';
|
|
252
|
+
if (!q || q.length < this.minInputLength()) {
|
|
253
|
+
this.closeDropdown();
|
|
254
|
+
return;
|
|
255
|
+
}
|
|
256
|
+
this.loading.set(true);
|
|
257
|
+
this.error.set(false);
|
|
258
|
+
// Open overlay if not yet open
|
|
259
|
+
if (!this.overlayRef?.hasAttached()) {
|
|
260
|
+
this.openDropdown(this.dd, this.origin.nativeElement);
|
|
261
|
+
}
|
|
262
|
+
// Call HTTP stream
|
|
263
|
+
this.httpStream()(q).subscribe({
|
|
264
|
+
next: (list) => {
|
|
265
|
+
this.loading.set(false);
|
|
266
|
+
this.data.set(list);
|
|
267
|
+
if (!this.overlayRef?.hasAttached() && list.length > 0) {
|
|
268
|
+
this.openDropdown(this.dd, this.origin.nativeElement);
|
|
269
|
+
}
|
|
270
|
+
},
|
|
271
|
+
error: () => {
|
|
272
|
+
this.loading.set(false);
|
|
273
|
+
this.error.set(true);
|
|
274
|
+
},
|
|
275
|
+
});
|
|
276
|
+
});
|
|
269
277
|
if (this.control()?.value) {
|
|
270
278
|
this.handleControlChanges(this.control().value);
|
|
271
279
|
}
|
|
272
|
-
this.control()?.valueChanges.subscribe(this.handleControlChanges);
|
|
280
|
+
this.controlSubscription = this.control()?.valueChanges.subscribe(this.handleControlChanges);
|
|
281
|
+
// Handle searchValue input changes
|
|
282
|
+
if (this.searchValue()) {
|
|
283
|
+
this.searchInput.patchValue(this.searchValue(), { emitEvent: false });
|
|
284
|
+
}
|
|
273
285
|
}
|
|
274
286
|
ngOnChanges() {
|
|
275
|
-
|
|
276
|
-
|
|
287
|
+
// Handle searchValue changes
|
|
288
|
+
if (this.searchValue() !== undefined) {
|
|
289
|
+
this.searchInput.patchValue(this.searchValue(), { emitEvent: false });
|
|
277
290
|
}
|
|
291
|
+
// Handle disabled changes
|
|
278
292
|
if (this.disabled()) {
|
|
279
293
|
this.searchInput.disable();
|
|
280
294
|
}
|
|
@@ -283,6 +297,9 @@ export class AsyncDropdownComponent {
|
|
|
283
297
|
}
|
|
284
298
|
}
|
|
285
299
|
ngOnDestroy() {
|
|
300
|
+
this.searchSubscription?.unsubscribe();
|
|
301
|
+
this.controlSubscription?.unsubscribe();
|
|
302
|
+
this.httpStreamTrigger.complete();
|
|
286
303
|
this.overlayRef?.dispose();
|
|
287
304
|
}
|
|
288
305
|
// === Methods ===
|
|
@@ -314,10 +331,12 @@ export class AsyncDropdownComponent {
|
|
|
314
331
|
width: origin.clientWidth,
|
|
315
332
|
});
|
|
316
333
|
this.overlayRef = this.overlay.create(configs);
|
|
317
|
-
if (this.dropdownListWidth())
|
|
334
|
+
if (this.dropdownListWidth()) {
|
|
318
335
|
this.overlayRef.updateSize({ width: this.dropdownListWidth() });
|
|
336
|
+
}
|
|
319
337
|
this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));
|
|
320
338
|
this.overlayRef.backdropClick().subscribe(() => this.closeDropdown());
|
|
339
|
+
this.opened.set(true);
|
|
321
340
|
}
|
|
322
341
|
closeDropdown() {
|
|
323
342
|
this.opened.set(false);
|
|
@@ -337,6 +356,8 @@ export class AsyncDropdownComponent {
|
|
|
337
356
|
selectData(item, effectedFromOutside = true) {
|
|
338
357
|
if (item.disabled)
|
|
339
358
|
return;
|
|
359
|
+
// Set flag to prevent effect from reopening dropdown
|
|
360
|
+
this.isSelecting.set(true);
|
|
340
361
|
this.itemSelected.emit(item);
|
|
341
362
|
if (!this.multi()) {
|
|
342
363
|
this.searchInput.patchValue(item[this.displayKey()], { emitEvent: false });
|
|
@@ -357,6 +378,11 @@ export class AsyncDropdownComponent {
|
|
|
357
378
|
this.data.set([]);
|
|
358
379
|
}
|
|
359
380
|
this.closeDropdown();
|
|
381
|
+
// Reset flag after a microtask to allow closeDropdown to complete
|
|
382
|
+
// but before any potential subscription runs
|
|
383
|
+
queueMicrotask(() => {
|
|
384
|
+
this.isSelecting.set(false);
|
|
385
|
+
});
|
|
360
386
|
}
|
|
361
387
|
removeItem(item) {
|
|
362
388
|
this.itemRemoved.emit(item);
|
|
@@ -377,7 +403,7 @@ export class AsyncDropdownComponent {
|
|
|
377
403
|
this.clear.emit(true);
|
|
378
404
|
}
|
|
379
405
|
defaultCall() {
|
|
380
|
-
if (this.minInputLength() === -1) {
|
|
406
|
+
if (this.minInputLength() === -1 || this.minInputLength() === 0) {
|
|
381
407
|
this.loading.set(true);
|
|
382
408
|
this.httpStream()(this.searchInput.value || '').subscribe({
|
|
383
409
|
next: (list) => {
|
|
@@ -463,4 +489,4 @@ export class AsyncDropdownComponent {
|
|
|
463
489
|
args: ['document:keydown', ['$event']]
|
|
464
490
|
}] }); })();
|
|
465
491
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AsyncDropdownComponent, { className: "AsyncDropdownComponent" }); })();
|
|
466
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-dropdown.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.ts","../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EAEZ,YAAY,EAIZ,SAAS,GAEV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAEL,aAAa,EAEb,sBAAsB,GACvB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;;;;;;;;ICXhC,AAHF,+BAEwC,eAEL;IAC/B,YACF;IAAA,iBAAO;IACP,gCAIuC;IAAjC,AADA,iNAAS,0BAAgB,KAAC,gNACX,0BAAgB,KAAC;IAExC,AADE,iBAAO,EACH;;;;IAZD,oGAAsE;IAEnE,cAA8D;IAA9D,oGAA8D;IAElE,cACF;IADE,6DACF;IAEM,cAAiF;IAAjF,+FAAiF;;;IAT3F,+BAAuE;IACrE,+EAEwC;IAY1C,iBAAM;;;IAZkB,cAAgB;IAAhB,8CAAgB;;;IAiBtC,+BAAiF;IAC/E,0BAAwD;IAC1D,iBAAM;;;IADC,cAA+B;IAA/B,sEAA+B;;;IAGpC,2BAA8C;;;;IAkBhD,+BAIwC;IAAnC,AADA,+KAAS,yBAAkB,KAAC,8KACb,yBAAkB,KAAC;IACvC,iBAAM;;;IAeJ,4BAAwG;;;IAAjD,sDAAiC;;;IAEtF,+BAAiE;IAC/D,iCAA6C;IAC/C,iBAAM;;IADQ,cAAmB;IAAnB,iCAAmB;;;IADjC,oHAAiE;;;IAAlC,+DAAgC;;;IAHnE,6BAAgC;IAE9B,AADA,wHAAyF,yIAC7D;;;;;IADb,cAAoB;IAAA,AAApB,0CAAoB,8BAAkB;;;IASvD,6BAA8B;IAE1B,AADF,+BAA8B,QACzB;IAAA,4CAA4B;IAAA,qBAAK;IAAC,wCAAuB;IAC9D,AAD8D,iBAAI,EAC5D;;;;IAUF,6BAAoD;IAClD,4BAC6E;;;;;IAD/D,cAA+B;IAC/B,AADA,oDAA+B,iEACgB;;;;IAK7D,0BAAyC;IACzC,+BAG6C;IAAxC,AADA,0QAAS,2BAAiB,KAAK,CAAC,KAAC,yQAClB,2BAAiB,KAAK,CAAC,KAAC;IAExC,AADF,+BAAmB,cACI;IAAA,YAAwB;IAAA,iBAAM;IACnD,+BAAuB;IAAA,YAAiC;IAE5D,AADE,AAD0D,iBAAM,EAC1D,EACF;;;;IAPD,cAAsC;IAAtC,2DAAsC;IAIlB,eAAwB;IAAxB,kDAAwB;IACtB,eAAiC;IAAjC,2DAAiC;;;;IAnBlE,6BAA0C;IACxC,+BAA+E;IAAxC,AAAlC,wOAAS,2BAAiB,KAAK,CAAC,KAAC,uOAAgB,2BAAiB,KAAK,CAAC,KAAC;IAC5E,0BAAyC;IASzC,AANA,8HAAoD,+IAMzB;IAY7B,iBAAM;;;;;IAlBW,eAAkB;IAAA,AAAlB,wCAAkB,8BAAiB;;;IANxD,2BAAyD;IACvD,+GAA0C;IAyB5C,iBAAM;;;IAzB2B,cAAS;IAAT,uCAAS;;;IA6BxC,AADF,2BAAgF,cAClD;IAAA,iCAAiB;IAC/C,AAD+C,iBAAM,EAC/C;;;IAxDR,+BAKkD;IAiDhD,AA7BA,AAPA,AAVA,yGAAgC,4FAUF,0EAO2B,0EA6BuB;IAGlF,iBAAM;;;IApDD,AAHA,AADA,kGAAoE,qEACnB,oDAGL;IAGhC,cAAe;IAAf,uCAAe;IAUf,cAAa;IAAb,qCAAa;IAOtB,cAAiD;IAAjD,uFAAiD;IA6BjD,cAAwE;IAAxE,qHAAwE;;ADnFlF,MAAM,OAAO,sBAAsB;IACjC,YACU,OAAgB,EAChB,gBAAkC,EAClC,OAAe,EACf,QAAkB;QAHlB,YAAO,GAAP,OAAO,CAAS;QAChB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,YAAO,GAAP,OAAO,CAAQ;QACf,aAAQ,GAAR,QAAQ,CAAU;QAG5B,iBAAiB;QACjB,WAAM,GAAG,KAAK,EAAU,CAAC;QACzB,UAAK,GAAG,KAAK,EAAU,CAAC;QACxB,SAAI,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QAChC,eAAU,GAAG,KAAK,CAAC,QAAQ,EAA8B,CAAC;QAC1D,eAAU,GAAG,KAAK,EAAO,CAAC;QAC1B,wBAAmB,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QACxC,gBAAW,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC9B,iBAAY,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;QAC1B,mBAAc,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1B,UAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QACrB,cAAS,GAAG,KAAK,EAAU,CAAC;QAC5B,YAAO,GAAG,KAAK,CAAyB,IAAI,CAAC,CAAC;QAC9C,aAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QACxB,aAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QACxB,qBAAgB,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAChC,sBAAiB,GAAG,KAAK,EAAU,CAAC;QACpC,yBAAoB,GAAG,KAAK,CAAmB,MAAM,CAAC,CAAC;QACvD,0BAAqB,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAC1C,eAAU,GAAG,KAAK,CAAmB,IAAI,GAAG,EAAE,CAAC,CAAC;QAChD,gBAAW,GAAG,KAAK,EAAO,CAAC;QAE3B,kBAAkB;QAClB,aAAQ,GAAG,MAAM,EAA2B,CAAC;QAC7C,sBAAiB,GAAG,MAAM,EAAU,CAAC;QACrC,UAAK,GAAG,MAAM,EAAW,CAAC;QAC1B,iBAAY,GAAG,MAAM,EAAa,CAAC;QACnC,gBAAW,GAAG,MAAM,EAAa,CAAC;QASlC,yBAAyB;QACzB,gBAAW,GAAuB,IAAI,kBAAkB,EAAE,CAAC;QACnD,sBAAiB,GAAG,IAAI,OAAO,EAAU,CAAC;QAGlD,kBAAkB;QAClB,WAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACvB,YAAO,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACxB,UAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACtB,mBAAc,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC/B,SAAI,GAAG,MAAM,CAAc,EAAE,CAAC,CAAC;QAE/B,kCAAkC;QAC1B,iBAAY,GAAG,MAAM,CAAC,GAAG,EAAE;YACjC,iDAAiD;YACjD,KAAK,CACH,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAChC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAC9C,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,EACjC,oBAAoB,EAAE,CACvB,EACD,IAAI,CAAC,iBAAiB,CACvB,CAAC,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;gBAC5B,MAAM,CAAC,GAAG,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;gBAC9B,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;oBAC3C,IAAI,CAAC,aAAa,EAAE,CAAC;oBACrB,OAAO;gBACT,CAAC;gBAED,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAEtB,+BAA+B;gBAC/B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,EAAE,EAAE,CAAC;oBACpC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;gBACxD,CAAC;gBAED,mBAAmB;gBACnB,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;oBAC7B,IAAI,EAAE,CAAC,IAAiB,EAAE,EAAE;wBAC1B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;wBACxB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBACtB,CAAC;oBACD,KAAK,EAAE,GAAG,EAAE;wBACV,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;wBACxB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBACvB,CAAC;iBACF,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAqCK,yBAAoB,GAAG,CAAC,MAAmB,EAAE,EAAE;YACrD,MAAM,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC;QACpD,CAAC,CAAC;IA9HC,CAAC;IAyFJ,oBAAoB;IACpB,QAAQ;QACN,IAAI,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACtC,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;QACzD,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE;YAAE,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAEhD,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC;YAC1B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,OAAO,EAAG,CAAC,KAAK,CAAC,CAAC;QACnD,CAAC;QAED,IAAI,CAAC,OAAO,EAAE,EAAE,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IACpE,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YACvB,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAClD,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YACpB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;IAC7B,CAAC;IAED,kBAAkB;IAClB,iBAAiB,CAAC,KAAa;QAC7B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAMO,YAAY,CAAC,QAA8B,EAAE,MAAmB;QACtE,MAAM,eAAe,GAAG;YACtB,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,EACvC,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,EACtC,CAAC,EACD,CAAC,CACF;YACD,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,EACrC,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EACpC,CAAC,EACD,CAAC,CACF;SACF,CAAC;QACF,MAAM,YAAY,GAAG;YACnB,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EACpC,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,EACzC,CAAC,EACD,CAAC,CAAC,CACH;YACD,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAClC,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,EACvC,CAAC,EACD,CAAC,CAAC,CACH;SACF,CAAC;QAEF,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO;aAClC,QAAQ,EAAE;aACV,mBAAmB,CAAC,MAAM,CAAC;aAC3B,aAAa,CAAC;YACb,GAAG,CAAC,IAAI,CAAC,oBAAoB,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC;YAC1F,GAAG,CAAC,IAAI,CAAC,oBAAoB,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC;SACrF,CAAC;aACD,QAAQ,CAAC,IAAI,CAAC,CAAC;QAElB,MAAM,OAAO,GAAG,IAAI,aAAa,CAAC;YAChC,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;YACjD,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;YAC1D,gBAAgB;YAChB,KAAK,EAAE,MAAM,CAAC,WAAW;SAC1B,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/C,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAAE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAC;QAE9F,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,cAAc,CAAC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAC5E,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,aAAa;QACX,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC;QAC1B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACpB,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAGD,aAAa,CAAC,KAAoB;QAChC,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;YAC3B,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAe,EAAE,mBAAmB,GAAG,IAAI;QACpD,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAE1B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE7B,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;YAClB,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAC3E,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC;gBACnD,IAAI,CAAC,UAAU,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;YACtD,CAAC;YACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACzC,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBACzB,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;oBACpC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC;gBAC/C,CAAC,EAAE,EAAE,CAAC,CAAC;YACT,CAAC;YACD,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YAChC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACpB,CAAC;QACD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,UAAU,CAAC,IAAe;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACjD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACzC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACtC,CAAC;IAEO,eAAe,CAAC,KAA8B;QACpD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED,IAAI,aAAa;QACf,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC;IAChD,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAClB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACvB,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC;gBACxD,IAAI,EAAE,CAAC,IAAiB,EAAE,EAAE;oBAC1B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACxB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBACpB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,EAAE,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBACvD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;oBACxD,CAAC;gBACH,CAAC;gBACD,KAAK,EAAE,GAAG,EAAE;oBACV,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACxB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACvB,CAAC;aACF,CAAC,CAAC;QACL,CAAC;IACH,CAAC;uHA/QU,sBAAsB;oEAAtB,sBAAsB;;;;;;;;;;;;;;;;;YAAtB,qGAAA,yBAAqB,iCAAC;;;YC9BnC,iCAGY;YAGV,uEAAuE;YAkBvE,8BAA0B;YAKxB,AAHA,uEAAiF,2GAGjD;YAKhC,oCAWkD;YAA3C,AADA,AADA,AADA,AADA,wIAAS,iBAAa,KAAC,uIACR,sBAAkB,KAAC,yHAC1B,sBAAkB,GAAG,KAAK,GAAG,IAAI,KAAC,2HACjC,sBAAkB,GAAG,KAAK,GAAG,IAAI,KAAC,uHACpC,sBAAkB,GAAG,KAAK,GAAG,IAAI,KAAC;YAXhD,iBAWkD;YAGlD,wEAIwC;YAG5C,AADE,iBAAM,EACF;YAGN,2HAAiB;;;YAxDZ,oCAAuB;YADvB,mGAA4E;YAKnD,eAAyC;YAAzC,kEAAyC;YAoB7D,eAA+B;YAAA,AAA/B,kDAA+B,mCAAsB;YAQpD,eAAkE;YAElE,AADA,AADA,+FAAkE,kCACrC,gCACF;;YAa5B,eAA+B;YAA/B,0FAA+B;;;iFDnB5B,sBAAsB;cALlC,SAAS;2BACE,2BAA2B;mHA0CE,MAAM;kBAA5C,SAAS;mBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YACE,QAAQ;kBAA9C,SAAS;mBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YACD,EAAE;kBAArC,SAAS;mBAAC,IAAI,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YACgB,UAAU;kBAA3D,YAAY;mBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YACM,YAAY;kBAAjE,YAAY;mBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YA8JpD,aAAa;kBADZ,YAAY;mBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC;;kFAvMjC,sBAAsB","sourcesContent":["import {\n  Component,\n  ContentChild,\n  ElementRef,\n  HostListener,\n  Injector,\n  NgZone,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { AbstractControl, UntypedFormControl } from '@angular/forms';\nimport {\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ConnectionPositionPair,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { signal, effect, input, output } from '@angular/core';\nimport { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators';\nimport { merge, Subject } from 'rxjs';\n\ntype IListData = any;\n\n@Component({\n  selector: 'mis-async-search-dropdown',\n  templateUrl: './async-dropdown.component.html',\n  styleUrls: ['./async-dropdown.component.scss'],\n})\nexport class AsyncDropdownComponent {\n  constructor(\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private _ngZone: NgZone,\n    private injector: Injector\n  ) {}\n\n  // === Inputs ===\n  height = input<string>();\n  width = input<string>();\n  size = input<'md' | 'sm'>('md');\n  httpStream = input.required<(searchKey: string) => any>();\n  displayKey = input<any>();\n  secondaryDisplayKey = input<string>('');\n  placeholder = input('Select');\n  debounceTime = input(400);\n  minInputLength = input(2);\n  multi = input(false);\n  uniqueKey = input<string>();\n  control = input<AbstractControl | null>(null);\n  disabled = input(false);\n  readonly = input(false);\n  disableCopyPaste = input(false);\n  dropdownListWidth = input<string>();\n  dropdownListPosition = input<'Left' | 'Right'>('Left');\n  customPlaceholderIcon = input<string>('');\n  selections = input<Map<string, any>>(new Map());\n  searchValue = input<any>();\n\n  // === Outputs ===\n  onSelect = output<IListData | IListData[]>();\n  searchQueryChange = output<string>();\n  clear = output<boolean>();\n  itemSelected = output<IListData>();\n  itemRemoved = output<IListData>();\n\n  // === Template Refs ===\n  @ViewChild('ddBtn', { static: false }) origin!: ElementRef;\n  @ViewChild('input', { static: false }) inputRef!: ElementRef;\n  @ViewChild('dd', { static: false }) dd!: TemplateRef<Element>;\n  @ContentChild('misCustomItem', { static: false }) customItem!: TemplateRef<Element>;\n  @ContentChild('asyncCustomLoader', { static: false }) customLoader!: TemplateRef<Element>;\n\n  // === Internal state ===\n  searchInput: UntypedFormControl = new UntypedFormControl();\n  private httpStreamTrigger = new Subject<string>();\n  private overlayRef?: OverlayRef;\n\n  // === Signals ===\n  opened = signal(false);\n  loading = signal(false);\n  error = signal(false);\n  openPopUpOnTab = signal(false);\n  data = signal<IListData[]>([]);\n\n  // === Effect to handle search ===\n  private searchEffect = effect(() => {\n    // Merge form control changes and manual triggers\n    merge(\n      this.searchInput.valueChanges.pipe(\n        tap((val) => this.searchQueryChange.emit(val)),\n        debounceTime(this.debounceTime()),\n        distinctUntilChanged()\n      ),\n      this.httpStreamTrigger\n    ).subscribe((query: string) => {\n      const q = query?.trim() ?? '';\n      if (!q || q.length < this.minInputLength()) {\n        this.closeDropdown();\n        return;\n      }\n\n      this.loading.set(true);\n      this.error.set(false);\n\n      // Open overlay if not yet open\n      if (!this.overlayRef?.hasAttached()) {\n        this.openDropdown(this.dd, this.origin.nativeElement);\n      }\n\n      // Call HTTP stream\n      this.httpStream()(q).subscribe({\n        next: (list: IListData[]) => {\n          this.loading.set(false);\n          this.data.set(list);\n        },\n        error: () => {\n          this.loading.set(false);\n          this.error.set(true);\n        },\n      });\n    });\n  });\n\n  // === Lifecycle ===\n  ngOnInit() {\n    if (this.multi() && !this.uniqueKey()) {\n      throw new Error('[uniqueKey] required in multi mode.');\n    }\n\n    if (this.disabled()) this.searchInput.disable();\n\n    if (this.control()?.value) {\n      this.handleControlChanges(this.control()!.value);\n    }\n\n    this.control()?.valueChanges.subscribe(this.handleControlChanges);\n  }\n\n  ngOnChanges() {\n    if (this.searchValue()) {\n      this.searchInput.patchValue(this.searchValue());\n    }\n    if (this.disabled()) {\n      this.searchInput.disable();\n    } else {\n      this.searchInput.enable();\n    }\n  }\n\n  ngOnDestroy() {\n    this.overlayRef?.dispose();\n  }\n\n  // === Methods ===\n  refreshHttpStream(query: string) {\n    this.httpStreamTrigger.next(query);\n  }\n\n  private handleControlChanges = (values: IListData[]) => {\n    values.forEach((el) => this.selectData(el, true));\n  };\n\n  private openDropdown(template: TemplateRef<Element>, origin: HTMLElement) {\n    const positionsBottom = [\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'top' },\n        0,\n        4\n      ),\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'bottom' },\n        { overlayX: 'end', overlayY: 'top' },\n        0,\n        4\n      ),\n    ];\n    const positionsTop = [\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'start', overlayY: 'bottom' },\n        0,\n        -4\n      ),\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'end', overlayY: 'bottom' },\n        0,\n        -4\n      ),\n    ];\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(origin)\n      .withPositions([\n        ...(this.dropdownListPosition() === 'Right' ? positionsBottom.reverse() : positionsBottom),\n        ...(this.dropdownListPosition() === 'Right' ? positionsTop.reverse() : positionsTop),\n      ])\n      .withPush(true);\n\n    const configs = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy,\n      width: origin.clientWidth,\n    });\n\n    this.overlayRef = this.overlay.create(configs);\n    if (this.dropdownListWidth()) this.overlayRef.updateSize({ width: this.dropdownListWidth() });\n\n    this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));\n    this.overlayRef.backdropClick().subscribe(() => this.closeDropdown());\n  }\n\n  closeDropdown() {\n    this.opened.set(false);\n    this.openPopUpOnTab.set(false);\n    this.overlayRef?.detach();\n    this.data.set([]);\n  }\n\n  enablePopUpOnTab() {\n    this.openPopUpOnTab.set(true);\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  handleKeyDown(event: KeyboardEvent) {\n    if (event.key === 'Escape') {\n      this.searchInput.reset();\n      this.closeDropdown();\n    }\n  }\n\n  selectData(item: IListData, effectedFromOutside = true) {\n    if (item.disabled) return;\n\n    this.itemSelected.emit(item);\n\n    if (!this.multi()) {\n      this.searchInput.patchValue(item[this.displayKey()], { emitEvent: false });\n      this.setControlValue(item);\n    } else {\n      if (!this.selections().has(item[this.uniqueKey()])) {\n        this.selections().set(item[this.uniqueKey()], item);\n      }\n      this.setControlValue(this.selectedItems);\n      if (!effectedFromOutside) {\n        setTimeout(() => {\n          this.inputRef.nativeElement.focus();\n          this.inputRef.nativeElement.scrollIntoView();\n        }, 10);\n      }\n      this.searchInput.patchValue('');\n      this.data.set([]);\n    }\n    this.closeDropdown();\n  }\n\n  removeItem(item: IListData) {\n    this.itemRemoved.emit(item);\n    this.selections().delete(item[this.uniqueKey()]);\n    this.setControlValue(this.selectedItems);\n    this.inputRef.nativeElement.focus();\n  }\n\n  private setControlValue(value: IListData | IListData[]) {\n    this.onSelect.emit(value);\n    this.control()?.patchValue(value, { emitEvent: false });\n  }\n\n  get selectedItems() {\n    return Array.from(this.selections().values());\n  }\n\n  removeInputValue() {\n    this.searchInput.reset();\n    this.data.set([]);\n    this.clear.emit(true);\n  }\n\n  defaultCall() {\n    if (this.minInputLength() === -1) {\n      this.loading.set(true);\n      this.httpStream()(this.searchInput.value || '').subscribe({\n        next: (list: IListData[]) => {\n          this.loading.set(false);\n          this.data.set(list);\n          if (!this.overlayRef?.hasAttached() && list.length > 0) {\n            this.openDropdown(this.dd, this.origin.nativeElement);\n          }\n        },\n        error: () => {\n          this.loading.set(false);\n          this.error.set(true);\n        },\n      });\n    }\n  }\n}\n","<div class=\"dd-wrapper\"\n     [ngClass]=\"{ opened: opened(), disabled: disabled(), readonly: readonly() }\"\n     [style.width]=\"width()\"\n     #ddBtn>\n  \n  <!-- Selected chips for multi-select -->\n  <div class=\"selected-list\" *ngIf=\"multi() && selectedItems.length > 0\">\n    <div class=\"chip\"\n         [ngClass]=\"{ 'chip-md': size() === 'md', 'chip-sm': size() === 'sm' }\"\n         *ngFor=\"let item of selectedItems\">\n      <span [ngClass]=\"{ 'h6': size() === 'md', 'h8-b': size() === 'sm' }\"\n            style=\"margin-right: 4px;\">\n        {{ item[displayKey()] }}\n      </span>\n      <span class=\"icon-ic-navigation-cancel-24\"\n            [ngStyle]=\"{ cursor: 'pointer', 'font-size': size() === 'sm' ? '12px' : '14px' }\"\n            tabindex=\"0\"\n            (click)=\"removeItem(item)\"\n            (keyup.enter)=\"removeItem(item)\">\n      </span>\n    </div>\n  </div>\n\n  <!-- Search input -->\n  <div class=\"search-input\">\n    <!-- Placeholder icon -->\n    <div *ngIf=\"customPlaceholderIcon(); else defaultSearchIcon\" class=\"custom-icon\">\n      <img [src]=\"customPlaceholderIcon()\" alt=\"customIcon\" />\n    </div>\n    <ng-template #defaultSearchIcon>\n      <span class=\"icon-ic-action-search-24\"></span>\n    </ng-template>\n\n    <!-- Input field -->\n    <input [ngClass]=\"{ 'ip-md': size() === 'md', 'ip-sm': size() === 'sm' }\"\n           [placeholder]=\"placeholder()\"\n           [formControl]=\"searchInput\"\n           [attr.tabindex]=\"0\"\n           type=\"text\"\n           class=\"black-text h6\"\n           #input\n           (focus)=\"defaultCall()\"\n           (keyup.enter)=\"enablePopUpOnTab()\"\n           (copy)=\"disableCopyPaste() ? false : true\"\n           (paste)=\"disableCopyPaste() ? false : true\"\n           (cut)=\"disableCopyPaste() ? false : true\"/>\n\n    <!-- Clear input -->\n    <div class=\"icon-ic-navigation-cancel-24 croos-icon\"\n         *ngIf=\"searchInput.value?.length\"\n         tabindex=\"0\"\n         (click)=\"removeInputValue()\"\n         (keyup.enter)=\"removeInputValue()\">\n    </div>\n  </div>\n</div>\n\n<!-- Dropdown template -->\n<ng-template #dd>\n  <div class=\"dd-list\"\n       [ngStyle]=\"{ 'max-height': height(), 'width': dropdownListWidth() }\"\n       [ngClass]=\"{ 'dd-list-pd': data().length === 0 }\"\n       tabindex=\"0\"\n       cdkTrapFocus\n       [cdkTrapFocusAutoCapture]=\"openPopUpOnTab()\">\n\n    <!-- Loader -->\n    <ng-container *ngIf=\"loading()\">\n      <ng-container *ngIf=\"customLoader; else defaultLoader\" [ngTemplateOutlet]=\"customLoader\"></ng-container>\n      <ng-template #defaultLoader>\n        <div class=\"status-container\" *ngIf=\"loading() && !customLoader\">\n          <mis-loader [mobileView]=\"true\"></mis-loader>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Error -->\n    <ng-container *ngIf=\"error()\">\n      <div class=\"status-container\">\n        <p>Unknown error has occurred, <br/> Please try again later.</p>\n      </div>\n    </ng-container>\n\n    <!-- Data list -->\n    <div *ngIf=\"!loading() && !error() && data().length > 0\">\n      <ng-container *ngFor=\"let item of data()\">\n        <div (click)=\"selectData(item, false)\" (keyup.enter)=\"selectData(item, false)\">\n          <div tabindex=\"-1\" cdkFocusInitial></div>\n\n          <!-- Custom item -->\n          <ng-container *ngIf=\"customItem; else standardItem\">\n            <ng-container [ngTemplateOutlet]=\"customItem\"\n                          [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\n          </ng-container>\n\n          <!-- Standard item -->\n          <ng-template #standardItem>\n            <div tabindex=\"-1\" cdkFocusInitial></div>\n            <div class=\"item\"\n                 [tabindex]=\"openPopUpOnTab() ? 0 : -1\"\n                 (click)=\"selectData(item, false)\"\n                 (keyup.enter)=\"selectData(item, false)\">\n              <div class=\"value\">\n                <div class=\"primary\">{{ item[displayKey()] }}</div>\n                <div class=\"secondary\">{{ item[secondaryDisplayKey()] }}</div>\n              </div>\n            </div>\n          </ng-template>\n        </div>\n      </ng-container>\n    </div>\n\n    <!-- No data -->\n    <div *ngIf=\"!loading() && !error() && data().length === 0 && searchInput.value\">\n      <div class=\"data-not-found\">No Data Available</div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
492
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-dropdown.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.ts","../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  ElementRef,\n  HostListener,\n  Injector,\n  NgZone,\n  OnInit,\n  OnDestroy,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { AbstractControl, UntypedFormControl } from '@angular/forms';\nimport {\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ConnectionPositionPair,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { signal, input, output } from '@angular/core';\nimport { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators';\nimport { merge, Subject, Subscription } from 'rxjs';\n\ntype IListData = any;\n\n@Component({\n  selector: 'mis-async-search-dropdown',\n  templateUrl: './async-dropdown.component.html',\n  styleUrls: ['./async-dropdown.component.scss'],\n})\nexport class AsyncDropdownComponent implements OnInit, OnDestroy {\n  constructor(\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private _ngZone: NgZone,\n    private injector: Injector\n  ) {}\n\n  // === Inputs ===\n  height = input<string>();\n  width = input<string>();\n  size = input<'md' | 'sm'>('md');\n  httpStream = input.required<(searchKey: string) => any>();\n  displayKey = input<any>();\n  secondaryDisplayKey = input<string>('');\n  placeholder = input('Select');\n  debounceTime = input(400);\n  minInputLength = input(2);\n  multi = input(false);\n  uniqueKey = input<string>();\n  control = input<AbstractControl | null>(null);\n  disabled = input(false);\n  readonly = input(false);\n  disableCopyPaste = input(false);\n  dropdownListWidth = input<string>();\n  dropdownListPosition = input<'Left' | 'Right'>('Left');\n  customPlaceholderIcon = input<string>('');\n  selections = input<Map<string, any>>(new Map());\n  searchValue = input<any>();\n\n  // === Outputs ===\n  onSelect = output<IListData | IListData[]>();\n  searchQueryChange = output<string>();\n  clear = output<boolean>();\n  itemSelected = output<IListData>();\n  itemRemoved = output<IListData>();\n\n  // === Template Refs ===\n  @ViewChild('ddBtn', { static: false }) origin!: ElementRef;\n  @ViewChild('input', { static: false }) inputRef!: ElementRef;\n  @ViewChild('dd', { static: false }) dd!: TemplateRef<Element>;\n  @ContentChild('misCustomItem', { static: false }) customItem!: TemplateRef<Element>;\n  @ContentChild('asyncCustomLoader', { static: false }) customLoader!: TemplateRef<Element>;\n\n  // === Internal state ===\n  searchInput: UntypedFormControl = new UntypedFormControl();\n  private httpStreamTrigger = new Subject<string>();\n  private overlayRef?: OverlayRef;\n  private searchSubscription?: Subscription;\n  private controlSubscription?: Subscription;\n\n  // === Signals ===\n  opened = signal(false);\n  loading = signal(false);\n  error = signal(false);\n  openPopUpOnTab = signal(false);\n  data = signal<IListData[]>([]);\n  private isSelecting = signal(false); // Flag to prevent reopening after selection\n\n  // === Lifecycle ===\n  ngOnInit() {\n    if (this.multi() && !this.uniqueKey()) {\n      throw new Error('[uniqueKey] required in multi mode.');\n    }\n\n    if (this.disabled()) {\n      this.searchInput.disable();\n    }\n\n    // Set up search subscription in ngOnInit (proper lifecycle, not in effect)\n    const searchObservable = this.searchInput.valueChanges.pipe(\n      tap((val) => this.searchQueryChange.emit(val)),\n      debounceTime(this.debounceTime()),\n      distinctUntilChanged()\n    );\n\n    this.searchSubscription = merge(searchObservable, this.httpStreamTrigger)\n      .subscribe((query: string) => {\n        // Don't process if we're in the middle of selecting\n        if (this.isSelecting()) {\n          return;\n        }\n\n        const q = query?.trim() ?? '';\n        if (!q || q.length < this.minInputLength()) {\n          this.closeDropdown();\n          return;\n        }\n\n        this.loading.set(true);\n        this.error.set(false);\n\n        // Open overlay if not yet open\n        if (!this.overlayRef?.hasAttached()) {\n          this.openDropdown(this.dd, this.origin.nativeElement);\n        }\n\n        // Call HTTP stream\n        this.httpStream()(q).subscribe({\n          next: (list: IListData[]) => {\n            this.loading.set(false);\n            this.data.set(list);\n            if (!this.overlayRef?.hasAttached() && list.length > 0) {\n              this.openDropdown(this.dd, this.origin.nativeElement);\n            }\n          },\n          error: () => {\n            this.loading.set(false);\n            this.error.set(true);\n          },\n        });\n      });\n\n    if (this.control()?.value) {\n      this.handleControlChanges(this.control()!.value);\n    }\n\n    this.controlSubscription = this.control()?.valueChanges.subscribe(\n      this.handleControlChanges\n    );\n\n    // Handle searchValue input changes\n    if (this.searchValue()) {\n      this.searchInput.patchValue(this.searchValue(), { emitEvent: false });\n    }\n  }\n\n  ngOnChanges() {\n    // Handle searchValue changes\n    if (this.searchValue() !== undefined) {\n      this.searchInput.patchValue(this.searchValue(), { emitEvent: false });\n    }\n\n    // Handle disabled changes\n    if (this.disabled()) {\n      this.searchInput.disable();\n    } else {\n      this.searchInput.enable();\n    }\n  }\n\n  ngOnDestroy() {\n    this.searchSubscription?.unsubscribe();\n    this.controlSubscription?.unsubscribe();\n    this.httpStreamTrigger.complete();\n    this.overlayRef?.dispose();\n  }\n\n  // === Methods ===\n  refreshHttpStream(query: string) {\n    this.httpStreamTrigger.next(query);\n  }\n\n  private handleControlChanges = (values: IListData[]) => {\n    values.forEach((el) => this.selectData(el, true));\n  };\n\n  private openDropdown(template: TemplateRef<Element>, origin: HTMLElement) {\n    const positionsBottom = [\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'top' },\n        0,\n        4\n      ),\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'bottom' },\n        { overlayX: 'end', overlayY: 'top' },\n        0,\n        4\n      ),\n    ];\n    const positionsTop = [\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'start', overlayY: 'bottom' },\n        0,\n        -4\n      ),\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'end', overlayY: 'bottom' },\n        0,\n        -4\n      ),\n    ];\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(origin)\n      .withPositions([\n        ...(this.dropdownListPosition() === 'Right' ? positionsBottom.reverse() : positionsBottom),\n        ...(this.dropdownListPosition() === 'Right' ? positionsTop.reverse() : positionsTop),\n      ])\n      .withPush(true);\n\n    const configs = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy,\n      width: origin.clientWidth,\n    });\n\n    this.overlayRef = this.overlay.create(configs);\n    if (this.dropdownListWidth()) {\n      this.overlayRef.updateSize({ width: this.dropdownListWidth() });\n    }\n\n    this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));\n    this.overlayRef.backdropClick().subscribe(() => this.closeDropdown());\n    this.opened.set(true);\n  }\n\n  closeDropdown() {\n    this.opened.set(false);\n    this.openPopUpOnTab.set(false);\n    this.overlayRef?.detach();\n    this.data.set([]);\n  }\n\n  enablePopUpOnTab() {\n    this.openPopUpOnTab.set(true);\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  handleKeyDown(event: KeyboardEvent) {\n    if (event.key === 'Escape') {\n      this.searchInput.reset();\n      this.closeDropdown();\n    }\n  }\n\n  selectData(item: IListData, effectedFromOutside = true) {\n    if (item.disabled) return;\n\n    // Set flag to prevent effect from reopening dropdown\n    this.isSelecting.set(true);\n\n    this.itemSelected.emit(item);\n\n    if (!this.multi()) {\n      this.searchInput.patchValue(item[this.displayKey()], { emitEvent: false });\n      this.setControlValue(item);\n    } else {\n      if (!this.selections().has(item[this.uniqueKey()!])) {\n        this.selections().set(item[this.uniqueKey()!], item);\n      }\n      this.setControlValue(this.selectedItems);\n      if (!effectedFromOutside) {\n        setTimeout(() => {\n          this.inputRef.nativeElement.focus();\n          this.inputRef.nativeElement.scrollIntoView();\n        }, 10);\n      }\n      this.searchInput.patchValue('');\n      this.data.set([]);\n    }\n\n    this.closeDropdown();\n\n    // Reset flag after a microtask to allow closeDropdown to complete\n    // but before any potential subscription runs\n    queueMicrotask(() => {\n      this.isSelecting.set(false);\n    });\n  }\n\n  removeItem(item: IListData) {\n    this.itemRemoved.emit(item);\n    this.selections().delete(item[this.uniqueKey()!]);\n    this.setControlValue(this.selectedItems);\n    this.inputRef.nativeElement.focus();\n  }\n\n  private setControlValue(value: IListData | IListData[]) {\n    this.onSelect.emit(value);\n    this.control()?.patchValue(value, { emitEvent: false });\n  }\n\n  get selectedItems() {\n    return Array.from(this.selections().values());\n  }\n\n  removeInputValue() {\n    this.searchInput.reset();\n    this.data.set([]);\n    this.clear.emit(true);\n  }\n\n  defaultCall() {\n    if (this.minInputLength() === -1 || this.minInputLength() === 0) {\n      this.loading.set(true);\n      this.httpStream()(this.searchInput.value || '').subscribe({\n        next: (list: IListData[]) => {\n          this.loading.set(false);\n          this.data.set(list);\n          if (!this.overlayRef?.hasAttached() && list.length > 0) {\n            this.openDropdown(this.dd, this.origin.nativeElement);\n          }\n        },\n        error: () => {\n          this.loading.set(false);\n          this.error.set(true);\n        },\n      });\n    }\n  }\n}","<div class=\"dd-wrapper\"\n     [ngClass]=\"{ opened: opened(), disabled: disabled(), readonly: readonly() }\"\n     [style.width]=\"width()\"\n     #ddBtn>\n  \n  <!-- Selected chips for multi-select -->\n  <div class=\"selected-list\" *ngIf=\"multi() && selectedItems.length > 0\">\n    <div class=\"chip\"\n         [ngClass]=\"{ 'chip-md': size() === 'md', 'chip-sm': size() === 'sm' }\"\n         *ngFor=\"let item of selectedItems\">\n      <span [ngClass]=\"{ 'h6': size() === 'md', 'h8-b': size() === 'sm' }\"\n            style=\"margin-right: 4px;\">\n        {{ item[displayKey()] }}\n      </span>\n      <span class=\"icon-ic-navigation-cancel-24\"\n            [ngStyle]=\"{ cursor: 'pointer', 'font-size': size() === 'sm' ? '12px' : '14px' }\"\n            tabindex=\"0\"\n            (click)=\"removeItem(item)\"\n            (keyup.enter)=\"removeItem(item)\">\n      </span>\n    </div>\n  </div>\n\n  <!-- Search input -->\n  <div class=\"search-input\">\n    <!-- Placeholder icon -->\n    <div *ngIf=\"customPlaceholderIcon(); else defaultSearchIcon\" class=\"custom-icon\">\n      <img [src]=\"customPlaceholderIcon()\" alt=\"customIcon\" />\n    </div>\n    <ng-template #defaultSearchIcon>\n      <span class=\"icon-ic-action-search-24\"></span>\n    </ng-template>\n\n    <!-- Input field -->\n    <input [ngClass]=\"{ 'ip-md': size() === 'md', 'ip-sm': size() === 'sm' }\"\n           [placeholder]=\"placeholder()\"\n           [formControl]=\"searchInput\"\n           [attr.tabindex]=\"0\"\n           type=\"text\"\n           class=\"black-text h6\"\n           #input\n           (focus)=\"defaultCall()\"\n           (keyup.enter)=\"enablePopUpOnTab()\"\n           (copy)=\"disableCopyPaste() ? false : true\"\n           (paste)=\"disableCopyPaste() ? false : true\"\n           (cut)=\"disableCopyPaste() ? false : true\"/>\n\n    <!-- Clear input -->\n    <div class=\"icon-ic-navigation-cancel-24 croos-icon\"\n         *ngIf=\"searchInput.value?.length\"\n         tabindex=\"0\"\n         (click)=\"removeInputValue()\"\n         (keyup.enter)=\"removeInputValue()\">\n    </div>\n  </div>\n</div>\n\n<!-- Dropdown template -->\n<ng-template #dd>\n  <div class=\"dd-list\"\n       [ngStyle]=\"{ 'max-height': height(), 'width': dropdownListWidth() }\"\n       [ngClass]=\"{ 'dd-list-pd': data().length === 0 }\"\n       tabindex=\"0\"\n       cdkTrapFocus\n       [cdkTrapFocusAutoCapture]=\"openPopUpOnTab()\">\n\n    <!-- Loader -->\n    <ng-container *ngIf=\"loading()\">\n      <ng-container *ngIf=\"customLoader; else defaultLoader\" [ngTemplateOutlet]=\"customLoader\"></ng-container>\n      <ng-template #defaultLoader>\n        <div class=\"status-container\" *ngIf=\"loading() && !customLoader\">\n          <mis-loader [mobileView]=\"true\"></mis-loader>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Error -->\n    <ng-container *ngIf=\"error()\">\n      <div class=\"status-container\">\n        <p>Unknown error has occurred, <br/> Please try again later.</p>\n      </div>\n    </ng-container>\n\n    <!-- Data list -->\n    <div *ngIf=\"!loading() && !error() && data().length > 0\">\n      <ng-container *ngFor=\"let item of data()\">\n        <div (click)=\"selectData(item, false)\" (keyup.enter)=\"selectData(item, false)\">\n          <div tabindex=\"-1\" cdkFocusInitial></div>\n\n          <!-- Custom item -->\n          <ng-container *ngIf=\"customItem; else standardItem\">\n            <ng-container [ngTemplateOutlet]=\"customItem\"\n                          [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\n          </ng-container>\n\n          <!-- Standard item -->\n          <ng-template #standardItem>\n            <div tabindex=\"-1\" cdkFocusInitial></div>\n            <div class=\"item\"\n                 [tabindex]=\"openPopUpOnTab() ? 0 : -1\"\n                 (click)=\"selectData(item, false)\"\n                 (keyup.enter)=\"selectData(item, false)\">\n              <div class=\"value\">\n                <div class=\"primary\">{{ item[displayKey()] }}</div>\n                <div class=\"secondary\">{{ item[secondaryDisplayKey()] }}</div>\n              </div>\n            </div>\n          </ng-template>\n        </div>\n      </ng-container>\n    </div>\n\n    <!-- No data -->\n    <div *ngIf=\"!loading() && !error() && data().length === 0 && searchInput.value\">\n      <div class=\"data-not-found\">No Data Available</div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -77,11 +77,11 @@ export class MisInputComponent {
|
|
|
77
77
|
i0.ɵɵtextInterpolate(ctx.placeholder() || ((tmp_2_0 = ctx.formInput()) == null ? null : tmp_2_0.el.nativeElement.placeholder));
|
|
78
78
|
i0.ɵɵadvance();
|
|
79
79
|
i0.ɵɵproperty("ngIf", ctx.isMandatory());
|
|
80
|
-
} }, dependencies: [i1.NgClass, i1.NgIf], styles: ["[_ngcontent-%COMP%]:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.input-container[_ngcontent-%COMP%]{position:relative;padding-bottom:24px}.input-container.mis-disabled[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{pointer-events:none!important}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{box-sizing:border-box;display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;transition:all ease-in 60ms;background-color:var(--bg-primary, #FFFFFF);padding:3px 16px;gap:16px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%]{flex:1 1 auto;z-index:0;position:relative;display:flex;align-items:center}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{flex:1 1 auto;border:none;outline:none;height:100%;padding:0;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;height:24px;color:var(--text-primary, #181F33);background-color:transparent;width:100%;vertical-align:middle;position:relative}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]::placeholder{transition:all ease-in .1s;opacity:0;transform-origin:left center;color:transparent}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{position:absolute;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;line-height:24px;color:var(--text-secondary, #6A737D);transition:all ease-in .15s;pointer-events:none}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{background-color:var(--bg-tertiary, #F5F5F5)}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid #0937B2}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%], .input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-icon][_ngcontent-%COMP%]{width:18px;height:18px;color:var(--text-secondary, #6A737D);font-size:24px;line-height:18px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%]{cursor:pointer}.input-container.no-hint[_ngcontent-%COMP%]{padding-bottom:0}.input-container.has-value[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:transparent!important}.input-container.rounded[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{box-sizing:initial}.input-container.rounded.sm[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:3px 16px}.input-container.rounded.md[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:9px 16px}.input-container.rounded.lg[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:15px 16px}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border-radius:4px;border:1px solid var(--border-primary, #E0E0E0);padding:0}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:hover{background-color:var(--bg-tertiary, #F5F5F5)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid var(--brand-primary, #0937B2)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:
|
|
80
|
+
} }, dependencies: [i1.NgClass, i1.NgIf], styles: ["[_ngcontent-%COMP%]:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.input-container[_ngcontent-%COMP%]{position:relative;padding-bottom:24px}.input-container.mis-disabled[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{pointer-events:none!important}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{box-sizing:border-box;display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;transition:all ease-in 60ms;background-color:var(--bg-primary, #FFFFFF);padding:3px 16px;gap:16px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%]{flex:1 1 auto;z-index:0;position:relative;display:flex;align-items:center}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{flex:1 1 auto;border:none;outline:none;height:100%;padding:0;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;height:24px;color:var(--text-primary, #181F33);background-color:transparent;width:100%;vertical-align:middle;position:relative}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]::placeholder{transition:all ease-in .1s;opacity:0;transform-origin:left center;color:transparent}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{position:absolute;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;line-height:24px;color:var(--text-secondary, #6A737D);transition:all ease-in .15s;pointer-events:none}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{background-color:var(--bg-tertiary, #F5F5F5)}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid #0937B2}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%], .input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-icon][_ngcontent-%COMP%]{width:18px;height:18px;color:var(--text-secondary, #6A737D);font-size:24px;line-height:18px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%]{cursor:pointer}.input-container.no-hint[_ngcontent-%COMP%]{padding-bottom:0}.input-container.has-value[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:transparent!important}.input-container.rounded[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{box-sizing:initial}.input-container.rounded.sm[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:3px 16px}.input-container.rounded.md[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:9px 16px}.input-container.rounded.lg[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:15px 16px}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border-radius:4px;border:1px solid var(--border-primary, #E0E0E0);padding:0}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:hover{background-color:var(--bg-tertiary, #F5F5F5)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid var(--brand-primary, #0937B2)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:not(:placeholder-shown) + .mis-placeholder[_ngcontent-%COMP%]{color:transparent!important}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{margin-left:16px;transition-duration:50ms}.input-container.rounded.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border:1px solid var(--brand-error, #B00020)!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{padding-top:24px;padding-bottom:7px;border-bottom:1px solid var(--border-primary, #E0E0E0)}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:focus + .mis-placeholder[_ngcontent-%COMP%]{color:var(--brand-primary, #0937B2)!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:not(:placeholder-shown) + .mis-placeholder[_ngcontent-%COMP%], .input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:focus + .mis-placeholder[_ngcontent-%COMP%]{transform:translateY(calc(-100% + 6px))!important;font-size:12px!important;letter-spacing:.2px!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:none;border-bottom:1px solid var(--brand-primary, #0937B2)}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within input[_ngcontent-%COMP%]::placeholder{color:var(--text-secondary, #6A737D);opacity:1;font-size:16px}.input-container.floating.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border-bottom:1px solid var(--brand-error, #B00020)!important}.input-container.floating.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:var(--brand-error, #B00020)!important}.input-container[_ngcontent-%COMP%] [mis-input-hint][_ngcontent-%COMP%], .input-container[_ngcontent-%COMP%] [mis-input-error][_ngcontent-%COMP%]{position:absolute;left:0;right:0;bottom:0;line-height:24px;height:24px;font-size:12px;color:var(--text-secondary, #6A737D);letter-spacing:.2px}.input-container[_ngcontent-%COMP%] [mis-input-error][_ngcontent-%COMP%]{color:var(--brand-error, #B00020)}"] }); }
|
|
81
81
|
}
|
|
82
82
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MisInputComponent, [{
|
|
83
83
|
type: Component,
|
|
84
|
-
args: [{ selector: "mis-input", template: "<div\n [class]=\"'input-container ' + size()\"\n [ngClass]=\"{\n rounded: type() === 'rounded',\n floating: type() === 'floating',\n 'has-error': isInvalid(),\n 'no-hint': noHints(),\n 'mis-disabled': inputCtrl()?.disabled,\n 'has-value': hasValue()\n }\"\n>\n <div class=\"input-wrapper\">\n <ng-content select=\"[mis-input-icon]\"></ng-content>\n <div class=\"mis-input\">\n <ng-content select=\"input\"></ng-content>\n <span class=\"mis-placeholder\">{{ placeholder() || formInput()?.el.nativeElement.placeholder }}<span *ngIf=\"isMandatory()\" style=\"color: red;\">*</span></span>\n </div>\n <ng-content select=\"[mis-input-act]\"></ng-content>\n </div>\n <ng-content select=\"[mis-input-hint]\"></ng-content>\n <ng-content select=\"[mis-input-error]\"></ng-content>\n</div>\n\n", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.input-container{position:relative;padding-bottom:24px}.input-container.mis-disabled .input-wrapper{pointer-events:none!important}.input-container .input-wrapper{box-sizing:border-box;display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;transition:all ease-in 60ms;background-color:var(--bg-primary, #FFFFFF);padding:3px 16px;gap:16px}.input-container .input-wrapper .mis-input{flex:1 1 auto;z-index:0;position:relative;display:flex;align-items:center}.input-container .input-wrapper input{flex:1 1 auto;border:none;outline:none;height:100%;padding:0;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;height:24px;color:var(--text-primary, #181F33);background-color:transparent;width:100%;vertical-align:middle;position:relative}.input-container .input-wrapper input::placeholder{transition:all ease-in .1s;opacity:0;transform-origin:left center;color:transparent}.input-container .input-wrapper .mis-placeholder{position:absolute;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;line-height:24px;color:var(--text-secondary, #6A737D);transition:all ease-in .15s;pointer-events:none}.input-container .input-wrapper:focus-within{background-color:var(--bg-tertiary, #F5F5F5)}.input-container .input-wrapper:focus-within{border:1px solid #0937B2}.input-container .input-wrapper [mis-input-act],.input-container .input-wrapper [mis-input-icon]{width:18px;height:18px;color:var(--text-secondary, #6A737D);font-size:24px;line-height:18px}.input-container .input-wrapper [mis-input-act]{cursor:pointer}.input-container.no-hint{padding-bottom:0}.input-container.has-value .mis-input .mis-placeholder{color:transparent!important}.input-container.rounded input{box-sizing:initial}.input-container.rounded.sm input{padding:3px 16px}.input-container.rounded.md input{padding:9px 16px}.input-container.rounded.lg input{padding:15px 16px}.input-container.rounded .input-wrapper{border-radius:4px;border:1px solid var(--border-primary, #E0E0E0);padding:0}.input-container.rounded .input-wrapper:hover{background-color:var(--bg-tertiary, #F5F5F5)}.input-container.rounded .input-wrapper:focus-within{border:1px solid var(--brand-primary, #0937B2)}.input-container.rounded .input-wrapper
|
|
84
|
+
args: [{ selector: "mis-input", template: "<div\n [class]=\"'input-container ' + size()\"\n [ngClass]=\"{\n rounded: type() === 'rounded',\n floating: type() === 'floating',\n 'has-error': isInvalid(),\n 'no-hint': noHints(),\n 'mis-disabled': inputCtrl()?.disabled,\n 'has-value': hasValue()\n }\"\n>\n <div class=\"input-wrapper\">\n <ng-content select=\"[mis-input-icon]\"></ng-content>\n <div class=\"mis-input\">\n <ng-content select=\"input\"></ng-content>\n <span class=\"mis-placeholder\">{{ placeholder() || formInput()?.el.nativeElement.placeholder }}<span *ngIf=\"isMandatory()\" style=\"color: red;\">*</span></span>\n </div>\n <ng-content select=\"[mis-input-act]\"></ng-content>\n </div>\n <ng-content select=\"[mis-input-hint]\"></ng-content>\n <ng-content select=\"[mis-input-error]\"></ng-content>\n</div>\n\n", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.input-container{position:relative;padding-bottom:24px}.input-container.mis-disabled .input-wrapper{pointer-events:none!important}.input-container .input-wrapper{box-sizing:border-box;display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;transition:all ease-in 60ms;background-color:var(--bg-primary, #FFFFFF);padding:3px 16px;gap:16px}.input-container .input-wrapper .mis-input{flex:1 1 auto;z-index:0;position:relative;display:flex;align-items:center}.input-container .input-wrapper input{flex:1 1 auto;border:none;outline:none;height:100%;padding:0;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;height:24px;color:var(--text-primary, #181F33);background-color:transparent;width:100%;vertical-align:middle;position:relative}.input-container .input-wrapper input::placeholder{transition:all ease-in .1s;opacity:0;transform-origin:left center;color:transparent}.input-container .input-wrapper .mis-placeholder{position:absolute;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;line-height:24px;color:var(--text-secondary, #6A737D);transition:all ease-in .15s;pointer-events:none}.input-container .input-wrapper:focus-within{background-color:var(--bg-tertiary, #F5F5F5)}.input-container .input-wrapper:focus-within{border:1px solid #0937B2}.input-container .input-wrapper [mis-input-act],.input-container .input-wrapper [mis-input-icon]{width:18px;height:18px;color:var(--text-secondary, #6A737D);font-size:24px;line-height:18px}.input-container .input-wrapper [mis-input-act]{cursor:pointer}.input-container.no-hint{padding-bottom:0}.input-container.has-value .mis-input .mis-placeholder{color:transparent!important}.input-container.rounded input{box-sizing:initial}.input-container.rounded.sm input{padding:3px 16px}.input-container.rounded.md input{padding:9px 16px}.input-container.rounded.lg input{padding:15px 16px}.input-container.rounded .input-wrapper{border-radius:4px;border:1px solid var(--border-primary, #E0E0E0);padding:0}.input-container.rounded .input-wrapper:hover{background-color:var(--bg-tertiary, #F5F5F5)}.input-container.rounded .input-wrapper:focus-within{border:1px solid var(--brand-primary, #0937B2)}.input-container.rounded .input-wrapper input:not(:placeholder-shown)+.mis-placeholder{color:transparent!important}.input-container.rounded .input-wrapper .mis-placeholder{margin-left:16px;transition-duration:50ms}.input-container.rounded.has-error .input-wrapper{border:1px solid var(--brand-error, #B00020)!important}.input-container.floating .input-wrapper{padding-top:24px;padding-bottom:7px;border-bottom:1px solid var(--border-primary, #E0E0E0)}.input-container.floating .input-wrapper input:focus+.mis-placeholder{color:var(--brand-primary, #0937B2)!important}.input-container.floating .input-wrapper input:not(:placeholder-shown)+.mis-placeholder,.input-container.floating .input-wrapper input:focus+.mis-placeholder{transform:translateY(calc(-100% + 6px))!important;font-size:12px!important;letter-spacing:.2px!important}.input-container.floating .input-wrapper:focus-within{border:none;border-bottom:1px solid var(--brand-primary, #0937B2)}.input-container.floating .input-wrapper:focus-within input::placeholder{color:var(--text-secondary, #6A737D);opacity:1;font-size:16px}.input-container.floating.has-error .input-wrapper{border-bottom:1px solid var(--brand-error, #B00020)!important}.input-container.floating.has-error .input-wrapper .mis-placeholder{color:var(--brand-error, #B00020)!important}.input-container [mis-input-hint],.input-container [mis-input-error]{position:absolute;left:0;right:0;bottom:0;line-height:24px;height:24px;font-size:12px;color:var(--text-secondary, #6A737D);letter-spacing:.2px}.input-container [mis-input-error]{color:var(--brand-error, #B00020)}\n"] }]
|
|
85
85
|
}], () => [], null); })();
|
|
86
86
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MisInputComponent, { className: "MisInputComponent" }); })();
|
|
87
87
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlzLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21pcy1jb21wb25lbnRzL2lucHV0L21pcy1pbnB1dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9taXMtY29tcG9uZW50cy9pbnB1dC9taXMtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBd0MsUUFBUSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUE4QixNQUFNLGVBQWUsQ0FBQztBQUNuSixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7Ozs7OztJQ2M2QiwrQkFBZ0Q7SUFBQSxpQkFBQztJQUFBLGlCQUFPOztBRFA1SixNQUFNLE9BQU8saUJBQWlCO0lBNkI1QjtRQTVCQSxtQ0FBbUM7UUFDNUIsU0FBSSxHQUFHLEtBQUssQ0FBeUIsVUFBVSxDQUFDLENBQUM7UUFDakQsU0FBSSxHQUFHLEtBQUssQ0FBcUIsSUFBSSxDQUFDLENBQUM7UUFDdkMsZ0JBQVcsR0FBRyxLQUFLLENBQXFCLFNBQVMsQ0FBQyxDQUFDO1FBQ25ELFlBQU8sR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDaEMsYUFBUSxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNqQyxnQkFBVyxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUUzQyw4Q0FBOEM7UUFDdkMsYUFBUSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDOUIsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ25DLElBQUksQ0FBQyxTQUFTO2dCQUFFLE9BQU8sS0FBSyxDQUFDO1lBRTdCLE1BQU0sS0FBSyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLG1DQUFtQztZQUNwRSxPQUFPLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsSUFBSSxLQUFLLEtBQUssRUFBRSxDQUFDO1FBQy9ELENBQUMsQ0FBQyxDQUFDO1FBRUgsNEJBQTRCO1FBQ3JCLGNBQVMsR0FBRyxZQUFZLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUVuRCw0RUFBNEU7UUFDNUUsMkVBQTJFO1FBQ3BFLGNBQVMsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFLE9BQU8sRUFBRSxPQUFPLElBQUksSUFBSSxDQUFDLENBQUM7UUFFOUUsc0RBQXNEO1FBQ3RELDhGQUE4RjtRQUN2RixrQkFBYSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksSUFBSSxDQUFDLENBQUM7UUFnQjVFLHlEQUF5RDtRQUNsRCxjQUFTLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBZDFFLHNFQUFzRTtRQUN0RSxtQ0FBbUM7UUFDbkMsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNWLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNuQyxNQUFNLFlBQVksR0FBRyxTQUFTLEVBQUUsRUFBRSxDQUFDLGFBQWEsQ0FBQztZQUVqRCw0RkFBNEY7WUFDNUYsSUFBSSxZQUFZLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxLQUFLLFVBQVUsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7Z0JBQ2xHLFlBQVksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1lBQ2hDLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7a0hBekNVLGlCQUFpQjtvRUFBakIsaUJBQWlCOzZEQW1CSSxpQkFBaUI7Ozs7O1lDaEJqRCxBQVhGLDhCQVVDLGFBQzRCO1lBQ3pCLGtCQUFtRDtZQUNuRCw4QkFBdUI7WUFDckIscUJBQXdDO1lBQ3hDLCtCQUE4QjtZQUFBLFlBQWdFO1lBQUEsb0VBQWdEO1lBQ2hKLEFBRHdKLGlCQUFPLEVBQ3pKO1lBQ04scUJBQWtEO1lBQ3BELGlCQUFNO1lBQ04scUJBQW1EO1lBQ25ELHNCQUFvRDtZQUN0RCxpQkFBTTs7OztZQXBCSiw4Q0FBcUM7WUFDckMsd05BT0U7WUFNZ0MsZUFBZ0U7WUFBaEUsOEhBQWdFO1lBQU8sY0FBbUI7WUFBbkIsd0NBQW1COzs7aUZEUGpILGlCQUFpQjtjQUw3QixTQUFTOzJCQUNFLFdBQVc7O2tGQUlWLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBPbkRlc3Ryb3ksIFZpZXdFbmNhcHN1bGF0aW9uLCBjb21wdXRlZCwgY29udGVudENoaWxkLCBpbnB1dCwgZWZmZWN0LCBzaWduYWwsIGluamVjdCwgRGVzdHJveVJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBNaXNJbnB1dERpcmVjdGl2ZSB9IGZyb20gXCIuL2RpcmVjdGl2ZXMvaW5wdXQvaW5wdXQuZGlyZWN0aXZlXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJtaXMtaW5wdXRcIixcbiAgdGVtcGxhdGVVcmw6IFwiLi9taXMtaW5wdXQuY29tcG9uZW50Lmh0bWxcIixcbiAgc3R5bGVVcmxzOiBbXCIuL21pcy1pbnB1dC5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgTWlzSW5wdXRDb21wb25lbnR7XG4gIC8vIFNpZ25hbCBJbnB1dHMgcmVwbGFjaW5nIEBJbnB1dCgpXG4gIHB1YmxpYyB0eXBlID0gaW5wdXQ8XCJyb3VuZGVkXCIgfCBcImZsb2F0aW5nXCI+KFwiZmxvYXRpbmdcIik7XG4gIHB1YmxpYyBzaXplID0gaW5wdXQ8XCJzbVwiIHwgXCJtZFwiIHwgXCJsZ1wiPihcInNtXCIpO1xuICBwdWJsaWMgcGxhY2Vob2xkZXIgPSBpbnB1dDxzdHJpbmcgfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG4gIHB1YmxpYyBub0hpbnRzID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICBwdWJsaWMgaGFzRXJyb3IgPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG4gIHB1YmxpYyBpc01hbmRhdG9yeSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcblxuICAvLyBDb21wdXRlZCBzaWduYWwgdG8gdHJhY2sgaWYgaW5wdXQgaGFzIHZhbHVlXG4gIHB1YmxpYyBoYXNWYWx1ZSA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBmb3JtSW5wdXQgPSB0aGlzLmZvcm1JbnB1dCgpO1xuICAgIGlmICghZm9ybUlucHV0KSByZXR1cm4gZmFsc2U7XG4gICAgXG4gICAgY29uc3QgdmFsdWUgPSBmb3JtSW5wdXQudmFsdWUoKTsgLy8gVXNlIHRoZSBkaXJlY3RpdmUncyB2YWx1ZSBzaWduYWxcbiAgICByZXR1cm4gdmFsdWUgIT09IG51bGwgJiYgdmFsdWUgIT09IHVuZGVmaW5lZCAmJiB2YWx1ZSAhPT0gJyc7XG4gIH0pO1xuXG4gIC8vIENvbnRlbnQgQ2hpbGQgYXMgYSBzaWduYWxcbiAgcHVibGljIGZvcm1JbnB1dCA9IGNvbnRlbnRDaGlsZChNaXNJbnB1dERpcmVjdGl2ZSk7XG5cbiAgLy8gVXNlIGEgY29tcHV0ZWQgc2lnbmFsIHRvIGRlcml2ZSB0aGUgaW5wdXQgY29udHJvbCBmcm9tIHRoZSBjb250ZW50IGNoaWxkLlxuICAvLyBUaGlzIHdpbGwgYXV0b21hdGljYWxseSB1cGRhdGUgd2hlbiB0aGUgY29udGVudCBjaGlsZCBiZWNvbWVzIGF2YWlsYWJsZS5cbiAgcHVibGljIGlucHV0Q3RybCA9IGNvbXB1dGVkKCgpID0+IHRoaXMuZm9ybUlucHV0KCk/LmNvbnRyb2w/LmNvbnRyb2wgfHwgbnVsbCk7XG5cbiAgLy8gVXNlIGEgY29tcHV0ZWQgc2lnbmFsIHRvIGRlcml2ZSB0aGUgdmFsaWRpdHkgc3RhdGUuXG4gIC8vIEl0IHJlYWRzIHRoZSBzaWduYWwgZnJvbSB0aGUgZGlyZWN0aXZlIGFuZCB1cGRhdGVzIHdoZW5ldmVyIHRoZSBkaXJlY3RpdmUncyBzaWduYWwgY2hhbmdlcy5cbiAgcHVibGljIGlucHV0VmFsaWRpdHkgPSBjb21wdXRlZCgoKSA9PiB0aGlzLmZvcm1JbnB1dCgpPy52YWxpZGl0eSgpID8/IHRydWUpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIC8vIFRoaXMgZWZmZWN0IGlzIG5vdyBvbmx5IGZvciBhIHNpZGUtZWZmZWN0IChtb2RpZnlpbmcgYSBET00gZWxlbWVudClcbiAgICAvLyBhbmQgbm8gbG9uZ2VyIHdyaXRlcyB0byBzaWduYWxzLlxuICAgIGVmZmVjdCgoKSA9PiB7XG4gICAgICBjb25zdCBmb3JtSW5wdXQgPSB0aGlzLmZvcm1JbnB1dCgpO1xuICAgICAgY29uc3QgaW5wdXRFbGVtZW50ID0gZm9ybUlucHV0Py5lbC5uYXRpdmVFbGVtZW50O1xuXG4gICAgICAvLyBGb3IgZmxvYXRpbmcgbGFiZWxzLCB3ZSBtdXN0IGNsZWFyIHRoZSBuYXRpdmUgcGxhY2Vob2xkZXIgdG8gcHJldmVudCBpdCBmcm9tIG92ZXJsYXBwaW5nLlxuICAgICAgaWYgKGlucHV0RWxlbWVudCAmJiB0aGlzLnR5cGUoKSA9PT0gJ2Zsb2F0aW5nJyAmJiAhdGhpcy5wbGFjZWhvbGRlcigpICYmIGlucHV0RWxlbWVudC5wbGFjZWhvbGRlcikge1xuICAgICAgICBpbnB1dEVsZW1lbnQucGxhY2Vob2xkZXIgPSAnJztcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIC8vIENvbXB1dGVkIHNpZ25hbCB0byBkZXRlcm1pbmUgdGhlIG92ZXJhbGwgaW52YWxpZCBzdGF0ZVxuICBwdWJsaWMgaXNJbnZhbGlkID0gY29tcHV0ZWQoKCkgPT4gIXRoaXMuaW5wdXRWYWxpZGl0eSgpIHx8IHRoaXMuaGFzRXJyb3IoKSk7XG59XG4iLCI8ZGl2XG4gIFtjbGFzc109XCInaW5wdXQtY29udGFpbmVyICcgKyBzaXplKClcIlxuICBbbmdDbGFzc109XCJ7XG4gICAgcm91bmRlZDogdHlwZSgpID09PSAncm91bmRlZCcsXG4gICAgZmxvYXRpbmc6IHR5cGUoKSA9PT0gJ2Zsb2F0aW5nJyxcbiAgICAnaGFzLWVycm9yJzogaXNJbnZhbGlkKCksXG4gICAgJ25vLWhpbnQnOiBub0hpbnRzKCksXG4gICAgJ21pcy1kaXNhYmxlZCc6IGlucHV0Q3RybCgpPy5kaXNhYmxlZCxcbiAgICAnaGFzLXZhbHVlJzogaGFzVmFsdWUoKVxuICB9XCJcbj5cbiAgPGRpdiBjbGFzcz1cImlucHV0LXdyYXBwZXJcIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbbWlzLWlucHV0LWljb25dXCI+PC9uZy1jb250ZW50PlxuICAgIDxkaXYgY2xhc3M9XCJtaXMtaW5wdXRcIj5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImlucHV0XCI+PC9uZy1jb250ZW50PlxuICAgICAgPHNwYW4gY2xhc3M9XCJtaXMtcGxhY2Vob2xkZXJcIj57eyBwbGFjZWhvbGRlcigpIHx8IGZvcm1JbnB1dCgpPy5lbC5uYXRpdmVFbGVtZW50LnBsYWNlaG9sZGVyIH19PHNwYW4gKm5nSWY9XCJpc01hbmRhdG9yeSgpXCIgc3R5bGU9XCJjb2xvcjogcmVkO1wiPio8L3NwYW4+PC9zcGFuPlxuICAgIDwvZGl2PlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlttaXMtaW5wdXQtYWN0XVwiPjwvbmctY29udGVudD5cbiAgPC9kaXY+XG4gIDxuZy1jb250ZW50IHNlbGVjdD1cIlttaXMtaW5wdXQtaGludF1cIj48L25nLWNvbnRlbnQ+XG4gIDxuZy1jb250ZW50IHNlbGVjdD1cIlttaXMtaW5wdXQtZXJyb3JdXCI+PC9uZy1jb250ZW50PlxuPC9kaXY+XG5cbiJdfQ==
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive, input, output, signal, } from '@angular/core';
|
|
1
|
+
import { Directive, input, output, signal, effect, } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class SortIconsDirective {
|
|
4
4
|
constructor(el, renderer) {
|
|
@@ -14,6 +14,17 @@ export class SortIconsDirective {
|
|
|
14
14
|
this.multiSortChange = output();
|
|
15
15
|
// Internal state as signals
|
|
16
16
|
this.currentDirection = signal('');
|
|
17
|
+
// Watch for changes in activeSort and activeSorts signals
|
|
18
|
+
// Signal inputs don't trigger ngOnChanges, so we need to use effect()
|
|
19
|
+
effect(() => {
|
|
20
|
+
// Access the signals to create a dependency (we don't need to store the values)
|
|
21
|
+
this.activeSort();
|
|
22
|
+
this.activeSorts();
|
|
23
|
+
// Update icon styles when signals change (only after icons are created)
|
|
24
|
+
if (this.upIcon && this.downIcon) {
|
|
25
|
+
this.updateIconStyles();
|
|
26
|
+
}
|
|
27
|
+
});
|
|
17
28
|
}
|
|
18
29
|
ngOnInit() {
|
|
19
30
|
// Create a container for the icons
|
|
@@ -144,4 +155,4 @@ export class SortIconsDirective {
|
|
|
144
155
|
selector: '[appSortIcons]',
|
|
145
156
|
}]
|
|
146
157
|
}], () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], null); })();
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-icons.directive.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/sort-icons.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  OnChanges,\n  OnInit,\n  Renderer2,\n  SimpleChanges,\n  input,\n  output,\n  signal,\n} from '@angular/core';\n\nexport interface SortState {\n  column: string;\n  direction: 'ASC' | 'DESC' | '';\n}\n\nexport interface SortColumn {\n  data: string;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\n\n@Directive({\n  selector: '[appSortIcons]',\n})\nexport class SortIconsDirective implements OnInit, OnChanges {\n  // Convert inputs to signals\n  column = input<SortColumn>();\n  activeSort = input<SortState>();\n  activeSorts = input<SortState[]>();\n  multiColumnSort = input<boolean>(false);\n  \n  // Convert output to signal\n  sortChange = output<SortState>();\n  multiSortChange = output<SortState[]>();\n\n  // Internal state as signals\n  currentDirection = signal<'ASC' | 'DESC' | ''>('');\n\n  // Assets\n  private upIcon!: HTMLImageElement;\n  private downIcon!: HTMLImageElement;\n  private sortOrderElement?: HTMLSpanElement;\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\n\n  ngOnInit() {\n    \n    // Create a container for the icons\n    const container = this.renderer.createElement('div');\n    this.renderer?.setStyle(container, 'display', 'inline-flex');\n    this.renderer?.setStyle(container, 'align-items', 'center');\n\n    const iconContainer = this.renderer.createElement('div');\n    this.renderer?.setStyle(iconContainer, 'display', 'inline-flex');\n    this.renderer?.setStyle(iconContainer, 'flex-direction', 'column');\n    this.renderer?.setStyle(iconContainer, 'align-items', 'center');\n\n    this.upIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.upIcon, 'src', this.column()?.sortAscIcon);\n    this.renderer?.setStyle(this.upIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.upIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.upIcon, 'width', '9px');\n    this.renderer?.setStyle(this.upIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.upIcon, 'click', () => this.setSortDirection('ASC'));\n\n    this.downIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.downIcon, 'src', this.column()?.sortDescIcon);\n    this.renderer?.setStyle(this.downIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.downIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.downIcon, 'width', '9px');\n    this.renderer?.setStyle(this.downIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.downIcon, 'click', () => this.setSortDirection('DESC'));\n\n    this.renderer?.appendChild(iconContainer, this.upIcon);\n    this.renderer?.appendChild(iconContainer, this.downIcon);\n    this.renderer?.appendChild(container, iconContainer);\n\n    if (this.multiColumnSort()) {\n      this.sortOrderElement = this.renderer.createElement('span');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-size', '12px');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-weight', 'bold');\n      this.renderer?.setStyle(this.sortOrderElement, 'color', '#000');\n      this.renderer?.appendChild(container, this.sortOrderElement);\n    }\n\n    this.renderer?.appendChild(this.el.nativeElement, container);\n    this.updateIconStyles();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['activeSort'] || changes['activeSorts']) {\n      this.updateIconStyles();\n    }\n  }\n\n  private setSortDirection(direction: 'ASC' | 'DESC'): void {\n    if (this.multiColumnSort()) {\n      this.handleMultiColumnSort(direction);\n    } else {\n      this.handleSingleColumnSort(direction);\n    }\n  }\n\n  private handleSingleColumnSort(direction: 'ASC' | 'DESC'): void {\n    if (this.currentDirection() === direction) {\n      this.currentDirection.set(''); // Reset sorting if the same direction is clicked\n    } else {\n      this.currentDirection.set(direction);\n    }\n\n    this.sortChange.emit({ \n      column: this.column()?.data || '', \n      direction: this.currentDirection()\n    });\n    this.updateIconStyles();\n  }\n\n  private handleMultiColumnSort(direction: 'ASC' | 'DESC'): void {\n    const activeSorts = this.activeSorts();\n    \n    if (!Array.isArray(activeSorts)) {\n      return;\n    }\n    \n    const existingSortIndex = activeSorts.findIndex(sort => sort.column === this.column()?.data);\n    \n    if (existingSortIndex !== -1) {\n      if (activeSorts[existingSortIndex].direction !== direction) {\n        activeSorts[existingSortIndex].direction = direction;\n      } else {\n        return;\n      }\n    } else {\n      activeSorts.push({ \n        column: this.column()?.data || '', \n        direction\n      });\n    }\n    this.multiSortChange.emit([...activeSorts]);\n    this.updateIconStyles();\n  }\n\n  private updateIconStyles(): void {\n    if (this.multiColumnSort()) {\n      this.updateMultiColumnIconStyles();\n    } else {\n      this.updateSingleColumnIconStyles();\n    }\n  }\n\n  private updateSingleColumnIconStyles(): void {\n    const isActiveColumn = this.activeSort()?.column === this.column()?.data;\n\n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'DESC' ? '1' : '0.5'\n      );\n    }, 0);\n  }\n\n  private updateMultiColumnIconStyles(): void {\n    const activeSorts = this.activeSorts();\n    \n    if (!Array.isArray(activeSorts)) {\n      return;\n    }\n    \n    const columnSort = activeSorts.find(sort => sort.column === this.column()?.data);\n    \n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        columnSort?.direction === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        columnSort?.direction === 'DESC' ? '1' : '0.5'\n      );\n\n      if (this.sortOrderElement) {\n        const sortIndex = activeSorts.findIndex(sort => sort.column === this.column()?.data);\n        if (sortIndex !== -1) {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', (sortIndex + 1).toString());\n        } else {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', '');\n        }\n      }\n    }, 0);\n  }\n}"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-icons.directive.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/sort-icons.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  OnChanges,\n  OnInit,\n  Renderer2,\n  SimpleChanges,\n  input,\n  output,\n  signal,\n  effect,\n} from '@angular/core';\n\nexport interface SortState {\n  column: string;\n  direction: 'ASC' | 'DESC' | '';\n}\n\nexport interface SortColumn {\n  data: string;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\n\n@Directive({\n  selector: '[appSortIcons]',\n})\nexport class SortIconsDirective implements OnInit, OnChanges {\n  // Convert inputs to signals\n  column = input<SortColumn>();\n  activeSort = input<SortState>();\n  activeSorts = input<SortState[]>();\n  multiColumnSort = input<boolean>(false);\n  \n  // Convert output to signal\n  sortChange = output<SortState>();\n  multiSortChange = output<SortState[]>();\n\n  // Internal state as signals\n  currentDirection = signal<'ASC' | 'DESC' | ''>('');\n\n  // Assets\n  private upIcon!: HTMLImageElement;\n  private downIcon!: HTMLImageElement;\n  private sortOrderElement?: HTMLSpanElement;\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {\n    // Watch for changes in activeSort and activeSorts signals\n    // Signal inputs don't trigger ngOnChanges, so we need to use effect()\n    effect(() => {\n      // Access the signals to create a dependency (we don't need to store the values)\n      this.activeSort();\n      this.activeSorts();\n      // Update icon styles when signals change (only after icons are created)\n      if (this.upIcon && this.downIcon) {\n        this.updateIconStyles();\n      }\n    });\n  }\n\n  ngOnInit() {\n    \n    // Create a container for the icons\n    const container = this.renderer.createElement('div');\n    this.renderer?.setStyle(container, 'display', 'inline-flex');\n    this.renderer?.setStyle(container, 'align-items', 'center');\n\n    const iconContainer = this.renderer.createElement('div');\n    this.renderer?.setStyle(iconContainer, 'display', 'inline-flex');\n    this.renderer?.setStyle(iconContainer, 'flex-direction', 'column');\n    this.renderer?.setStyle(iconContainer, 'align-items', 'center');\n\n    this.upIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.upIcon, 'src', this.column()?.sortAscIcon);\n    this.renderer?.setStyle(this.upIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.upIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.upIcon, 'width', '9px');\n    this.renderer?.setStyle(this.upIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.upIcon, 'click', () => this.setSortDirection('ASC'));\n\n    this.downIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.downIcon, 'src', this.column()?.sortDescIcon);\n    this.renderer?.setStyle(this.downIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.downIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.downIcon, 'width', '9px');\n    this.renderer?.setStyle(this.downIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.downIcon, 'click', () => this.setSortDirection('DESC'));\n\n    this.renderer?.appendChild(iconContainer, this.upIcon);\n    this.renderer?.appendChild(iconContainer, this.downIcon);\n    this.renderer?.appendChild(container, iconContainer);\n\n    if (this.multiColumnSort()) {\n      this.sortOrderElement = this.renderer.createElement('span');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-size', '12px');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-weight', 'bold');\n      this.renderer?.setStyle(this.sortOrderElement, 'color', '#000');\n      this.renderer?.appendChild(container, this.sortOrderElement);\n    }\n\n    this.renderer?.appendChild(this.el.nativeElement, container);\n    this.updateIconStyles();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['activeSort'] || changes['activeSorts']) {\n      this.updateIconStyles();\n    }\n  }\n\n  private setSortDirection(direction: 'ASC' | 'DESC'): void {\n    if (this.multiColumnSort()) {\n      this.handleMultiColumnSort(direction);\n    } else {\n      this.handleSingleColumnSort(direction);\n    }\n  }\n\n  private handleSingleColumnSort(direction: 'ASC' | 'DESC'): void {\n    if (this.currentDirection() === direction) {\n      this.currentDirection.set(''); // Reset sorting if the same direction is clicked\n    } else {\n      this.currentDirection.set(direction);\n    }\n\n    this.sortChange.emit({ \n      column: this.column()?.data || '', \n      direction: this.currentDirection()\n    });\n    this.updateIconStyles();\n  }\n\n  private handleMultiColumnSort(direction: 'ASC' | 'DESC'): void {\n    const activeSorts = this.activeSorts();\n    \n    if (!Array.isArray(activeSorts)) {\n      return;\n    }\n    \n    const existingSortIndex = activeSorts.findIndex(sort => sort.column === this.column()?.data);\n    \n    if (existingSortIndex !== -1) {\n      if (activeSorts[existingSortIndex].direction !== direction) {\n        activeSorts[existingSortIndex].direction = direction;\n      } else {\n        return;\n      }\n    } else {\n      activeSorts.push({ \n        column: this.column()?.data || '', \n        direction\n      });\n    }\n    this.multiSortChange.emit([...activeSorts]);\n    this.updateIconStyles();\n  }\n\n  private updateIconStyles(): void {\n    if (this.multiColumnSort()) {\n      this.updateMultiColumnIconStyles();\n    } else {\n      this.updateSingleColumnIconStyles();\n    }\n  }\n\n  private updateSingleColumnIconStyles(): void {\n    const isActiveColumn = this.activeSort()?.column === this.column()?.data;\n\n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'DESC' ? '1' : '0.5'\n      );\n    }, 0);\n  }\n\n  private updateMultiColumnIconStyles(): void {\n    const activeSorts = this.activeSorts();\n    \n    if (!Array.isArray(activeSorts)) {\n      return;\n    }\n    \n    const columnSort = activeSorts.find(sort => sort.column === this.column()?.data);\n    \n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        columnSort?.direction === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        columnSort?.direction === 'DESC' ? '1' : '0.5'\n      );\n\n      if (this.sortOrderElement) {\n        const sortIndex = activeSorts.findIndex(sort => sort.column === this.column()?.data);\n        if (sortIndex !== -1) {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', (sortIndex + 1).toString());\n        } else {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', '');\n        }\n      }\n    }, 0);\n  }\n}"]}
|