-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Expand file tree
/
Copy pathdatetime-input.ts
More file actions
97 lines (90 loc) · 3.22 KB
/
datetime-input.ts
File metadata and controls
97 lines (90 loc) · 3.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*
* Copyright 2025 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
import { DynamicComponent } from '../rendering/dynamic-component';
import { Types } from '../types';
@Component({
selector: 'a2ui-datetime-input',
template: `
<div
[class]="theme.components.DateTimeInput.container"
[style]="theme.additionalStyles?.DateTimeInput"
>
<label [class]="theme.components.DateTimeInput.label" [for]="inputId">
{{ resolvedLabel() }}
</label>
<input
[type]="inputType()"
[class]="theme.components.DateTimeInput.element"
[id]="inputId"
[value]="resolvedValue() ?? ''"
(change)="onChange($event)"
/>
</div>
`,
styles: `
:host {
display: block;
}
input {
color: #333;
}
input::-webkit-datetime-edit,
input::-webkit-datetime-edit-fields-wrapper {
color: #333;
}
`,
changeDetection: ChangeDetectionStrategy.OnPush,
})
export class DateTimeInput extends DynamicComponent<Types.DateTimeInputNode> {
readonly label = input<Types.StringValue | null>(null);
readonly value = input.required<Types.StringValue | null>();
readonly enableDate = input<boolean>(true);
readonly enableTime = input<boolean>(false);
protected readonly inputId = super.getUniqueId('a2ui-datetime-input');
protected inputType = computed(() => {
if (this.enableDate() && this.enableTime()) return 'datetime-local';
if (this.enableTime()) return 'time';
return 'date';
});
protected readonly resolvedLabel = computed(() => super.resolvePrimitive(this.label()));
protected resolvedValue = computed(() => super.resolvePrimitive(this.value()));
onChange(event: Event) {
const value = (event.target as HTMLInputElement).value;
const valueNode = this.value();
if (valueNode && typeof valueNode === 'object' && 'path' in valueNode && valueNode.path) {
// Update the local data model directly to ensure immediate UI feedback and avoid unnecessary network requests.
this.processor.processMessages([{
dataModelUpdate: {
surfaceId: this.surfaceId()!,
path: this.processor.resolvePath(valueNode.path as string, this.component().dataContextPath),
contents: [{ key: '.', valueString: value }],
},
}]);
} else {
this.handleAction('change', { value });
}
}
private handleAction(name: string, context: Record<string, unknown>) {
super.sendAction({
name,
context: Object.entries(context).map(([key, val]) => ({
key,
value: typeof val === 'number' ? { literalNumber: val } : { literalString: String(val) },
})),
});
}
}