@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.
- package/README.md +4 -28
- package/date-picker/index.d.ts +4 -0
- package/date-picker/lib/date-picker-base.d.ts +34 -0
- package/date-picker/lib/date-picker-trigger-for.directive.d.ts +70 -0
- package/date-picker/lib/date-picker.component.d.ts +10 -0
- package/date-picker/lib/date-picker.module.d.ts +15 -0
- package/date-picker/lib/date-range-picker.component.d.ts +12 -0
- package/esm2020/date-picker/ifsworld-granite-components-date-picker.mjs +5 -0
- package/esm2020/date-picker/index.mjs +5 -0
- package/esm2020/date-picker/lib/date-picker-base.mjs +53 -0
- package/esm2020/date-picker/lib/date-picker-trigger-for.directive.mjs +228 -0
- package/esm2020/date-picker/lib/date-picker.component.mjs +30 -0
- package/esm2020/date-picker/lib/date-picker.module.mjs +58 -0
- package/esm2020/date-picker/lib/date-range-picker.component.mjs +46 -0
- package/esm2020/lib/arrange-grid/arrange-grid-item.component.mjs +14 -14
- package/esm2020/lib/arrange-grid/arrange-grid.component.mjs +19 -19
- package/esm2020/lib/arrange-grid/arrange-grid.module.mjs +5 -5
- package/esm2020/lib/badge/badge.component.mjs +5 -5
- package/esm2020/lib/badge/badge.module.mjs +5 -5
- package/esm2020/lib/button/button.component.mjs +9 -9
- package/esm2020/lib/button/button.module.mjs +5 -5
- package/esm2020/lib/checkbox/checkbox-group.component.mjs +4 -4
- package/esm2020/lib/checkbox/checkbox.component.mjs +11 -8
- package/esm2020/lib/checkbox/checkbox.module.mjs +5 -5
- package/esm2020/lib/chips/chip-input.mjs +25 -25
- package/esm2020/lib/chips/chip-list.component.mjs +47 -47
- package/esm2020/lib/chips/chip.component.mjs +48 -48
- package/esm2020/lib/chips/chips.module.mjs +5 -5
- package/esm2020/lib/core/common-behaviors/disabled.mjs +4 -4
- package/esm2020/lib/core/core.module.mjs +5 -5
- package/esm2020/lib/core/devices/client-input-desktop.directive.mjs +4 -4
- package/esm2020/lib/core/devices/client-input-touch.directive.mjs +4 -4
- package/esm2020/lib/core/devices/client-output-desktop.directive.mjs +4 -4
- package/esm2020/lib/core/devices/client-output-touch.directive.mjs +4 -4
- package/esm2020/lib/core/pipes/pure-pipes.module.mjs +5 -5
- package/esm2020/lib/core/pipes/title.pipe.mjs +4 -4
- package/esm2020/lib/core/radio-checkbox-base.mjs +4 -4
- package/esm2020/lib/grid/grid.component.mjs +10 -10
- package/esm2020/lib/grid/grid.module.mjs +5 -5
- package/esm2020/lib/icon/icon.component.mjs +5 -5
- package/esm2020/lib/icon/icon.module.mjs +5 -5
- package/esm2020/lib/input-field/input-field.component.mjs +7 -7
- package/esm2020/lib/input-field/input-field.module.mjs +5 -5
- package/esm2020/lib/label/label.component.mjs +4 -4
- package/esm2020/lib/label/label.module.mjs +5 -5
- package/esm2020/lib/menu/divider.directive.mjs +4 -4
- package/esm2020/lib/menu/menu-base.mjs +31 -31
- package/esm2020/lib/menu/menu-item.component.mjs +8 -8
- package/esm2020/lib/menu/menu-touch-close.component.mjs +5 -5
- package/esm2020/lib/menu/menu-touch-title.component.mjs +8 -8
- package/esm2020/lib/menu/menu-trigger-for.directive.mjs +9 -7
- package/esm2020/lib/menu/menu.component.mjs +8 -8
- package/esm2020/lib/menu/menu.module.mjs +5 -5
- package/esm2020/lib/menu/title.directive.mjs +4 -4
- package/esm2020/lib/radio-button/radio-button.component.mjs +11 -8
- package/esm2020/lib/radio-button/radio-button.module.mjs +5 -5
- package/esm2020/lib/radio-button/radio-group.component.mjs +4 -4
- package/esm2020/lib/toggle-switch/toggle-switch.component.mjs +12 -8
- package/esm2020/lib/toggle-switch/toggle-switch.module.mjs +5 -5
- package/esm2020/table/lib/cell/cell-align/cell-align-classes.directive.mjs +4 -4
- package/esm2020/table/lib/cell/cell.mjs +4 -4
- package/esm2020/table/lib/cell/table-data-cell.component.mjs +5 -5
- package/esm2020/table/lib/cell/table-header-cell.component.mjs +5 -5
- package/esm2020/table/lib/column/table-column.directive.mjs +4 -4
- package/esm2020/table/lib/table.component.mjs +9 -9
- package/esm2020/table/lib/table.module.mjs +5 -5
- package/esm2020/tooltip/lib/tooltip-trigger-for.directive.mjs +4 -4
- package/esm2020/tooltip/lib/tooltip.component.mjs +5 -5
- package/esm2020/tooltip/lib/tooltip.module.mjs +5 -5
- package/fesm2015/ifsworld-granite-components-date-picker.mjs +401 -0
- package/fesm2015/ifsworld-granite-components-date-picker.mjs.map +1 -0
- package/fesm2015/ifsworld-granite-components-table.mjs +26 -26
- package/fesm2015/ifsworld-granite-components-table.mjs.map +1 -1
- package/fesm2015/ifsworld-granite-components-tooltip.mjs +11 -11
- package/fesm2015/ifsworld-granite-components-tooltip.mjs.map +1 -1
- package/fesm2015/ifsworld-granite-components.mjs +368 -356
- package/fesm2015/ifsworld-granite-components.mjs.map +1 -1
- package/fesm2020/ifsworld-granite-components-date-picker.mjs +396 -0
- package/fesm2020/ifsworld-granite-components-date-picker.mjs.map +1 -0
- package/fesm2020/ifsworld-granite-components-table.mjs +26 -26
- package/fesm2020/ifsworld-granite-components-table.mjs.map +1 -1
- package/fesm2020/ifsworld-granite-components-tooltip.mjs +11 -11
- package/fesm2020/ifsworld-granite-components-tooltip.mjs.map +1 -1
- package/fesm2020/ifsworld-granite-components.mjs +368 -356
- package/fesm2020/ifsworld-granite-components.mjs.map +1 -1
- package/lib/arrange-grid/arrange-grid-item.component.d.ts +1 -1
- package/lib/arrange-grid/arrange-grid.component.d.ts +1 -1
- package/lib/badge/badge.component.d.ts +1 -1
- package/lib/button/button.component.d.ts +2 -2
- package/lib/checkbox/checkbox-group.component.d.ts +1 -1
- package/lib/checkbox/checkbox.component.d.ts +1 -1
- package/lib/chips/chip-input.d.ts +1 -1
- package/lib/chips/chip-list.component.d.ts +1 -1
- package/lib/chips/chip.component.d.ts +1 -1
- package/lib/core/client-environment.d.ts +2 -2
- package/lib/core/common-behaviors/disabled.d.ts +1 -1
- package/lib/core/devices/client-input-desktop.directive.d.ts +1 -1
- package/lib/core/devices/client-input-touch.directive.d.ts +1 -1
- package/lib/core/devices/client-output-desktop.directive.d.ts +1 -1
- package/lib/core/devices/client-output-touch.directive.d.ts +1 -1
- package/lib/core/pipes/title.pipe.d.ts +1 -1
- package/lib/core/radio-checkbox-base.d.ts +1 -1
- package/lib/core/types.d.ts +2 -2
- package/lib/grid/grid.component.d.ts +2 -2
- package/lib/icon/icon.component.d.ts +1 -1
- package/lib/input-field/input-field.component.d.ts +1 -1
- package/lib/label/label.component.d.ts +1 -1
- package/lib/menu/divider.directive.d.ts +1 -1
- package/lib/menu/menu-base.d.ts +3 -3
- package/lib/menu/menu-item.component.d.ts +1 -1
- package/lib/menu/menu-panel.d.ts +1 -1
- package/lib/menu/menu-positions.d.ts +2 -2
- package/lib/menu/menu-touch-close.component.d.ts +1 -1
- package/lib/menu/menu-touch-title.component.d.ts +1 -1
- package/lib/menu/menu-trigger-for.directive.d.ts +2 -1
- package/lib/menu/menu.component.d.ts +1 -1
- package/lib/menu/title.directive.d.ts +1 -1
- package/lib/radio-button/radio-button.component.d.ts +1 -1
- package/lib/radio-button/radio-group.component.d.ts +1 -1
- package/lib/toggle-switch/toggle-switch.component.d.ts +1 -1
- package/package.json +25 -14
- package/src/lib/core/style/_mixins.scss +14 -6
- package/src/lib/core/style/_overlay.scss +11 -1
- package/src/lib/core/style/_tokens.scss +1 -1
- package/src/lib/core/style/_z-index.scss +4 -0
- package/table/lib/cell/cell-align/cell-align-classes.directive.d.ts +1 -1
- package/table/lib/cell/cell.d.ts +1 -1
- package/table/lib/cell/table-data-cell.component.d.ts +1 -1
- package/table/lib/cell/table-header-cell.component.d.ts +1 -1
- package/table/lib/column/table-column.directive.d.ts +1 -1
- package/table/lib/table.component.d.ts +1 -1
- package/table/lib/table.types.d.ts +1 -1
- package/tooltip/lib/tooltip-trigger-for.directive.d.ts +1 -1
- package/tooltip/lib/tooltip.component.d.ts +1 -1
- package/ifsworld-granite-components.d.ts +0 -5
- package/table/ifsworld-granite-components-table.d.ts +0 -5
- package/table/package.json +0 -18
- package/tooltip/ifsworld-granite-components-tooltip.d.ts +0 -5
- 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
|
-

|
|
7
|
-
[](https://snyk.io/advisor/npm-package/@ifsworld/granite-components)
|
|
8
|
-
|
|
9
|
-
[](http://commitizen.github.io/cz-cli/)
|
|
10
|
-
[](https://github.com/semantic-release/semantic-release)
|
|
5
|
+
[](https://angular.io/guide/creating-libraries#ensuring-library-version-compatibility)
|
|
11
6
|
[](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
|
-
|
|
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
|
|
69
|
+
## What we're working on now
|
|
89
70
|
|
|
90
|
-
|
|
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,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"]}
|