igniteui-angular 17.2.0-rc.1 → 17.2.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.
Files changed (44) hide show
  1. package/esm2022/lib/calendar/month-picker/month-picker.component.mjs +224 -6
  2. package/esm2022/lib/core/utils.mjs +3 -1
  3. package/esm2022/lib/directives/button/button-base.mjs +39 -2
  4. package/esm2022/lib/directives/button/button.directive.mjs +2 -1
  5. package/esm2022/lib/directives/toggle/toggle.directive.mjs +18 -6
  6. package/fesm2022/igniteui-angular.mjs +276 -8
  7. package/fesm2022/igniteui-angular.mjs.map +1 -1
  8. package/lib/calendar/month-picker/month-picker.component.d.ts +83 -2
  9. package/lib/core/styles/components/button/_button-component.scss +16 -0
  10. package/lib/core/styles/components/button/_button-theme.scss +203 -273
  11. package/lib/core/styles/components/button-group/_button-group-theme.scss +314 -85
  12. package/lib/core/styles/components/icon-button/_icon-button-theme.scss +27 -51
  13. package/lib/core/styles/components/overlay/_overlay-component.scss +4 -0
  14. package/lib/core/styles/components/overlay/_overlay-theme.scss +17 -1
  15. package/lib/core/utils.d.ts +2 -0
  16. package/lib/directives/button/button-base.d.ts +21 -0
  17. package/lib/directives/toggle/toggle.directive.d.ts +5 -3
  18. package/package.json +3 -3
  19. package/styles/igniteui-angular-dark.css +1 -1
  20. package/styles/igniteui-angular.css +1 -1
  21. package/styles/igniteui-bootstrap-dark.css +1 -1
  22. package/styles/igniteui-bootstrap-light.css +1 -1
  23. package/styles/igniteui-dark-green.css +1 -1
  24. package/styles/igniteui-fluent-dark-excel.css +1 -1
  25. package/styles/igniteui-fluent-dark-word.css +1 -1
  26. package/styles/igniteui-fluent-dark.css +1 -1
  27. package/styles/igniteui-fluent-light-excel.css +1 -1
  28. package/styles/igniteui-fluent-light-word.css +1 -1
  29. package/styles/igniteui-fluent-light.css +1 -1
  30. package/styles/igniteui-indigo-dark.css +1 -1
  31. package/styles/igniteui-indigo-light.css +1 -1
  32. package/styles/maps/igniteui-angular-dark.css.map +1 -1
  33. package/styles/maps/igniteui-angular.css.map +1 -1
  34. package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
  35. package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
  36. package/styles/maps/igniteui-dark-green.css.map +1 -1
  37. package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
  38. package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
  39. package/styles/maps/igniteui-fluent-dark.css.map +1 -1
  40. package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
  41. package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
  42. package/styles/maps/igniteui-fluent-light.css.map +1 -1
  43. package/styles/maps/igniteui-indigo-dark.css.map +1 -1
  44. package/styles/maps/igniteui-indigo-light.css.map +1 -1
@@ -6,7 +6,8 @@ import { IgxOverlayService } from '../../services/overlay/overlay';
6
6
  import { Subject } from 'rxjs';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "../../core/navigation";
9
- import * as i2 from "../../services/overlay/overlay";
9
+ import * as i2 from "../../core/utils";
10
+ import * as i3 from "../../services/overlay/overlay";
10
11
  export class IgxToggleDirective {
11
12
  /**
12
13
  * @hidden
@@ -26,6 +27,11 @@ export class IgxToggleDirective {
26
27
  get hiddenClass() {
27
28
  return this.collapsed;
28
29
  }
30
+ get hiddenWebkitClass() {
31
+ const isSafari = this.platform?.isSafari;
32
+ const browserVersion = this.platform?.browserVersion;
33
+ return this.collapsed && isSafari && !!browserVersion && browserVersion < 17.5;
34
+ }
29
35
  /**
30
36
  * @hidden
31
37
  */
@@ -35,11 +41,12 @@ export class IgxToggleDirective {
35
41
  /**
36
42
  * @hidden
37
43
  */
38
- constructor(elementRef, cdr, overlayService, navigationService) {
44
+ constructor(elementRef, cdr, overlayService, navigationService, platform) {
39
45
  this.elementRef = elementRef;
40
46
  this.cdr = cdr;
41
47
  this.overlayService = overlayService;
42
48
  this.navigationService = navigationService;
49
+ this.platform = platform;
43
50
  /**
44
51
  * Emits an event after the toggle container is opened.
45
52
  *
@@ -316,8 +323,8 @@ export class IgxToggleDirective {
316
323
  subscription.unsubscribe();
317
324
  }
318
325
  }
319
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxToggleDirective, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: IgxOverlayService }, { token: i1.IgxNavigationService, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
320
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.4", type: IgxToggleDirective, isStandalone: true, selector: "[igxToggle]", inputs: { id: "id" }, outputs: { opened: "opened", opening: "opening", closed: "closed", closing: "closing", appended: "appended" }, host: { properties: { "class.igx-toggle--hidden": "this.hiddenClass", "attr.aria-hidden": "this.hiddenClass", "class.igx-toggle": "this.defaultClass" } }, exportAs: ["toggle"], ngImport: i0 }); }
326
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxToggleDirective, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: IgxOverlayService }, { token: i1.IgxNavigationService, optional: true }, { token: i2.PlatformUtil, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
327
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.4", type: IgxToggleDirective, isStandalone: true, selector: "[igxToggle]", inputs: { id: "id" }, outputs: { opened: "opened", opening: "opening", closed: "closed", closing: "closing", appended: "appended" }, host: { properties: { "class.igx-toggle--hidden": "this.hiddenClass", "attr.aria-hidden": "this.hiddenClass", "class.igx-toggle--hidden-webkit": "this.hiddenWebkitClass", "class.igx-toggle": "this.defaultClass" } }, exportAs: ["toggle"], ngImport: i0 }); }
321
328
  }
322
329
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxToggleDirective, decorators: [{
323
330
  type: Directive,
@@ -326,11 +333,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
326
333
  selector: '[igxToggle]',
327
334
  standalone: true
328
335
  }]
329
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i2.IgxOverlayService, decorators: [{
336
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i3.IgxOverlayService, decorators: [{
330
337
  type: Inject,
331
338
  args: [IgxOverlayService]
332
339
  }] }, { type: i1.IgxNavigationService, decorators: [{
333
340
  type: Optional
341
+ }] }, { type: i2.PlatformUtil, decorators: [{
342
+ type: Optional
334
343
  }] }], propDecorators: { opened: [{
335
344
  type: Output
336
345
  }], opening: [{
@@ -349,6 +358,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
349
358
  }, {
350
359
  type: HostBinding,
351
360
  args: ['attr.aria-hidden']
361
+ }], hiddenWebkitClass: [{
362
+ type: HostBinding,
363
+ args: ['class.igx-toggle--hidden-webkit']
352
364
  }], defaultClass: [{
353
365
  type: HostBinding,
354
366
  args: ['class.igx-toggle']
@@ -464,4 +476,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
464
476
  standalone: true
465
477
  }]
466
478
  }], ctorParameters: () => [{ type: i0.ElementRef }] });
467
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/toggle/toggle.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,SAAS,EAET,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,wDAAwD,CAAC;AAEhG,OAAO,EAAE,4BAA4B,EAAE,MAAM,gEAAgE,CAAC;AAC9G,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAGnE,OAAO,EAAgB,OAAO,EAA4B,MAAM,MAAM,CAAC;;;;AAevE,MAAM,OAAO,kBAAkB;IAgG3B;;OAEG;IACH,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAYD;;OAEG;IACH,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,IAEW,WAAW;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,IACW,YAAY;QACnB,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC;IAC3B,CAAC;IAeD;;OAEG;IACH,YACY,UAAsB,EACtB,GAAsB,EACO,cAAiC,EAClD,iBAAuC;QAHnD,eAAU,GAAV,UAAU,CAAY;QACtB,QAAG,GAAH,GAAG,CAAmB;QACO,mBAAc,GAAd,cAAc,CAAmB;QAClD,sBAAiB,GAAjB,iBAAiB,CAAsB;QA5J/D;;;;;;;;;;;;;;;WAeG;QAEI,WAAM,GAAG,IAAI,YAAY,EAAuB,CAAC;QAExD;;;;;;;;;;;;;;;WAeG;QAEI,YAAO,GAAG,IAAI,YAAY,EAAiC,CAAC;QAEnE;;;;;;;;;;;;;;;WAeG;QAEI,WAAM,GAAG,IAAI,YAAY,EAAuB,CAAC;QAExD;;;;;;;;;;;;;;;WAeG;QAEI,YAAO,GAAG,IAAI,YAAY,EAAiC,CAAC;QAEnE;;;;;;;;;;;;;;;WAeG;QAEI,aAAQ,GAAG,IAAI,YAAY,EAAuB,CAAC;QA6ClD,eAAU,GAAG,IAAI,CAAC;QAChB,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;QACpC,sBAAiB,GAA6F;YAClH,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,UAAU,CAAC;YACrC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC3B,CAAC;QA+JM,kBAAa,GAAG,CAAC,CAAC,EAAE,EAAE;YAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC3C,MAAM,IAAI,GAAwB,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;YACvF,OAAO,IAAI,CAAC,UAAU,CAAC;YACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC;IA1JF,CAAC;IAED;;;;;;OAMG;IACI,IAAI,CAAC,eAAiC;QACzC,yCAAyC;QACzC,yEAAyE;QACzE,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjE,MAAM,oBAAoB,GAAG,IAAI,EAAE,mBAAmB,EAAE,UAAU,EAAE,IAAI,KAAK,CAAC;QAC9E,MAAM,qBAAqB,GAAG,IAAI,EAAE,oBAAoB,EAAE,UAAU,EAAE,IAAI,KAAK,CAAC;QAChF,IAAI,oBAAoB,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,qBAAqB,CAAC,EAAE;YACrE,OAAO;SACV;QAED,MAAM,MAAM,GAAG,eAAe,IAAI,eAAe,CAAC,MAAM,CAAC;QAEzD,uCAAuC;QACvC,IAAI,MAAM,IAAI,MAAM,YAAY,OAAO,EAAE;YACrC,MAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC;YAClE,MAAM,UAAU,GAAG,MAAM,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;YACxD,MAAM,IAAI,GAAG,aAAa,IAAI,UAAU,IAAI,GAAG,CAAC;YAChD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;SACtE;QAED,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAEzB,IAAI,CAAC,IAAI,EAAE;YACP,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;SAClF;QAED,MAAM,IAAI,GAAkC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;QAChG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC5C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,OAAO,IAAI,CAAC,UAAU,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,OAAO;SACV;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;IAC/D,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,KAAa;QACtB,qCAAqC;QACrC,oEAAoE;QACpE,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjE,MAAM,qBAAqB,GAAG,IAAI,EAAE,oBAAoB,EAAE,UAAU,EAAE,IAAI,KAAK,CAAC;QAChF,IAAI,IAAI,CAAC,UAAU,IAAI,qBAAqB,EAAE;YAC1C,OAAO;SACV;QAED,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,eAAiC;QAC3C,oCAAoC;QACpC,iDAAiD;QACjD,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,EAAE;YAClC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC9B;aAAM;YACH,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;IACL,CAAC;IAED,wBAAwB;IACxB,IAAW,SAAS;QAChB,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjE,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;IAClE,CAAC;IAED;;;;;OAKG;IACH,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED;;;;;OAKG;IACI,UAAU;QACb,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC;IAED;;OAEG;IACI,SAAS,CAAC,MAAc,EAAE,MAAc;QAC3C,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACnE,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,EAAE,EAAE;YACnC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;SAC7C;IACL,CAAC;IAED;;OAEG;IACI,WAAW;QACd,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,EAAE,EAAE;YACnC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAC1C;QACD,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAC/C;QACD,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IAaO,SAAS;QACb,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,cAAc;aAChD,eAAe;aACf,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACvC,SAAS,CAAC,GAAG,EAAE;YACZ,MAAM,IAAI,GAAwB,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;YACvE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc;aACvC,MAAM;aACN,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC;aAC/B,SAAS,CAAC,GAAG,EAAE;YACZ,MAAM,IAAI,GAAwB,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;YACvE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,cAAc;aACxC,OAAO;aACP,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC;aAC/B,SAAS,CAAC,CAAC,CAA0B,EAAE,EAAE;YACtC,MAAM,IAAI,GAAkC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;YAChH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxB,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAEvB,wFAAwF;YACxF,yFAAyF;YACzF,oEAAoE;YACpE,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE;gBACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;aACnD;QACL,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc;aACvC,MAAM;aACN,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC;aAC/B,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACvC,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC/C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAChD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC/C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;IAC5D,CAAC;IAEO,iBAAiB,CAAC,YAA0B;QAChD,IAAI,YAAY,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;YACtC,YAAY,CAAC,WAAW,EAAE,CAAC;SAC9B;IACL,CAAC;8GA5WQ,kBAAkB,6EA4Jf,iBAAiB;kGA5JpB,kBAAkB;;2FAAlB,kBAAkB;kBAL9B,SAAS;mBAAC;oBACP,QAAQ,EAAE,QAAQ;oBAClB,QAAQ,EAAE,aAAa;oBACvB,UAAU,EAAE,IAAI;iBACnB;;0BA6JQ,MAAM;2BAAC,iBAAiB;;0BACxB,QAAQ;yCA3IN,MAAM;sBADZ,MAAM;gBAoBA,OAAO;sBADb,MAAM;gBAoBA,MAAM;sBADZ,MAAM;gBAoBA,OAAO;sBADb,MAAM;gBAoBA,QAAQ;sBADd,MAAM;gBAkBA,EAAE;sBADR,KAAK;gBAeK,WAAW;sBAFrB,WAAW;uBAAC,0BAA0B;;sBACtC,WAAW;uBAAC,kBAAkB;gBASpB,YAAY;sBADtB,WAAW;uBAAC,kBAAkB;;AAgPnC,MAAM,OAAO,wBAAwB;IA8BjC;;OAEG;IACH,IACW,MAAM,CAAC,MAAW;QACzB,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,EAAE,EAAE;YAClC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;SACzB;IACL,CAAC;IAED;;OAEG;IACH,IAAW,MAAM;QACb,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,EAAE;YAClC,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACnD;QACD,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAKD,YAAoB,OAAmB,EAAsB,iBAAuC;QAAhF,YAAO,GAAP,OAAO,CAAY;QAAsB,sBAAiB,GAAjB,iBAAiB,CAAsB;IAAI,CAAC;IAEzG;;OAEG;IAEI,OAAO;QACV,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;SAC9C;QAED,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QACtF,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC;QAC3C,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QACjD,IAAI,CAAC,gBAAgB,GAAG;YACpB,MAAM,EAAE,aAAa;YACrB,gBAAgB,EAAE,IAAI,4BAA4B,EAAE;YACpD,cAAc,EAAE,IAAI,sBAAsB,EAAE;YAC5C,mBAAmB,EAAE,IAAI;YACzB,KAAK,EAAE,KAAK;YACZ,uBAAuB,EAAE,CAAC,aAA4B,CAAC;SAC1D,CAAC;IACN,CAAC;IAED;;;;;OAKG;IACO,qBAAqB,CAAC,QAAyB;QACrD,IAAI,QAAQ,IAAI,QAAQ,CAAC,gBAAgB,EAAE;YACvC,MAAM,qBAAqB,GAAsB,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YACnF,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;YAC7C,QAAQ,CAAC,gBAAgB,GAAG,qBAAqB,CAAC;SACrD;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;8GAlGQ,wBAAwB;kGAAxB,wBAAwB;;2FAAxB,wBAAwB;kBALpC,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE,mBAAmB;oBAC7B,UAAU,EAAE,IAAI;iBACnB;;0BAsD6C,QAAQ;yCArC3C,eAAe;sBADrB,KAAK;gBAaC,MAAM;sBADZ,KAAK;uBAAC,iBAAiB;gBAOb,MAAM;sBADhB,KAAK;uBAAC,iBAAiB;gBA0BjB,OAAO;sBADb,YAAY;uBAAC,OAAO;;AA2CzB;;;;;;GAMG;AAMH,MAAM,OAAO,yBAAyB;IAClC,YAAmB,OAAgC;QAAhC,YAAO,GAAP,OAAO,CAAyB;IAAI,CAAC;IAExD,cAAc;IACd,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;IACtC,CAAC;8GANQ,yBAAyB;kGAAzB,yBAAyB;;2FAAzB,yBAAyB;kBALrC,SAAS;mBAAC;oBACP,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,oBAAoB;oBAC9B,UAAU,EAAE,IAAI;iBACnB","sourcesContent":["import {\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output\n} from '@angular/core';\nimport { AbsoluteScrollStrategy } from '../../services/overlay/scroll/absolute-scroll-strategy';\nimport { CancelableBrowserEventArgs, IBaseEventArgs } from '../../core/utils';\nimport { ConnectedPositioningStrategy } from '../../services/overlay/position/connected-positioning-strategy';\nimport { filter, first, takeUntil } from 'rxjs/operators';\nimport { IgxNavigationService, IToggleView } from '../../core/navigation';\nimport { IgxOverlayService } from '../../services/overlay/overlay';\nimport { IPositionStrategy } from '../../services/overlay/position/IPositionStrategy';\nimport { OverlayClosingEventArgs, OverlayEventArgs, OverlaySettings } from '../../services/overlay/utilities';\nimport { Subscription, Subject, MonoTypeOperatorFunction } from 'rxjs';\n\nexport interface ToggleViewEventArgs extends IBaseEventArgs {\n    /** Id of the toggle view */\n    id: string;\n    event?: Event;\n}\n\nexport interface ToggleViewCancelableEventArgs extends ToggleViewEventArgs, CancelableBrowserEventArgs { }\n\n@Directive({\n    exportAs: 'toggle',\n    selector: '[igxToggle]',\n    standalone: true\n})\nexport class IgxToggleDirective implements IToggleView, OnInit, OnDestroy {\n    /**\n     * Emits an event after the toggle container is opened.\n     *\n     * ```typescript\n     * onToggleOpened(event) {\n     *    alert(\"Toggle opened!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (opened)='onToggleOpened($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public opened = new EventEmitter<ToggleViewEventArgs>();\n\n    /**\n     * Emits an event before the toggle container is opened.\n     *\n     * ```typescript\n     * onToggleOpening(event) {\n     *  alert(\"Toggle opening!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (opening)='onToggleOpening($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public opening = new EventEmitter<ToggleViewCancelableEventArgs>();\n\n    /**\n     * Emits an event after the toggle container is closed.\n     *\n     * ```typescript\n     * onToggleClosed(event) {\n     *  alert(\"Toggle closed!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (closed)='onToggleClosed($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public closed = new EventEmitter<ToggleViewEventArgs>();\n\n    /**\n     * Emits an event before the toggle container is closed.\n     *\n     * ```typescript\n     * onToggleClosing(event) {\n     *  alert(\"Toggle closing!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *  igxToggle\n     *  (closing)='onToggleClosing($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public closing = new EventEmitter<ToggleViewCancelableEventArgs>();\n\n    /**\n     * Emits an event after the toggle element is appended to the overlay container.\n     *\n     * ```typescript\n     * onAppended() {\n     *  alert(\"Content appended!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (appended)='onToggleAppended()'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public appended = new EventEmitter<ToggleViewEventArgs>();\n\n    /**\n     * @hidden\n     */\n    public get collapsed(): boolean {\n        return this._collapsed;\n    }\n\n    /**\n     * Identifier which is registered into `IgxNavigationService`\n     *\n     * ```typescript\n     * let myToggleId = this.toggle.id;\n     * ```\n     */\n    @Input()\n    public id: string;\n\n    /**\n     * @hidden\n     */\n    public get element(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-toggle--hidden')\n    @HostBinding('attr.aria-hidden')\n    public get hiddenClass() {\n        return this.collapsed;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-toggle')\n    public get defaultClass() {\n        return !this.collapsed;\n    }\n\n    protected _overlayId: string;\n\n    private _collapsed = true;\n    protected destroy$ = new Subject<boolean>();\n    private _overlaySubFilter: [MonoTypeOperatorFunction<OverlayEventArgs>, MonoTypeOperatorFunction<OverlayEventArgs>] = [\n        filter(x => x.id === this._overlayId),\n        takeUntil(this.destroy$)\n    ];\n    private _overlayOpenedSub: Subscription;\n    private _overlayClosingSub: Subscription;\n    private _overlayClosedSub: Subscription;\n    private _overlayContentAppendedSub: Subscription;\n\n    /**\n     * @hidden\n     */\n    constructor(\n        private elementRef: ElementRef,\n        private cdr: ChangeDetectorRef,\n        @Inject(IgxOverlayService) protected overlayService: IgxOverlayService,\n        @Optional() private navigationService: IgxNavigationService) {\n    }\n\n    /**\n     * Opens the toggle.\n     *\n     * ```typescript\n     * this.myToggle.open();\n     * ```\n     */\n    public open(overlaySettings?: OverlaySettings) {\n        //  if there is open animation do nothing\n        //  if toggle is not collapsed and there is no close animation do nothing\n        const info = this.overlayService.getOverlayById(this._overlayId);\n        const openAnimationStarted = info?.openAnimationPlayer?.hasStarted() ?? false;\n        const closeAnimationStarted = info?.closeAnimationPlayer?.hasStarted() ?? false;\n        if (openAnimationStarted || !(this._collapsed || closeAnimationStarted)) {\n            return;\n        }\n\n        const target = overlaySettings && overlaySettings.target;\n\n        // Get the size from the target element\n        if (target && target instanceof Element) {\n            const styles = window.getComputedStyle(target);\n            const componentSize = styles.getPropertyValue('--component-size');\n            const globalSize = styles.getPropertyValue('--ig-size');\n            const size = componentSize || globalSize || '3';\n            this.elementRef.nativeElement.style.setProperty('--ig-size', size);\n        }\n\n        this._collapsed = false;\n        this.cdr.detectChanges();\n\n        if (!info) {\n            this.unsubscribe();\n            this.subscribe();\n            this._overlayId = this.overlayService.attach(this.elementRef, overlaySettings);\n        }\n\n        const args: ToggleViewCancelableEventArgs = { cancel: false, owner: this, id: this._overlayId };\n        this.opening.emit(args);\n        if (args.cancel) {\n            this.unsubscribe();\n            this.overlayService.detach(this._overlayId);\n            this._collapsed = true;\n            delete this._overlayId;\n            this.cdr.detectChanges();\n            return;\n        }\n        this.overlayService.show(this._overlayId, overlaySettings);\n    }\n\n    /**\n     * Closes the toggle.\n     *\n     * ```typescript\n     * this.myToggle.close();\n     * ```\n     */\n    public close(event?: Event) {\n        //  if toggle is collapsed do nothing\n        //  if there is close animation do nothing, toggle will close anyway\n        const info = this.overlayService.getOverlayById(this._overlayId);\n        const closeAnimationStarted = info?.closeAnimationPlayer?.hasStarted() || false;\n        if (this._collapsed || closeAnimationStarted) {\n            return;\n        }\n\n        this.overlayService.hide(this._overlayId, event);\n    }\n\n    /**\n     * Opens or closes the toggle, depending on its current state.\n     *\n     * ```typescript\n     * this.myToggle.toggle();\n     * ```\n     */\n    public toggle(overlaySettings?: OverlaySettings) {\n        //  if toggle is collapsed call open\n        //  if there is running close animation call open\n        if (this.collapsed || this.isClosing) {\n            this.open(overlaySettings);\n        } else {\n            this.close();\n        }\n    }\n\n    /** @hidden @internal */\n    public get isClosing() {\n        const info = this.overlayService.getOverlayById(this._overlayId);\n        return info ? info.closeAnimationPlayer?.hasStarted() : false;\n    }\n\n    /**\n     * Returns the id of the overlay the content is rendered in.\n     * ```typescript\n     * this.myToggle.overlayId;\n     * ```\n     */\n    public get overlayId() {\n        return this._overlayId;\n    }\n\n    /**\n     * Repositions the toggle.\n     * ```typescript\n     * this.myToggle.reposition();\n     * ```\n     */\n    public reposition() {\n        this.overlayService.reposition(this._overlayId);\n    }\n\n    /**\n     * Offsets the content along the corresponding axis by the provided amount\n     */\n    public setOffset(deltaX: number, deltaY: number) {\n        this.overlayService.setOffset(this._overlayId, deltaX, deltaY);\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnInit() {\n        if (this.navigationService && this.id) {\n            this.navigationService.add(this.id, this);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy() {\n        if (this.navigationService && this.id) {\n            this.navigationService.remove(this.id);\n        }\n        if (this._overlayId) {\n            this.overlayService.detach(this._overlayId);\n        }\n        this.unsubscribe();\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    private overlayClosed = (e) => {\n        this._collapsed = true;\n        this.cdr.detectChanges();\n        this.unsubscribe();\n        this.overlayService.detach(this.overlayId);\n        const args: ToggleViewEventArgs = { owner: this, id: this._overlayId, event: e.event };\n        delete this._overlayId;\n        this.closed.emit(args);\n        this.cdr.markForCheck();\n    };\n\n    private subscribe() {\n        this._overlayContentAppendedSub = this.overlayService\n            .contentAppended\n            .pipe(first(), takeUntil(this.destroy$))\n            .subscribe(() => {\n                const args: ToggleViewEventArgs = { owner: this, id: this._overlayId };\n                this.appended.emit(args);\n            });\n\n        this._overlayOpenedSub = this.overlayService\n            .opened\n            .pipe(...this._overlaySubFilter)\n            .subscribe(() => {\n                const args: ToggleViewEventArgs = { owner: this, id: this._overlayId };\n                this.opened.emit(args);\n            });\n\n        this._overlayClosingSub = this.overlayService\n            .closing\n            .pipe(...this._overlaySubFilter)\n            .subscribe((e: OverlayClosingEventArgs) => {\n                const args: ToggleViewCancelableEventArgs = { cancel: false, event: e.event, owner: this, id: this._overlayId };\n                this.closing.emit(args);\n                e.cancel = args.cancel;\n\n                //  in case event is not canceled this will close the toggle and we need to unsubscribe.\n                //  Otherwise if for some reason, e.g. close on outside click, close() gets called before\n                //  closed was fired we will end with calling closing more than once\n                if (!e.cancel) {\n                    this.clearSubscription(this._overlayClosingSub);\n                }\n            });\n\n        this._overlayClosedSub = this.overlayService\n            .closed\n            .pipe(...this._overlaySubFilter)\n            .subscribe(this.overlayClosed);\n    }\n\n    private unsubscribe() {\n        this.clearSubscription(this._overlayOpenedSub);\n        this.clearSubscription(this._overlayClosingSub);\n        this.clearSubscription(this._overlayClosedSub);\n        this.clearSubscription(this._overlayContentAppendedSub);\n    }\n\n    private clearSubscription(subscription: Subscription) {\n        if (subscription && !subscription.closed) {\n            subscription.unsubscribe();\n        }\n    }\n}\n\n@Directive({\n    exportAs: 'toggle-action',\n    selector: '[igxToggleAction]',\n    standalone: true\n})\nexport class IgxToggleActionDirective implements OnInit {\n    /**\n     * Provide settings that control the toggle overlay positioning, interaction and scroll behavior.\n     * ```typescript\n     * const settings: OverlaySettings = {\n     *      closeOnOutsideClick: false,\n     *      modal: false\n     *  }\n     * ```\n     * ---\n     * ```html\n     * <!--set-->\n     * <div igxToggleAction [overlaySettings]=\"settings\"></div>\n     * ```\n     */\n    @Input()\n    public overlaySettings: OverlaySettings;\n\n    /**\n     * Determines where the toggle element overlay should be attached.\n     *\n     * ```html\n     * <!--set-->\n     * <div igxToggleAction [igxToggleOutlet]=\"outlet\"></div>\n     * ```\n     * Where `outlet` in an instance of `IgxOverlayOutletDirective` or an `ElementRef`\n     */\n    @Input('igxToggleOutlet')\n    public outlet: IgxOverlayOutletDirective | ElementRef;\n\n    /**\n     * @hidden\n     */\n    @Input('igxToggleAction')\n    public set target(target: any) {\n        if (target !== null && target !== '') {\n            this._target = target;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public get target(): any {\n        if (typeof this._target === 'string') {\n            return this.navigationService.get(this._target);\n        }\n        return this._target;\n    }\n\n    protected _overlayDefaults: OverlaySettings;\n    protected _target: IToggleView | string;\n\n    constructor(private element: ElementRef, @Optional() private navigationService: IgxNavigationService) { }\n\n    /**\n     * @hidden\n     */\n    @HostListener('click')\n    public onClick() {\n        if (this.outlet) {\n            this._overlayDefaults.outlet = this.outlet;\n        }\n\n        const clonedSettings = Object.assign({}, this._overlayDefaults, this.overlaySettings);\n        this.updateOverlaySettings(clonedSettings);\n        this.target.toggle(clonedSettings);\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnInit() {\n        const targetElement = this.element.nativeElement;\n        this._overlayDefaults = {\n            target: targetElement,\n            positionStrategy: new ConnectedPositioningStrategy(),\n            scrollStrategy: new AbsoluteScrollStrategy(),\n            closeOnOutsideClick: true,\n            modal: false,\n            excludeFromOutsideClick: [targetElement as HTMLElement]\n        };\n    }\n\n    /**\n     * Updates provided overlay settings\n     *\n     * @param settings settings to update\n     * @returns returns updated copy of provided overlay settings\n     */\n    protected updateOverlaySettings(settings: OverlaySettings): OverlaySettings {\n        if (settings && settings.positionStrategy) {\n            const positionStrategyClone: IPositionStrategy = settings.positionStrategy.clone();\n            settings.target = this.element.nativeElement;\n            settings.positionStrategy = positionStrategyClone;\n        }\n\n        return settings;\n    }\n}\n\n/**\n * Mark an element as an igxOverlay outlet container.\n * Directive instance is exported as `overlay-outlet` to be assigned to templates variables:\n * ```html\n * <div igxOverlayOutlet #outlet=\"overlay-outlet\"></div>\n * ```\n */\n@Directive({\n    exportAs: 'overlay-outlet',\n    selector: '[igxOverlayOutlet]',\n    standalone: true\n})\nexport class IgxOverlayOutletDirective {\n    constructor(public element: ElementRef<HTMLElement>) { }\n\n    /** @hidden */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n}\n"]}
479
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/toggle/toggle.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,SAAS,EAET,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,wDAAwD,CAAC;AAEhG,OAAO,EAAE,4BAA4B,EAAE,MAAM,gEAAgE,CAAC;AAC9G,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAGnE,OAAO,EAAgB,OAAO,EAA4B,MAAM,MAAM,CAAC;;;;;AAevE,MAAM,OAAO,kBAAkB;IAgG3B;;OAEG;IACH,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAYD;;OAEG;IACH,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,IAEW,WAAW;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IACW,iBAAiB;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC;QACzC,MAAM,cAAc,GAAG,IAAI,CAAC,QAAQ,EAAE,cAAc,CAAC;QAErD,OAAO,IAAI,CAAC,SAAS,IAAI,QAAQ,IAAI,CAAC,CAAC,cAAc,IAAI,cAAc,GAAG,IAAI,CAAC;IACnF,CAAC;IAED;;OAEG;IACH,IACW,YAAY;QACnB,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC;IAC3B,CAAC;IAeD;;OAEG;IACH,YACY,UAAsB,EACtB,GAAsB,EACO,cAAiC,EAClD,iBAAuC,EACvC,QAAuB;QAJnC,eAAU,GAAV,UAAU,CAAY;QACtB,QAAG,GAAH,GAAG,CAAmB;QACO,mBAAc,GAAd,cAAc,CAAmB;QAClD,sBAAiB,GAAjB,iBAAiB,CAAsB;QACvC,aAAQ,GAAR,QAAQ,CAAe;QArK/C;;;;;;;;;;;;;;;WAeG;QAEI,WAAM,GAAG,IAAI,YAAY,EAAuB,CAAC;QAExD;;;;;;;;;;;;;;;WAeG;QAEI,YAAO,GAAG,IAAI,YAAY,EAAiC,CAAC;QAEnE;;;;;;;;;;;;;;;WAeG;QAEI,WAAM,GAAG,IAAI,YAAY,EAAuB,CAAC;QAExD;;;;;;;;;;;;;;;WAeG;QAEI,YAAO,GAAG,IAAI,YAAY,EAAiC,CAAC;QAEnE;;;;;;;;;;;;;;;WAeG;QAEI,aAAQ,GAAG,IAAI,YAAY,EAAuB,CAAC;QAqDlD,eAAU,GAAG,IAAI,CAAC;QAChB,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;QACpC,sBAAiB,GAA6F;YAClH,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,UAAU,CAAC;YACrC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC3B,CAAC;QAiKM,kBAAa,GAAG,CAAC,CAAC,EAAE,EAAE;YAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC3C,MAAM,IAAI,GAAwB,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;YACvF,OAAO,IAAI,CAAC,UAAU,CAAC;YACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC;IA1JF,CAAC;IAED;;;;;;OAMG;IACI,IAAI,CAAC,eAAiC;QACzC,yCAAyC;QACzC,yEAAyE;QACzE,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjE,MAAM,oBAAoB,GAAG,IAAI,EAAE,mBAAmB,EAAE,UAAU,EAAE,IAAI,KAAK,CAAC;QAC9E,MAAM,qBAAqB,GAAG,IAAI,EAAE,oBAAoB,EAAE,UAAU,EAAE,IAAI,KAAK,CAAC;QAChF,IAAI,oBAAoB,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,qBAAqB,CAAC,EAAE;YACrE,OAAO;SACV;QAED,MAAM,MAAM,GAAG,eAAe,IAAI,eAAe,CAAC,MAAM,CAAC;QAEzD,uCAAuC;QACvC,IAAI,MAAM,IAAI,MAAM,YAAY,OAAO,EAAE;YACrC,MAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAC/C,MAAM,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC;YAClE,MAAM,UAAU,GAAG,MAAM,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;YACxD,MAAM,IAAI,GAAG,aAAa,IAAI,UAAU,IAAI,GAAG,CAAC;YAChD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;SACtE;QAED,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAEzB,IAAI,CAAC,IAAI,EAAE;YACP,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;SAClF;QAED,MAAM,IAAI,GAAkC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;QAChG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC5C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,OAAO,IAAI,CAAC,UAAU,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,OAAO;SACV;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;IAC/D,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,KAAa;QACtB,qCAAqC;QACrC,oEAAoE;QACpE,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjE,MAAM,qBAAqB,GAAG,IAAI,EAAE,oBAAoB,EAAE,UAAU,EAAE,IAAI,KAAK,CAAC;QAChF,IAAI,IAAI,CAAC,UAAU,IAAI,qBAAqB,EAAE;YAC1C,OAAO;SACV;QAED,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,eAAiC;QAC3C,oCAAoC;QACpC,iDAAiD;QACjD,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,EAAE;YAClC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC9B;aAAM;YACH,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;IACL,CAAC;IAED,wBAAwB;IACxB,IAAW,SAAS;QAChB,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjE,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;IAClE,CAAC;IAED;;;;;OAKG;IACH,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED;;;;;OAKG;IACI,UAAU;QACb,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC;IAED;;OAEG;IACI,SAAS,CAAC,MAAc,EAAE,MAAc;QAC3C,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACnE,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,EAAE,EAAE;YACnC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;SAC7C;IACL,CAAC;IAED;;OAEG;IACI,WAAW;QACd,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,EAAE,EAAE;YACnC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAC1C;QACD,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAC/C;QACD,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IAaO,SAAS;QACb,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,cAAc;aAChD,eAAe;aACf,IAAI,CAAC,KAAK,EAAE,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACvC,SAAS,CAAC,GAAG,EAAE;YACZ,MAAM,IAAI,GAAwB,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;YACvE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc;aACvC,MAAM;aACN,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC;aAC/B,SAAS,CAAC,GAAG,EAAE;YACZ,MAAM,IAAI,GAAwB,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;YACvE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,cAAc;aACxC,OAAO;aACP,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC;aAC/B,SAAS,CAAC,CAAC,CAA0B,EAAE,EAAE;YACtC,MAAM,IAAI,GAAkC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;YAChH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxB,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAEvB,wFAAwF;YACxF,yFAAyF;YACzF,oEAAoE;YACpE,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE;gBACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;aACnD;QACL,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc;aACvC,MAAM;aACN,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC;aAC/B,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACvC,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC/C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAChD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC/C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;IAC5D,CAAC;IAEO,iBAAiB,CAAC,YAA0B;QAChD,IAAI,YAAY,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;YACtC,YAAY,CAAC,WAAW,EAAE,CAAC;SAC9B;IACL,CAAC;8GAtXQ,kBAAkB,6EAoKf,iBAAiB;kGApKpB,kBAAkB;;2FAAlB,kBAAkB;kBAL9B,SAAS;mBAAC;oBACP,QAAQ,EAAE,QAAQ;oBAClB,QAAQ,EAAE,aAAa;oBACvB,UAAU,EAAE,IAAI;iBACnB;;0BAqKQ,MAAM;2BAAC,iBAAiB;;0BACxB,QAAQ;;0BACR,QAAQ;yCApJN,MAAM;sBADZ,MAAM;gBAoBA,OAAO;sBADb,MAAM;gBAoBA,MAAM;sBADZ,MAAM;gBAoBA,OAAO;sBADb,MAAM;gBAoBA,QAAQ;sBADd,MAAM;gBAkBA,EAAE;sBADR,KAAK;gBAeK,WAAW;sBAFrB,WAAW;uBAAC,0BAA0B;;sBACtC,WAAW;uBAAC,kBAAkB;gBAMpB,iBAAiB;sBAD3B,WAAW;uBAAC,iCAAiC;gBAYnC,YAAY;sBADtB,WAAW;uBAAC,kBAAkB;;AAkPnC,MAAM,OAAO,wBAAwB;IA8BjC;;OAEG;IACH,IACW,MAAM,CAAC,MAAW;QACzB,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,EAAE,EAAE;YAClC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;SACzB;IACL,CAAC;IAED;;OAEG;IACH,IAAW,MAAM;QACb,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,EAAE;YAClC,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACnD;QACD,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAKD,YAAoB,OAAmB,EAAsB,iBAAuC;QAAhF,YAAO,GAAP,OAAO,CAAY;QAAsB,sBAAiB,GAAjB,iBAAiB,CAAsB;IAAI,CAAC;IAEzG;;OAEG;IAEI,OAAO;QACV,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;SAC9C;QAED,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QACtF,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC;QAC3C,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QACjD,IAAI,CAAC,gBAAgB,GAAG;YACpB,MAAM,EAAE,aAAa;YACrB,gBAAgB,EAAE,IAAI,4BAA4B,EAAE;YACpD,cAAc,EAAE,IAAI,sBAAsB,EAAE;YAC5C,mBAAmB,EAAE,IAAI;YACzB,KAAK,EAAE,KAAK;YACZ,uBAAuB,EAAE,CAAC,aAA4B,CAAC;SAC1D,CAAC;IACN,CAAC;IAED;;;;;OAKG;IACO,qBAAqB,CAAC,QAAyB;QACrD,IAAI,QAAQ,IAAI,QAAQ,CAAC,gBAAgB,EAAE;YACvC,MAAM,qBAAqB,GAAsB,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YACnF,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;YAC7C,QAAQ,CAAC,gBAAgB,GAAG,qBAAqB,CAAC;SACrD;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;8GAlGQ,wBAAwB;kGAAxB,wBAAwB;;2FAAxB,wBAAwB;kBALpC,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE,mBAAmB;oBAC7B,UAAU,EAAE,IAAI;iBACnB;;0BAsD6C,QAAQ;yCArC3C,eAAe;sBADrB,KAAK;gBAaC,MAAM;sBADZ,KAAK;uBAAC,iBAAiB;gBAOb,MAAM;sBADhB,KAAK;uBAAC,iBAAiB;gBA0BjB,OAAO;sBADb,YAAY;uBAAC,OAAO;;AA2CzB;;;;;;GAMG;AAMH,MAAM,OAAO,yBAAyB;IAClC,YAAmB,OAAgC;QAAhC,YAAO,GAAP,OAAO,CAAyB;IAAI,CAAC;IAExD,cAAc;IACd,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;IACtC,CAAC;8GANQ,yBAAyB;kGAAzB,yBAAyB;;2FAAzB,yBAAyB;kBALrC,SAAS;mBAAC;oBACP,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,oBAAoB;oBAC9B,UAAU,EAAE,IAAI;iBACnB","sourcesContent":["import {\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output\n} from '@angular/core';\nimport { AbsoluteScrollStrategy } from '../../services/overlay/scroll/absolute-scroll-strategy';\nimport { CancelableBrowserEventArgs, IBaseEventArgs, PlatformUtil } from '../../core/utils';\nimport { ConnectedPositioningStrategy } from '../../services/overlay/position/connected-positioning-strategy';\nimport { filter, first, takeUntil } from 'rxjs/operators';\nimport { IgxNavigationService, IToggleView } from '../../core/navigation';\nimport { IgxOverlayService } from '../../services/overlay/overlay';\nimport { IPositionStrategy } from '../../services/overlay/position/IPositionStrategy';\nimport { OverlayClosingEventArgs, OverlayEventArgs, OverlaySettings } from '../../services/overlay/utilities';\nimport { Subscription, Subject, MonoTypeOperatorFunction } from 'rxjs';\n\nexport interface ToggleViewEventArgs extends IBaseEventArgs {\n    /** Id of the toggle view */\n    id: string;\n    event?: Event;\n}\n\nexport interface ToggleViewCancelableEventArgs extends ToggleViewEventArgs, CancelableBrowserEventArgs { }\n\n@Directive({\n    exportAs: 'toggle',\n    selector: '[igxToggle]',\n    standalone: true\n})\nexport class IgxToggleDirective implements IToggleView, OnInit, OnDestroy {\n    /**\n     * Emits an event after the toggle container is opened.\n     *\n     * ```typescript\n     * onToggleOpened(event) {\n     *    alert(\"Toggle opened!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (opened)='onToggleOpened($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public opened = new EventEmitter<ToggleViewEventArgs>();\n\n    /**\n     * Emits an event before the toggle container is opened.\n     *\n     * ```typescript\n     * onToggleOpening(event) {\n     *  alert(\"Toggle opening!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (opening)='onToggleOpening($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public opening = new EventEmitter<ToggleViewCancelableEventArgs>();\n\n    /**\n     * Emits an event after the toggle container is closed.\n     *\n     * ```typescript\n     * onToggleClosed(event) {\n     *  alert(\"Toggle closed!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (closed)='onToggleClosed($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public closed = new EventEmitter<ToggleViewEventArgs>();\n\n    /**\n     * Emits an event before the toggle container is closed.\n     *\n     * ```typescript\n     * onToggleClosing(event) {\n     *  alert(\"Toggle closing!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *  igxToggle\n     *  (closing)='onToggleClosing($event)'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public closing = new EventEmitter<ToggleViewCancelableEventArgs>();\n\n    /**\n     * Emits an event after the toggle element is appended to the overlay container.\n     *\n     * ```typescript\n     * onAppended() {\n     *  alert(\"Content appended!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <div\n     *   igxToggle\n     *   (appended)='onToggleAppended()'>\n     * </div>\n     * ```\n     */\n    @Output()\n    public appended = new EventEmitter<ToggleViewEventArgs>();\n\n    /**\n     * @hidden\n     */\n    public get collapsed(): boolean {\n        return this._collapsed;\n    }\n\n    /**\n     * Identifier which is registered into `IgxNavigationService`\n     *\n     * ```typescript\n     * let myToggleId = this.toggle.id;\n     * ```\n     */\n    @Input()\n    public id: string;\n\n    /**\n     * @hidden\n     */\n    public get element(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-toggle--hidden')\n    @HostBinding('attr.aria-hidden')\n    public get hiddenClass() {\n        return this.collapsed;\n    }\n\n    @HostBinding('class.igx-toggle--hidden-webkit')\n    public get hiddenWebkitClass() {\n        const isSafari = this.platform?.isSafari;\n        const browserVersion = this.platform?.browserVersion;\n\n        return this.collapsed && isSafari && !!browserVersion && browserVersion < 17.5;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-toggle')\n    public get defaultClass() {\n        return !this.collapsed;\n    }\n\n    protected _overlayId: string;\n\n    private _collapsed = true;\n    protected destroy$ = new Subject<boolean>();\n    private _overlaySubFilter: [MonoTypeOperatorFunction<OverlayEventArgs>, MonoTypeOperatorFunction<OverlayEventArgs>] = [\n        filter(x => x.id === this._overlayId),\n        takeUntil(this.destroy$)\n    ];\n    private _overlayOpenedSub: Subscription;\n    private _overlayClosingSub: Subscription;\n    private _overlayClosedSub: Subscription;\n    private _overlayContentAppendedSub: Subscription;\n\n    /**\n     * @hidden\n     */\n    constructor(\n        private elementRef: ElementRef,\n        private cdr: ChangeDetectorRef,\n        @Inject(IgxOverlayService) protected overlayService: IgxOverlayService,\n        @Optional() private navigationService: IgxNavigationService,\n        @Optional() private platform?: PlatformUtil\n    ) {\n    }\n\n    /**\n     * Opens the toggle.\n     *\n     * ```typescript\n     * this.myToggle.open();\n     * ```\n     */\n    public open(overlaySettings?: OverlaySettings) {\n        //  if there is open animation do nothing\n        //  if toggle is not collapsed and there is no close animation do nothing\n        const info = this.overlayService.getOverlayById(this._overlayId);\n        const openAnimationStarted = info?.openAnimationPlayer?.hasStarted() ?? false;\n        const closeAnimationStarted = info?.closeAnimationPlayer?.hasStarted() ?? false;\n        if (openAnimationStarted || !(this._collapsed || closeAnimationStarted)) {\n            return;\n        }\n\n        const target = overlaySettings && overlaySettings.target;\n\n        // Get the size from the target element\n        if (target && target instanceof Element) {\n            const styles = window.getComputedStyle(target);\n            const componentSize = styles.getPropertyValue('--component-size');\n            const globalSize = styles.getPropertyValue('--ig-size');\n            const size = componentSize || globalSize || '3';\n            this.elementRef.nativeElement.style.setProperty('--ig-size', size);\n        }\n\n        this._collapsed = false;\n        this.cdr.detectChanges();\n\n        if (!info) {\n            this.unsubscribe();\n            this.subscribe();\n            this._overlayId = this.overlayService.attach(this.elementRef, overlaySettings);\n        }\n\n        const args: ToggleViewCancelableEventArgs = { cancel: false, owner: this, id: this._overlayId };\n        this.opening.emit(args);\n        if (args.cancel) {\n            this.unsubscribe();\n            this.overlayService.detach(this._overlayId);\n            this._collapsed = true;\n            delete this._overlayId;\n            this.cdr.detectChanges();\n            return;\n        }\n        this.overlayService.show(this._overlayId, overlaySettings);\n    }\n\n    /**\n     * Closes the toggle.\n     *\n     * ```typescript\n     * this.myToggle.close();\n     * ```\n     */\n    public close(event?: Event) {\n        //  if toggle is collapsed do nothing\n        //  if there is close animation do nothing, toggle will close anyway\n        const info = this.overlayService.getOverlayById(this._overlayId);\n        const closeAnimationStarted = info?.closeAnimationPlayer?.hasStarted() || false;\n        if (this._collapsed || closeAnimationStarted) {\n            return;\n        }\n\n        this.overlayService.hide(this._overlayId, event);\n    }\n\n    /**\n     * Opens or closes the toggle, depending on its current state.\n     *\n     * ```typescript\n     * this.myToggle.toggle();\n     * ```\n     */\n    public toggle(overlaySettings?: OverlaySettings) {\n        //  if toggle is collapsed call open\n        //  if there is running close animation call open\n        if (this.collapsed || this.isClosing) {\n            this.open(overlaySettings);\n        } else {\n            this.close();\n        }\n    }\n\n    /** @hidden @internal */\n    public get isClosing() {\n        const info = this.overlayService.getOverlayById(this._overlayId);\n        return info ? info.closeAnimationPlayer?.hasStarted() : false;\n    }\n\n    /**\n     * Returns the id of the overlay the content is rendered in.\n     * ```typescript\n     * this.myToggle.overlayId;\n     * ```\n     */\n    public get overlayId() {\n        return this._overlayId;\n    }\n\n    /**\n     * Repositions the toggle.\n     * ```typescript\n     * this.myToggle.reposition();\n     * ```\n     */\n    public reposition() {\n        this.overlayService.reposition(this._overlayId);\n    }\n\n    /**\n     * Offsets the content along the corresponding axis by the provided amount\n     */\n    public setOffset(deltaX: number, deltaY: number) {\n        this.overlayService.setOffset(this._overlayId, deltaX, deltaY);\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnInit() {\n        if (this.navigationService && this.id) {\n            this.navigationService.add(this.id, this);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy() {\n        if (this.navigationService && this.id) {\n            this.navigationService.remove(this.id);\n        }\n        if (this._overlayId) {\n            this.overlayService.detach(this._overlayId);\n        }\n        this.unsubscribe();\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    private overlayClosed = (e) => {\n        this._collapsed = true;\n        this.cdr.detectChanges();\n        this.unsubscribe();\n        this.overlayService.detach(this.overlayId);\n        const args: ToggleViewEventArgs = { owner: this, id: this._overlayId, event: e.event };\n        delete this._overlayId;\n        this.closed.emit(args);\n        this.cdr.markForCheck();\n    };\n\n    private subscribe() {\n        this._overlayContentAppendedSub = this.overlayService\n            .contentAppended\n            .pipe(first(), takeUntil(this.destroy$))\n            .subscribe(() => {\n                const args: ToggleViewEventArgs = { owner: this, id: this._overlayId };\n                this.appended.emit(args);\n            });\n\n        this._overlayOpenedSub = this.overlayService\n            .opened\n            .pipe(...this._overlaySubFilter)\n            .subscribe(() => {\n                const args: ToggleViewEventArgs = { owner: this, id: this._overlayId };\n                this.opened.emit(args);\n            });\n\n        this._overlayClosingSub = this.overlayService\n            .closing\n            .pipe(...this._overlaySubFilter)\n            .subscribe((e: OverlayClosingEventArgs) => {\n                const args: ToggleViewCancelableEventArgs = { cancel: false, event: e.event, owner: this, id: this._overlayId };\n                this.closing.emit(args);\n                e.cancel = args.cancel;\n\n                //  in case event is not canceled this will close the toggle and we need to unsubscribe.\n                //  Otherwise if for some reason, e.g. close on outside click, close() gets called before\n                //  closed was fired we will end with calling closing more than once\n                if (!e.cancel) {\n                    this.clearSubscription(this._overlayClosingSub);\n                }\n            });\n\n        this._overlayClosedSub = this.overlayService\n            .closed\n            .pipe(...this._overlaySubFilter)\n            .subscribe(this.overlayClosed);\n    }\n\n    private unsubscribe() {\n        this.clearSubscription(this._overlayOpenedSub);\n        this.clearSubscription(this._overlayClosingSub);\n        this.clearSubscription(this._overlayClosedSub);\n        this.clearSubscription(this._overlayContentAppendedSub);\n    }\n\n    private clearSubscription(subscription: Subscription) {\n        if (subscription && !subscription.closed) {\n            subscription.unsubscribe();\n        }\n    }\n}\n\n@Directive({\n    exportAs: 'toggle-action',\n    selector: '[igxToggleAction]',\n    standalone: true\n})\nexport class IgxToggleActionDirective implements OnInit {\n    /**\n     * Provide settings that control the toggle overlay positioning, interaction and scroll behavior.\n     * ```typescript\n     * const settings: OverlaySettings = {\n     *      closeOnOutsideClick: false,\n     *      modal: false\n     *  }\n     * ```\n     * ---\n     * ```html\n     * <!--set-->\n     * <div igxToggleAction [overlaySettings]=\"settings\"></div>\n     * ```\n     */\n    @Input()\n    public overlaySettings: OverlaySettings;\n\n    /**\n     * Determines where the toggle element overlay should be attached.\n     *\n     * ```html\n     * <!--set-->\n     * <div igxToggleAction [igxToggleOutlet]=\"outlet\"></div>\n     * ```\n     * Where `outlet` in an instance of `IgxOverlayOutletDirective` or an `ElementRef`\n     */\n    @Input('igxToggleOutlet')\n    public outlet: IgxOverlayOutletDirective | ElementRef;\n\n    /**\n     * @hidden\n     */\n    @Input('igxToggleAction')\n    public set target(target: any) {\n        if (target !== null && target !== '') {\n            this._target = target;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public get target(): any {\n        if (typeof this._target === 'string') {\n            return this.navigationService.get(this._target);\n        }\n        return this._target;\n    }\n\n    protected _overlayDefaults: OverlaySettings;\n    protected _target: IToggleView | string;\n\n    constructor(private element: ElementRef, @Optional() private navigationService: IgxNavigationService) { }\n\n    /**\n     * @hidden\n     */\n    @HostListener('click')\n    public onClick() {\n        if (this.outlet) {\n            this._overlayDefaults.outlet = this.outlet;\n        }\n\n        const clonedSettings = Object.assign({}, this._overlayDefaults, this.overlaySettings);\n        this.updateOverlaySettings(clonedSettings);\n        this.target.toggle(clonedSettings);\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnInit() {\n        const targetElement = this.element.nativeElement;\n        this._overlayDefaults = {\n            target: targetElement,\n            positionStrategy: new ConnectedPositioningStrategy(),\n            scrollStrategy: new AbsoluteScrollStrategy(),\n            closeOnOutsideClick: true,\n            modal: false,\n            excludeFromOutsideClick: [targetElement as HTMLElement]\n        };\n    }\n\n    /**\n     * Updates provided overlay settings\n     *\n     * @param settings settings to update\n     * @returns returns updated copy of provided overlay settings\n     */\n    protected updateOverlaySettings(settings: OverlaySettings): OverlaySettings {\n        if (settings && settings.positionStrategy) {\n            const positionStrategyClone: IPositionStrategy = settings.positionStrategy.clone();\n            settings.target = this.element.nativeElement;\n            settings.positionStrategy = positionStrategyClone;\n        }\n\n        return settings;\n    }\n}\n\n/**\n * Mark an element as an igxOverlay outlet container.\n * Directive instance is exported as `overlay-outlet` to be assigned to templates variables:\n * ```html\n * <div igxOverlayOutlet #outlet=\"overlay-outlet\"></div>\n * ```\n */\n@Directive({\n    exportAs: 'overlay-outlet',\n    selector: '[igxOverlayOutlet]',\n    standalone: true\n})\nexport class IgxOverlayOutletDirective {\n    constructor(public element: ElementRef<HTMLElement>) { }\n\n    /** @hidden */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n}\n"]}