@skyux/datetime 5.0.2 → 5.1.2
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/bundles/skyux-datetime-testing.umd.js +3 -1
- package/bundles/skyux-datetime-testing.umd.js.map +1 -1
- package/bundles/skyux-datetime.umd.js +871 -434
- package/bundles/skyux-datetime.umd.js.map +1 -1
- package/documentation.json +1355 -971
- package/esm2015/modules/date-pipe/date-format-utility.js +10 -10
- package/esm2015/modules/date-pipe/date-pipe.module.js +9 -30
- package/esm2015/modules/date-pipe/date.pipe.js +7 -6
- package/esm2015/modules/date-pipe/fuzzy-date.pipe.js +5 -5
- package/esm2015/modules/date-range-picker/date-range-picker.component.js +30 -30
- package/esm2015/modules/date-range-picker/date-range-picker.module.js +11 -13
- package/esm2015/modules/date-range-picker/date-range.service.js +8 -13
- package/esm2015/modules/date-range-picker/types/date-range-calculation.js +1 -1
- package/esm2015/modules/date-range-picker/types/date-range-calculator-config.js +1 -1
- package/esm2015/modules/date-range-picker/types/date-range-calculator-date-range-function.js +1 -1
- package/esm2015/modules/date-range-picker/types/date-range-calculator-id.js +1 -1
- package/esm2015/modules/date-range-picker/types/date-range-calculator-type.js +1 -1
- package/esm2015/modules/date-range-picker/types/date-range-calculator-validate-function.js +1 -1
- package/esm2015/modules/date-range-picker/types/date-range-calculator.js +2 -2
- package/esm2015/modules/date-range-picker/types/date-range-default-calculator-config.js +1 -1
- package/esm2015/modules/date-range-picker/types/date-range-default-calculator-configs.js +25 -25
- package/esm2015/modules/date-range-picker/types/date-range-relative-value.js +17 -17
- package/esm2015/modules/date-range-picker/types/date-range.js +1 -1
- package/esm2015/modules/datepicker/date-formatter.js +4 -3
- package/esm2015/modules/datepicker/datepicker-adapter.service.js +4 -4
- package/esm2015/modules/datepicker/datepicker-calendar-change.js +2 -0
- package/esm2015/modules/datepicker/datepicker-calendar-inner.component.js +42 -15
- package/esm2015/modules/datepicker/datepicker-calendar.component.js +24 -14
- package/esm2015/modules/datepicker/datepicker-config.service.js +5 -5
- package/esm2015/modules/datepicker/datepicker-custom-date.js +2 -0
- package/esm2015/modules/datepicker/datepicker-date.js +1 -1
- package/esm2015/modules/datepicker/datepicker-input-fuzzy.directive.js +41 -41
- package/esm2015/modules/datepicker/datepicker-input.directive.js +38 -39
- package/esm2015/modules/datepicker/datepicker.component.js +68 -17
- package/esm2015/modules/datepicker/datepicker.module.js +28 -13
- package/esm2015/modules/datepicker/datepicker.service.js +21 -0
- package/esm2015/modules/datepicker/daypicker-button.component.js +25 -0
- package/esm2015/modules/datepicker/daypicker-cell.component.js +128 -0
- package/esm2015/modules/datepicker/daypicker.component.js +111 -20
- package/esm2015/modules/datepicker/fuzzy-date.js +1 -1
- package/esm2015/modules/datepicker/fuzzy-date.service.js +55 -27
- package/esm2015/modules/datepicker/monthpicker.component.js +8 -10
- package/esm2015/modules/datepicker/yearpicker.component.js +17 -12
- package/esm2015/modules/shared/sky-datetime-resources.module.js +102 -15
- package/esm2015/modules/timepicker/timepicker.component.js +29 -30
- package/esm2015/modules/timepicker/timepicker.directive.js +37 -36
- package/esm2015/modules/timepicker/timepicker.interface.js +1 -1
- package/esm2015/modules/timepicker/timepicker.module.js +10 -18
- package/esm2015/public-api.js +3 -1
- package/esm2015/testing/datepicker-fixture.js +4 -2
- package/esm2015/testing/timepicker-fixture.js +1 -1
- package/fesm2015/skyux-datetime-testing.js +3 -1
- package/fesm2015/skyux-datetime-testing.js.map +1 -1
- package/fesm2015/skyux-datetime.js +850 -422
- package/fesm2015/skyux-datetime.js.map +1 -1
- package/modules/datepicker/datepicker-calendar-change.d.ts +24 -0
- package/modules/datepicker/datepicker-calendar-inner.component.d.ts +13 -3
- package/modules/datepicker/datepicker-calendar.component.d.ts +8 -2
- package/modules/datepicker/datepicker-custom-date.d.ts +21 -0
- package/modules/datepicker/datepicker-date.d.ts +2 -0
- package/modules/datepicker/datepicker.component.d.ts +14 -1
- package/modules/datepicker/datepicker.module.d.ts +11 -8
- package/modules/datepicker/datepicker.service.d.ts +15 -0
- package/modules/datepicker/daypicker-button.component.d.ts +16 -0
- package/modules/datepicker/daypicker-cell.component.d.ts +40 -0
- package/modules/datepicker/daypicker.component.d.ts +18 -3
- package/package.json +7 -7
- package/public-api.d.ts +2 -0
|
@@ -5,13 +5,96 @@
|
|
|
5
5
|
* To update this file, simply rerun the command.
|
|
6
6
|
*/
|
|
7
7
|
import { NgModule } from '@angular/core';
|
|
8
|
-
import { getLibStringForLocale, SkyI18nModule, SKY_LIB_RESOURCES_PROVIDERS } from '@skyux/i18n';
|
|
8
|
+
import { getLibStringForLocale, SkyI18nModule, SKY_LIB_RESOURCES_PROVIDERS, } from '@skyux/i18n';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
const RESOURCES = {
|
|
11
|
-
'EN-AU': {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
11
|
+
'EN-AU': {
|
|
12
|
+
skyux_date_range_picker_format_label_last_fiscal_year: {
|
|
13
|
+
message: 'Last financial year',
|
|
14
|
+
},
|
|
15
|
+
skyux_date_range_picker_format_label_this_fiscal_year: {
|
|
16
|
+
message: 'This financial year',
|
|
17
|
+
},
|
|
18
|
+
skyux_date_range_picker_format_label_next_fiscal_year: {
|
|
19
|
+
message: 'Next financial year',
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
'EN-GB': {
|
|
23
|
+
skyux_date_range_picker_format_label_last_fiscal_year: {
|
|
24
|
+
message: 'Last financial year',
|
|
25
|
+
},
|
|
26
|
+
skyux_date_range_picker_format_label_this_fiscal_year: {
|
|
27
|
+
message: 'This financial year',
|
|
28
|
+
},
|
|
29
|
+
skyux_date_range_picker_format_label_next_fiscal_year: {
|
|
30
|
+
message: 'Next financial year',
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
'EN-NZ': {
|
|
34
|
+
skyux_date_range_picker_format_label_last_fiscal_year: {
|
|
35
|
+
message: 'Last financial year',
|
|
36
|
+
},
|
|
37
|
+
skyux_date_range_picker_format_label_this_fiscal_year: {
|
|
38
|
+
message: 'This financial year',
|
|
39
|
+
},
|
|
40
|
+
skyux_date_range_picker_format_label_next_fiscal_year: {
|
|
41
|
+
message: 'Next financial year',
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
'EN-US': {
|
|
45
|
+
skyux_date_field_default_label: { message: 'Date' },
|
|
46
|
+
skyux_datepicker_trigger_button_label: { message: 'Select date' },
|
|
47
|
+
skyux_timepicker_button_label: { message: 'Choose time' },
|
|
48
|
+
skyux_timepicker_close: { message: 'Done' },
|
|
49
|
+
skyux_timepicker_input_default_label: { message: 'Time' },
|
|
50
|
+
skyux_date_range_picker_default_label: { message: 'Select a date range' },
|
|
51
|
+
skyux_date_range_picker_format_label_specific_range: {
|
|
52
|
+
message: 'Specific range',
|
|
53
|
+
},
|
|
54
|
+
skyux_date_range_picker_format_label_before: { message: 'Before' },
|
|
55
|
+
skyux_date_range_picker_format_label_after: { message: 'After' },
|
|
56
|
+
skyux_date_range_picker_format_label_any_time: { message: 'At any time' },
|
|
57
|
+
skyux_date_range_picker_format_label_yesterday: { message: 'Yesterday' },
|
|
58
|
+
skyux_date_range_picker_format_label_today: { message: 'Today' },
|
|
59
|
+
skyux_date_range_picker_format_label_tomorrow: { message: 'Tomorrow' },
|
|
60
|
+
skyux_date_range_picker_format_label_last_week: { message: 'Last week' },
|
|
61
|
+
skyux_date_range_picker_format_label_this_week: { message: 'This week' },
|
|
62
|
+
skyux_date_range_picker_format_label_next_week: { message: 'Next week' },
|
|
63
|
+
skyux_date_range_picker_format_label_last_month: { message: 'Last month' },
|
|
64
|
+
skyux_date_range_picker_format_label_this_month: { message: 'This month' },
|
|
65
|
+
skyux_date_range_picker_format_label_next_month: { message: 'Next month' },
|
|
66
|
+
skyux_date_range_picker_format_label_last_quarter: {
|
|
67
|
+
message: 'Last quarter',
|
|
68
|
+
},
|
|
69
|
+
skyux_date_range_picker_format_label_this_quarter: {
|
|
70
|
+
message: 'This quarter',
|
|
71
|
+
},
|
|
72
|
+
skyux_date_range_picker_format_label_next_quarter: {
|
|
73
|
+
message: 'Next quarter',
|
|
74
|
+
},
|
|
75
|
+
skyux_date_range_picker_format_label_last_calendar_year: {
|
|
76
|
+
message: 'Last calendar year',
|
|
77
|
+
},
|
|
78
|
+
skyux_date_range_picker_format_label_this_calendar_year: {
|
|
79
|
+
message: 'This calendar year',
|
|
80
|
+
},
|
|
81
|
+
skyux_date_range_picker_format_label_next_calendar_year: {
|
|
82
|
+
message: 'Next calendar year',
|
|
83
|
+
},
|
|
84
|
+
skyux_date_range_picker_format_label_last_fiscal_year: {
|
|
85
|
+
message: 'Last fiscal year',
|
|
86
|
+
},
|
|
87
|
+
skyux_date_range_picker_format_label_this_fiscal_year: {
|
|
88
|
+
message: 'This fiscal year',
|
|
89
|
+
},
|
|
90
|
+
skyux_date_range_picker_format_label_next_fiscal_year: {
|
|
91
|
+
message: 'Next fiscal year',
|
|
92
|
+
},
|
|
93
|
+
skyux_date_range_picker_start_date_label: { message: 'From date' },
|
|
94
|
+
skyux_date_range_picker_end_date_label: { message: 'To date' },
|
|
95
|
+
skyux_date_range_picker_before_date_label: { message: 'Before date' },
|
|
96
|
+
skyux_date_range_picker_after_date_label: { message: 'After date' },
|
|
97
|
+
},
|
|
15
98
|
};
|
|
16
99
|
export class SkyDatetimeResourcesProvider {
|
|
17
100
|
getString(localeInfo, name) {
|
|
@@ -23,22 +106,26 @@ export class SkyDatetimeResourcesProvider {
|
|
|
23
106
|
*/
|
|
24
107
|
export class SkyDatetimeResourcesModule {
|
|
25
108
|
}
|
|
26
|
-
SkyDatetimeResourcesModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
27
|
-
SkyDatetimeResourcesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.
|
|
28
|
-
SkyDatetimeResourcesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.
|
|
109
|
+
SkyDatetimeResourcesModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.14", ngImport: i0, type: SkyDatetimeResourcesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
110
|
+
SkyDatetimeResourcesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.14", ngImport: i0, type: SkyDatetimeResourcesModule, exports: [SkyI18nModule] });
|
|
111
|
+
SkyDatetimeResourcesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.14", ngImport: i0, type: SkyDatetimeResourcesModule, providers: [
|
|
112
|
+
{
|
|
29
113
|
provide: SKY_LIB_RESOURCES_PROVIDERS,
|
|
30
114
|
useClass: SkyDatetimeResourcesProvider,
|
|
31
|
-
multi: true
|
|
32
|
-
}
|
|
33
|
-
|
|
115
|
+
multi: true,
|
|
116
|
+
},
|
|
117
|
+
], imports: [SkyI18nModule] });
|
|
118
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.14", ngImport: i0, type: SkyDatetimeResourcesModule, decorators: [{
|
|
34
119
|
type: NgModule,
|
|
35
120
|
args: [{
|
|
36
121
|
exports: [SkyI18nModule],
|
|
37
|
-
providers: [
|
|
122
|
+
providers: [
|
|
123
|
+
{
|
|
38
124
|
provide: SKY_LIB_RESOURCES_PROVIDERS,
|
|
39
125
|
useClass: SkyDatetimeResourcesProvider,
|
|
40
|
-
multi: true
|
|
41
|
-
}
|
|
126
|
+
multi: true,
|
|
127
|
+
},
|
|
128
|
+
],
|
|
42
129
|
}]
|
|
43
130
|
}] });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sky-datetime-resources.module.js","sourceRoot":"","sources":["../../../../../projects/datetime/src/modules/shared/sky-datetime-resources.module.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * NOTICE: DO NOT MODIFY THIS FILE!\n * The contents of this file were automatically generated by\n * the 'ng generate @skyux/i18n:lib-resources-module modules/shared/sky-datetime' schematic.\n * To update this file, simply rerun the command.\n */\n\nimport { NgModule } from '@angular/core';\nimport {\n  getLibStringForLocale,\n  SkyAppLocaleInfo,\n  SkyI18nModule,\n  SkyLibResources,\n  SkyLibResourcesProvider,\n  SKY_LIB_RESOURCES_PROVIDERS\n} from '@skyux/i18n';\n\nconst RESOURCES: { [locale: string]: SkyLibResources } = {\n  'EN-AU': {\"skyux_date_range_picker_format_label_last_fiscal_year\":{\"message\":\"Last financial year\"},\"skyux_date_range_picker_format_label_this_fiscal_year\":{\"message\":\"This financial year\"},\"skyux_date_range_picker_format_label_next_fiscal_year\":{\"message\":\"Next financial year\"}},\n  'EN-GB': {\"skyux_date_range_picker_format_label_last_fiscal_year\":{\"message\":\"Last financial year\"},\"skyux_date_range_picker_format_label_this_fiscal_year\":{\"message\":\"This financial year\"},\"skyux_date_range_picker_format_label_next_fiscal_year\":{\"message\":\"Next financial year\"}},\n  'EN-NZ': {\"skyux_date_range_picker_format_label_last_fiscal_year\":{\"message\":\"Last financial year\"},\"skyux_date_range_picker_format_label_this_fiscal_year\":{\"message\":\"This financial year\"},\"skyux_date_range_picker_format_label_next_fiscal_year\":{\"message\":\"Next financial year\"}},\n  'EN-US': {\"skyux_date_field_default_label\":{\"message\":\"Date\"},\"skyux_datepicker_trigger_button_label\":{\"message\":\"Select date\"},\"skyux_timepicker_button_label\":{\"message\":\"Choose time\"},\"skyux_timepicker_close\":{\"message\":\"Done\"},\"skyux_timepicker_input_default_label\":{\"message\":\"Time\"},\"skyux_date_range_picker_default_label\":{\"message\":\"Select a date range\"},\"skyux_date_range_picker_format_label_specific_range\":{\"message\":\"Specific range\"},\"skyux_date_range_picker_format_label_before\":{\"message\":\"Before\"},\"skyux_date_range_picker_format_label_after\":{\"message\":\"After\"},\"skyux_date_range_picker_format_label_any_time\":{\"message\":\"At any time\"},\"skyux_date_range_picker_format_label_yesterday\":{\"message\":\"Yesterday\"},\"skyux_date_range_picker_format_label_today\":{\"message\":\"Today\"},\"skyux_date_range_picker_format_label_tomorrow\":{\"message\":\"Tomorrow\"},\"skyux_date_range_picker_format_label_last_week\":{\"message\":\"Last week\"},\"skyux_date_range_picker_format_label_this_week\":{\"message\":\"This week\"},\"skyux_date_range_picker_format_label_next_week\":{\"message\":\"Next week\"},\"skyux_date_range_picker_format_label_last_month\":{\"message\":\"Last month\"},\"skyux_date_range_picker_format_label_this_month\":{\"message\":\"This month\"},\"skyux_date_range_picker_format_label_next_month\":{\"message\":\"Next month\"},\"skyux_date_range_picker_format_label_last_quarter\":{\"message\":\"Last quarter\"},\"skyux_date_range_picker_format_label_this_quarter\":{\"message\":\"This quarter\"},\"skyux_date_range_picker_format_label_next_quarter\":{\"message\":\"Next quarter\"},\"skyux_date_range_picker_format_label_last_calendar_year\":{\"message\":\"Last calendar year\"},\"skyux_date_range_picker_format_label_this_calendar_year\":{\"message\":\"This calendar year\"},\"skyux_date_range_picker_format_label_next_calendar_year\":{\"message\":\"Next calendar year\"},\"skyux_date_range_picker_format_label_last_fiscal_year\":{\"message\":\"Last fiscal year\"},\"skyux_date_range_picker_format_label_this_fiscal_year\":{\"message\":\"This fiscal year\"},\"skyux_date_range_picker_format_label_next_fiscal_year\":{\"message\":\"Next fiscal year\"},\"skyux_date_range_picker_start_date_label\":{\"message\":\"From date\"},\"skyux_date_range_picker_end_date_label\":{\"message\":\"To date\"},\"skyux_date_range_picker_before_date_label\":{\"message\":\"Before date\"},\"skyux_date_range_picker_after_date_label\":{\"message\":\"After date\"}},\n};\n\nexport class SkyDatetimeResourcesProvider implements SkyLibResourcesProvider {\n  public getString(localeInfo: SkyAppLocaleInfo, name: string): string {\n    return getLibStringForLocale(RESOURCES, localeInfo.locale, name);\n  }\n}\n\n/**\n * Import into any component library module that needs to use resource strings.\n */\n@NgModule({\n  exports: [SkyI18nModule],\n  providers: [{\n    provide: SKY_LIB_RESOURCES_PROVIDERS,\n    useClass: SkyDatetimeResourcesProvider,\n    multi: true\n  }]\n})\nexport class SkyDatetimeResourcesModule { }\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sky-datetime-resources.module.js","sourceRoot":"","sources":["../../../../../projects/datetime/src/modules/shared/sky-datetime-resources.module.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * NOTICE: DO NOT MODIFY THIS FILE!\n * The contents of this file were automatically generated by\n * the 'ng generate @skyux/i18n:lib-resources-module modules/shared/sky-datetime' schematic.\n * To update this file, simply rerun the command.\n */\n\nimport { NgModule } from '@angular/core';\nimport {\n  getLibStringForLocale,\n  SkyAppLocaleInfo,\n  SkyI18nModule,\n  SkyLibResources,\n  SkyLibResourcesProvider,\n  SKY_LIB_RESOURCES_PROVIDERS,\n} from '@skyux/i18n';\n\nconst RESOURCES: { [locale: string]: SkyLibResources } = {\n  'EN-AU': {\n    skyux_date_range_picker_format_label_last_fiscal_year: {\n      message: 'Last financial year',\n    },\n    skyux_date_range_picker_format_label_this_fiscal_year: {\n      message: 'This financial year',\n    },\n    skyux_date_range_picker_format_label_next_fiscal_year: {\n      message: 'Next financial year',\n    },\n  },\n  'EN-GB': {\n    skyux_date_range_picker_format_label_last_fiscal_year: {\n      message: 'Last financial year',\n    },\n    skyux_date_range_picker_format_label_this_fiscal_year: {\n      message: 'This financial year',\n    },\n    skyux_date_range_picker_format_label_next_fiscal_year: {\n      message: 'Next financial year',\n    },\n  },\n  'EN-NZ': {\n    skyux_date_range_picker_format_label_last_fiscal_year: {\n      message: 'Last financial year',\n    },\n    skyux_date_range_picker_format_label_this_fiscal_year: {\n      message: 'This financial year',\n    },\n    skyux_date_range_picker_format_label_next_fiscal_year: {\n      message: 'Next financial year',\n    },\n  },\n  'EN-US': {\n    skyux_date_field_default_label: { message: 'Date' },\n    skyux_datepicker_trigger_button_label: { message: 'Select date' },\n    skyux_timepicker_button_label: { message: 'Choose time' },\n    skyux_timepicker_close: { message: 'Done' },\n    skyux_timepicker_input_default_label: { message: 'Time' },\n    skyux_date_range_picker_default_label: { message: 'Select a date range' },\n    skyux_date_range_picker_format_label_specific_range: {\n      message: 'Specific range',\n    },\n    skyux_date_range_picker_format_label_before: { message: 'Before' },\n    skyux_date_range_picker_format_label_after: { message: 'After' },\n    skyux_date_range_picker_format_label_any_time: { message: 'At any time' },\n    skyux_date_range_picker_format_label_yesterday: { message: 'Yesterday' },\n    skyux_date_range_picker_format_label_today: { message: 'Today' },\n    skyux_date_range_picker_format_label_tomorrow: { message: 'Tomorrow' },\n    skyux_date_range_picker_format_label_last_week: { message: 'Last week' },\n    skyux_date_range_picker_format_label_this_week: { message: 'This week' },\n    skyux_date_range_picker_format_label_next_week: { message: 'Next week' },\n    skyux_date_range_picker_format_label_last_month: { message: 'Last month' },\n    skyux_date_range_picker_format_label_this_month: { message: 'This month' },\n    skyux_date_range_picker_format_label_next_month: { message: 'Next month' },\n    skyux_date_range_picker_format_label_last_quarter: {\n      message: 'Last quarter',\n    },\n    skyux_date_range_picker_format_label_this_quarter: {\n      message: 'This quarter',\n    },\n    skyux_date_range_picker_format_label_next_quarter: {\n      message: 'Next quarter',\n    },\n    skyux_date_range_picker_format_label_last_calendar_year: {\n      message: 'Last calendar year',\n    },\n    skyux_date_range_picker_format_label_this_calendar_year: {\n      message: 'This calendar year',\n    },\n    skyux_date_range_picker_format_label_next_calendar_year: {\n      message: 'Next calendar year',\n    },\n    skyux_date_range_picker_format_label_last_fiscal_year: {\n      message: 'Last fiscal year',\n    },\n    skyux_date_range_picker_format_label_this_fiscal_year: {\n      message: 'This fiscal year',\n    },\n    skyux_date_range_picker_format_label_next_fiscal_year: {\n      message: 'Next fiscal year',\n    },\n    skyux_date_range_picker_start_date_label: { message: 'From date' },\n    skyux_date_range_picker_end_date_label: { message: 'To date' },\n    skyux_date_range_picker_before_date_label: { message: 'Before date' },\n    skyux_date_range_picker_after_date_label: { message: 'After date' },\n  },\n};\n\nexport class SkyDatetimeResourcesProvider implements SkyLibResourcesProvider {\n  public getString(localeInfo: SkyAppLocaleInfo, name: string): string {\n    return getLibStringForLocale(RESOURCES, localeInfo.locale, name);\n  }\n}\n\n/**\n * Import into any component library module that needs to use resource strings.\n */\n@NgModule({\n  exports: [SkyI18nModule],\n  providers: [\n    {\n      provide: SKY_LIB_RESOURCES_PROVIDERS,\n      useClass: SkyDatetimeResourcesProvider,\n      multi: true,\n    },\n  ],\n})\nexport class SkyDatetimeResourcesModule {}\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Optional, Output, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
2
|
-
import { SkyAffixAutoFitContext } from '@skyux/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Optional, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { SkyAffixAutoFitContext, } from '@skyux/core';
|
|
3
3
|
import { fromEvent, Subject } from 'rxjs';
|
|
4
4
|
import { takeUntil } from 'rxjs/operators';
|
|
5
|
-
import moment from
|
|
5
|
+
import moment from 'moment';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@skyux/core";
|
|
8
8
|
import * as i2 from "@skyux/forms";
|
|
@@ -58,10 +58,10 @@ export class SkyTimepickerComponent {
|
|
|
58
58
|
if (this.is8601) {
|
|
59
59
|
hourOffset = 0;
|
|
60
60
|
}
|
|
61
|
-
hour = moment({
|
|
61
|
+
hour = moment({ hour: setHour }).add(hourOffset, 'hours').hour();
|
|
62
62
|
this.activeTime = moment({
|
|
63
|
-
|
|
64
|
-
|
|
63
|
+
hour: hour,
|
|
64
|
+
minute: moment(this.activeTime).get('minute') + 0,
|
|
65
65
|
}).toDate();
|
|
66
66
|
this.selectedTimeChanged.emit(this.selectedTime);
|
|
67
67
|
}
|
|
@@ -92,8 +92,8 @@ export class SkyTimepickerComponent {
|
|
|
92
92
|
}
|
|
93
93
|
set selectedMinute(minute) {
|
|
94
94
|
this.activeTime = moment({
|
|
95
|
-
|
|
96
|
-
|
|
95
|
+
hour: moment(this.activeTime).get('hour') + 0,
|
|
96
|
+
minute: minute,
|
|
97
97
|
}).toDate();
|
|
98
98
|
this.selectedTimeChanged.emit(this.selectedTime);
|
|
99
99
|
}
|
|
@@ -118,8 +118,9 @@ export class SkyTimepickerComponent {
|
|
|
118
118
|
timezone: parseInt(moment(this.activeTime).format('Z'), 10),
|
|
119
119
|
iso8601: this.activeTime,
|
|
120
120
|
local: moment(this.activeTime).format(this.localeFormat),
|
|
121
|
-
customFormat:
|
|
122
|
-
? this.returnFormat
|
|
121
|
+
customFormat: typeof this.returnFormat !== 'undefined'
|
|
122
|
+
? this.returnFormat
|
|
123
|
+
: this.localeFormat,
|
|
123
124
|
};
|
|
124
125
|
return time;
|
|
125
126
|
}
|
|
@@ -147,7 +148,7 @@ export class SkyTimepickerComponent {
|
|
|
147
148
|
if (this.inputBoxHostService) {
|
|
148
149
|
this.inputBoxHostService.populate({
|
|
149
150
|
inputTemplate: this.inputTemplateRef,
|
|
150
|
-
buttonsTemplate: this.triggerButtonTemplateRef
|
|
151
|
+
buttonsTemplate: this.triggerButtonTemplateRef,
|
|
151
152
|
});
|
|
152
153
|
}
|
|
153
154
|
}
|
|
@@ -179,8 +180,7 @@ export class SkyTimepickerComponent {
|
|
|
179
180
|
}
|
|
180
181
|
let data;
|
|
181
182
|
data = {
|
|
182
|
-
|
|
183
|
-
.map(function (x, i) {
|
|
183
|
+
hours: Array.apply(undefined, Array(h)).map(function (x, i) {
|
|
184
184
|
if (format === 'hh') {
|
|
185
185
|
return ++i;
|
|
186
186
|
}
|
|
@@ -192,12 +192,11 @@ export class SkyTimepickerComponent {
|
|
|
192
192
|
/* sanity check */
|
|
193
193
|
return 0;
|
|
194
194
|
}),
|
|
195
|
-
|
|
196
|
-
.map(function (x, i) {
|
|
195
|
+
minutes: Array.apply(undefined, Array(m)).map(function (x, i) {
|
|
197
196
|
return i * minuteMultiplier;
|
|
198
197
|
}),
|
|
199
|
-
|
|
200
|
-
|
|
198
|
+
localeFormat: localeFormat,
|
|
199
|
+
minuteMultiplier: minuteMultiplier,
|
|
201
200
|
};
|
|
202
201
|
this.hours = data.hours;
|
|
203
202
|
this.minutes = data.minutes;
|
|
@@ -251,7 +250,7 @@ export class SkyTimepickerComponent {
|
|
|
251
250
|
affixer.placementChange
|
|
252
251
|
.pipe(takeUntil(this.timepickerUnsubscribe))
|
|
253
252
|
.subscribe((change) => {
|
|
254
|
-
this.isVisible =
|
|
253
|
+
this.isVisible = change.placement !== null;
|
|
255
254
|
this.changeDetector.markForCheck();
|
|
256
255
|
});
|
|
257
256
|
affixer.affixTo(this.triggerButtonRef.nativeElement, {
|
|
@@ -259,7 +258,7 @@ export class SkyTimepickerComponent {
|
|
|
259
258
|
enableAutoFit: true,
|
|
260
259
|
horizontalAlignment: 'right',
|
|
261
260
|
isSticky: true,
|
|
262
|
-
placement: 'below'
|
|
261
|
+
placement: 'below',
|
|
263
262
|
});
|
|
264
263
|
this.affixer = affixer;
|
|
265
264
|
}
|
|
@@ -273,7 +272,7 @@ export class SkyTimepickerComponent {
|
|
|
273
272
|
createOverlay() {
|
|
274
273
|
const overlay = this.overlayService.create({
|
|
275
274
|
enableClose: false,
|
|
276
|
-
enablePointerEvents: false
|
|
275
|
+
enablePointerEvents: false,
|
|
277
276
|
});
|
|
278
277
|
overlay.backdropClick
|
|
279
278
|
.pipe(takeUntil(this.timepickerUnsubscribe))
|
|
@@ -318,16 +317,16 @@ export class SkyTimepickerComponent {
|
|
|
318
317
|
(_a = this.overlayKeydownListner) === null || _a === void 0 ? void 0 : _a.unsubscribe();
|
|
319
318
|
}
|
|
320
319
|
}
|
|
321
|
-
SkyTimepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
322
|
-
SkyTimepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.
|
|
323
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
320
|
+
SkyTimepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.14", ngImport: i0, type: SkyTimepickerComponent, deps: [{ token: i1.SkyAffixService }, { token: i0.ChangeDetectorRef }, { token: i1.SkyCoreAdapterService }, { token: i1.SkyOverlayService }, { token: i2.SkyInputBoxHostService, optional: true }, { token: i3.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
321
|
+
SkyTimepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.14", type: SkyTimepickerComponent, selector: "sky-timepicker", outputs: { selectedTimeChanged: "selectedTimeChanged" }, viewQueries: [{ propertyName: "timepickerRef", first: true, predicate: ["timepickerRef"], descendants: true, read: ElementRef }, { propertyName: "timepickerTemplateRef", first: true, predicate: ["timepickerTemplateRef"], descendants: true, read: TemplateRef }, { propertyName: "triggerButtonRef", first: true, predicate: ["triggerButtonRef"], descendants: true, read: ElementRef }, { propertyName: "inputTemplateRef", first: true, predicate: ["inputTemplateRef"], descendants: true, read: TemplateRef, static: true }, { propertyName: "triggerButtonTemplateRef", first: true, predicate: ["triggerButtonTemplateRef"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<div class=\"sky-timepicker\">\n <ng-container *ngIf=\"!inputBoxHostService\">\n <div class=\"sky-input-group\">\n <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n </div>\n </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n <div class=\"sky-input-group-btn\">\n <button\n aria-haspopup=\"dialog\"\n class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n type=\"button\"\n [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"clock-o\" size=\"lg\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"clock\"\n size=\"lg\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n <div\n class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n role=\"dialog\"\n [attr.aria-labelledby]=\"triggerButtonId\"\n [attr.id]=\"timepickerId\"\n [class.sky-timepicker-hidden]=\"!isVisible\"\n #timepickerRef\n >\n <div class=\"sky-timepicker-content\">\n <section\n class=\"sky-timepicker-column\"\n [ngClass]=\"{ 'sky-timepicker-24hour': is8601 }\"\n >\n <ol>\n <li *ngFor=\"let hour of hours\">\n <button\n name=\"hour\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedHour === hour }\"\n (click)=\"setTime($event)\"\n >\n {{ hour }}\n </button>\n </li>\n </ol>\n </section>\n <section class=\"sky-timepicker-column\">\n <ol>\n <li *ngFor=\"let minute of minutes\">\n <button\n name=\"minute\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n (click)=\"setTime($event)\"\n >\n {{ '00'.substring(0, 2 - minute.toString().length) + minute }}\n </button>\n </li>\n </ol>\n </section>\n <section *ngIf=\"!is8601\" class=\"sky-timepicker-column\">\n <ol>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n (click)=\"setTime($event)\"\n >\n AM\n </button>\n </li>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n (click)=\"setTime($event)\"\n >\n PM\n </button>\n </li>\n </ol>\n </section>\n </div>\n <div class=\"sky-timepicker-footer\">\n <section class=\"sky-timepicker-column\">\n <button\n class=\"sky-btn sky-btn-primary\"\n type=\"button\"\n (click)=\"onCloseButtonCick()\"\n >\n {{ 'skyux_timepicker_close' | skyLibResources }}\n </button>\n </section>\n </div>\n </div>\n</ng-template>\n", styles: [".sky-timepicker-container{position:fixed;font-size:15px;padding:5px;background-color:#eeeeef;border-radius:5px}.sky-timepicker-container :last-child ol{display:flex;flex-direction:column;height:100%}.sky-timepicker-container :last-child ol li{border-bottom:1px solid #e2e3e4;flex:1}.sky-timepicker-column{margin:5px}.sky-timepicker-column ol{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;grid-column-gap:1px;column-gap:1px;columns:2;list-style-type:none;margin:0;padding:0}.sky-timepicker-column ol li{text-align:center;cursor:pointer;margin:0}.sky-timepicker-column ol li button{cursor:pointer}.sky-timepicker-column ol li button:focus{outline:thin dotted;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.sky-timepicker-column ol li button:hover{background-color:#eeeeef}.sky-timepicker-column ol li button:active{background-color:#e2e3e4}.sky-timepicker-column ol li button.sky-btn-active:hover{background-color:#c1e8fb}.sky-timepicker-column ol .sky-btn-active{background-color:#c1e8fb;box-shadow:inset 0 0 0 2px #00b4f1;border-radius:3px}.sky-timepicker-column.sky-timepicker-24hour ol{columns:4}.sky-timepicker-column.sky-timepicker-24hour ol li{border-bottom-width:0}.sky-timepicker-content{display:flex}.sky-timepicker-content button{background-color:#fff;border-width:0;padding:5px 15px;width:100%;height:100%}.sky-timepicker-footer{margin:0;padding:0 5px}.sky-timepicker-footer .sky-timepicker-column{margin-left:0;margin-right:0;width:100%}.sky-timepicker-hidden{visibility:hidden}.sky-timepicker-clock-icon-modern{display:none}.sky-theme-modern .sky-timepicker-clock-icon-default{display:none}.sky-theme-modern .sky-timepicker-clock-icon-modern{display:inline}.sky-theme-modern .sky-timepicker-container{background-color:#fff;border:solid 1px #cdcfd2;border-radius:6px;font-size:16px}.sky-theme-modern .sky-timepicker-container:focus-within{border:solid 2px #1870B8;padding:4px}.sky-theme-modern .sky-timepicker-container:last-child ol li{border-bottom:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-default{border-width:1px;border-color:transparent;padding:4px 6px;outline:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover:not(.sky-btn-active){background-color:transparent}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover{box-shadow:inset 0 0 0 1px #00b4f1;border-radius:6px}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:focus{outline:none;border-radius:6px;box-shadow:inset 0 0 0 2px #1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container:not(:focus-within){border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol{border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol button{background-color:transparent;color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol .sky-btn-active{background-color:#009cd1}\n"], components: [{ type: i4.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "skyLibResources": i6.SkyLibResourcesPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
322
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.14", ngImport: i0, type: SkyTimepickerComponent, decorators: [{
|
|
324
323
|
type: Component,
|
|
325
324
|
args: [{
|
|
326
325
|
selector: 'sky-timepicker',
|
|
327
326
|
templateUrl: './timepicker.component.html',
|
|
328
327
|
styleUrls: ['./timepicker.component.scss'],
|
|
329
328
|
encapsulation: ViewEncapsulation.None,
|
|
330
|
-
changeDetection: ChangeDetectionStrategy.OnPush
|
|
329
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
331
330
|
}]
|
|
332
331
|
}], ctorParameters: function () { return [{ type: i1.SkyAffixService }, { type: i0.ChangeDetectorRef }, { type: i1.SkyCoreAdapterService }, { type: i1.SkyOverlayService }, { type: i2.SkyInputBoxHostService, decorators: [{
|
|
333
332
|
type: Optional
|
|
@@ -338,29 +337,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImpo
|
|
|
338
337
|
}], timepickerRef: [{
|
|
339
338
|
type: ViewChild,
|
|
340
339
|
args: ['timepickerRef', {
|
|
341
|
-
read: ElementRef
|
|
340
|
+
read: ElementRef,
|
|
342
341
|
}]
|
|
343
342
|
}], timepickerTemplateRef: [{
|
|
344
343
|
type: ViewChild,
|
|
345
344
|
args: ['timepickerTemplateRef', {
|
|
346
|
-
read: TemplateRef
|
|
345
|
+
read: TemplateRef,
|
|
347
346
|
}]
|
|
348
347
|
}], triggerButtonRef: [{
|
|
349
348
|
type: ViewChild,
|
|
350
349
|
args: ['triggerButtonRef', {
|
|
351
|
-
read: ElementRef
|
|
350
|
+
read: ElementRef,
|
|
352
351
|
}]
|
|
353
352
|
}], inputTemplateRef: [{
|
|
354
353
|
type: ViewChild,
|
|
355
354
|
args: ['inputTemplateRef', {
|
|
356
355
|
read: TemplateRef,
|
|
357
|
-
static: true
|
|
356
|
+
static: true,
|
|
358
357
|
}]
|
|
359
358
|
}], triggerButtonTemplateRef: [{
|
|
360
359
|
type: ViewChild,
|
|
361
360
|
args: ['triggerButtonTemplateRef', {
|
|
362
361
|
read: TemplateRef,
|
|
363
|
-
static: true
|
|
362
|
+
static: true,
|
|
364
363
|
}]
|
|
365
364
|
}] } });
|
|
366
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../../projects/datetime/src/modules/timepicker/timepicker.component.ts","../../../../../projects/datetime/src/modules/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\n\nimport {\n  SkyAffixAutoFitContext,\n  SkyAffixer,\n  SkyAffixService,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService\n} from '@skyux/core';\n\nimport {\n  SkyInputBoxHostService\n} from '@skyux/forms';\n\nimport {\n  SkyThemeService\n} from '@skyux/theme';\n\nimport {\n  fromEvent,\n  Subject,\n  Subscription\n} from 'rxjs';\n\nimport {\n  takeUntil\n} from 'rxjs/operators';\n\nimport {\n  SkyTimepickerTimeOutput\n} from './timepicker.interface';\n\nimport moment from \"moment\"\n\nlet nextId = 0;\n\n/**\n * Creates a SKY UX-themed replacement for the HTML `input` element with `type=\"time\"`.\n * The value that users select is driven through the `ngModel` attribute\n * specified on the `input` element. You must wrap this component around an `input`\n * with the `skyTimepickerInput` directive.\n */\n@Component({\n  selector: 'sky-timepicker',\n  templateUrl: './timepicker.component.html',\n  styleUrls: ['./timepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class SkyTimepickerComponent implements OnInit, OnDestroy {\n\n  /**\n   * Fires when the value in the timepicker input changes.\n   */\n  @Output()\n  public selectedTimeChanged: EventEmitter<SkyTimepickerTimeOutput> =\n    new EventEmitter<SkyTimepickerTimeOutput>();\n\n  public set disabled(value: boolean) {\n    this._disabled = value;\n    this.changeDetector.markForCheck();\n  }\n\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n\n  public set selectedHour(setHour: number) {\n    let hour: number;\n    let hourOffset: number = 0;\n    if (this.selectedMeridies === 'AM' && setHour === 12) { hourOffset = -12; }\n    if (this.selectedMeridies === 'PM' && setHour !== 12) { hourOffset = 12; }\n    if (this.is8601) { hourOffset = 0; }\n    hour = moment({ 'hour': setHour }).add(hourOffset, 'hours').hour();\n\n    this.activeTime = moment({\n      'hour': hour,\n      'minute': moment(this.activeTime).get('minute') + 0\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedHour(): number {\n    if (!this.is8601) {\n      /* istanbul ignore next */\n      return parseInt(moment(this.activeTime).format('h'), 0) || 1;\n    }\n    /* istanbul ignore else */\n    if (this.is8601) {\n      return moment(this.activeTime).hour() + 0;\n    }\n  }\n\n  public set selectedMeridies(meridies: string) {\n    /* istanbul ignore else */\n    if (!this.is8601) {\n      if (meridies.trim() !== this.selectedMeridies) {\n        this.activeTime = moment(this.activeTime).add(12, 'hours').toDate();\n        this.selectedTimeChanged.emit(this.selectedTime);\n      }\n    }\n  }\n\n  public get selectedMeridies(): string {\n    if (this.activeTime) {\n      return moment(this.activeTime).format('A');\n    }\n    return '';\n  }\n\n  public set selectedMinute(minute: number) {\n    this.activeTime = moment({\n      'hour': moment(this.activeTime).get('hour') + 0,\n      'minute': minute\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedMinute(): number {\n    return moment(this.activeTime).minute() + 0;\n  }\n\n  public set selectedTime(newTime: SkyTimepickerTimeOutput) {\n    if (typeof newTime !== 'undefined') {\n      /* sanity check */\n      /* istanbul ignore else */\n      if (newTime.local !== 'Invalid date') {\n        this.activeTime = newTime.iso8601;\n        this.changeDetector.markForCheck();\n      }\n    }\n  }\n\n  public get selectedTime(): SkyTimepickerTimeOutput {\n    const time: SkyTimepickerTimeOutput = {\n      hour: moment(this.activeTime).hour(),\n      minute: moment(this.activeTime).minute(),\n      meridie: moment(this.activeTime).format('A'),\n      timezone: parseInt(moment(this.activeTime).format('Z'), 10),\n      iso8601: this.activeTime,\n      local: moment(this.activeTime).format(this.localeFormat),\n      customFormat: (typeof this.returnFormat !== 'undefined')\n        ? this.returnFormat : this.localeFormat\n    };\n\n    return time;\n  }\n\n  public activeTime: Date;\n\n  public hours: Array<number>;\n\n  public is8601: boolean = false;\n\n  public isOpen: boolean;\n\n  public isVisible: boolean;\n\n  public localeFormat: string;\n\n  public minutes: Array<number>;\n\n  public minuteMultiplier: number;\n\n  public returnFormat: string;\n\n  public timeFormat: string = 'hh';\n\n  public timepickerId: string;\n\n  public triggerButtonId: string;\n\n  @ViewChild('timepickerRef', {\n    read: ElementRef\n  })\n  private set timepickerRef(value: ElementRef) {\n    if (value) {\n      this._timepickerRef = value;\n\n      // Wait for the timepicker component to render before guaging dimensions.\n      setTimeout(() => {\n        this.destroyAffixer();\n        this.createAffixer();\n\n        setTimeout(() => {\n          this.coreAdapter.getFocusableChildrenAndApplyFocus(\n            this.timepickerRef,\n            '.sky-timepicker-content',\n            false\n          );\n\n          this.isVisible = true;\n          this.changeDetector.markForCheck();\n        });\n      });\n    }\n  }\n\n  private get timepickerRef(): ElementRef {\n    return this._timepickerRef;\n  }\n\n  @ViewChild('timepickerTemplateRef', {\n    read: TemplateRef\n  })\n  private timepickerTemplateRef: TemplateRef<any>;\n\n  @ViewChild('triggerButtonRef', {\n    read: ElementRef\n  })\n  private triggerButtonRef: ElementRef;\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true\n  })\n  private inputTemplateRef: TemplateRef<any>;\n\n  @ViewChild('triggerButtonTemplateRef', {\n    read: TemplateRef,\n    static: true\n  })\n  private triggerButtonTemplateRef: TemplateRef<any>;\n\n  private affixer: SkyAffixer;\n\n  private timepickerUnsubscribe: Subject<void>;\n\n  private ngUnsubscribe = new Subject();\n\n  private overlay: SkyOverlayInstance;\n\n  private overlayKeydownListner: Subscription;\n\n  private _disabled: boolean;\n\n  private _timepickerRef: ElementRef;\n\n  constructor(\n    private affixService: SkyAffixService,\n    private changeDetector: ChangeDetectorRef,\n    private coreAdapter: SkyCoreAdapterService,\n    private overlayService: SkyOverlayService,\n    @Optional() public inputBoxHostService?: SkyInputBoxHostService,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    const uniqueId = nextId++;\n    this.timepickerId = `sky-timepicker-${uniqueId}`;\n    this.triggerButtonId = `sky-timepicker-button-${uniqueId}`;\n\n    // Update icons when theme changes.\n    themeSvc?.settingsChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnInit(): void {\n    this.setFormat(this.timeFormat);\n    this.addKeydownListner();\n\n    if (this.inputBoxHostService) {\n      this.inputBoxHostService.populate(\n        {\n          inputTemplate: this.inputTemplateRef,\n          buttonsTemplate: this.triggerButtonTemplateRef\n        }\n      );\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.removePickerEventListeners();\n    this.destroyAffixer();\n    this.destroyOverlay();\n  }\n\n  public setFormat(format: string): void {\n    let h: number = 12;\n    let m: number = 12;\n    let minuteMultiplier: number = 5;\n    let localeFormat: string = 'h:mm A';\n    if (format === 'hh') {\n      h = 12;\n      m = 12;\n      minuteMultiplier = 5;\n      localeFormat = 'h:mm A';\n      this.is8601 = false;\n    }\n    if (format === 'HH') {\n      h = 24;\n      m = 4;\n      minuteMultiplier = 15;\n      localeFormat = 'HH:mm';\n      this.is8601 = true;\n    }\n    let data: {\n      'hours': Array<number>,\n      'minutes': Array<number>,\n      'localeFormat': string,\n      'minuteMultiplier': number\n    };\n\n    data = {\n      'hours': Array.apply(undefined, Array(h))\n        .map(function (x: number, i: number) {\n          if (format === 'hh') { return ++i; }\n          /* istanbul ignore else */\n          if (format === 'HH') { return i; }\n          /* istanbul ignore next */\n          /* sanity check */\n          return 0;\n        }),\n      'minutes': Array.apply(undefined, Array(m))\n        .map(function (x: number, i: number) {\n          return i * minuteMultiplier;\n        }),\n      'localeFormat': localeFormat,\n      'minuteMultiplier': minuteMultiplier\n    };\n\n    this.hours = data.hours;\n    this.minutes = data.minutes;\n    this.localeFormat = data.localeFormat;\n    this.minuteMultiplier = data.minuteMultiplier;\n  }\n\n  public onCloseButtonCick(): void {\n    this.closePicker();\n  }\n\n  public setTime(event: any): void {\n    /* istanbul ignore else */\n    if (typeof event !== 'undefined') {\n      /* istanbul ignore else */\n      if (event.type === 'click') {\n        event.stopPropagation();\n        if (event.target.name === 'hour') {\n          this.selectedHour = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'minute') {\n          this.selectedMinute = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'meridie') {\n          this.selectedMeridies = event.target.innerHTML;\n        }\n      }\n    }\n  }\n\n  public onTriggerButtonClick(): void {\n    this.openPicker();\n  }\n\n  private closePicker() {\n    this.destroyAffixer();\n    this.destroyOverlay();\n    this.removePickerEventListeners();\n    this.triggerButtonRef.nativeElement.focus();\n    this.isOpen = false;\n  }\n\n  private openPicker(): void {\n    this.isVisible = false;\n    this.changeDetector.markForCheck();\n\n    this.removePickerEventListeners();\n    this.timepickerUnsubscribe = new Subject<void>();\n    this.destroyOverlay();\n    this.createOverlay();\n\n    this.isOpen = true;\n    this.changeDetector.markForCheck();\n  }\n\n  private createAffixer(): void {\n    const affixer = this.affixService.createAffixer(this.timepickerRef);\n\n    // Hide timepicker when trigger button is scrolled off screen.\n    affixer.placementChange\n      .pipe(takeUntil(this.timepickerUnsubscribe))\n      .subscribe((change) => {\n        this.isVisible = (change.placement !== null);\n        this.changeDetector.markForCheck();\n      });\n\n    affixer.affixTo(this.triggerButtonRef.nativeElement, {\n      autoFitContext: SkyAffixAutoFitContext.Viewport,\n      enableAutoFit: true,\n      horizontalAlignment: 'right',\n      isSticky: true,\n      placement: 'below'\n    });\n\n    this.affixer = affixer;\n  }\n\n  private destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.affixer) {\n      this.affixer.destroy();\n      this.affixer = undefined;\n    }\n  }\n\n  private createOverlay(): void {\n    const overlay = this.overlayService.create({\n      enableClose: false,\n      enablePointerEvents: false\n    });\n\n    overlay.backdropClick\n      .pipe(takeUntil(this.timepickerUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.isOpen) {\n          this.closePicker();\n        }\n      });\n\n    this.addKeydownListner();\n\n    overlay.attachTemplate(this.timepickerTemplateRef);\n\n    this.overlay = overlay;\n  }\n\n  private destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.overlay) {\n      this.overlayService.close(this.overlay);\n      this.overlay = undefined;\n    }\n  }\n\n  private addKeydownListner(): void {\n    this.overlayKeydownListner = fromEvent(window.document, 'keydown')\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((event: KeyboardEvent) => {\n        const key = event.key?.toLowerCase();\n        /* istanbul ignore else */\n        if (key === 'escape' && this.isOpen) {\n          this.closePicker();\n        }\n      });\n  }\n\n  private removePickerEventListeners(): void {\n    /* istanbul ignore else */\n    if (this.timepickerUnsubscribe) {\n      this.timepickerUnsubscribe.next();\n      this.timepickerUnsubscribe.complete();\n      this.timepickerUnsubscribe = undefined;\n    }\n    /* istanbul ignore next */\n    this.overlayKeydownListner?.unsubscribe();\n  }\n}\n","<div\n  class=\"sky-timepicker\"\n>\n  <ng-container *ngIf=\"!inputBoxHostService\">\n    <div\n      class=\"sky-input-group\"\n    >\n      <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n  <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n  <div\n    class=\"sky-input-group-btn\"\n  >\n    <button\n      aria-haspopup=\"dialog\"\n      class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n      type=\"button\"\n      [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n      [attr.aria-expanded]=\"isOpen\"\n      [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon *skyThemeIf=\"'default'\"\n        icon=\"clock-o\"\n        size=\"lg\"\n      ></sky-icon>\n      <sky-icon *skyThemeIf=\"'modern'\"\n        icon=\"clock\"\n        size=\"lg\"\n        iconType=\"skyux\"\n      ></sky-icon>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n  <div\n    class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n    role=\"dialog\"\n    [attr.aria-labelledby]=\"triggerButtonId\"\n    [attr.id]=\"timepickerId\"\n    [class.sky-timepicker-hidden]=\"!isVisible\"\n    #timepickerRef\n  >\n    <div\n      class=\"sky-timepicker-content\"\n    >\n      <section\n        class=\"sky-timepicker-column\"\n        [ngClass]=\"{ 'sky-timepicker-24hour':is8601 }\"\n      >\n        <ol>\n          <li *ngFor=\"let hour of hours;\">\n            <button\n              name=\"hour\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active' : selectedHour === hour }\"\n              (click)=\"setTime($event)\"\n            >\n              {{hour}}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section\n        class=\"sky-timepicker-column\"\n      >\n        <ol>\n          <li *ngFor=\"let minute of minutes;\">\n            <button\n              name=\"minute\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n              (click)=\"setTime($event)\"\n            >\n              {{ '00' .substring(0, 2 - (minute) .toString() .length) + (minute) }}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section *ngIf=\"!is8601\"\n        class=\"sky-timepicker-column\"\n      >\n        <ol>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n              (click)=\"setTime($event)\"\n            >\n              AM\n            </button>\n          </li>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n              (click)=\"setTime($event)\"\n            >\n              PM\n            </button>\n          </li>\n        </ol>\n      </section>\n    </div>\n    <div\n      class=\"sky-timepicker-footer\"\n    >\n      <section\n        class=\"sky-timepicker-column\"\n      >\n        <button\n          class=\"sky-btn sky-btn-primary\"\n          type=\"button\"\n          (click)=\"onCloseButtonCick()\"\n        >\n          {{ 'skyux_timepicker_close' | skyLibResources }}\n        </button>\n      </section>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
365
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../../projects/datetime/src/modules/timepicker/timepicker.component.ts","../../../../../projects/datetime/src/modules/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport {\n  SkyAffixAutoFitContext,\n  SkyAffixer,\n  SkyAffixService,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n} from '@skyux/core';\n\nimport { SkyInputBoxHostService } from '@skyux/forms';\n\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { fromEvent, Subject, Subscription } from 'rxjs';\n\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyTimepickerTimeOutput } from './timepicker.interface';\n\nimport moment from 'moment';\n\nlet nextId = 0;\n\n/**\n * Creates a SKY UX-themed replacement for the HTML `input` element with `type=\"time\"`.\n * The value that users select is driven through the `ngModel` attribute\n * specified on the `input` element. You must wrap this component around an `input`\n * with the `skyTimepickerInput` directive.\n */\n@Component({\n  selector: 'sky-timepicker',\n  templateUrl: './timepicker.component.html',\n  styleUrls: ['./timepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyTimepickerComponent implements OnInit, OnDestroy {\n  /**\n   * Fires when the value in the timepicker input changes.\n   */\n  @Output()\n  public selectedTimeChanged: EventEmitter<SkyTimepickerTimeOutput> = new EventEmitter<SkyTimepickerTimeOutput>();\n\n  public set disabled(value: boolean) {\n    this._disabled = value;\n    this.changeDetector.markForCheck();\n  }\n\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n\n  public set selectedHour(setHour: number) {\n    let hour: number;\n    let hourOffset: number = 0;\n    if (this.selectedMeridies === 'AM' && setHour === 12) {\n      hourOffset = -12;\n    }\n    if (this.selectedMeridies === 'PM' && setHour !== 12) {\n      hourOffset = 12;\n    }\n    if (this.is8601) {\n      hourOffset = 0;\n    }\n    hour = moment({ hour: setHour }).add(hourOffset, 'hours').hour();\n\n    this.activeTime = moment({\n      hour: hour,\n      minute: moment(this.activeTime).get('minute') + 0,\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedHour(): number {\n    if (!this.is8601) {\n      /* istanbul ignore next */\n      return parseInt(moment(this.activeTime).format('h'), 0) || 1;\n    }\n    /* istanbul ignore else */\n    if (this.is8601) {\n      return moment(this.activeTime).hour() + 0;\n    }\n  }\n\n  public set selectedMeridies(meridies: string) {\n    /* istanbul ignore else */\n    if (!this.is8601) {\n      if (meridies.trim() !== this.selectedMeridies) {\n        this.activeTime = moment(this.activeTime).add(12, 'hours').toDate();\n        this.selectedTimeChanged.emit(this.selectedTime);\n      }\n    }\n  }\n\n  public get selectedMeridies(): string {\n    if (this.activeTime) {\n      return moment(this.activeTime).format('A');\n    }\n    return '';\n  }\n\n  public set selectedMinute(minute: number) {\n    this.activeTime = moment({\n      hour: moment(this.activeTime).get('hour') + 0,\n      minute: minute,\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedMinute(): number {\n    return moment(this.activeTime).minute() + 0;\n  }\n\n  public set selectedTime(newTime: SkyTimepickerTimeOutput) {\n    if (typeof newTime !== 'undefined') {\n      /* sanity check */\n      /* istanbul ignore else */\n      if (newTime.local !== 'Invalid date') {\n        this.activeTime = newTime.iso8601;\n        this.changeDetector.markForCheck();\n      }\n    }\n  }\n\n  public get selectedTime(): SkyTimepickerTimeOutput {\n    const time: SkyTimepickerTimeOutput = {\n      hour: moment(this.activeTime).hour(),\n      minute: moment(this.activeTime).minute(),\n      meridie: moment(this.activeTime).format('A'),\n      timezone: parseInt(moment(this.activeTime).format('Z'), 10),\n      iso8601: this.activeTime,\n      local: moment(this.activeTime).format(this.localeFormat),\n      customFormat:\n        typeof this.returnFormat !== 'undefined'\n          ? this.returnFormat\n          : this.localeFormat,\n    };\n\n    return time;\n  }\n\n  public activeTime: Date;\n\n  public hours: Array<number>;\n\n  public is8601: boolean = false;\n\n  public isOpen: boolean;\n\n  public isVisible: boolean;\n\n  public localeFormat: string;\n\n  public minutes: Array<number>;\n\n  public minuteMultiplier: number;\n\n  public returnFormat: string;\n\n  public timeFormat: string = 'hh';\n\n  public timepickerId: string;\n\n  public triggerButtonId: string;\n\n  @ViewChild('timepickerRef', {\n    read: ElementRef,\n  })\n  private set timepickerRef(value: ElementRef) {\n    if (value) {\n      this._timepickerRef = value;\n\n      // Wait for the timepicker component to render before guaging dimensions.\n      setTimeout(() => {\n        this.destroyAffixer();\n        this.createAffixer();\n\n        setTimeout(() => {\n          this.coreAdapter.getFocusableChildrenAndApplyFocus(\n            this.timepickerRef,\n            '.sky-timepicker-content',\n            false\n          );\n\n          this.isVisible = true;\n          this.changeDetector.markForCheck();\n        });\n      });\n    }\n  }\n\n  private get timepickerRef(): ElementRef {\n    return this._timepickerRef;\n  }\n\n  @ViewChild('timepickerTemplateRef', {\n    read: TemplateRef,\n  })\n  private timepickerTemplateRef: TemplateRef<any>;\n\n  @ViewChild('triggerButtonRef', {\n    read: ElementRef,\n  })\n  private triggerButtonRef: ElementRef;\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  private inputTemplateRef: TemplateRef<any>;\n\n  @ViewChild('triggerButtonTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  private triggerButtonTemplateRef: TemplateRef<any>;\n\n  private affixer: SkyAffixer;\n\n  private timepickerUnsubscribe: Subject<void>;\n\n  private ngUnsubscribe = new Subject();\n\n  private overlay: SkyOverlayInstance;\n\n  private overlayKeydownListner: Subscription;\n\n  private _disabled: boolean;\n\n  private _timepickerRef: ElementRef;\n\n  constructor(\n    private affixService: SkyAffixService,\n    private changeDetector: ChangeDetectorRef,\n    private coreAdapter: SkyCoreAdapterService,\n    private overlayService: SkyOverlayService,\n    @Optional() public inputBoxHostService?: SkyInputBoxHostService,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    const uniqueId = nextId++;\n    this.timepickerId = `sky-timepicker-${uniqueId}`;\n    this.triggerButtonId = `sky-timepicker-button-${uniqueId}`;\n\n    // Update icons when theme changes.\n    themeSvc?.settingsChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnInit(): void {\n    this.setFormat(this.timeFormat);\n    this.addKeydownListner();\n\n    if (this.inputBoxHostService) {\n      this.inputBoxHostService.populate({\n        inputTemplate: this.inputTemplateRef,\n        buttonsTemplate: this.triggerButtonTemplateRef,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.removePickerEventListeners();\n    this.destroyAffixer();\n    this.destroyOverlay();\n  }\n\n  public setFormat(format: string): void {\n    let h: number = 12;\n    let m: number = 12;\n    let minuteMultiplier: number = 5;\n    let localeFormat: string = 'h:mm A';\n    if (format === 'hh') {\n      h = 12;\n      m = 12;\n      minuteMultiplier = 5;\n      localeFormat = 'h:mm A';\n      this.is8601 = false;\n    }\n    if (format === 'HH') {\n      h = 24;\n      m = 4;\n      minuteMultiplier = 15;\n      localeFormat = 'HH:mm';\n      this.is8601 = true;\n    }\n    let data: {\n      hours: Array<number>;\n      minutes: Array<number>;\n      localeFormat: string;\n      minuteMultiplier: number;\n    };\n\n    data = {\n      hours: Array.apply(undefined, Array(h)).map(function (\n        x: number,\n        i: number\n      ) {\n        if (format === 'hh') {\n          return ++i;\n        }\n        /* istanbul ignore else */\n        if (format === 'HH') {\n          return i;\n        }\n        /* istanbul ignore next */\n        /* sanity check */\n        return 0;\n      }),\n      minutes: Array.apply(undefined, Array(m)).map(function (\n        x: number,\n        i: number\n      ) {\n        return i * minuteMultiplier;\n      }),\n      localeFormat: localeFormat,\n      minuteMultiplier: minuteMultiplier,\n    };\n\n    this.hours = data.hours;\n    this.minutes = data.minutes;\n    this.localeFormat = data.localeFormat;\n    this.minuteMultiplier = data.minuteMultiplier;\n  }\n\n  public onCloseButtonCick(): void {\n    this.closePicker();\n  }\n\n  public setTime(event: any): void {\n    /* istanbul ignore else */\n    if (typeof event !== 'undefined') {\n      /* istanbul ignore else */\n      if (event.type === 'click') {\n        event.stopPropagation();\n        if (event.target.name === 'hour') {\n          this.selectedHour = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'minute') {\n          this.selectedMinute = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'meridie') {\n          this.selectedMeridies = event.target.innerHTML;\n        }\n      }\n    }\n  }\n\n  public onTriggerButtonClick(): void {\n    this.openPicker();\n  }\n\n  private closePicker() {\n    this.destroyAffixer();\n    this.destroyOverlay();\n    this.removePickerEventListeners();\n    this.triggerButtonRef.nativeElement.focus();\n    this.isOpen = false;\n  }\n\n  private openPicker(): void {\n    this.isVisible = false;\n    this.changeDetector.markForCheck();\n\n    this.removePickerEventListeners();\n    this.timepickerUnsubscribe = new Subject<void>();\n    this.destroyOverlay();\n    this.createOverlay();\n\n    this.isOpen = true;\n    this.changeDetector.markForCheck();\n  }\n\n  private createAffixer(): void {\n    const affixer = this.affixService.createAffixer(this.timepickerRef);\n\n    // Hide timepicker when trigger button is scrolled off screen.\n    affixer.placementChange\n      .pipe(takeUntil(this.timepickerUnsubscribe))\n      .subscribe((change) => {\n        this.isVisible = change.placement !== null;\n        this.changeDetector.markForCheck();\n      });\n\n    affixer.affixTo(this.triggerButtonRef.nativeElement, {\n      autoFitContext: SkyAffixAutoFitContext.Viewport,\n      enableAutoFit: true,\n      horizontalAlignment: 'right',\n      isSticky: true,\n      placement: 'below',\n    });\n\n    this.affixer = affixer;\n  }\n\n  private destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.affixer) {\n      this.affixer.destroy();\n      this.affixer = undefined;\n    }\n  }\n\n  private createOverlay(): void {\n    const overlay = this.overlayService.create({\n      enableClose: false,\n      enablePointerEvents: false,\n    });\n\n    overlay.backdropClick\n      .pipe(takeUntil(this.timepickerUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.isOpen) {\n          this.closePicker();\n        }\n      });\n\n    this.addKeydownListner();\n\n    overlay.attachTemplate(this.timepickerTemplateRef);\n\n    this.overlay = overlay;\n  }\n\n  private destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.overlay) {\n      this.overlayService.close(this.overlay);\n      this.overlay = undefined;\n    }\n  }\n\n  private addKeydownListner(): void {\n    this.overlayKeydownListner = fromEvent(window.document, 'keydown')\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((event: KeyboardEvent) => {\n        const key = event.key?.toLowerCase();\n        /* istanbul ignore else */\n        if (key === 'escape' && this.isOpen) {\n          this.closePicker();\n        }\n      });\n  }\n\n  private removePickerEventListeners(): void {\n    /* istanbul ignore else */\n    if (this.timepickerUnsubscribe) {\n      this.timepickerUnsubscribe.next();\n      this.timepickerUnsubscribe.complete();\n      this.timepickerUnsubscribe = undefined;\n    }\n    /* istanbul ignore next */\n    this.overlayKeydownListner?.unsubscribe();\n  }\n}\n","<div class=\"sky-timepicker\">\n  <ng-container *ngIf=\"!inputBoxHostService\">\n    <div class=\"sky-input-group\">\n      <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n  <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n  <div class=\"sky-input-group-btn\">\n    <button\n      aria-haspopup=\"dialog\"\n      class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n      type=\"button\"\n      [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n      [attr.aria-expanded]=\"isOpen\"\n      [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon *skyThemeIf=\"'default'\" icon=\"clock-o\" size=\"lg\"></sky-icon>\n      <sky-icon\n        *skyThemeIf=\"'modern'\"\n        icon=\"clock\"\n        size=\"lg\"\n        iconType=\"skyux\"\n      ></sky-icon>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n  <div\n    class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n    role=\"dialog\"\n    [attr.aria-labelledby]=\"triggerButtonId\"\n    [attr.id]=\"timepickerId\"\n    [class.sky-timepicker-hidden]=\"!isVisible\"\n    #timepickerRef\n  >\n    <div class=\"sky-timepicker-content\">\n      <section\n        class=\"sky-timepicker-column\"\n        [ngClass]=\"{ 'sky-timepicker-24hour': is8601 }\"\n      >\n        <ol>\n          <li *ngFor=\"let hour of hours\">\n            <button\n              name=\"hour\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedHour === hour }\"\n              (click)=\"setTime($event)\"\n            >\n              {{ hour }}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section class=\"sky-timepicker-column\">\n        <ol>\n          <li *ngFor=\"let minute of minutes\">\n            <button\n              name=\"minute\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n              (click)=\"setTime($event)\"\n            >\n              {{ '00'.substring(0, 2 - minute.toString().length) + minute }}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section *ngIf=\"!is8601\" class=\"sky-timepicker-column\">\n        <ol>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n              (click)=\"setTime($event)\"\n            >\n              AM\n            </button>\n          </li>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n              (click)=\"setTime($event)\"\n            >\n              PM\n            </button>\n          </li>\n        </ol>\n      </section>\n    </div>\n    <div class=\"sky-timepicker-footer\">\n      <section class=\"sky-timepicker-column\">\n        <button\n          class=\"sky-btn sky-btn-primary\"\n          type=\"button\"\n          (click)=\"onCloseButtonCick()\"\n        >\n          {{ 'skyux_timepicker_close' | skyLibResources }}\n        </button>\n      </section>\n    </div>\n  </div>\n</ng-template>\n"]}
|