@ifsworld/granite-components 6.0.0-beta.5 → 6.0.0-beta.6

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 (139) hide show
  1. package/README.md +4 -28
  2. package/date-picker/index.d.ts +4 -0
  3. package/date-picker/lib/date-picker-base.d.ts +34 -0
  4. package/date-picker/lib/date-picker-trigger-for.directive.d.ts +70 -0
  5. package/date-picker/lib/date-picker.component.d.ts +10 -0
  6. package/date-picker/lib/date-picker.module.d.ts +15 -0
  7. package/date-picker/lib/date-range-picker.component.d.ts +12 -0
  8. package/esm2020/date-picker/ifsworld-granite-components-date-picker.mjs +5 -0
  9. package/esm2020/date-picker/index.mjs +5 -0
  10. package/esm2020/date-picker/lib/date-picker-base.mjs +53 -0
  11. package/esm2020/date-picker/lib/date-picker-trigger-for.directive.mjs +228 -0
  12. package/esm2020/date-picker/lib/date-picker.component.mjs +30 -0
  13. package/esm2020/date-picker/lib/date-picker.module.mjs +58 -0
  14. package/esm2020/date-picker/lib/date-range-picker.component.mjs +46 -0
  15. package/esm2020/lib/arrange-grid/arrange-grid-item.component.mjs +14 -14
  16. package/esm2020/lib/arrange-grid/arrange-grid.component.mjs +19 -19
  17. package/esm2020/lib/arrange-grid/arrange-grid.module.mjs +5 -5
  18. package/esm2020/lib/badge/badge.component.mjs +5 -5
  19. package/esm2020/lib/badge/badge.module.mjs +5 -5
  20. package/esm2020/lib/button/button.component.mjs +9 -9
  21. package/esm2020/lib/button/button.module.mjs +5 -5
  22. package/esm2020/lib/checkbox/checkbox-group.component.mjs +4 -4
  23. package/esm2020/lib/checkbox/checkbox.component.mjs +11 -8
  24. package/esm2020/lib/checkbox/checkbox.module.mjs +5 -5
  25. package/esm2020/lib/chips/chip-input.mjs +25 -25
  26. package/esm2020/lib/chips/chip-list.component.mjs +47 -47
  27. package/esm2020/lib/chips/chip.component.mjs +48 -48
  28. package/esm2020/lib/chips/chips.module.mjs +5 -5
  29. package/esm2020/lib/core/common-behaviors/disabled.mjs +4 -4
  30. package/esm2020/lib/core/core.module.mjs +5 -5
  31. package/esm2020/lib/core/devices/client-input-desktop.directive.mjs +4 -4
  32. package/esm2020/lib/core/devices/client-input-touch.directive.mjs +4 -4
  33. package/esm2020/lib/core/devices/client-output-desktop.directive.mjs +4 -4
  34. package/esm2020/lib/core/devices/client-output-touch.directive.mjs +4 -4
  35. package/esm2020/lib/core/pipes/pure-pipes.module.mjs +5 -5
  36. package/esm2020/lib/core/pipes/title.pipe.mjs +4 -4
  37. package/esm2020/lib/core/radio-checkbox-base.mjs +4 -4
  38. package/esm2020/lib/grid/grid.component.mjs +10 -10
  39. package/esm2020/lib/grid/grid.module.mjs +5 -5
  40. package/esm2020/lib/icon/icon.component.mjs +5 -5
  41. package/esm2020/lib/icon/icon.module.mjs +5 -5
  42. package/esm2020/lib/input-field/input-field.component.mjs +7 -7
  43. package/esm2020/lib/input-field/input-field.module.mjs +5 -5
  44. package/esm2020/lib/label/label.component.mjs +4 -4
  45. package/esm2020/lib/label/label.module.mjs +5 -5
  46. package/esm2020/lib/menu/divider.directive.mjs +4 -4
  47. package/esm2020/lib/menu/menu-base.mjs +31 -31
  48. package/esm2020/lib/menu/menu-item.component.mjs +8 -8
  49. package/esm2020/lib/menu/menu-touch-close.component.mjs +5 -5
  50. package/esm2020/lib/menu/menu-touch-title.component.mjs +8 -8
  51. package/esm2020/lib/menu/menu-trigger-for.directive.mjs +9 -7
  52. package/esm2020/lib/menu/menu.component.mjs +8 -8
  53. package/esm2020/lib/menu/menu.module.mjs +5 -5
  54. package/esm2020/lib/menu/title.directive.mjs +4 -4
  55. package/esm2020/lib/radio-button/radio-button.component.mjs +11 -8
  56. package/esm2020/lib/radio-button/radio-button.module.mjs +5 -5
  57. package/esm2020/lib/radio-button/radio-group.component.mjs +4 -4
  58. package/esm2020/lib/toggle-switch/toggle-switch.component.mjs +12 -8
  59. package/esm2020/lib/toggle-switch/toggle-switch.module.mjs +5 -5
  60. package/esm2020/table/lib/cell/cell-align/cell-align-classes.directive.mjs +4 -4
  61. package/esm2020/table/lib/cell/cell.mjs +4 -4
  62. package/esm2020/table/lib/cell/table-data-cell.component.mjs +5 -5
  63. package/esm2020/table/lib/cell/table-header-cell.component.mjs +5 -5
  64. package/esm2020/table/lib/column/table-column.directive.mjs +4 -4
  65. package/esm2020/table/lib/table.component.mjs +9 -9
  66. package/esm2020/table/lib/table.module.mjs +5 -5
  67. package/esm2020/tooltip/lib/tooltip-trigger-for.directive.mjs +4 -4
  68. package/esm2020/tooltip/lib/tooltip.component.mjs +5 -5
  69. package/esm2020/tooltip/lib/tooltip.module.mjs +5 -5
  70. package/fesm2015/ifsworld-granite-components-date-picker.mjs +401 -0
  71. package/fesm2015/ifsworld-granite-components-date-picker.mjs.map +1 -0
  72. package/fesm2015/ifsworld-granite-components-table.mjs +26 -26
  73. package/fesm2015/ifsworld-granite-components-table.mjs.map +1 -1
  74. package/fesm2015/ifsworld-granite-components-tooltip.mjs +11 -11
  75. package/fesm2015/ifsworld-granite-components-tooltip.mjs.map +1 -1
  76. package/fesm2015/ifsworld-granite-components.mjs +368 -356
  77. package/fesm2015/ifsworld-granite-components.mjs.map +1 -1
  78. package/fesm2020/ifsworld-granite-components-date-picker.mjs +396 -0
  79. package/fesm2020/ifsworld-granite-components-date-picker.mjs.map +1 -0
  80. package/fesm2020/ifsworld-granite-components-table.mjs +26 -26
  81. package/fesm2020/ifsworld-granite-components-table.mjs.map +1 -1
  82. package/fesm2020/ifsworld-granite-components-tooltip.mjs +11 -11
  83. package/fesm2020/ifsworld-granite-components-tooltip.mjs.map +1 -1
  84. package/fesm2020/ifsworld-granite-components.mjs +368 -356
  85. package/fesm2020/ifsworld-granite-components.mjs.map +1 -1
  86. package/lib/arrange-grid/arrange-grid-item.component.d.ts +1 -1
  87. package/lib/arrange-grid/arrange-grid.component.d.ts +1 -1
  88. package/lib/badge/badge.component.d.ts +1 -1
  89. package/lib/button/button.component.d.ts +2 -2
  90. package/lib/checkbox/checkbox-group.component.d.ts +1 -1
  91. package/lib/checkbox/checkbox.component.d.ts +1 -1
  92. package/lib/chips/chip-input.d.ts +1 -1
  93. package/lib/chips/chip-list.component.d.ts +1 -1
  94. package/lib/chips/chip.component.d.ts +1 -1
  95. package/lib/core/client-environment.d.ts +2 -2
  96. package/lib/core/common-behaviors/disabled.d.ts +1 -1
  97. package/lib/core/devices/client-input-desktop.directive.d.ts +1 -1
  98. package/lib/core/devices/client-input-touch.directive.d.ts +1 -1
  99. package/lib/core/devices/client-output-desktop.directive.d.ts +1 -1
  100. package/lib/core/devices/client-output-touch.directive.d.ts +1 -1
  101. package/lib/core/pipes/title.pipe.d.ts +1 -1
  102. package/lib/core/radio-checkbox-base.d.ts +1 -1
  103. package/lib/core/types.d.ts +2 -2
  104. package/lib/grid/grid.component.d.ts +2 -2
  105. package/lib/icon/icon.component.d.ts +1 -1
  106. package/lib/input-field/input-field.component.d.ts +1 -1
  107. package/lib/label/label.component.d.ts +1 -1
  108. package/lib/menu/divider.directive.d.ts +1 -1
  109. package/lib/menu/menu-base.d.ts +3 -3
  110. package/lib/menu/menu-item.component.d.ts +1 -1
  111. package/lib/menu/menu-panel.d.ts +1 -1
  112. package/lib/menu/menu-positions.d.ts +2 -2
  113. package/lib/menu/menu-touch-close.component.d.ts +1 -1
  114. package/lib/menu/menu-touch-title.component.d.ts +1 -1
  115. package/lib/menu/menu-trigger-for.directive.d.ts +2 -1
  116. package/lib/menu/menu.component.d.ts +1 -1
  117. package/lib/menu/title.directive.d.ts +1 -1
  118. package/lib/radio-button/radio-button.component.d.ts +1 -1
  119. package/lib/radio-button/radio-group.component.d.ts +1 -1
  120. package/lib/toggle-switch/toggle-switch.component.d.ts +1 -1
  121. package/package.json +25 -14
  122. package/src/lib/core/style/_mixins.scss +14 -6
  123. package/src/lib/core/style/_overlay.scss +11 -1
  124. package/src/lib/core/style/_tokens.scss +1 -1
  125. package/src/lib/core/style/_z-index.scss +4 -0
  126. package/table/lib/cell/cell-align/cell-align-classes.directive.d.ts +1 -1
  127. package/table/lib/cell/cell.d.ts +1 -1
  128. package/table/lib/cell/table-data-cell.component.d.ts +1 -1
  129. package/table/lib/cell/table-header-cell.component.d.ts +1 -1
  130. package/table/lib/column/table-column.directive.d.ts +1 -1
  131. package/table/lib/table.component.d.ts +1 -1
  132. package/table/lib/table.types.d.ts +1 -1
  133. package/tooltip/lib/tooltip-trigger-for.directive.d.ts +1 -1
  134. package/tooltip/lib/tooltip.component.d.ts +1 -1
  135. package/ifsworld-granite-components.d.ts +0 -5
  136. package/table/ifsworld-granite-components-table.d.ts +0 -5
  137. package/table/package.json +0 -18
  138. package/tooltip/ifsworld-granite-components-tooltip.d.ts +0 -5
  139. package/tooltip/package.json +0 -10
package/README.md CHANGED
@@ -2,12 +2,7 @@
2
2
 
3
3
  This library is an Angular implementation of the [IFS Design System](https://design.ifs.com). The IFS User Experience product group builds and maintains common UI components and tools. [The goal](docs/strategy.md) is to help product teams rapidly build applications with a delightful IFS branded experience.
4
4
 
5
- ![npm](https://img.shields.io/npm/v/@ifsworld/granite-components)
6
- ![npm weekly downloads](https://img.shields.io/npm/dw/@ifsworld/granite-components)
7
- [![@ifsworld/granite-components](https://snyk.io/advisor/npm-package/@ifsworld/granite-components/badge.svg)](https://snyk.io/advisor/npm-package/@ifsworld/granite-components)
8
-
9
- [![Commitizen friendly](https://img.shields.io/badge/commitizen-friendly-brightgreen.svg)](http://commitizen.github.io/cz-cli/)
10
- [![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg)](https://github.com/semantic-release/semantic-release)
5
+ [![npm peer dependency version (scoped)](https://img.shields.io/npm/dependency-version/%40ifsworld/granite-components/peer/%40angular%2Fcore?color=%23DE3641)](https://angular.io/guide/creating-libraries#ensuring-library-version-compatibility)
11
6
  [![Storybook](https://cdn.jsdelivr.net/gh/storybookjs/brand@main/badge/badge-storybook.svg)](https://uxstorybooklatest.z16.web.core.windows.net/)
12
7
 
13
8
  ## Deployments
@@ -53,21 +48,7 @@ Finally, add them in `src/styles.scss`:
53
48
 
54
49
  ### Support
55
50
 
56
- #### Angular version support matrix
57
-
58
- | Angular / Library | 0.x.x | 1.x.x | 2.x.x | 3.x.x | 4.x.x | 5.x.x |
59
- | ----------------- | ----- | ----- | ----- | ----- | ----- | ----- |
60
- | 10 | ❌ | ❌ | ❌ | ❌ | ❌ | ❌ |
61
- | 11 | ✅ | 🔶 | ✅ | ✅ | ✅ | ❌ |
62
- | 12 | ✅ | ✅ | ✅ | ✅ | 🔶 | ❌ |
63
- | 13 | ✅ | ✅ | ✅ | ✅ | 🔶 | ✅ |
64
- | 14 | 🔶 | 🔶 | 🔶 | 🔶 | 🔶 | 🔶 |
65
-
66
- _Note: we plan to only support our latest release. Beyond that we make no guarantees of continued support._
67
-
68
- ❌ unsupported
69
- 🔶 limited support
70
- ✅ fully supported
51
+ _Note: we only support our latest release. Beyond that we make no guarantees of continued support. Make sure to stay up to date._
71
52
 
72
53
  ## Contributing
73
54
 
@@ -85,14 +66,9 @@ To get more help on the Angular CLI use `ng help` or go check out the [Angular C
85
66
  - [Create your Standalone Angular Library in 10 minutes](https://indepth.dev/create-your-standalone-angular-library-in-10-minutes/)
86
67
  - [Creating monorepos using NX](https://nx.dev/)
87
68
 
88
- ## What we're working on now (2022)
69
+ ## What we're working on now
89
70
 
90
- - Multi Select Input Control
91
- - Date Picker Control
92
- - Advance Input Control
93
- - Advance Table Control
94
- - Rating Control
95
- - Label Control
71
+ Visit <https://design.ifs.com> to learn more.
96
72
 
97
73
  ## About the product group
98
74
 
@@ -0,0 +1,4 @@
1
+ export * from './lib/date-picker.module';
2
+ export * from './lib/date-picker.component';
3
+ export * from './lib/date-range-picker.component';
4
+ export * from './lib/date-picker-trigger-for.directive';
@@ -0,0 +1,34 @@
1
+ import { ElementRef, EventEmitter, OnInit, TemplateRef } from '@angular/core';
2
+ import { Direction } from '@angular/cdk/bidi';
3
+ import { PrimeNGConfig } from 'primeng/api';
4
+ import { ClientInputInterface, ClientOutputInterface } from '@ifsworld/granite-components';
5
+ import * as i0 from "@angular/core";
6
+ export type PositionX = 'before' | 'after';
7
+ export type PositionY = 'above' | 'below';
8
+ /** Base class with common functionality for date/date-range pickers. */
9
+ export declare class _DatePickerBase implements OnInit {
10
+ _elementRef: ElementRef;
11
+ config: PrimeNGConfig;
12
+ minDate: Date | null;
13
+ maxDate: Date | null;
14
+ firstDayOfWeek: number;
15
+ readonly pickerClosed: EventEmitter<any>;
16
+ templateRef: TemplateRef<any>;
17
+ xPosition: PositionX;
18
+ yPosition: PositionY;
19
+ direction: Direction;
20
+ /**
21
+ * Used for locating the panel in tests and setting the aria-control attribute
22
+ * for the picker trigger.
23
+ */
24
+ readonly panelId: string;
25
+ /** Client input device information */
26
+ clientInput: ClientInputInterface;
27
+ /** Client output device information */
28
+ clientOutput: ClientOutputInterface;
29
+ constructor(_elementRef: ElementRef, config: PrimeNGConfig);
30
+ ngOnInit(): void;
31
+ _handleKeydown(event: KeyboardEvent): void;
32
+ static ɵfac: i0.ɵɵFactoryDeclaration<_DatePickerBase, never>;
33
+ static ɵdir: i0.ɵɵDirectiveDeclaration<_DatePickerBase, never, never, { "minDate": "minDate"; "maxDate": "maxDate"; "firstDayOfWeek": "firstDayOfWeek"; }, { "pickerClosed": "pickerClosed"; }, never, never, false, never>;
34
+ }
@@ -0,0 +1,70 @@
1
+ import { AfterContentInit, ElementRef, OnDestroy, ViewContainerRef } from '@angular/core';
2
+ import { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';
3
+ import { Directionality } from '@angular/cdk/bidi';
4
+ import { Overlay, OverlayOutsideClickDispatcher } from '@angular/cdk/overlay';
5
+ import { ClientInputInterface, ClientOutputInterface } from '@ifsworld/granite-components';
6
+ import { GraniteDatePickerComponent } from './date-picker.component';
7
+ import { GraniteDateRangePickerComponent } from './date-range-picker.component';
8
+ import * as i0 from "@angular/core";
9
+ export declare class GraniteDatePickerTriggerForDirective implements AfterContentInit, OnDestroy {
10
+ private _overlay;
11
+ private _element;
12
+ private _viewContainerRef;
13
+ private _outsideClickDispatcher;
14
+ /** Client input device information */
15
+ _clientInput: ClientInputInterface;
16
+ /** Client output device information */
17
+ _clientOutput: ClientOutputInterface;
18
+ private _dir;
19
+ private _focusMonitor;
20
+ /** References the picker instance that the trigger is associated with. */
21
+ picker: GraniteDatePickerComponent | GraniteDateRangePickerComponent;
22
+ /** Whether the associated picker is open */
23
+ _isPickerOpen: boolean;
24
+ private _pickerCloseSubscription;
25
+ private _portal;
26
+ private _overlayRef;
27
+ constructor(_overlay: Overlay, _element: ElementRef<HTMLElement>, _viewContainerRef: ViewContainerRef, _outsideClickDispatcher: OverlayOutsideClickDispatcher,
28
+ /** Client input device information */
29
+ _clientInput: ClientInputInterface,
30
+ /** Client output device information */
31
+ _clientOutput: ClientOutputInterface, _dir: Directionality, _focusMonitor: FocusMonitor);
32
+ ngAfterContentInit(): void;
33
+ ngOnDestroy(): void;
34
+ isOpen(): boolean;
35
+ openPicker(): void;
36
+ /** Toggles the picker between the open and closed states. */
37
+ togglePicker(): void;
38
+ /** Close the associated picker */
39
+ closePicker(): void;
40
+ /** Handles key presses on the trigger. */
41
+ _handleKeydown(event: KeyboardEvent): void;
42
+ /** Handles click events on the trigger. */
43
+ _handleClick(): void;
44
+ /**
45
+ * Restores focus to the element that was focused before the picker was open.
46
+ */
47
+ _restoreFocus(origin?: FocusOrigin, options?: FocusOptions): void;
48
+ /**
49
+ * Returns strategy for positioning the overlay for desktop devices:
50
+ */
51
+ private _desktopPositionStrategy;
52
+ /**
53
+ * Sets the appropriate positions on a position strategy
54
+ * so the overlay connects with the trigger correctly.
55
+ * @param positionStrategy Strategy whose position to update.
56
+ */
57
+ private _setPosition;
58
+ /**
59
+ * Returns strategy for positioning the overlay depending on what type of
60
+ * device the picker is being shown on
61
+ */
62
+ private _positionStrategy;
63
+ /**
64
+ * Returns strategy for positioning the overlay for touch devices:
65
+ * Place centered in the screen.
66
+ */
67
+ private _touchPositionStrategy;
68
+ static ɵfac: i0.ɵɵFactoryDeclaration<GraniteDatePickerTriggerForDirective, [null, null, null, null, { optional: true; }, { optional: true; }, { optional: true; }, null]>;
69
+ static ɵdir: i0.ɵɵDirectiveDeclaration<GraniteDatePickerTriggerForDirective, "[graniteDatePickerTriggerFor]", never, { "picker": "graniteDatePickerTriggerFor"; }, {}, never, never, false, never>;
70
+ }
@@ -0,0 +1,10 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { _DatePickerBase } from './date-picker-base';
3
+ import * as i0 from "@angular/core";
4
+ export declare class GraniteDatePickerComponent extends _DatePickerBase {
5
+ selectedDate: Date | undefined;
6
+ readonly selectionChanged: EventEmitter<Date>;
7
+ dateSelectionChanged(newDate: Date): void;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<GraniteDatePickerComponent, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<GraniteDatePickerComponent, "granite-date-picker", never, { "selectedDate": "selectedDate"; }, { "selectionChanged": "selectionChanged"; }, never, never, false, never>;
10
+ }
@@ -0,0 +1,15 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "./date-picker.component";
3
+ import * as i2 from "./date-range-picker.component";
4
+ import * as i3 from "./date-picker-trigger-for.directive";
5
+ import * as i4 from "@angular/common";
6
+ import * as i5 from "@angular/cdk/overlay";
7
+ import * as i6 from "primeng/calendar";
8
+ import * as i7 from "@angular/forms";
9
+ import * as i8 from "@ifsworld/granite-components";
10
+ import * as i9 from "@angular/cdk/a11y";
11
+ export declare class GraniteDatePickerModule {
12
+ static ɵfac: i0.ɵɵFactoryDeclaration<GraniteDatePickerModule, never>;
13
+ static ɵmod: i0.ɵɵNgModuleDeclaration<GraniteDatePickerModule, [typeof i1.GraniteDatePickerComponent, typeof i2.GraniteDateRangePickerComponent, typeof i3.GraniteDatePickerTriggerForDirective], [typeof i4.CommonModule, typeof i5.OverlayModule, typeof i6.CalendarModule, typeof i7.FormsModule, typeof i8.GraniteIconModule, typeof i8.GraniteButtonModule, typeof i9.A11yModule], [typeof i1.GraniteDatePickerComponent, typeof i2.GraniteDateRangePickerComponent, typeof i3.GraniteDatePickerTriggerForDirective]>;
14
+ static ɵinj: i0.ɵɵInjectorDeclaration<GraniteDatePickerModule>;
15
+ }
@@ -0,0 +1,12 @@
1
+ import { EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
2
+ import { _DatePickerBase } from './date-picker-base';
3
+ import * as i0 from "@angular/core";
4
+ export declare class GraniteDateRangePickerComponent extends _DatePickerBase implements OnChanges {
5
+ selectedDateRange: Date[];
6
+ readonly selectionChanged: EventEmitter<Date[]>;
7
+ _selectedDateRangeInternal: Date[];
8
+ ngOnChanges(changes: SimpleChanges): void;
9
+ dateRangeSelectionChanged(date: Date): void;
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<GraniteDateRangePickerComponent, never>;
11
+ static ɵcmp: i0.ɵɵComponentDeclaration<GraniteDateRangePickerComponent, "granite-date-range-picker", never, { "selectedDateRange": "selectedDateRange"; }, { "selectionChanged": "selectionChanged"; }, never, never, false, never>;
12
+ }
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZzd29ybGQtZ3Jhbml0ZS1jb21wb25lbnRzLWRhdGUtcGlja2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9ncmFuaXRlLWNvbXBvbmVudHMvZGF0ZS1waWNrZXIvc3JjL2lmc3dvcmxkLWdyYW5pdGUtY29tcG9uZW50cy1kYXRlLXBpY2tlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -0,0 +1,5 @@
1
+ export * from './lib/date-picker.module';
2
+ export * from './lib/date-picker.component';
3
+ export * from './lib/date-range-picker.component';
4
+ export * from './lib/date-picker-trigger-for.directive';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2dyYW5pdGUtY29tcG9uZW50cy9kYXRlLXBpY2tlci9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5Q0FBeUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUtcGlja2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUtcGlja2VyLXRyaWdnZXItZm9yLmRpcmVjdGl2ZSc7XG4iXX0=
@@ -0,0 +1,53 @@
1
+ import { Directive, ElementRef, EventEmitter, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
2
+ // eslint-disable-next-line import/no-internal-modules
3
+ import { PrimeNGConfig } from 'primeng/api';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "primeng/api";
6
+ let pickerPanelUid = 0;
7
+ /** Base class with common functionality for date/date-range pickers. */
8
+ // eslint-disable-next-line @angular-eslint/directive-class-suffix
9
+ export class _DatePickerBase {
10
+ constructor(_elementRef, config) {
11
+ this._elementRef = _elementRef;
12
+ this.config = config;
13
+ this.minDate = null;
14
+ this.maxDate = null;
15
+ this.firstDayOfWeek = 0;
16
+ this.pickerClosed = new EventEmitter();
17
+ this.xPosition = 'before';
18
+ this.yPosition = 'below';
19
+ /**
20
+ * Used for locating the panel in tests and setting the aria-control attribute
21
+ * for the picker trigger.
22
+ */
23
+ this.panelId = `granite-date-picker-panel-${pickerPanelUid++}`;
24
+ }
25
+ // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
26
+ ngOnInit() {
27
+ this.config.setTranslation({
28
+ dayNamesMin: ['S', 'M', 'T', 'W', 'T', 'F', 'S'],
29
+ });
30
+ }
31
+ _handleKeydown(event) {
32
+ if (event.key === 'Escape') {
33
+ this.pickerClosed.emit();
34
+ }
35
+ }
36
+ }
37
+ _DatePickerBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: _DatePickerBase, deps: [{ token: i0.ElementRef }, { token: i1.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Directive });
38
+ _DatePickerBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: _DatePickerBase, inputs: { minDate: "minDate", maxDate: "maxDate", firstDayOfWeek: "firstDayOfWeek" }, outputs: { pickerClosed: "pickerClosed" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0 });
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: _DatePickerBase, decorators: [{
40
+ type: Directive
41
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.PrimeNGConfig }]; }, propDecorators: { minDate: [{
42
+ type: Input
43
+ }], maxDate: [{
44
+ type: Input
45
+ }], firstDayOfWeek: [{
46
+ type: Input
47
+ }], pickerClosed: [{
48
+ type: Output
49
+ }], templateRef: [{
50
+ type: ViewChild,
51
+ args: [TemplateRef]
52
+ }] } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXItYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZ3Jhbml0ZS1jb21wb25lbnRzL2RhdGUtcGlja2VyL3NyYy9saWIvZGF0ZS1waWNrZXItYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sRUFDTixXQUFXLEVBQ1gsU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBRXZCLHNEQUFzRDtBQUN0RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sYUFBYSxDQUFDOzs7QUFVNUMsSUFBSSxjQUFjLEdBQUcsQ0FBQyxDQUFDO0FBRXZCLHdFQUF3RTtBQUV4RSxrRUFBa0U7QUFDbEUsTUFBTSxPQUFPLGVBQWU7SUFnQzFCLFlBQW1CLFdBQXVCLEVBQVMsTUFBcUI7UUFBckQsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFBUyxXQUFNLEdBQU4sTUFBTSxDQUFlO1FBOUJ4RSxZQUFPLEdBQWdCLElBQUksQ0FBQztRQUc1QixZQUFPLEdBQWdCLElBQUksQ0FBQztRQUc1QixtQkFBYyxHQUFXLENBQUMsQ0FBQztRQUdsQixpQkFBWSxHQUFzQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBSTlELGNBQVMsR0FBYyxRQUFRLENBQUM7UUFDaEMsY0FBUyxHQUFjLE9BQU8sQ0FBQztRQUkvQjs7O1dBR0c7UUFDTSxZQUFPLEdBQUcsNkJBQTZCLGNBQWMsRUFBRSxFQUFFLENBQUM7SUFRUSxDQUFDO0lBRTVFLDZFQUE2RTtJQUM3RSxRQUFRO1FBQ04sSUFBSSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUM7WUFDekIsV0FBVyxFQUFFLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDO1NBQ2pELENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBb0I7UUFDakMsSUFBSSxLQUFLLENBQUMsR0FBRyxLQUFLLFFBQVEsRUFBRTtZQUMxQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQzFCO0lBQ0gsQ0FBQzs7NEdBN0NVLGVBQWU7Z0dBQWYsZUFBZSx3TUFhZixXQUFXOzJGQWJYLGVBQWU7a0JBRjNCLFNBQVM7NkhBSVIsT0FBTztzQkFETixLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJTixjQUFjO3NCQURiLEtBQUs7Z0JBSUcsWUFBWTtzQkFEcEIsTUFBTTtnQkFHaUIsV0FBVztzQkFBbEMsU0FBUzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGlyZWN0aXZlLFxuICBFbGVtZW50UmVmLFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIE91dHB1dCxcbiAgVGVtcGxhdGVSZWYsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaXJlY3Rpb24gfSBmcm9tICdAYW5ndWxhci9jZGsvYmlkaSc7XG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLWludGVybmFsLW1vZHVsZXNcbmltcG9ydCB7IFByaW1lTkdDb25maWcgfSBmcm9tICdwcmltZW5nL2FwaSc7XG5pbXBvcnQge1xuICBDbGllbnRJbnB1dEludGVyZmFjZSxcbiAgQ2xpZW50T3V0cHV0SW50ZXJmYWNlLFxufSBmcm9tICdAaWZzd29ybGQvZ3Jhbml0ZS1jb21wb25lbnRzJztcblxuZXhwb3J0IHR5cGUgUG9zaXRpb25YID0gJ2JlZm9yZScgfCAnYWZ0ZXInO1xuXG5leHBvcnQgdHlwZSBQb3NpdGlvblkgPSAnYWJvdmUnIHwgJ2JlbG93JztcblxubGV0IHBpY2tlclBhbmVsVWlkID0gMDtcblxuLyoqIEJhc2UgY2xhc3Mgd2l0aCBjb21tb24gZnVuY3Rpb25hbGl0eSBmb3IgZGF0ZS9kYXRlLXJhbmdlIHBpY2tlcnMuICovXG5ARGlyZWN0aXZlKClcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLWNsYXNzLXN1ZmZpeFxuZXhwb3J0IGNsYXNzIF9EYXRlUGlja2VyQmFzZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpXG4gIG1pbkRhdGU6IERhdGUgfCBudWxsID0gbnVsbDtcblxuICBASW5wdXQoKVxuICBtYXhEYXRlOiBEYXRlIHwgbnVsbCA9IG51bGw7XG5cbiAgQElucHV0KClcbiAgZmlyc3REYXlPZldlZWs6IG51bWJlciA9IDA7XG5cbiAgQE91dHB1dCgpXG4gIHJlYWRvbmx5IHBpY2tlckNsb3NlZDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgQFZpZXdDaGlsZChUZW1wbGF0ZVJlZikgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgeFBvc2l0aW9uOiBQb3NpdGlvblggPSAnYmVmb3JlJztcbiAgeVBvc2l0aW9uOiBQb3NpdGlvblkgPSAnYmVsb3cnO1xuXG4gIGRpcmVjdGlvbjogRGlyZWN0aW9uO1xuXG4gIC8qKlxuICAgKiBVc2VkIGZvciBsb2NhdGluZyB0aGUgcGFuZWwgaW4gdGVzdHMgYW5kIHNldHRpbmcgdGhlIGFyaWEtY29udHJvbCBhdHRyaWJ1dGVcbiAgICogZm9yIHRoZSBwaWNrZXIgdHJpZ2dlci5cbiAgICovXG4gIHJlYWRvbmx5IHBhbmVsSWQgPSBgZ3Jhbml0ZS1kYXRlLXBpY2tlci1wYW5lbC0ke3BpY2tlclBhbmVsVWlkKyt9YDtcblxuICAvKiogQ2xpZW50IGlucHV0IGRldmljZSBpbmZvcm1hdGlvbiAqL1xuICBjbGllbnRJbnB1dDogQ2xpZW50SW5wdXRJbnRlcmZhY2U7XG5cbiAgLyoqIENsaWVudCBvdXRwdXQgZGV2aWNlIGluZm9ybWF0aW9uICovXG4gIGNsaWVudE91dHB1dDogQ2xpZW50T3V0cHV0SW50ZXJmYWNlO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBfZWxlbWVudFJlZjogRWxlbWVudFJlZiwgcHVibGljIGNvbmZpZzogUHJpbWVOR0NvbmZpZykge31cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2V4cGxpY2l0LW1vZHVsZS1ib3VuZGFyeS10eXBlc1xuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmNvbmZpZy5zZXRUcmFuc2xhdGlvbih7XG4gICAgICBkYXlOYW1lc01pbjogWydTJywgJ00nLCAnVCcsICdXJywgJ1QnLCAnRicsICdTJ10sXG4gICAgfSk7XG4gIH1cblxuICBfaGFuZGxlS2V5ZG93bihldmVudDogS2V5Ym9hcmRFdmVudCk6IHZvaWQge1xuICAgIGlmIChldmVudC5rZXkgPT09ICdFc2NhcGUnKSB7XG4gICAgICB0aGlzLnBpY2tlckNsb3NlZC5lbWl0KCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -0,0 +1,228 @@
1
+ import { Directive, ElementRef, Inject, Input, Optional, ViewContainerRef, } from '@angular/core';
2
+ import { FocusMonitor } from '@angular/cdk/a11y';
3
+ import { Directionality } from '@angular/cdk/bidi';
4
+ import { Overlay, OverlayConfig, OverlayOutsideClickDispatcher, } from '@angular/cdk/overlay';
5
+ import { TemplatePortal } from '@angular/cdk/portal';
6
+ import { merge, Subscription } from 'rxjs';
7
+ import { GRANITE_CLIENT_INPUT, GRANITE_CLIENT_OUTPUT, } from '@ifsworld/granite-components';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/cdk/overlay";
10
+ import * as i2 from "@angular/cdk/bidi";
11
+ import * as i3 from "@angular/cdk/a11y";
12
+ export class GraniteDatePickerTriggerForDirective {
13
+ constructor(_overlay, _element, _viewContainerRef, _outsideClickDispatcher,
14
+ /** Client input device information */
15
+ _clientInput,
16
+ /** Client output device information */
17
+ _clientOutput, _dir, _focusMonitor) {
18
+ this._overlay = _overlay;
19
+ this._element = _element;
20
+ this._viewContainerRef = _viewContainerRef;
21
+ this._outsideClickDispatcher = _outsideClickDispatcher;
22
+ this._clientInput = _clientInput;
23
+ this._clientOutput = _clientOutput;
24
+ this._dir = _dir;
25
+ this._focusMonitor = _focusMonitor;
26
+ /** Whether the associated picker is open */
27
+ this._isPickerOpen = false;
28
+ this._pickerCloseSubscription = Subscription.EMPTY;
29
+ this._portal = null;
30
+ this._overlayRef = null;
31
+ }
32
+ ngAfterContentInit() {
33
+ const selectionChanged = this.picker.selectionChanged;
34
+ const closed = this.picker.pickerClosed;
35
+ this._pickerCloseSubscription = merge(selectionChanged, closed).subscribe(() => {
36
+ this.closePicker();
37
+ });
38
+ }
39
+ ngOnDestroy() {
40
+ if (this._overlayRef) {
41
+ this._overlayRef.dispose();
42
+ this._overlayRef = null;
43
+ }
44
+ this._pickerCloseSubscription.unsubscribe();
45
+ }
46
+ isOpen() {
47
+ return this._isPickerOpen;
48
+ }
49
+ openPicker() {
50
+ if (this._isPickerOpen) {
51
+ return;
52
+ }
53
+ this.picker.direction = this._dir.value === 'rtl' ? 'rtl' : 'ltr';
54
+ this.picker.clientInput = this._clientInput;
55
+ this.picker.clientOutput = this._clientOutput;
56
+ const panelClass = [];
57
+ if (this._clientOutput?.device === 'touch') {
58
+ panelClass.push('granite-overlay-pane-center');
59
+ }
60
+ const scrollStrategy = this._clientOutput?.device !== 'touch'
61
+ ? this._overlay.scrollStrategies.reposition()
62
+ : this._overlay.scrollStrategies.block();
63
+ const hasBackdrop = this._clientOutput?.device === 'touch';
64
+ if (!this._overlayRef) {
65
+ const config = new OverlayConfig({
66
+ positionStrategy: this._positionStrategy(),
67
+ backdropClass: 'granite-overlay-dark-glass-backdrop',
68
+ scrollStrategy,
69
+ direction: this._dir,
70
+ panelClass,
71
+ hasBackdrop,
72
+ });
73
+ this._overlayRef = this._overlay.create(config);
74
+ }
75
+ if (!this._portal || this._portal.templateRef !== this.picker.templateRef) {
76
+ this._portal = new TemplatePortal(this.picker.templateRef, this._viewContainerRef);
77
+ }
78
+ // Attach portal to overlay ref (which is a portal outlet)
79
+ this._overlayRef.attach(this._portal);
80
+ this._outsideClickDispatcher.add(this._overlayRef);
81
+ this._overlayRef.outsidePointerEvents().subscribe((event) => {
82
+ event.stopPropagation();
83
+ this.closePicker();
84
+ });
85
+ this._isPickerOpen = true;
86
+ }
87
+ /** Toggles the picker between the open and closed states. */
88
+ togglePicker() {
89
+ if (this._isPickerOpen) {
90
+ this.closePicker();
91
+ }
92
+ else {
93
+ this.openPicker();
94
+ }
95
+ }
96
+ /** Close the associated picker */
97
+ closePicker() {
98
+ if (!this._overlayRef || !this._isPickerOpen) {
99
+ return;
100
+ }
101
+ this._outsideClickDispatcher.remove(this._overlayRef);
102
+ this._overlayRef.detach();
103
+ this._restoreFocus();
104
+ this._isPickerOpen = false;
105
+ }
106
+ /** Handles key presses on the trigger. */
107
+ _handleKeydown(event) {
108
+ if (event.key === 'Enter') {
109
+ event.preventDefault();
110
+ this.togglePicker();
111
+ }
112
+ }
113
+ /** Handles click events on the trigger. */
114
+ _handleClick() {
115
+ this.togglePicker();
116
+ }
117
+ /**
118
+ * Restores focus to the element that was focused before the picker was open.
119
+ */
120
+ _restoreFocus(origin = 'program', options) {
121
+ if (this._focusMonitor) {
122
+ this._focusMonitor.focusVia(this._element, origin, options);
123
+ }
124
+ else {
125
+ this._element.nativeElement.focus(options);
126
+ }
127
+ }
128
+ /**
129
+ * Returns strategy for positioning the overlay for desktop devices:
130
+ */
131
+ _desktopPositionStrategy() {
132
+ const positionStrategy = this._overlay
133
+ .position()
134
+ .flexibleConnectedTo(this._element)
135
+ .withLockedPosition()
136
+ .withTransformOriginOn('.granite-date-picker')
137
+ .withPush(false);
138
+ this._setPosition(positionStrategy);
139
+ return positionStrategy;
140
+ }
141
+ /**
142
+ * Sets the appropriate positions on a position strategy
143
+ * so the overlay connects with the trigger correctly.
144
+ * @param positionStrategy Strategy whose position to update.
145
+ */
146
+ _setPosition(positionStrategy) {
147
+ const [originX, originFallbackX] = this.picker.xPosition === 'before' ? ['end', 'start'] : ['start', 'end'];
148
+ const [overlayY, overlayFallbackY] = this.picker.yPosition === 'above' ? ['bottom', 'top'] : ['top', 'bottom'];
149
+ let [originY, originFallbackY] = [overlayY, overlayFallbackY];
150
+ const [overlayX, overlayFallbackX] = [originX, originFallbackX];
151
+ const offsetY = 0;
152
+ originY = overlayY === 'top' ? 'bottom' : 'top';
153
+ originFallbackY = overlayFallbackY === 'top' ? 'bottom' : 'top';
154
+ positionStrategy.withPositions([
155
+ { originX, originY, overlayX, overlayY, offsetY },
156
+ {
157
+ originX: originFallbackX,
158
+ originY,
159
+ overlayX: overlayFallbackX,
160
+ overlayY,
161
+ offsetY,
162
+ },
163
+ {
164
+ originX,
165
+ originY: originFallbackY,
166
+ overlayX,
167
+ overlayY: overlayFallbackY,
168
+ offsetY: -offsetY,
169
+ },
170
+ {
171
+ originX: originFallbackX,
172
+ originY: originFallbackY,
173
+ overlayX: overlayFallbackX,
174
+ overlayY: overlayFallbackY,
175
+ offsetY: -offsetY,
176
+ },
177
+ ]);
178
+ }
179
+ /**
180
+ * Returns strategy for positioning the overlay depending on what type of
181
+ * device the picker is being shown on
182
+ */
183
+ _positionStrategy() {
184
+ if (this._clientOutput?.device !== 'touch') {
185
+ return this._desktopPositionStrategy();
186
+ }
187
+ return this._touchPositionStrategy();
188
+ }
189
+ /**
190
+ * Returns strategy for positioning the overlay for touch devices:
191
+ * Place centered in the screen.
192
+ */
193
+ _touchPositionStrategy() {
194
+ return this._overlay.position().global();
195
+ }
196
+ }
197
+ GraniteDatePickerTriggerForDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: GraniteDatePickerTriggerForDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i1.OverlayOutsideClickDispatcher }, { token: GRANITE_CLIENT_INPUT, optional: true }, { token: GRANITE_CLIENT_OUTPUT, optional: true }, { token: i2.Directionality, optional: true }, { token: i3.FocusMonitor }], target: i0.ɵɵFactoryTarget.Directive });
198
+ GraniteDatePickerTriggerForDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: GraniteDatePickerTriggerForDirective, selector: "[graniteDatePickerTriggerFor]", inputs: { picker: ["graniteDatePickerTriggerFor", "picker"] }, host: { attributes: { "aria-haspopup": "true" }, listeners: { "keydown": "_handleKeydown($event)", "click": "_handleClick($event)" }, properties: { "attr.aria-expanded": "_isPickerOpen || null", "attr.aria-controls": "_isPickerOpen ? picker.panelId : null" }, classAttribute: "granite-date-picker-trigger" }, ngImport: i0 });
199
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: GraniteDatePickerTriggerForDirective, decorators: [{
200
+ type: Directive,
201
+ args: [{
202
+ selector: `[graniteDatePickerTriggerFor]`,
203
+ host: {
204
+ class: 'granite-date-picker-trigger',
205
+ 'aria-haspopup': 'true',
206
+ '[attr.aria-expanded]': '_isPickerOpen || null',
207
+ '[attr.aria-controls]': '_isPickerOpen ? picker.panelId : null',
208
+ '(keydown)': '_handleKeydown($event)',
209
+ '(click)': '_handleClick($event)',
210
+ },
211
+ }]
212
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i1.OverlayOutsideClickDispatcher }, { type: undefined, decorators: [{
213
+ type: Inject,
214
+ args: [GRANITE_CLIENT_INPUT]
215
+ }, {
216
+ type: Optional
217
+ }] }, { type: undefined, decorators: [{
218
+ type: Inject,
219
+ args: [GRANITE_CLIENT_OUTPUT]
220
+ }, {
221
+ type: Optional
222
+ }] }, { type: i2.Directionality, decorators: [{
223
+ type: Optional
224
+ }] }, { type: i3.FocusMonitor }]; }, propDecorators: { picker: [{
225
+ type: Input,
226
+ args: ['graniteDatePickerTriggerFor']
227
+ }] } });
228
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-trigger-for.directive.js","sourceRoot":"","sources":["../../../../../../libs/granite-components/date-picker/src/lib/date-picker-trigger-for.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Directive,\n  ElementRef,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  ViewContainerRef,\n} from '@angular/core';\n\nimport { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';\nimport { Directionality } from '@angular/cdk/bidi';\nimport {\n  FlexibleConnectedPositionStrategy,\n  HorizontalConnectionPos,\n  Overlay,\n  OverlayConfig,\n  OverlayOutsideClickDispatcher,\n  OverlayRef,\n  PositionStrategy,\n  VerticalConnectionPos,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\n\nimport { merge, Observable, Subscription } from 'rxjs';\n\nimport {\n  ClientInputInterface,\n  ClientOutputInterface,\n  GRANITE_CLIENT_INPUT,\n  GRANITE_CLIENT_OUTPUT,\n} from '@ifsworld/granite-components';\nimport { GraniteDatePickerComponent } from './date-picker.component';\nimport { GraniteDateRangePickerComponent } from './date-range-picker.component';\n\n@Directive({\n  selector: `[graniteDatePickerTriggerFor]`,\n  host: {\n    class: 'granite-date-picker-trigger',\n    'aria-haspopup': 'true',\n    '[attr.aria-expanded]': '_isPickerOpen || null',\n    '[attr.aria-controls]': '_isPickerOpen ? picker.panelId : null',\n    '(keydown)': '_handleKeydown($event)',\n    '(click)': '_handleClick($event)',\n  },\n})\nexport class GraniteDatePickerTriggerForDirective\n  implements AfterContentInit, OnDestroy\n{\n  /** References the picker instance that the trigger is associated with. */\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('graniteDatePickerTriggerFor')\n  picker: GraniteDatePickerComponent | GraniteDateRangePickerComponent;\n\n  /** Whether the associated picker is open */\n  _isPickerOpen: boolean = false;\n\n  private _pickerCloseSubscription = Subscription.EMPTY;\n\n  private _portal: TemplatePortal | null = null;\n  private _overlayRef: OverlayRef | null = null;\n\n  constructor(\n    private _overlay: Overlay,\n    private _element: ElementRef<HTMLElement>,\n    private _viewContainerRef: ViewContainerRef,\n    private _outsideClickDispatcher: OverlayOutsideClickDispatcher,\n\n    /** Client input device information */\n    @Inject(GRANITE_CLIENT_INPUT)\n    @Optional()\n    public _clientInput: ClientInputInterface,\n\n    /** Client output device information */\n    @Inject(GRANITE_CLIENT_OUTPUT)\n    @Optional()\n    public _clientOutput: ClientOutputInterface,\n\n    @Optional()\n    private _dir: Directionality,\n\n    private _focusMonitor: FocusMonitor\n  ) {}\n\n  ngAfterContentInit(): void {\n    const selectionChanged = this.picker.selectionChanged as Observable<any>;\n    const closed = this.picker.pickerClosed as Observable<any>;\n\n    this._pickerCloseSubscription = merge(selectionChanged, closed).subscribe(\n      () => {\n        this.closePicker();\n      }\n    );\n  }\n\n  ngOnDestroy(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n    this._pickerCloseSubscription.unsubscribe();\n  }\n\n  isOpen(): boolean {\n    return this._isPickerOpen;\n  }\n\n  openPicker(): void {\n    if (this._isPickerOpen) {\n      return;\n    }\n\n    this.picker.direction = this._dir.value === 'rtl' ? 'rtl' : 'ltr';\n    this.picker.clientInput = this._clientInput;\n    this.picker.clientOutput = this._clientOutput;\n\n    const panelClass: string[] = [];\n    if (this._clientOutput?.device === 'touch') {\n      panelClass.push('granite-overlay-pane-center');\n    }\n\n    const scrollStrategy =\n      this._clientOutput?.device !== 'touch'\n        ? this._overlay.scrollStrategies.reposition()\n        : this._overlay.scrollStrategies.block();\n\n    const hasBackdrop = this._clientOutput?.device === 'touch';\n\n    if (!this._overlayRef) {\n      const config = new OverlayConfig({\n        positionStrategy: this._positionStrategy(),\n        backdropClass: 'granite-overlay-dark-glass-backdrop',\n        scrollStrategy,\n        direction: this._dir,\n        panelClass,\n        hasBackdrop,\n      });\n\n      this._overlayRef = this._overlay.create(config);\n    }\n\n    if (!this._portal || this._portal.templateRef !== this.picker.templateRef) {\n      this._portal = new TemplatePortal(\n        this.picker.templateRef,\n        this._viewContainerRef\n      );\n    }\n    // Attach portal to overlay ref (which is a portal outlet)\n    this._overlayRef.attach(this._portal);\n    this._outsideClickDispatcher.add(this._overlayRef);\n    this._overlayRef.outsidePointerEvents().subscribe((event: MouseEvent) => {\n      event.stopPropagation();\n      this.closePicker();\n    });\n\n    this._isPickerOpen = true;\n  }\n\n  /** Toggles the picker between the open and closed states. */\n  togglePicker(): void {\n    if (this._isPickerOpen) {\n      this.closePicker();\n    } else {\n      this.openPicker();\n    }\n  }\n\n  /** Close the associated picker */\n  closePicker(): void {\n    if (!this._overlayRef || !this._isPickerOpen) {\n      return;\n    }\n\n    this._outsideClickDispatcher.remove(this._overlayRef);\n    this._overlayRef.detach();\n\n    this._restoreFocus();\n    this._isPickerOpen = false;\n  }\n\n  /** Handles key presses on the trigger. */\n  _handleKeydown(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      event.preventDefault();\n      this.togglePicker();\n    }\n  }\n\n  /** Handles click events on the trigger. */\n  _handleClick(): void {\n    this.togglePicker();\n  }\n\n  /**\n   * Restores focus to the element that was focused before the picker was open.\n   */\n  _restoreFocus(origin: FocusOrigin = 'program', options?: FocusOptions): void {\n    if (this._focusMonitor) {\n      this._focusMonitor.focusVia(this._element, origin, options);\n    } else {\n      this._element.nativeElement.focus(options);\n    }\n  }\n\n  /**\n   * Returns strategy for positioning the overlay for desktop devices:\n   */\n  private _desktopPositionStrategy(): PositionStrategy {\n    const positionStrategy: FlexibleConnectedPositionStrategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this._element)\n      .withLockedPosition()\n      .withTransformOriginOn('.granite-date-picker')\n      .withPush(false);\n\n    this._setPosition(positionStrategy);\n    return positionStrategy;\n  }\n\n  /**\n   * Sets the appropriate positions on a position strategy\n   * so the overlay connects with the trigger correctly.\n   * @param positionStrategy Strategy whose position to update.\n   */\n  private _setPosition(positionStrategy: FlexibleConnectedPositionStrategy) {\n    const [originX, originFallbackX]: HorizontalConnectionPos[] =\n      this.picker.xPosition === 'before' ? ['end', 'start'] : ['start', 'end'];\n\n    const [overlayY, overlayFallbackY]: VerticalConnectionPos[] =\n      this.picker.yPosition === 'above' ? ['bottom', 'top'] : ['top', 'bottom'];\n\n    let [originY, originFallbackY] = [overlayY, overlayFallbackY];\n    const [overlayX, overlayFallbackX] = [originX, originFallbackX];\n    const offsetY = 0;\n\n    originY = overlayY === 'top' ? 'bottom' : 'top';\n    originFallbackY = overlayFallbackY === 'top' ? 'bottom' : 'top';\n\n    positionStrategy.withPositions([\n      { originX, originY, overlayX, overlayY, offsetY },\n      {\n        originX: originFallbackX,\n        originY,\n        overlayX: overlayFallbackX,\n        overlayY,\n        offsetY,\n      },\n      {\n        originX,\n        originY: originFallbackY,\n        overlayX,\n        overlayY: overlayFallbackY,\n        offsetY: -offsetY,\n      },\n      {\n        originX: originFallbackX,\n        originY: originFallbackY,\n        overlayX: overlayFallbackX,\n        overlayY: overlayFallbackY,\n        offsetY: -offsetY,\n      },\n    ]);\n  }\n\n  /**\n   * Returns strategy for positioning the overlay depending on what type of\n   * device the picker is being shown on\n   */\n  private _positionStrategy(): PositionStrategy {\n    if (this._clientOutput?.device !== 'touch') {\n      return this._desktopPositionStrategy();\n    }\n    return this._touchPositionStrategy();\n  }\n\n  /**\n   * Returns strategy for positioning the overlay for touch devices:\n   * Place centered in the screen.\n   */\n  private _touchPositionStrategy(): PositionStrategy {\n    return this._overlay.position().global();\n  }\n}\n"]}