@skyux/datetime 7.0.0-beta.12 → 7.0.0-beta.13

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 (57) hide show
  1. package/documentation.json +1532 -991
  2. package/esm2020/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +20 -0
  3. package/esm2020/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +20 -0
  4. package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +262 -204
  5. package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +11 -3
  6. package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +42 -38
  7. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +1 -1
  8. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +1 -1
  9. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +15 -15
  10. package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +4 -2
  11. package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +1 -1
  12. package/esm2020/lib/modules/datepicker/date-formatter.mjs +2 -2
  13. package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +7 -14
  14. package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +43 -20
  15. package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +28 -35
  16. package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +1 -1
  17. package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +223 -209
  18. package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +212 -220
  19. package/esm2020/lib/modules/datepicker/datepicker.component.mjs +117 -138
  20. package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +3 -3
  21. package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +61 -59
  22. package/esm2020/lib/modules/datepicker/daypicker.component.mjs +143 -137
  23. package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +123 -132
  24. package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +51 -49
  25. package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +52 -50
  26. package/esm2020/lib/modules/timepicker/timepicker.component.mjs +104 -88
  27. package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +105 -98
  28. package/fesm2015/skyux-datetime.mjs +1642 -1516
  29. package/fesm2015/skyux-datetime.mjs.map +1 -1
  30. package/fesm2020/skyux-datetime.mjs +1618 -1510
  31. package/fesm2020/skyux-datetime.mjs.map +1 -1
  32. package/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.d.ts +8 -0
  33. package/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.d.ts +8 -0
  34. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +14 -43
  35. package/lib/modules/date-range-picker/date-range-picker.module.d.ts +9 -7
  36. package/lib/modules/date-range-picker/date-range.service.d.ts +1 -5
  37. package/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.d.ts +1 -1
  38. package/lib/modules/date-range-picker/types/date-range-calculator-validate-function.d.ts +1 -1
  39. package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +3 -8
  40. package/lib/modules/date-range-picker/types/date-range.d.ts +2 -2
  41. package/lib/modules/datepicker/date-formatter.d.ts +3 -3
  42. package/lib/modules/datepicker/datepicker-adapter.service.d.ts +1 -5
  43. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +18 -19
  44. package/lib/modules/datepicker/datepicker-calendar.component.d.ts +14 -25
  45. package/lib/modules/datepicker/datepicker-config.service.d.ts +3 -3
  46. package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +17 -53
  47. package/lib/modules/datepicker/datepicker-input.directive.d.ts +13 -68
  48. package/lib/modules/datepicker/datepicker.component.d.ts +21 -58
  49. package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
  50. package/lib/modules/datepicker/daypicker-cell.component.d.ts +3 -10
  51. package/lib/modules/datepicker/daypicker.component.d.ts +4 -16
  52. package/lib/modules/datepicker/fuzzy-date.service.d.ts +6 -30
  53. package/lib/modules/datepicker/monthpicker.component.d.ts +1 -4
  54. package/lib/modules/datepicker/yearpicker.component.d.ts +1 -3
  55. package/lib/modules/timepicker/timepicker.component.d.ts +14 -32
  56. package/lib/modules/timepicker/timepicker.directive.d.ts +9 -27
  57. package/package.json +8 -8
@@ -1,3 +1,5 @@
1
+ var _SkyDayPickerCellComponent_instances, _SkyDayPickerCellComponent_activeUid, _SkyDayPickerCellComponent_cancelPopover, _SkyDayPickerCellComponent_popoverOpen, _SkyDayPickerCellComponent_ngUnsubscribe, _SkyDayPickerCellComponent_datepicker, _SkyDayPickerCellComponent_datepickerService, _SkyDayPickerCellComponent_hideTooltip, _SkyDayPickerCellComponent_showTooltip;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
2
4
  import { SkyPopoverMessageType } from '@skyux/popovers';
3
5
  import { Subject } from 'rxjs';
@@ -15,112 +17,112 @@ import * as i5 from "./daypicker-button.component";
15
17
  */
16
18
  export class SkyDayPickerCellComponent {
17
19
  constructor(datepicker, datepickerService) {
18
- this.datepicker = datepicker;
19
- this.datepickerService = datepickerService;
20
+ _SkyDayPickerCellComponent_instances.add(this);
20
21
  this.hasTooltip = false;
21
22
  this.popoverController = new Subject();
22
- this.activeUid = '';
23
- this.cancelPopover = false;
24
- this.popoverOpen = false;
25
- this.ngUnsubscribe = new Subject();
23
+ _SkyDayPickerCellComponent_activeUid.set(this, '');
24
+ _SkyDayPickerCellComponent_cancelPopover.set(this, false);
25
+ _SkyDayPickerCellComponent_popoverOpen.set(this, false);
26
+ _SkyDayPickerCellComponent_ngUnsubscribe.set(this, new Subject());
27
+ _SkyDayPickerCellComponent_datepicker.set(this, void 0);
28
+ _SkyDayPickerCellComponent_datepickerService.set(this, void 0);
29
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_datepicker, datepicker, "f");
30
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_datepickerService, datepickerService, "f");
26
31
  }
27
32
  ngOnInit() {
28
- this.hasTooltip =
33
+ this.hasTooltip = !!(this.date &&
29
34
  this.date.keyDate &&
30
- this.date.keyDateText &&
31
- this.date.keyDateText.length > 0 &&
32
- this.date.keyDateText[0].length > 0;
35
+ this.date.keyDateText &&
36
+ this.date.keyDateText.length > 0 &&
37
+ this.date.keyDateText[0].length > 0);
33
38
  // show the tooltip if this is the active date and is not the
34
39
  // initial active date (activeDateHasChanged)
35
- if (this.datepicker.isActive(this.date) &&
40
+ if (!!this.date &&
41
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_datepicker, "f").isActive(this.date) &&
36
42
  this.activeDateHasChanged &&
37
43
  this.hasTooltip) {
38
- this.activeUid = this.date.uid;
39
- this.showTooltip();
44
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_activeUid, this.date.uid, "f");
45
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_instances, "m", _SkyDayPickerCellComponent_showTooltip).call(this);
40
46
  }
41
47
  if (this.hasTooltip) {
42
- this.datepickerService.keyDatePopoverStream
43
- .pipe(takeUntil(this.ngUnsubscribe))
48
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_datepickerService, "f").keyDatePopoverStream
49
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDayPickerCellComponent_ngUnsubscribe, "f")))
44
50
  .subscribe((date) => {
45
51
  if (date) {
46
- this.activeUid = date.uid;
52
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_activeUid, date.uid, "f");
47
53
  }
48
54
  else {
49
- this.activeUid = '';
55
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_activeUid, '', "f");
50
56
  }
51
57
  // If this day has an open popover and they have moved off of the day close the popover.
52
- if (this.date.uid !== this.activeUid) {
53
- this.hideTooltip();
58
+ if (this.date?.uid !== __classPrivateFieldGet(this, _SkyDayPickerCellComponent_activeUid, "f")) {
59
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_instances, "m", _SkyDayPickerCellComponent_hideTooltip).call(this);
54
60
  }
55
61
  });
56
62
  }
57
63
  }
58
64
  ngOnDestroy() {
59
- this.ngUnsubscribe.next();
60
- this.ngUnsubscribe.complete();
65
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_ngUnsubscribe, "f").next();
66
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_ngUnsubscribe, "f").complete();
61
67
  }
62
68
  onDayMouseenter() {
63
- this.cancelPopover = false;
69
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_cancelPopover, false, "f");
64
70
  if (this.hasTooltip) {
65
- this.showTooltip();
66
- this.datepickerService.keyDatePopoverStream.next(this.date);
71
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_instances, "m", _SkyDayPickerCellComponent_showTooltip).call(this);
72
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_datepickerService, "f").keyDatePopoverStream.next(this.date);
67
73
  }
68
74
  }
69
75
  onDayMouseleave() {
70
- this.cancelPopover = true;
76
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_cancelPopover, true, "f");
71
77
  if (this.hasTooltip) {
72
- this.hideTooltip();
78
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_instances, "m", _SkyDayPickerCellComponent_hideTooltip).call(this);
73
79
  }
74
- this.datepickerService.keyDatePopoverStream.next(undefined);
80
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_datepickerService, "f").keyDatePopoverStream.next(undefined);
75
81
  }
76
82
  onPopoverClosed() {
77
- this.popoverOpen = false;
83
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_popoverOpen, false, "f");
78
84
  }
79
85
  onPopoverOpened() {
80
- this.popoverOpen = true;
86
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_popoverOpen, true, "f");
81
87
  /* istanbul ignore else */
82
- if (this.cancelPopover) {
88
+ if (__classPrivateFieldGet(this, _SkyDayPickerCellComponent_cancelPopover, "f")) {
83
89
  // If the popover gets opened just as a mouseout event happens, close it.
84
- this.hideTooltip();
85
- this.cancelPopover = false;
90
+ __classPrivateFieldGet(this, _SkyDayPickerCellComponent_instances, "m", _SkyDayPickerCellComponent_hideTooltip).call(this);
91
+ __classPrivateFieldSet(this, _SkyDayPickerCellComponent_cancelPopover, false, "f");
86
92
  }
87
93
  }
88
94
  getKeyDateLabel() {
89
- if (this.hasTooltip) {
90
- return this.date.keyDateText.join(', ');
91
- }
92
- else {
93
- return '';
94
- }
95
+ return this.hasTooltip && this.date?.keyDateText
96
+ ? this.date.keyDateText.join(', ')
97
+ : '';
95
98
  }
96
- hideTooltip() {
97
- /* istanbul ignore else */
98
- if (this.popoverOpen) {
99
- this.popoverController.next({ type: SkyPopoverMessageType.Close });
100
- }
99
+ }
100
+ _SkyDayPickerCellComponent_activeUid = new WeakMap(), _SkyDayPickerCellComponent_cancelPopover = new WeakMap(), _SkyDayPickerCellComponent_popoverOpen = new WeakMap(), _SkyDayPickerCellComponent_ngUnsubscribe = new WeakMap(), _SkyDayPickerCellComponent_datepicker = new WeakMap(), _SkyDayPickerCellComponent_datepickerService = new WeakMap(), _SkyDayPickerCellComponent_instances = new WeakSet(), _SkyDayPickerCellComponent_hideTooltip = function _SkyDayPickerCellComponent_hideTooltip() {
101
+ /* istanbul ignore else */
102
+ if (__classPrivateFieldGet(this, _SkyDayPickerCellComponent_popoverOpen, "f")) {
103
+ this.popoverController.next({ type: SkyPopoverMessageType.Close });
101
104
  }
102
- showTooltip() {
103
- /* istanbul ignore else */
104
- if (this.hasTooltip && !this.popoverOpen) {
105
- /**
106
- * Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.
107
- */
108
- setTimeout(() => {
109
- if (!this.cancelPopover && this.activeUid === this.date.uid) {
110
- this.popoverController.next({ type: SkyPopoverMessageType.Open });
111
- }
112
- }, 500);
113
- }
105
+ }, _SkyDayPickerCellComponent_showTooltip = function _SkyDayPickerCellComponent_showTooltip() {
106
+ /* istanbul ignore else */
107
+ if (this.hasTooltip && !__classPrivateFieldGet(this, _SkyDayPickerCellComponent_popoverOpen, "f")) {
108
+ /**
109
+ * Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.
110
+ */
111
+ setTimeout(() => {
112
+ if (!__classPrivateFieldGet(this, _SkyDayPickerCellComponent_cancelPopover, "f") && __classPrivateFieldGet(this, _SkyDayPickerCellComponent_activeUid, "f") === this.date?.uid) {
113
+ this.popoverController.next({ type: SkyPopoverMessageType.Open });
114
+ }
115
+ }, 500);
114
116
  }
115
- }
117
+ };
116
118
  SkyDayPickerCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDayPickerCellComponent, deps: [{ token: i1.SkyDatepickerCalendarInnerComponent }, { token: i2.SkyDatepickerService }], target: i0.ɵɵFactoryTarget.Component });
117
- SkyDayPickerCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyDayPickerCellComponent, selector: "sky-daypicker-cell", inputs: { activeDateHasChanged: "activeDateHasChanged", date: "date" }, ngImport: i0, template: "<div\n *ngIf=\"hasTooltip\"\n class=\"sky-daypicker-cell\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n skyPopoverPlacement=\"left\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n <sky-popover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n #dayInfoPopover\n >\n <div *ngFor=\"let text of date.keyDateText\">\n {{ text }}\n </div>\n </sky-popover>\n</div>\n<div\n *ngIf=\"!hasTooltip\"\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.λ6, selector: "sky-popover", inputs: ["alignment", "dismissOnBlur", "placement", "popoverTitle", "popoverType"], outputs: ["popoverClosed", "popoverOpened"] }, { kind: "directive", type: i4.λ7, selector: "[skyPopover]", inputs: ["skyPopover", "skyPopoverAlignment", "skyPopoverMessageStream", "skyPopoverPlacement", "skyPopoverTrigger"] }, { kind: "component", type: i5.SkyDayPickerButtonComponent, selector: "sky-daypicker-button", inputs: ["date"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
119
+ SkyDayPickerCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyDayPickerCellComponent, selector: "sky-daypicker-cell", inputs: { activeDateHasChanged: "activeDateHasChanged", date: "date" }, ngImport: i0, template: "<div\n *ngIf=\"hasTooltip\"\n class=\"sky-daypicker-cell\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n skyPopoverPlacement=\"left\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n <sky-popover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n #dayInfoPopover\n >\n <div *ngFor=\"let text of date?.keyDateText\">\n {{ text }}\n </div>\n </sky-popover>\n</div>\n<div\n *ngIf=\"!hasTooltip\"\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.λ6, selector: "sky-popover", inputs: ["alignment", "dismissOnBlur", "placement", "popoverTitle", "popoverType"], outputs: ["popoverClosed", "popoverOpened"] }, { kind: "directive", type: i4.λ7, selector: "[skyPopover]", inputs: ["skyPopover", "skyPopoverAlignment", "skyPopoverMessageStream", "skyPopoverPlacement", "skyPopoverTrigger"] }, { kind: "component", type: i5.SkyDayPickerButtonComponent, selector: "sky-daypicker-button", inputs: ["date"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
118
120
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDayPickerCellComponent, decorators: [{
119
121
  type: Component,
120
- args: [{ selector: 'sky-daypicker-cell', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"hasTooltip\"\n class=\"sky-daypicker-cell\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n skyPopoverPlacement=\"left\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n <sky-popover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n #dayInfoPopover\n >\n <div *ngFor=\"let text of date.keyDateText\">\n {{ text }}\n </div>\n </sky-popover>\n</div>\n<div\n *ngIf=\"!hasTooltip\"\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n" }]
122
+ args: [{ selector: 'sky-daypicker-cell', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"hasTooltip\"\n class=\"sky-daypicker-cell\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n skyPopoverPlacement=\"left\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n <sky-popover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n #dayInfoPopover\n >\n <div *ngFor=\"let text of date?.keyDateText\">\n {{ text }}\n </div>\n </sky-popover>\n</div>\n<div\n *ngIf=\"!hasTooltip\"\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n" }]
121
123
  }], ctorParameters: function () { return [{ type: i1.SkyDatepickerCalendarInnerComponent }, { type: i2.SkyDatepickerService }]; }, propDecorators: { activeDateHasChanged: [{
122
124
  type: Input
123
125
  }], date: [{
124
126
  type: Input
125
127
  }] } });
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker-cell.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker-cell.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport { SkyPopoverMessage, SkyPopoverMessageType } from '@skyux/popovers';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerDate } from './datepicker-date';\nimport { SkyDatepickerService } from './datepicker.service';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-daypicker-cell',\n  templateUrl: 'daypicker-cell.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDayPickerCellComponent implements OnInit, OnDestroy {\n  /**\n   * Specifies if the active date has been changed.\n   */\n  @Input()\n  public activeDateHasChanged: boolean;\n\n  /**\n   * Specifies the date this picker cell will represent on the calendar.\n   */\n  @Input()\n  public date: SkyDatepickerDate;\n\n  public hasTooltip = false;\n\n  public popoverController = new Subject<SkyPopoverMessage>();\n\n  private activeUid = '';\n\n  private cancelPopover = false;\n\n  private popoverOpen = false;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  public constructor(\n    private datepicker: SkyDatepickerCalendarInnerComponent,\n    private datepickerService: SkyDatepickerService\n  ) {}\n\n  public ngOnInit(): void {\n    this.hasTooltip =\n      this.date.keyDate &&\n      this.date.keyDateText &&\n      this.date.keyDateText.length > 0 &&\n      this.date.keyDateText[0].length > 0;\n\n    // show the tooltip if this is the active date and is not the\n    // initial active date (activeDateHasChanged)\n    if (\n      this.datepicker.isActive(this.date) &&\n      this.activeDateHasChanged &&\n      this.hasTooltip\n    ) {\n      this.activeUid = this.date.uid;\n      this.showTooltip();\n    }\n\n    if (this.hasTooltip) {\n      this.datepickerService.keyDatePopoverStream\n        .pipe(takeUntil(this.ngUnsubscribe))\n        .subscribe((date) => {\n          if (date) {\n            this.activeUid = date.uid;\n          } else {\n            this.activeUid = '';\n          }\n          // If this day has an open popover and they have moved off of the day close the popover.\n          if (this.date.uid !== this.activeUid) {\n            this.hideTooltip();\n          }\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n  }\n\n  public onDayMouseenter(): void {\n    this.cancelPopover = false;\n    if (this.hasTooltip) {\n      this.showTooltip();\n      this.datepickerService.keyDatePopoverStream.next(this.date);\n    }\n  }\n\n  public onDayMouseleave(): void {\n    this.cancelPopover = true;\n    if (this.hasTooltip) {\n      this.hideTooltip();\n    }\n    this.datepickerService.keyDatePopoverStream.next(undefined);\n  }\n\n  public onPopoverClosed(): void {\n    this.popoverOpen = false;\n  }\n\n  public onPopoverOpened(): void {\n    this.popoverOpen = true;\n    /* istanbul ignore else */\n    if (this.cancelPopover) {\n      // If the popover gets opened just as a mouseout event happens, close it.\n      this.hideTooltip();\n      this.cancelPopover = false;\n    }\n  }\n\n  public getKeyDateLabel(): string {\n    if (this.hasTooltip) {\n      return this.date.keyDateText.join(', ');\n    } else {\n      return '';\n    }\n  }\n\n  private hideTooltip(): void {\n    /* istanbul ignore else */\n    if (this.popoverOpen) {\n      this.popoverController.next({ type: SkyPopoverMessageType.Close });\n    }\n  }\n\n  private showTooltip(): void {\n    /* istanbul ignore else */\n    if (this.hasTooltip && !this.popoverOpen) {\n      /**\n       * Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.\n       */\n      setTimeout(() => {\n        if (!this.cancelPopover && this.activeUid === this.date.uid) {\n          this.popoverController.next({ type: SkyPopoverMessageType.Open });\n        }\n      }, 500);\n    }\n  }\n}\n","<div\n  *ngIf=\"hasTooltip\"\n  class=\"sky-daypicker-cell\"\n  [attr.aria-label]=\"getKeyDateLabel()\"\n  [skyPopover]=\"dayInfoPopover\"\n  skyPopoverPlacement=\"left\"\n  [skyPopoverMessageStream]=\"popoverController\"\n  (mouseenter)=\"onDayMouseenter()\"\n  (mouseleave)=\"onDayMouseleave()\"\n>\n  <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n  <sky-popover\n    (popoverClosed)=\"onPopoverClosed()\"\n    (popoverOpened)=\"onPopoverOpened()\"\n    #dayInfoPopover\n  >\n    <div *ngFor=\"let text of date.keyDateText\">\n      {{ text }}\n    </div>\n  </sky-popover>\n</div>\n<div\n  *ngIf=\"!hasTooltip\"\n  class=\"sky-daypicker-cell\"\n  (mouseenter)=\"onDayMouseenter()\"\n  (mouseleave)=\"onDayMouseleave()\"\n>\n  <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n  <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker-cell.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker-cell.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport { SkyPopoverMessage, SkyPopoverMessageType } from '@skyux/popovers';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerDate } from './datepicker-date';\nimport { SkyDatepickerService } from './datepicker.service';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-daypicker-cell',\n  templateUrl: 'daypicker-cell.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDayPickerCellComponent implements OnInit, OnDestroy {\n  /**\n   * Specifies if the active date has been changed.\n   */\n  @Input()\n  public activeDateHasChanged: boolean | undefined;\n\n  /**\n   * Specifies the date this picker cell will represent on the calendar.\n   */\n  @Input()\n  public date: SkyDatepickerDate | undefined;\n\n  public hasTooltip = false;\n\n  public popoverController = new Subject<SkyPopoverMessage>();\n\n  #activeUid = '';\n\n  #cancelPopover = false;\n\n  #popoverOpen = false;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #datepicker: SkyDatepickerCalendarInnerComponent;\n  #datepickerService: SkyDatepickerService;\n\n  public constructor(\n    datepicker: SkyDatepickerCalendarInnerComponent,\n    datepickerService: SkyDatepickerService\n  ) {\n    this.#datepicker = datepicker;\n    this.#datepickerService = datepickerService;\n  }\n\n  public ngOnInit(): void {\n    this.hasTooltip = !!(\n      this.date &&\n      this.date.keyDate &&\n      this.date.keyDateText &&\n      this.date.keyDateText.length > 0 &&\n      this.date.keyDateText[0].length > 0\n    );\n\n    // show the tooltip if this is the active date and is not the\n    // initial active date (activeDateHasChanged)\n    if (\n      !!this.date &&\n      this.#datepicker.isActive(this.date) &&\n      this.activeDateHasChanged &&\n      this.hasTooltip\n    ) {\n      this.#activeUid = this.date.uid;\n      this.#showTooltip();\n    }\n\n    if (this.hasTooltip) {\n      this.#datepickerService.keyDatePopoverStream\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((date) => {\n          if (date) {\n            this.#activeUid = date.uid;\n          } else {\n            this.#activeUid = '';\n          }\n          // If this day has an open popover and they have moved off of the day close the popover.\n          if (this.date?.uid !== this.#activeUid) {\n            this.#hideTooltip();\n          }\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public onDayMouseenter(): void {\n    this.#cancelPopover = false;\n    if (this.hasTooltip) {\n      this.#showTooltip();\n      this.#datepickerService.keyDatePopoverStream.next(this.date);\n    }\n  }\n\n  public onDayMouseleave(): void {\n    this.#cancelPopover = true;\n    if (this.hasTooltip) {\n      this.#hideTooltip();\n    }\n    this.#datepickerService.keyDatePopoverStream.next(undefined);\n  }\n\n  public onPopoverClosed(): void {\n    this.#popoverOpen = false;\n  }\n\n  public onPopoverOpened(): void {\n    this.#popoverOpen = true;\n    /* istanbul ignore else */\n    if (this.#cancelPopover) {\n      // If the popover gets opened just as a mouseout event happens, close it.\n      this.#hideTooltip();\n      this.#cancelPopover = false;\n    }\n  }\n\n  public getKeyDateLabel(): string {\n    return this.hasTooltip && this.date?.keyDateText\n      ? this.date.keyDateText.join(', ')\n      : '';\n  }\n\n  #hideTooltip(): void {\n    /* istanbul ignore else */\n    if (this.#popoverOpen) {\n      this.popoverController.next({ type: SkyPopoverMessageType.Close });\n    }\n  }\n\n  #showTooltip(): void {\n    /* istanbul ignore else */\n    if (this.hasTooltip && !this.#popoverOpen) {\n      /**\n       * Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.\n       */\n      setTimeout(() => {\n        if (!this.#cancelPopover && this.#activeUid === this.date?.uid) {\n          this.popoverController.next({ type: SkyPopoverMessageType.Open });\n        }\n      }, 500);\n    }\n  }\n}\n","<div\n  *ngIf=\"hasTooltip\"\n  class=\"sky-daypicker-cell\"\n  [attr.aria-label]=\"getKeyDateLabel()\"\n  [skyPopover]=\"dayInfoPopover\"\n  skyPopoverPlacement=\"left\"\n  [skyPopoverMessageStream]=\"popoverController\"\n  (mouseenter)=\"onDayMouseenter()\"\n  (mouseleave)=\"onDayMouseleave()\"\n>\n  <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n  <sky-popover\n    (popoverClosed)=\"onPopoverClosed()\"\n    (popoverOpened)=\"onPopoverOpened()\"\n    #dayInfoPopover\n  >\n    <div *ngFor=\"let text of date?.keyDateText\">\n      {{ text }}\n    </div>\n  </sky-popover>\n</div>\n<div\n  *ngIf=\"!hasTooltip\"\n  class=\"sky-daypicker-cell\"\n  (mouseenter)=\"onDayMouseenter()\"\n  (mouseleave)=\"onDayMouseleave()\"\n>\n  <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n  <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n"]}