@dhutaryan/ngx-mat-timepicker 14.0.0 → 16.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -0
- package/_timepicker-theme.scss +9 -11
- package/{esm2020 → esm2022}/lib/adapter/index.mjs +8 -8
- package/{esm2020 → esm2022}/lib/adapter/native-date-time-adapter.mjs +4 -4
- package/esm2022/lib/clock-dials.mjs +82 -0
- package/esm2022/lib/hours-clock-dial.mjs +183 -0
- package/esm2022/lib/minutes-clock-dial.mjs +155 -0
- package/esm2022/lib/time-face-base.mjs +317 -0
- package/esm2022/lib/time-input-base.mjs +73 -0
- package/esm2022/lib/time-inputs.mjs +170 -0
- package/{esm2020 → esm2022}/lib/time-period.mjs +5 -5
- package/{esm2020 → esm2022}/lib/time-selection-model.mjs +14 -14
- package/esm2022/lib/timepicker-actions.mjs +130 -0
- package/esm2022/lib/timepicker-base.mjs +393 -0
- package/{esm2020 → esm2022}/lib/timepicker-content-layout.mjs +5 -5
- package/{esm2020 → esm2022}/lib/timepicker-content.mjs +8 -8
- package/esm2022/lib/timepicker-input-base.mjs +223 -0
- package/esm2022/lib/timepicker-input.mjs +135 -0
- package/{esm2020 → esm2022}/lib/timepicker-intl.mjs +4 -4
- package/esm2022/lib/timepicker-toggle.mjs +68 -0
- package/{esm2020 → esm2022}/lib/timepicker.mjs +7 -7
- package/esm2022/lib/timepicker.module.mjs +157 -0
- package/{fesm2020 → fesm2022}/dhutaryan-ngx-mat-timepicker.mjs +311 -300
- package/fesm2022/dhutaryan-ngx-mat-timepicker.mjs.map +1 -0
- package/lib/clock-dials.d.ts +2 -2
- package/lib/hours-clock-dial.d.ts +1 -1
- package/lib/minutes-clock-dial.d.ts +1 -1
- package/lib/orientation.d.ts +1 -1
- package/lib/time-face-base.d.ts +1 -1
- package/lib/time-input-base.d.ts +1 -1
- package/lib/time-inputs.d.ts +3 -3
- package/lib/time-period.d.ts +2 -2
- package/lib/time-selection-model.d.ts +1 -1
- package/lib/timepicker-actions.d.ts +4 -4
- package/lib/timepicker-base.d.ts +6 -6
- package/lib/timepicker-content-layout.d.ts +1 -1
- package/lib/timepicker-content.d.ts +1 -1
- package/lib/timepicker-input-base.d.ts +1 -1
- package/lib/timepicker-input.d.ts +1 -1
- package/lib/timepicker-toggle.d.ts +2 -2
- package/lib/timepicker.d.ts +1 -1
- package/package.json +8 -14
- package/esm2020/lib/clock-dials.mjs +0 -82
- package/esm2020/lib/hours-clock-dial.mjs +0 -183
- package/esm2020/lib/minutes-clock-dial.mjs +0 -155
- package/esm2020/lib/time-face-base.mjs +0 -317
- package/esm2020/lib/time-input-base.mjs +0 -70
- package/esm2020/lib/time-inputs.mjs +0 -170
- package/esm2020/lib/timepicker-actions.mjs +0 -130
- package/esm2020/lib/timepicker-base.mjs +0 -393
- package/esm2020/lib/timepicker-input-base.mjs +0 -223
- package/esm2020/lib/timepicker-input.mjs +0 -135
- package/esm2020/lib/timepicker-toggle.mjs +0 -68
- package/esm2020/lib/timepicker.module.mjs +0 -149
- package/fesm2015/dhutaryan-ngx-mat-timepicker.mjs +0 -2594
- package/fesm2015/dhutaryan-ngx-mat-timepicker.mjs.map +0 -1
- package/fesm2020/dhutaryan-ngx-mat-timepicker.mjs.map +0 -1
- /package/{esm2020 → esm2022}/dhutaryan-ngx-mat-timepicker.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/adapter/time-adapter.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/clock-dial-adnimation.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/orientation.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/timepicker-actions-default.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/timepicker-animations.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/timepicker-scroll-strategy.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
package/README.md
CHANGED
|
@@ -14,6 +14,8 @@ The timepicker module using Angular material.
|
|
|
14
14
|
| 12.x.x | >=12.0.0 && <15.0.0 |
|
|
15
15
|
| 13.x.x | >=13.0.0 && <15.0.0 |
|
|
16
16
|
| 14.x.x | ^14.0.0 |
|
|
17
|
+
| 15.x.x | ^15.0.0 |
|
|
18
|
+
| 16.x.x | ^16.0.0 |
|
|
17
19
|
|
|
18
20
|
## Documentation
|
|
19
21
|
|
|
@@ -93,6 +95,15 @@ Then you have to define a theme. [More details about theming](https://material.a
|
|
|
93
95
|
```scss
|
|
94
96
|
@use "@dhutaryan/ngx-mat-timepicker" as mat-timepicker;
|
|
95
97
|
|
|
98
|
+
// timepicker uses these component
|
|
99
|
+
@include mat.form-field-theme(theme.$ngx-mat-timepicker-theme);
|
|
100
|
+
@include mat.input-theme(theme.$ngx-mat-timepicker-theme);
|
|
101
|
+
@include mat.button-theme(theme.$ngx-mat-timepicker-theme);
|
|
102
|
+
@include mat.fab-theme(theme.$ngx-mat-timepicker-theme);
|
|
103
|
+
@include mat.icon-button-theme(theme.$ngx-mat-timepicker-theme);
|
|
104
|
+
@include mat.divider-theme(theme.$ngx-mat-timepicker-theme);
|
|
105
|
+
|
|
106
|
+
// timepicker theme
|
|
96
107
|
@include mat-timepicker.timepicker-theme($theme);
|
|
97
108
|
```
|
|
98
109
|
|
package/_timepicker-theme.scss
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
@use "sass:map";
|
|
3
3
|
@use "@angular/material" as mat;
|
|
4
4
|
|
|
5
|
-
$timepicker-content-title-font-size:
|
|
5
|
+
$timepicker-content-title-font-size: 12px !default;
|
|
6
6
|
$input-font-size: 2rem !default;
|
|
7
7
|
$inputs-separator-font-size: 3rem !default;
|
|
8
8
|
$inputs-separator-line-height: 1.25rem;
|
|
@@ -36,13 +36,6 @@ $primary-opacity: 0.15;
|
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
38
|
|
|
39
|
-
[mat-mini-fab].mat-clock-dial-cell.mat-button-disabled.mat-clock-dial-cell-active {
|
|
40
|
-
background-color: color.adjust(
|
|
41
|
-
mat.get-color-from-palette($palette),
|
|
42
|
-
$alpha: -0.6
|
|
43
|
-
);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
39
|
[mat-mini-fab].mat-clock-dial-cell.mat-clock-dial-cell-disabled.mat-clock-dial-cell-active {
|
|
47
40
|
background-color: color.adjust(
|
|
48
41
|
mat.get-color-from-palette($palette),
|
|
@@ -91,7 +84,8 @@ $primary-opacity: 0.15;
|
|
|
91
84
|
}
|
|
92
85
|
|
|
93
86
|
.mat-clock-dial-value,
|
|
94
|
-
.mat-clock-dial
|
|
87
|
+
.mat-clock-dial,
|
|
88
|
+
.mat-mdc-text-field-wrapper {
|
|
95
89
|
background-color: mat.get-color-from-palette($background, background);
|
|
96
90
|
}
|
|
97
91
|
|
|
@@ -113,6 +107,10 @@ $primary-opacity: 0.15;
|
|
|
113
107
|
|
|
114
108
|
[mat-mini-fab].mat-clock-dial-cell.mat-clock-dial-cell-disabled {
|
|
115
109
|
color: mat.get-color-from-palette($foreground, disabled-button);
|
|
110
|
+
|
|
111
|
+
.mat-mdc-button-persistent-ripple::before {
|
|
112
|
+
background-color: transparent;
|
|
113
|
+
}
|
|
116
114
|
}
|
|
117
115
|
}
|
|
118
116
|
|
|
@@ -122,12 +120,12 @@ $primary-opacity: 0.15;
|
|
|
122
120
|
h6.mat-timepicker-content-layout-title {
|
|
123
121
|
font: {
|
|
124
122
|
size: $timepicker-content-title-font-size;
|
|
125
|
-
weight: mat.font-weight($config,
|
|
123
|
+
weight: mat.font-weight($config, subtitle-2);
|
|
126
124
|
}
|
|
127
125
|
}
|
|
128
126
|
|
|
129
127
|
.mat-time-inputs-field {
|
|
130
|
-
input.mat-input-element {
|
|
128
|
+
input.mat-mdc-input-element {
|
|
131
129
|
font-size: $input-font-size;
|
|
132
130
|
line-height: normal;
|
|
133
131
|
}
|
|
@@ -6,14 +6,14 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
export * from './time-adapter';
|
|
7
7
|
export * from './native-date-time-adapter';
|
|
8
8
|
export class MatNativeDateTimeModule {
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatNativeDateTimeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.5", ngImport: i0, type: MatNativeDateTimeModule, imports: [PlatformModule] }); }
|
|
11
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatNativeDateTimeModule, providers: [
|
|
12
|
+
{ provide: TimeAdapter, useClass: NativeDateTimeAdapter },
|
|
13
|
+
MAT_TIME_LOCALE_PROVIDER,
|
|
14
|
+
], imports: [PlatformModule] }); }
|
|
9
15
|
}
|
|
10
|
-
|
|
11
|
-
MatNativeDateTimeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: MatNativeDateTimeModule, imports: [PlatformModule] });
|
|
12
|
-
MatNativeDateTimeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MatNativeDateTimeModule, providers: [
|
|
13
|
-
{ provide: TimeAdapter, useClass: NativeDateTimeAdapter },
|
|
14
|
-
MAT_TIME_LOCALE_PROVIDER,
|
|
15
|
-
], imports: [PlatformModule] });
|
|
16
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MatNativeDateTimeModule, decorators: [{
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatNativeDateTimeModule, decorators: [{
|
|
17
17
|
type: NgModule,
|
|
18
18
|
args: [{
|
|
19
19
|
imports: [PlatformModule],
|
|
@@ -23,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
23
23
|
],
|
|
24
24
|
}]
|
|
25
25
|
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXQtdGltZXBpY2tlci9zcmMvbGliL2FkYXB0ZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekMsT0FBTyxFQUFFLHdCQUF3QixFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQUVuRSxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsNEJBQTRCLENBQUM7QUFTM0MsTUFBTSxPQUFPLHVCQUF1Qjs4R0FBdkIsdUJBQXVCOytHQUF2Qix1QkFBdUIsWUFOeEIsY0FBYzsrR0FNYix1QkFBdUIsYUFMdkI7WUFDVCxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLHFCQUFxQixFQUFFO1lBQ3pELHdCQUF3QjtTQUN6QixZQUpTLGNBQWM7OzJGQU1iLHVCQUF1QjtrQkFQbkMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxjQUFjLENBQUM7b0JBQ3pCLFNBQVMsRUFBRTt3QkFDVCxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLHFCQUFxQixFQUFFO3dCQUN6RCx3QkFBd0I7cUJBQ3pCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhdGZvcm1Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcGxhdGZvcm0nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgTUFUX1RJTUVfTE9DQUxFX1BST1ZJREVSLCBUaW1lQWRhcHRlciB9IGZyb20gJy4vdGltZS1hZGFwdGVyJztcbmltcG9ydCB7IE5hdGl2ZURhdGVUaW1lQWRhcHRlciB9IGZyb20gJy4vbmF0aXZlLWRhdGUtdGltZS1hZGFwdGVyJztcblxuZXhwb3J0ICogZnJvbSAnLi90aW1lLWFkYXB0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9uYXRpdmUtZGF0ZS10aW1lLWFkYXB0ZXInO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbUGxhdGZvcm1Nb2R1bGVdLFxuICBwcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IFRpbWVBZGFwdGVyLCB1c2VDbGFzczogTmF0aXZlRGF0ZVRpbWVBZGFwdGVyIH0sXG4gICAgTUFUX1RJTUVfTE9DQUxFX1BST1ZJREVSLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXROYXRpdmVEYXRlVGltZU1vZHVsZSB7fVxuIl19
|
|
@@ -116,10 +116,10 @@ export class NativeDateTimeAdapter extends TimeAdapter {
|
|
|
116
116
|
d.setUTCHours(date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds());
|
|
117
117
|
return dtf.format(d);
|
|
118
118
|
}
|
|
119
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: NativeDateTimeAdapter, deps: [{ token: MAT_TIME_LOCALE, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
120
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: NativeDateTimeAdapter }); }
|
|
119
121
|
}
|
|
120
|
-
|
|
121
|
-
NativeDateTimeAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NativeDateTimeAdapter });
|
|
122
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NativeDateTimeAdapter, decorators: [{
|
|
122
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: NativeDateTimeAdapter, decorators: [{
|
|
123
123
|
type: Injectable
|
|
124
124
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
125
125
|
type: Optional
|
|
@@ -127,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
127
127
|
type: Inject,
|
|
128
128
|
args: [MAT_TIME_LOCALE]
|
|
129
129
|
}] }]; } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"native-date-time-adapter.js","sourceRoot":"","sources":["../../../../../projects/mat-timepicker/src/lib/adapter/native-date-time-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional } from '@angular/core';\n\nimport { MAT_TIME_LOCALE, TimeAdapter } from './time-adapter';\nimport { MatTimePeriodType } from '../time-period';\n\n/**\n * Matches strings that have the form of a valid RFC 3339 string\n * (https://tools.ietf.org/html/rfc3339). Note that the string may not actually be a valid date\n * because the regex will match strings an with out of bounds month, date, etc.\n */\nconst ISO_8601_REGEX =\n  /^\\d{4}-\\d{2}-\\d{2}(?:T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(?:Z|(?:(?:\\+|-)\\d{2}:\\d{2}))?)?$/;\n\n/** Adapts the native JS Date for components that work with time. */\n@Injectable()\nexport class NativeDateTimeAdapter extends TimeAdapter<Date> {\n  constructor(@Optional() @Inject(MAT_TIME_LOCALE) matTimeLocale: string) {\n    super();\n    super.setLocale(matTimeLocale);\n  }\n\n  now(): Date {\n    return new Date();\n  }\n\n  parse(value: any, parseFormat?: any): Date | null {\n    // We have no way using the native JS Date to set the parse format or locale, so we ignore these\n    // parameters.\n    if (typeof value == 'number') {\n      return new Date(value);\n    }\n\n    const { hour, minute } = this.parseTime(value);\n    const date = new Date();\n    date.setHours(Number(hour));\n    date.setMinutes(Number(minute));\n\n    return value ? new Date(date) : null;\n  }\n\n  parseTime(value: string) {\n    const [hour, minute] = value\n      .replace(/(\\sam|\\spm|\\sAM|\\sPM|am|pm|AM|PM)/g, '')\n      .split(':');\n\n    return { hour, minute };\n  }\n\n  getHour(date: Date): number {\n    return date.getHours();\n  }\n\n  getMinute(date: Date): number {\n    return date.getMinutes();\n  }\n\n  updateHour(date: Date, hour: number): Date {\n    const copy = new Date(date.getTime());\n    copy.setHours(hour);\n\n    return copy;\n  }\n\n  updateMinute(date: Date, minute: number): Date {\n    const copy = new Date(date.getTime());\n    copy.setMinutes(minute);\n\n    return copy;\n  }\n\n  getPeriod(date: Date): MatTimePeriodType {\n    return date.getHours() < 12 ? 'am' : 'pm';\n  }\n\n  format(date: Date, displayFormat: Object): string {\n    if (!this.isValid(date)) {\n      throw Error('NativeDateTimeAdapter: Cannot format invalid date.');\n    }\n\n    const dtf = new Intl.DateTimeFormat(this.locale, {\n      ...displayFormat,\n      timeZone: 'utc',\n    });\n\n    return this._format(dtf, date);\n  }\n\n  /**\n   * Returns the given value if given a valid Date or null. Deserializes valid ISO 8601 strings\n   * (https://www.ietf.org/rfc/rfc3339.txt) into valid Dates and empty string into null. Returns an\n   * invalid date for all other values.\n   */\n  override deserialize(value: any): Date | null {\n    if (typeof value === 'string') {\n      if (!value) {\n        return null;\n      }\n      // The `Date` constructor accepts formats other than ISO 8601, so we need to make sure the\n      // string is the right format first.\n      if (ISO_8601_REGEX.test(value)) {\n        const date = new Date(value);\n        if (this.isValid(date)) {\n          return date;\n        }\n      }\n    }\n    return super.deserialize(value);\n  }\n\n  isTimeInstance(obj: any): boolean {\n    return obj instanceof Date;\n  }\n\n  isValid(date: Date): boolean {\n    return !isNaN(date.getTime());\n  }\n\n  invalid(): Date {\n    return new Date(NaN);\n  }\n\n  compareTime(first: Date, second: Date): number {\n    return (\n      first.getHours() - second.getHours() ||\n      first.getMinutes() - second.getMinutes()\n    );\n  }\n\n  /**\n   * When converting Date object to string, javascript built-in functions may return wrong\n   * results because it applies its internal DST rules. The DST rules around the world change\n   * very frequently, and the current valid rule is not always valid in previous years though.\n   * We work around this problem building a new Date object which has its internal UTC\n   * representation with the local date and time.\n   * @param dtf Intl.DateTimeFormat object, containing the desired string format. It must have\n   *    timeZone set to 'utc' to work fine.\n   * @param date Date from which we want to get the string representation according to dtf\n   * @returns A Date object with its UTC representation based on the passed in date info\n   */\n  private _format(dtf: Intl.DateTimeFormat, date: Date) {\n    // Passing the year to the constructor causes year numbers <100 to be converted to 19xx.\n    // To work around this we use `setUTCFullYear` and `setUTCHours` instead.\n    const d = new Date();\n    d.setUTCFullYear(date.getFullYear(), date.getMonth(), date.getDate());\n    d.setUTCHours(\n      date.getHours(),\n      date.getMinutes(),\n      date.getSeconds(),\n      date.getMilliseconds()\n    );\n    return dtf.format(d);\n  }\n}\n"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"native-date-time-adapter.js","sourceRoot":"","sources":["../../../../../projects/mat-timepicker/src/lib/adapter/native-date-time-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional } from '@angular/core';\n\nimport { MAT_TIME_LOCALE, TimeAdapter } from './time-adapter';\nimport { MatTimePeriodType } from '../time-period';\n\n/**\n * Matches strings that have the form of a valid RFC 3339 string\n * (https://tools.ietf.org/html/rfc3339). Note that the string may not actually be a valid date\n * because the regex will match strings an with out of bounds month, date, etc.\n */\nconst ISO_8601_REGEX =\n  /^\\d{4}-\\d{2}-\\d{2}(?:T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(?:Z|(?:(?:\\+|-)\\d{2}:\\d{2}))?)?$/;\n\n/** Adapts the native JS Date for components that work with time. */\n@Injectable()\nexport class NativeDateTimeAdapter extends TimeAdapter<Date> {\n  constructor(@Optional() @Inject(MAT_TIME_LOCALE) matTimeLocale: string) {\n    super();\n    super.setLocale(matTimeLocale);\n  }\n\n  now(): Date {\n    return new Date();\n  }\n\n  parse(value: any, parseFormat?: any): Date | null {\n    // We have no way using the native JS Date to set the parse format or locale, so we ignore these\n    // parameters.\n    if (typeof value == 'number') {\n      return new Date(value);\n    }\n\n    const { hour, minute } = this.parseTime(value);\n    const date = new Date();\n    date.setHours(Number(hour));\n    date.setMinutes(Number(minute));\n\n    return value ? new Date(date) : null;\n  }\n\n  parseTime(value: string) {\n    const [hour, minute] = value\n      .replace(/(\\sam|\\spm|\\sAM|\\sPM|am|pm|AM|PM)/g, '')\n      .split(':');\n\n    return { hour, minute };\n  }\n\n  getHour(date: Date): number {\n    return date.getHours();\n  }\n\n  getMinute(date: Date): number {\n    return date.getMinutes();\n  }\n\n  updateHour(date: Date, hour: number): Date {\n    const copy = new Date(date.getTime());\n    copy.setHours(hour);\n\n    return copy;\n  }\n\n  updateMinute(date: Date, minute: number): Date {\n    const copy = new Date(date.getTime());\n    copy.setMinutes(minute);\n\n    return copy;\n  }\n\n  getPeriod(date: Date): MatTimePeriodType {\n    return date.getHours() < 12 ? 'am' : 'pm';\n  }\n\n  format(date: Date, displayFormat: Object): string {\n    if (!this.isValid(date)) {\n      throw Error('NativeDateTimeAdapter: Cannot format invalid date.');\n    }\n\n    const dtf = new Intl.DateTimeFormat(this.locale, {\n      ...displayFormat,\n      timeZone: 'utc',\n    });\n\n    return this._format(dtf, date);\n  }\n\n  /**\n   * Returns the given value if given a valid Date or null. Deserializes valid ISO 8601 strings\n   * (https://www.ietf.org/rfc/rfc3339.txt) into valid Dates and empty string into null. Returns an\n   * invalid date for all other values.\n   */\n  override deserialize(value: any): Date | null {\n    if (typeof value === 'string') {\n      if (!value) {\n        return null;\n      }\n      // The `Date` constructor accepts formats other than ISO 8601, so we need to make sure the\n      // string is the right format first.\n      if (ISO_8601_REGEX.test(value)) {\n        const date = new Date(value);\n        if (this.isValid(date)) {\n          return date;\n        }\n      }\n    }\n    return super.deserialize(value);\n  }\n\n  isTimeInstance(obj: any): boolean {\n    return obj instanceof Date;\n  }\n\n  isValid(date: Date): boolean {\n    return !isNaN(date.getTime());\n  }\n\n  invalid(): Date {\n    return new Date(NaN);\n  }\n\n  compareTime(first: Date, second: Date): number {\n    return (\n      first.getHours() - second.getHours() ||\n      first.getMinutes() - second.getMinutes()\n    );\n  }\n\n  /**\n   * When converting Date object to string, javascript built-in functions may return wrong\n   * results because it applies its internal DST rules. The DST rules around the world change\n   * very frequently, and the current valid rule is not always valid in previous years though.\n   * We work around this problem building a new Date object which has its internal UTC\n   * representation with the local date and time.\n   * @param dtf Intl.DateTimeFormat object, containing the desired string format. It must have\n   *    timeZone set to 'utc' to work fine.\n   * @param date Date from which we want to get the string representation according to dtf\n   * @returns A Date object with its UTC representation based on the passed in date info\n   */\n  private _format(dtf: Intl.DateTimeFormat, date: Date) {\n    // Passing the year to the constructor causes year numbers <100 to be converted to 19xx.\n    // To work around this we use `setUTCFullYear` and `setUTCHours` instead.\n    const d = new Date();\n    d.setUTCFullYear(date.getFullYear(), date.getMonth(), date.getDate());\n    d.setUTCHours(\n      date.getHours(),\n      date.getMinutes(),\n      date.getSeconds(),\n      date.getMilliseconds()\n    );\n    return dtf.format(d);\n  }\n}\n"]}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, ViewEncapsulation, Optional, Input, } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, Subscription, take } from 'rxjs';
|
|
3
|
+
import { MatTimeFaceBase } from './time-face-base';
|
|
4
|
+
import { withZeroPrefixMeridiem } from './time-input-base';
|
|
5
|
+
import { enterLeaveAnimation } from './clock-dial-adnimation';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "./timepicker-intl";
|
|
8
|
+
import * as i2 from "./adapter";
|
|
9
|
+
import * as i3 from "@angular/common";
|
|
10
|
+
import * as i4 from "./timepicker-content-layout";
|
|
11
|
+
import * as i5 from "./hours-clock-dial";
|
|
12
|
+
import * as i6 from "./minutes-clock-dial";
|
|
13
|
+
import * as i7 from "./time-period";
|
|
14
|
+
export class MatClockDials extends MatTimeFaceBase {
|
|
15
|
+
constructor(_intl, _timeAdapter, _ngZone, _elementRef) {
|
|
16
|
+
super(_timeAdapter);
|
|
17
|
+
this._intl = _intl;
|
|
18
|
+
this._ngZone = _ngZone;
|
|
19
|
+
this._elementRef = _elementRef;
|
|
20
|
+
this.isHoursView = true;
|
|
21
|
+
/** Specifies the view of clock dial. */
|
|
22
|
+
this._view = new BehaviorSubject('hours');
|
|
23
|
+
this._viewSubscription = Subscription.EMPTY;
|
|
24
|
+
}
|
|
25
|
+
ngOnInit() {
|
|
26
|
+
this._viewSubscription = this._view.subscribe((view) => (this.isHoursView = view === 'hours'));
|
|
27
|
+
}
|
|
28
|
+
ngOnDestroy() {
|
|
29
|
+
this._viewSubscription?.unsubscribe();
|
|
30
|
+
this._viewSubscription = null;
|
|
31
|
+
}
|
|
32
|
+
/** Changes clock dial view. */
|
|
33
|
+
onViewChange(event, view) {
|
|
34
|
+
event.preventDefault();
|
|
35
|
+
this._view.next(view);
|
|
36
|
+
}
|
|
37
|
+
focusActiveCell() {
|
|
38
|
+
this._ngZone.runOutsideAngular(() => {
|
|
39
|
+
this._ngZone.onStable.pipe(take(1)).subscribe(() => {
|
|
40
|
+
setTimeout(() => {
|
|
41
|
+
const activeCell = this._elementRef.nativeElement.querySelector('.mat-clock-dial-cell-active');
|
|
42
|
+
if (activeCell) {
|
|
43
|
+
activeCell.focus();
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const activePoint = this._elementRef.nativeElement.querySelector('.mat-clock-dial-hand-point');
|
|
47
|
+
if (activePoint) {
|
|
48
|
+
// if no active cell we need to focus a small dot
|
|
49
|
+
activePoint.focus();
|
|
50
|
+
}
|
|
51
|
+
}, 50);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
_withZeroPrefix(value) {
|
|
56
|
+
if (value === 0) {
|
|
57
|
+
return '00';
|
|
58
|
+
}
|
|
59
|
+
return withZeroPrefixMeridiem(value, this.isMeridiem);
|
|
60
|
+
}
|
|
61
|
+
/** Handles hour selection. */
|
|
62
|
+
_onHourChanged({ hour, changeView = false, }) {
|
|
63
|
+
if (changeView) {
|
|
64
|
+
this._view.next('minutes');
|
|
65
|
+
}
|
|
66
|
+
this._onHourSelected(hour);
|
|
67
|
+
}
|
|
68
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatClockDials, deps: [{ token: i1.MatTimepickerIntl }, { token: i2.TimeAdapter, optional: true }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: MatClockDials, selector: "mat-clock-dials", inputs: { orientation: "orientation" }, host: { attributes: { "role": "dial" }, classAttribute: "mat-clock-dials" }, exportAs: ["matClockDials"], usesInheritance: true, ngImport: i0, template: "<mat-timepicker-content-layout\n [title]=\"_intl.dialsTitle\"\n [orientation]=\"orientation\"\n>\n <div\n tabindex=\"0\"\n class=\"mat-clock-dial-value\"\n hours\n [class.mat-clock-dial-value-active]=\"isHoursView\"\n (click)=\"onViewChange($event,'hours')\"\n (keydown.space)=\"onViewChange($event, 'hours')\"\n >\n {{ _withZeroPrefix(selectedHour) }}\n </div>\n <div\n tabindex=\"0\"\n class=\"mat-clock-dial-value\"\n minutes\n [class.mat-clock-dial-value-active]=\"!isHoursView\"\n (click)=\"onViewChange($event,'minutes')\"\n (keydown.space)=\"onViewChange($event,'minutes')\"\n >\n {{ _withZeroPrefix(selectedMinute) }}\n </div>\n\n <ng-template mat-time-period [ngIf]=\"isMeridiem\">\n <mat-time-period\n [period]=\"period\"\n [disabledPeriod]=\"disabledPeriod\"\n [vertical]=\"orientation === 'vertical'\"\n (periodChanged)=\"_onPeriodChanged($event)\"\n ></mat-time-period>\n </ng-template>\n\n <div\n class=\"mat-clock-dial-faces\"\n [class.mat-clock-dial-faces-horizontal]=\"orientation === 'horizontal'\"\n >\n <ng-template [ngIf]=\"isHoursView\">\n <mat-hours-clock-dial\n [@enterLeaveAnimation]\n [color]=\"color\"\n [selectedHour]=\"selectedHour\"\n [isMeridiem]=\"isMeridiem\"\n [availableHours]=\"_getAvailableHours()\"\n (selectedChange)=\"_onHourChanged($event)\"\n (keydown)=\"_onKeydown($event, 'hour')\"\n ></mat-hours-clock-dial>\n </ng-template>\n <ng-template [ngIf]=\"!isHoursView\">\n <mat-minutes-clock-dial\n [@enterLeaveAnimation]\n [color]=\"color\"\n [selectedMinute]=\"selectedMinute\"\n [interval]=\"minuteInterval\"\n [availableMinutes]=\"availableMinutes\"\n (selectedChange)=\"_onMinuteSelected($event)\"\n (keydown)=\"_onKeydown($event, 'minute')\"\n ></mat-minutes-clock-dial>\n </ng-template>\n </div>\n</mat-timepicker-content-layout>\n", styles: [".mat-clock-dial-values{display:flex;width:100%}.mat-clock-dial-value{display:flex;align-items:center;justify-content:center;height:4.5rem;border-radius:.25rem;cursor:pointer}.mat-clock-dial-faces{margin-top:2.25rem}.mat-clock-dial-faces.mat-clock-dial-faces-horizontal{margin-top:0}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatTimepickerContentLayout, selector: "mat-timepicker-content-layout", inputs: ["title", "orientation"], exportAs: ["matTimepickerContent"] }, { kind: "component", type: i5.MatHoursClockDial, selector: "mat-hours-clock-dial", inputs: ["selectedHour", "isMeridiem", "availableHours", "color"], outputs: ["selectedChange"], exportAs: ["matHoursClockDial"] }, { kind: "component", type: i6.MatMinutesClockDial, selector: "mat-minutes-clock-dial", inputs: ["selectedMinute", "interval", "availableMinutes", "color"], outputs: ["selectedChange"], exportAs: ["matMinutesClockDial"] }, { kind: "component", type: i7.MatTimePeriod, selector: "mat-time-period", inputs: ["vertical", "period", "disabledPeriod"], outputs: ["periodChanged"] }], animations: [enterLeaveAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
70
|
+
}
|
|
71
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatClockDials, decorators: [{
|
|
72
|
+
type: Component,
|
|
73
|
+
args: [{ selector: 'mat-clock-dials', exportAs: 'matClockDials', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
|
74
|
+
role: 'dial',
|
|
75
|
+
class: 'mat-clock-dials',
|
|
76
|
+
}, animations: [enterLeaveAnimation], template: "<mat-timepicker-content-layout\n [title]=\"_intl.dialsTitle\"\n [orientation]=\"orientation\"\n>\n <div\n tabindex=\"0\"\n class=\"mat-clock-dial-value\"\n hours\n [class.mat-clock-dial-value-active]=\"isHoursView\"\n (click)=\"onViewChange($event,'hours')\"\n (keydown.space)=\"onViewChange($event, 'hours')\"\n >\n {{ _withZeroPrefix(selectedHour) }}\n </div>\n <div\n tabindex=\"0\"\n class=\"mat-clock-dial-value\"\n minutes\n [class.mat-clock-dial-value-active]=\"!isHoursView\"\n (click)=\"onViewChange($event,'minutes')\"\n (keydown.space)=\"onViewChange($event,'minutes')\"\n >\n {{ _withZeroPrefix(selectedMinute) }}\n </div>\n\n <ng-template mat-time-period [ngIf]=\"isMeridiem\">\n <mat-time-period\n [period]=\"period\"\n [disabledPeriod]=\"disabledPeriod\"\n [vertical]=\"orientation === 'vertical'\"\n (periodChanged)=\"_onPeriodChanged($event)\"\n ></mat-time-period>\n </ng-template>\n\n <div\n class=\"mat-clock-dial-faces\"\n [class.mat-clock-dial-faces-horizontal]=\"orientation === 'horizontal'\"\n >\n <ng-template [ngIf]=\"isHoursView\">\n <mat-hours-clock-dial\n [@enterLeaveAnimation]\n [color]=\"color\"\n [selectedHour]=\"selectedHour\"\n [isMeridiem]=\"isMeridiem\"\n [availableHours]=\"_getAvailableHours()\"\n (selectedChange)=\"_onHourChanged($event)\"\n (keydown)=\"_onKeydown($event, 'hour')\"\n ></mat-hours-clock-dial>\n </ng-template>\n <ng-template [ngIf]=\"!isHoursView\">\n <mat-minutes-clock-dial\n [@enterLeaveAnimation]\n [color]=\"color\"\n [selectedMinute]=\"selectedMinute\"\n [interval]=\"minuteInterval\"\n [availableMinutes]=\"availableMinutes\"\n (selectedChange)=\"_onMinuteSelected($event)\"\n (keydown)=\"_onKeydown($event, 'minute')\"\n ></mat-minutes-clock-dial>\n </ng-template>\n </div>\n</mat-timepicker-content-layout>\n", styles: [".mat-clock-dial-values{display:flex;width:100%}.mat-clock-dial-value{display:flex;align-items:center;justify-content:center;height:4.5rem;border-radius:.25rem;cursor:pointer}.mat-clock-dial-faces{margin-top:2.25rem}.mat-clock-dial-faces.mat-clock-dial-faces-horizontal{margin-top:0}\n"] }]
|
|
77
|
+
}], ctorParameters: function () { return [{ type: i1.MatTimepickerIntl }, { type: i2.TimeAdapter, decorators: [{
|
|
78
|
+
type: Optional
|
|
79
|
+
}] }, { type: i0.NgZone }, { type: i0.ElementRef }]; }, propDecorators: { orientation: [{
|
|
80
|
+
type: Input
|
|
81
|
+
}] } });
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clock-dials.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/clock-dials.ts","../../../../projects/mat-timepicker/src/lib/clock-dials.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  OnInit,\n  OnDestroy,\n  Optional,\n  NgZone,\n  ElementRef,\n  Input,\n} from '@angular/core';\nimport { BehaviorSubject, Subscription, take } from 'rxjs';\n\nimport { TimeAdapter } from './adapter';\nimport { MatTimeFaceBase } from './time-face-base';\nimport { withZeroPrefixMeridiem } from './time-input-base';\nimport { MatTimepickerIntl } from './timepicker-intl';\nimport { TimepickerOrientation } from './orientation';\nimport { enterLeaveAnimation } from './clock-dial-adnimation';\n\nexport type MatDialView = 'hours' | 'minutes';\n\n@Component({\n  selector: 'mat-clock-dials',\n  templateUrl: './clock-dials.html',\n  styleUrls: ['./clock-dials.scss'],\n  exportAs: 'matClockDials',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    role: 'dial',\n    class: 'mat-clock-dials',\n  },\n  animations: [enterLeaveAnimation],\n})\nexport class MatClockDials<T>\n  extends MatTimeFaceBase<T>\n  implements OnInit, OnDestroy\n{\n  /** Layout orientation. */\n  @Input() orientation: TimepickerOrientation;\n\n  isHoursView = true;\n\n  /** Specifies the view of clock dial. */\n  private readonly _view = new BehaviorSubject<MatDialView>('hours');\n  private _viewSubscription: Subscription | null = Subscription.EMPTY;\n\n  constructor(\n    public _intl: MatTimepickerIntl,\n    @Optional() _timeAdapter: TimeAdapter<T>,\n    private _ngZone: NgZone,\n    private _elementRef: ElementRef\n  ) {\n    super(_timeAdapter);\n  }\n\n  ngOnInit(): void {\n    this._viewSubscription = this._view.subscribe(\n      (view) => (this.isHoursView = view === 'hours')\n    );\n  }\n\n  ngOnDestroy(): void {\n    this._viewSubscription?.unsubscribe();\n    this._viewSubscription = null;\n  }\n\n  /** Changes clock dial view. */\n  onViewChange(event: Event, view: MatDialView): void {\n    event.preventDefault();\n    this._view.next(view);\n  }\n\n  focusActiveCell(): void {\n    this._ngZone.runOutsideAngular(() => {\n      this._ngZone.onStable.pipe(take(1)).subscribe(() => {\n        setTimeout(() => {\n          const activeCell: HTMLElement | null =\n            this._elementRef.nativeElement.querySelector(\n              '.mat-clock-dial-cell-active'\n            );\n\n          if (activeCell) {\n            activeCell.focus();\n            return;\n          }\n\n          const activePoint: HTMLElement | null =\n            this._elementRef.nativeElement.querySelector(\n              '.mat-clock-dial-hand-point'\n            );\n\n          if (activePoint) {\n            // if no active cell we need to focus a small dot\n            activePoint.focus();\n          }\n        }, 50);\n      });\n    });\n  }\n\n  _withZeroPrefix(value: number): string {\n    if (value === 0) {\n      return '00';\n    }\n\n    return withZeroPrefixMeridiem(value, this.isMeridiem);\n  }\n\n  /** Handles hour selection. */\n  _onHourChanged({\n    hour,\n    changeView = false,\n  }: {\n    hour: number;\n    changeView?: boolean;\n  }): void {\n    if (changeView) {\n      this._view.next('minutes');\n    }\n    this._onHourSelected(hour);\n  }\n}\n","<mat-timepicker-content-layout\n  [title]=\"_intl.dialsTitle\"\n  [orientation]=\"orientation\"\n>\n  <div\n    tabindex=\"0\"\n    class=\"mat-clock-dial-value\"\n    hours\n    [class.mat-clock-dial-value-active]=\"isHoursView\"\n    (click)=\"onViewChange($event,'hours')\"\n    (keydown.space)=\"onViewChange($event, 'hours')\"\n  >\n    {{ _withZeroPrefix(selectedHour) }}\n  </div>\n  <div\n    tabindex=\"0\"\n    class=\"mat-clock-dial-value\"\n    minutes\n    [class.mat-clock-dial-value-active]=\"!isHoursView\"\n    (click)=\"onViewChange($event,'minutes')\"\n    (keydown.space)=\"onViewChange($event,'minutes')\"\n  >\n    {{ _withZeroPrefix(selectedMinute) }}\n  </div>\n\n  <ng-template mat-time-period [ngIf]=\"isMeridiem\">\n    <mat-time-period\n      [period]=\"period\"\n      [disabledPeriod]=\"disabledPeriod\"\n      [vertical]=\"orientation === 'vertical'\"\n      (periodChanged)=\"_onPeriodChanged($event)\"\n    ></mat-time-period>\n  </ng-template>\n\n  <div\n    class=\"mat-clock-dial-faces\"\n    [class.mat-clock-dial-faces-horizontal]=\"orientation === 'horizontal'\"\n  >\n    <ng-template [ngIf]=\"isHoursView\">\n      <mat-hours-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedHour]=\"selectedHour\"\n        [isMeridiem]=\"isMeridiem\"\n        [availableHours]=\"_getAvailableHours()\"\n        (selectedChange)=\"_onHourChanged($event)\"\n        (keydown)=\"_onKeydown($event, 'hour')\"\n      ></mat-hours-clock-dial>\n    </ng-template>\n    <ng-template [ngIf]=\"!isHoursView\">\n      <mat-minutes-clock-dial\n        [@enterLeaveAnimation]\n        [color]=\"color\"\n        [selectedMinute]=\"selectedMinute\"\n        [interval]=\"minuteInterval\"\n        [availableMinutes]=\"availableMinutes\"\n        (selectedChange)=\"_onMinuteSelected($event)\"\n        (keydown)=\"_onKeydown($event, 'minute')\"\n      ></mat-minutes-clock-dial>\n    </ng-template>\n  </div>\n</mat-timepicker-content-layout>\n"]}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { debounceTime, fromEvent, merge, take } from 'rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@angular/material/button";
|
|
7
|
+
export const ALL_HOURS = Array(24)
|
|
8
|
+
.fill(null)
|
|
9
|
+
.map((_, i) => i);
|
|
10
|
+
const CLOCK_RADIUS = 128;
|
|
11
|
+
const CLOCK_TICK_RADIUS = 16;
|
|
12
|
+
const CLOCK_CORRECTED_RADIUS = CLOCK_RADIUS - CLOCK_TICK_RADIUS;
|
|
13
|
+
const CLOCK_OUTER_RADIUS = 100;
|
|
14
|
+
const CLOCK_INNER_RADIUS = CLOCK_OUTER_RADIUS - CLOCK_TICK_RADIUS * 2;
|
|
15
|
+
export class MatHoursClockDial {
|
|
16
|
+
/** Selected hour. */
|
|
17
|
+
get selectedHour() {
|
|
18
|
+
return this._selectedHour;
|
|
19
|
+
}
|
|
20
|
+
set selectedHour(value) {
|
|
21
|
+
this._selectedHour = value;
|
|
22
|
+
}
|
|
23
|
+
/** Whether the clock uses 12 hour format. */
|
|
24
|
+
get isMeridiem() {
|
|
25
|
+
return this._isMeridiem;
|
|
26
|
+
}
|
|
27
|
+
set isMeridiem(value) {
|
|
28
|
+
this._isMeridiem = value;
|
|
29
|
+
}
|
|
30
|
+
get availableHours() {
|
|
31
|
+
return this._availableHours;
|
|
32
|
+
}
|
|
33
|
+
set availableHours(value) {
|
|
34
|
+
this._availableHours = value;
|
|
35
|
+
this._initHours();
|
|
36
|
+
}
|
|
37
|
+
get disabledHand() {
|
|
38
|
+
return !this.availableHours.includes(this.selectedHour);
|
|
39
|
+
}
|
|
40
|
+
get isHour() {
|
|
41
|
+
return !!this.hours.find((hour) => hour.value === this.selectedHour);
|
|
42
|
+
}
|
|
43
|
+
constructor(_element, _cdr, _document, _window) {
|
|
44
|
+
this._element = _element;
|
|
45
|
+
this._cdr = _cdr;
|
|
46
|
+
this._document = _document;
|
|
47
|
+
this._window = _window;
|
|
48
|
+
this._availableHours = [];
|
|
49
|
+
/** Emits selected hour. */
|
|
50
|
+
this.selectedChange = new EventEmitter();
|
|
51
|
+
this.hours = [];
|
|
52
|
+
}
|
|
53
|
+
ngOnInit() {
|
|
54
|
+
this._initHours();
|
|
55
|
+
}
|
|
56
|
+
/** Hand styles based on selected hour. */
|
|
57
|
+
_handStyles() {
|
|
58
|
+
const deg = Math.round(this.selectedHour * (360 / (24 / 2)));
|
|
59
|
+
const radius = this._getRadius(this.selectedHour);
|
|
60
|
+
const height = radius;
|
|
61
|
+
const marginTop = CLOCK_RADIUS - radius;
|
|
62
|
+
return {
|
|
63
|
+
transform: `rotate(${deg}deg)`,
|
|
64
|
+
height: `${height}px`,
|
|
65
|
+
'margin-top': `${marginTop}px`,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
/** Handles mouse and touch events on dial and document. */
|
|
69
|
+
_onMouseDown(event) {
|
|
70
|
+
this._setHour(event);
|
|
71
|
+
const eventsSubscription = merge(fromEvent(this._document, 'mousemove'), fromEvent(this._document, 'touchmove'))
|
|
72
|
+
.pipe(debounceTime(0))
|
|
73
|
+
.subscribe({
|
|
74
|
+
next: (event) => {
|
|
75
|
+
event.preventDefault();
|
|
76
|
+
this._setHour(event);
|
|
77
|
+
},
|
|
78
|
+
});
|
|
79
|
+
merge(fromEvent(this._document, 'mouseup'), fromEvent(this._document, 'touchend'))
|
|
80
|
+
.pipe(take(1))
|
|
81
|
+
.subscribe({
|
|
82
|
+
next: () => {
|
|
83
|
+
eventsSubscription.unsubscribe();
|
|
84
|
+
this.selectedChange.emit({
|
|
85
|
+
hour: this.selectedHour,
|
|
86
|
+
changeView: true,
|
|
87
|
+
});
|
|
88
|
+
},
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
_isActiveCell(hour) {
|
|
92
|
+
return this.selectedHour === hour;
|
|
93
|
+
}
|
|
94
|
+
_trackBy(index, cell) {
|
|
95
|
+
return cell.value;
|
|
96
|
+
}
|
|
97
|
+
/** Changes selected hour based on coordinates. */
|
|
98
|
+
_setHour(event) {
|
|
99
|
+
const element = this._element.nativeElement;
|
|
100
|
+
const elementRect = element.getBoundingClientRect();
|
|
101
|
+
const width = element.offsetWidth;
|
|
102
|
+
const height = element.offsetHeight;
|
|
103
|
+
const pageX = event instanceof MouseEvent ? event.pageX : event.touches[0].pageX;
|
|
104
|
+
const pageY = event instanceof MouseEvent ? event.pageY : event.touches[0].pageY;
|
|
105
|
+
const x = width / 2 - (pageX - elementRect.left - this._window.scrollX);
|
|
106
|
+
const y = height / 2 - (pageY - elementRect.top - this._window.scrollY);
|
|
107
|
+
const unit = Math.PI / 6;
|
|
108
|
+
const atan2 = Math.atan2(-x, y);
|
|
109
|
+
const radian = atan2 < 0 ? Math.PI * 2 + atan2 : atan2;
|
|
110
|
+
const initialValue = Math.round(radian / unit);
|
|
111
|
+
const z = Math.sqrt(x * x + y * y);
|
|
112
|
+
const outer = z > CLOCK_OUTER_RADIUS - CLOCK_TICK_RADIUS;
|
|
113
|
+
const value = this._getHourValue(initialValue, outer);
|
|
114
|
+
if (this.availableHours.includes(value)) {
|
|
115
|
+
this.selectedHour = value;
|
|
116
|
+
this.selectedChange.emit({
|
|
117
|
+
hour: this.selectedHour,
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
this._cdr.detectChanges();
|
|
121
|
+
}
|
|
122
|
+
/** Return value of hour. */
|
|
123
|
+
_getHourValue(value, outer) {
|
|
124
|
+
const edgeValue = value === 0 || value === 12;
|
|
125
|
+
if (this.isMeridiem) {
|
|
126
|
+
return edgeValue ? 12 : value;
|
|
127
|
+
}
|
|
128
|
+
if (outer) {
|
|
129
|
+
return edgeValue ? 0 : value;
|
|
130
|
+
}
|
|
131
|
+
return edgeValue ? 12 : value + 12;
|
|
132
|
+
}
|
|
133
|
+
/** Creates list of hours. */
|
|
134
|
+
_initHours() {
|
|
135
|
+
const initialHours = this.isMeridiem ? ALL_HOURS.slice(1, 13) : ALL_HOURS;
|
|
136
|
+
this.hours = initialHours.map((hour) => {
|
|
137
|
+
const radian = (hour / 6) * Math.PI;
|
|
138
|
+
const radius = this._getRadius(hour);
|
|
139
|
+
return {
|
|
140
|
+
value: hour,
|
|
141
|
+
displayValue: hour === 0 ? '00' : String(hour),
|
|
142
|
+
left: CLOCK_CORRECTED_RADIUS + Math.sin(radian) * radius,
|
|
143
|
+
top: CLOCK_CORRECTED_RADIUS - Math.cos(radian) * radius,
|
|
144
|
+
disabled: !this.availableHours.includes(hour),
|
|
145
|
+
};
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
/** Returns radius based on hour */
|
|
149
|
+
_getRadius(hour) {
|
|
150
|
+
if (this.isMeridiem) {
|
|
151
|
+
return CLOCK_OUTER_RADIUS;
|
|
152
|
+
}
|
|
153
|
+
const outer = hour >= 0 && hour < 12;
|
|
154
|
+
const radius = outer ? CLOCK_OUTER_RADIUS : CLOCK_INNER_RADIUS;
|
|
155
|
+
return radius;
|
|
156
|
+
}
|
|
157
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatHoursClockDial, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: DOCUMENT }, { token: Window }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
158
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.5", type: MatHoursClockDial, selector: "mat-hours-clock-dial", inputs: { selectedHour: "selectedHour", isMeridiem: "isMeridiem", availableHours: "availableHours", color: "color" }, outputs: { selectedChange: "selectedChange" }, host: { listeners: { "mousedown": "_onMouseDown($event)" }, classAttribute: "mat-clock-dial mat-clock-dial-hours" }, exportAs: ["matHoursClockDial"], ngImport: i0, template: "<div\n class=\"mat-clock-dial-hand\"\n [class.mat-clock-dial-hand-pointless]=\"isHour\"\n [class.mat-clock-dial-hand-disabled]=\"disabledHand\"\n [ngStyle]=\"_handStyles()\"\n></div>\n<ng-template ngFor let-hour [ngForOf]=\"hours\" [ngForTrackBy]=\"_trackBy\">\n <button\n class=\"mat-clock-dial-cell\"\n mat-mini-fab\n disableRipple\n [tabIndex]=\"_isActiveCell(hour.value) ? 0 : -1\"\n [style.left.px]=\"hour.left\"\n [style.top.px]=\"hour.top\"\n [class.mat-clock-dial-cell-active]=\"_isActiveCell(hour.value)\"\n [class.mat-clock-dial-cell-disabled]=\"hour.disabled\"\n [color]=\"_isActiveCell(hour.value) ? color : undefined\"\n [attr.aria-disabled]=\"hour.disabled || null\"\n >\n {{ hour.displayValue }}\n </button>\n</ng-template>\n", styles: [".mat-clock-dial{position:relative;display:block;width:16rem;height:16rem;margin:0 auto;border-radius:50%}.mat-clock-dial:before{position:absolute;top:50%;left:50%;width:.4375rem;height:.4375rem;border-radius:50%;transform:translate(-50%,-50%);content:\"\"}[mat-mini-fab].mat-clock-dial-cell{position:absolute;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;box-shadow:none}[mat-mini-fab].mat-clock-dial-cell:disabled{pointer-events:none}[mat-mini-fab].mat-clock-dial-cell:focus,[mat-mini-fab].mat-clock-dial-cell:hover,[mat-mini-fab].mat-clock-dial-cell:active,[mat-mini-fab].mat-clock-dial-cell:focus:active{box-shadow:none}.mat-clock-dial-hand{position:absolute;inset:0;width:1px;margin:0 auto;transform-origin:bottom}.mat-clock-dial-hand:before{position:absolute;top:-.25rem;left:-.25rem;width:calc(.5rem + 1px);height:calc(.5rem + 1px);border-radius:50%;content:\"\"}.mat-clock-dial-hand.mat-clock-dial-hand-pointless:before{content:none}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.MatMiniFabButton, selector: "button[mat-mini-fab]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
159
|
+
}
|
|
160
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: MatHoursClockDial, decorators: [{
|
|
161
|
+
type: Component,
|
|
162
|
+
args: [{ selector: 'mat-hours-clock-dial', exportAs: 'matHoursClockDial', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
|
163
|
+
class: 'mat-clock-dial mat-clock-dial-hours',
|
|
164
|
+
'(mousedown)': '_onMouseDown($event)',
|
|
165
|
+
}, template: "<div\n class=\"mat-clock-dial-hand\"\n [class.mat-clock-dial-hand-pointless]=\"isHour\"\n [class.mat-clock-dial-hand-disabled]=\"disabledHand\"\n [ngStyle]=\"_handStyles()\"\n></div>\n<ng-template ngFor let-hour [ngForOf]=\"hours\" [ngForTrackBy]=\"_trackBy\">\n <button\n class=\"mat-clock-dial-cell\"\n mat-mini-fab\n disableRipple\n [tabIndex]=\"_isActiveCell(hour.value) ? 0 : -1\"\n [style.left.px]=\"hour.left\"\n [style.top.px]=\"hour.top\"\n [class.mat-clock-dial-cell-active]=\"_isActiveCell(hour.value)\"\n [class.mat-clock-dial-cell-disabled]=\"hour.disabled\"\n [color]=\"_isActiveCell(hour.value) ? color : undefined\"\n [attr.aria-disabled]=\"hour.disabled || null\"\n >\n {{ hour.displayValue }}\n </button>\n</ng-template>\n", styles: [".mat-clock-dial{position:relative;display:block;width:16rem;height:16rem;margin:0 auto;border-radius:50%}.mat-clock-dial:before{position:absolute;top:50%;left:50%;width:.4375rem;height:.4375rem;border-radius:50%;transform:translate(-50%,-50%);content:\"\"}[mat-mini-fab].mat-clock-dial-cell{position:absolute;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;box-shadow:none}[mat-mini-fab].mat-clock-dial-cell:disabled{pointer-events:none}[mat-mini-fab].mat-clock-dial-cell:focus,[mat-mini-fab].mat-clock-dial-cell:hover,[mat-mini-fab].mat-clock-dial-cell:active,[mat-mini-fab].mat-clock-dial-cell:focus:active{box-shadow:none}.mat-clock-dial-hand{position:absolute;inset:0;width:1px;margin:0 auto;transform-origin:bottom}.mat-clock-dial-hand:before{position:absolute;top:-.25rem;left:-.25rem;width:calc(.5rem + 1px);height:calc(.5rem + 1px);border-radius:50%;content:\"\"}.mat-clock-dial-hand.mat-clock-dial-hand-pointless:before{content:none}\n"] }]
|
|
166
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: Document, decorators: [{
|
|
167
|
+
type: Inject,
|
|
168
|
+
args: [DOCUMENT]
|
|
169
|
+
}] }, { type: Window, decorators: [{
|
|
170
|
+
type: Inject,
|
|
171
|
+
args: [Window]
|
|
172
|
+
}] }]; }, propDecorators: { selectedHour: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], isMeridiem: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], availableHours: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], color: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], selectedChange: [{
|
|
181
|
+
type: Output
|
|
182
|
+
}] } });
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hours-clock-dial.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/hours-clock-dial.ts","../../../../projects/mat-timepicker/src/lib/hours-clock-dial.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { debounceTime, fromEvent, merge, take } from 'rxjs';\n\nexport interface ClockDialViewCell {\n  value: number;\n  displayValue: string;\n  left: number;\n  top: number;\n  disabled: boolean;\n}\n\nexport const ALL_HOURS = Array(24)\n  .fill(null)\n  .map((_, i) => i);\nconst CLOCK_RADIUS = 128;\nconst CLOCK_TICK_RADIUS = 16;\nconst CLOCK_CORRECTED_RADIUS = CLOCK_RADIUS - CLOCK_TICK_RADIUS;\nconst CLOCK_OUTER_RADIUS = 100;\nconst CLOCK_INNER_RADIUS = CLOCK_OUTER_RADIUS - CLOCK_TICK_RADIUS * 2;\n\n@Component({\n  selector: 'mat-hours-clock-dial',\n  templateUrl: 'hours-clock-dial.html',\n  styleUrls: ['clock-dial.scss'],\n  exportAs: 'matHoursClockDial',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'mat-clock-dial mat-clock-dial-hours',\n    '(mousedown)': '_onMouseDown($event)',\n  },\n})\nexport class MatHoursClockDial implements OnInit {\n  /** Selected hour. */\n  @Input()\n  get selectedHour(): number {\n    return this._selectedHour;\n  }\n  set selectedHour(value: number) {\n    this._selectedHour = value;\n  }\n  private _selectedHour: number;\n\n  /** Whether the clock uses 12 hour format. */\n  @Input()\n  get isMeridiem(): boolean {\n    return this._isMeridiem;\n  }\n  set isMeridiem(value: boolean) {\n    this._isMeridiem = value;\n  }\n  private _isMeridiem: boolean;\n\n  @Input()\n  get availableHours(): number[] {\n    return this._availableHours;\n  }\n  set availableHours(value: number[]) {\n    this._availableHours = value;\n    this._initHours();\n  }\n  private _availableHours: number[] = [];\n\n  /** Color palette. */\n  @Input() color: ThemePalette;\n\n  /** Emits selected hour. */\n  @Output() selectedChange = new EventEmitter<{\n    hour: number;\n    changeView?: boolean;\n  }>();\n\n  hours: ClockDialViewCell[] = [];\n\n  get disabledHand(): boolean {\n    return !this.availableHours.includes(this.selectedHour);\n  }\n\n  get isHour(): boolean {\n    return !!this.hours.find((hour) => hour.value === this.selectedHour);\n  }\n\n  constructor(\n    private _element: ElementRef<HTMLElement>,\n    private _cdr: ChangeDetectorRef,\n    @Inject(DOCUMENT) private _document: Document,\n    @Inject(Window) private _window: Window\n  ) {}\n\n  ngOnInit(): void {\n    this._initHours();\n  }\n\n  /** Hand styles based on selected hour. */\n  _handStyles(): any {\n    const deg = Math.round(this.selectedHour * (360 / (24 / 2)));\n    const radius = this._getRadius(this.selectedHour);\n    const height = radius;\n    const marginTop = CLOCK_RADIUS - radius;\n\n    return {\n      transform: `rotate(${deg}deg)`,\n      height: `${height}px`,\n      'margin-top': `${marginTop}px`,\n    };\n  }\n\n  /** Handles mouse and touch events on dial and document. */\n  _onMouseDown(event: MouseEvent | TouchEvent): void {\n    this._setHour(event);\n\n    const eventsSubscription = merge(\n      fromEvent<MouseEvent>(this._document, 'mousemove'),\n      fromEvent<TouchEvent>(this._document, 'touchmove')\n    )\n      .pipe(debounceTime(0))\n      .subscribe({\n        next: (event) => {\n          event.preventDefault();\n          this._setHour(event);\n        },\n      });\n\n    merge(\n      fromEvent<MouseEvent>(this._document, 'mouseup'),\n      fromEvent<TouchEvent>(this._document, 'touchend')\n    )\n      .pipe(take(1))\n      .subscribe({\n        next: () => {\n          eventsSubscription.unsubscribe();\n          this.selectedChange.emit({\n            hour: this.selectedHour,\n            changeView: true,\n          });\n        },\n      });\n  }\n\n  _isActiveCell(hour: number): boolean {\n    return this.selectedHour === hour;\n  }\n\n  _trackBy(index: number, cell: ClockDialViewCell): number {\n    return cell.value;\n  }\n\n  /** Changes selected hour based on coordinates. */\n  private _setHour(event: MouseEvent | TouchEvent): void {\n    const element = this._element.nativeElement;\n    const elementRect = element.getBoundingClientRect();\n    const width = element.offsetWidth;\n    const height = element.offsetHeight;\n    const pageX =\n      event instanceof MouseEvent ? event.pageX : event.touches[0].pageX;\n    const pageY =\n      event instanceof MouseEvent ? event.pageY : event.touches[0].pageY;\n    const x = width / 2 - (pageX - elementRect.left - this._window.scrollX);\n    const y = height / 2 - (pageY - elementRect.top - this._window.scrollY);\n    const unit = Math.PI / 6;\n    const atan2 = Math.atan2(-x, y);\n    const radian = atan2 < 0 ? Math.PI * 2 + atan2 : atan2;\n    const initialValue = Math.round(radian / unit);\n    const z = Math.sqrt(x * x + y * y);\n    const outer = z > CLOCK_OUTER_RADIUS - CLOCK_TICK_RADIUS;\n    const value = this._getHourValue(initialValue, outer);\n\n    if (this.availableHours.includes(value)) {\n      this.selectedHour = value;\n      this.selectedChange.emit({\n        hour: this.selectedHour,\n      });\n    }\n\n    this._cdr.detectChanges();\n  }\n\n  /** Return value of hour. */\n  private _getHourValue(value: number, outer: boolean): number {\n    const edgeValue = value === 0 || value === 12;\n\n    if (this.isMeridiem) {\n      return edgeValue ? 12 : value;\n    }\n\n    if (outer) {\n      return edgeValue ? 0 : value;\n    }\n\n    return edgeValue ? 12 : value + 12;\n  }\n\n  /** Creates list of hours. */\n  private _initHours(): void {\n    const initialHours = this.isMeridiem ? ALL_HOURS.slice(1, 13) : ALL_HOURS;\n\n    this.hours = initialHours.map((hour) => {\n      const radian = (hour / 6) * Math.PI;\n      const radius = this._getRadius(hour);\n\n      return {\n        value: hour,\n        displayValue: hour === 0 ? '00' : String(hour),\n        left: CLOCK_CORRECTED_RADIUS + Math.sin(radian) * radius,\n        top: CLOCK_CORRECTED_RADIUS - Math.cos(radian) * radius,\n        disabled: !this.availableHours.includes(hour),\n      };\n    });\n  }\n\n  /** Returns radius based on hour */\n  private _getRadius(hour: number): number {\n    if (this.isMeridiem) {\n      return CLOCK_OUTER_RADIUS;\n    }\n\n    const outer = hour >= 0 && hour < 12;\n    const radius = outer ? CLOCK_OUTER_RADIUS : CLOCK_INNER_RADIUS;\n\n    return radius;\n  }\n}\n","<div\n  class=\"mat-clock-dial-hand\"\n  [class.mat-clock-dial-hand-pointless]=\"isHour\"\n  [class.mat-clock-dial-hand-disabled]=\"disabledHand\"\n  [ngStyle]=\"_handStyles()\"\n></div>\n<ng-template ngFor let-hour [ngForOf]=\"hours\" [ngForTrackBy]=\"_trackBy\">\n  <button\n    class=\"mat-clock-dial-cell\"\n    mat-mini-fab\n    disableRipple\n    [tabIndex]=\"_isActiveCell(hour.value) ? 0 : -1\"\n    [style.left.px]=\"hour.left\"\n    [style.top.px]=\"hour.top\"\n    [class.mat-clock-dial-cell-active]=\"_isActiveCell(hour.value)\"\n    [class.mat-clock-dial-cell-disabled]=\"hour.disabled\"\n    [color]=\"_isActiveCell(hour.value) ? color : undefined\"\n    [attr.aria-disabled]=\"hour.disabled || null\"\n  >\n    {{ hour.displayValue }}\n  </button>\n</ng-template>\n"]}
|