carbon-components-angular
Version:
Next generation components
214 lines • 16.2 kB
JavaScript
import { Component, Input, Output, EventEmitter, HostBinding, TemplateRef, HostListener } from "@angular/core";
import { NG_VALUE_ACCESSOR } from "@angular/forms";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
/**
* Get started with importing the module:
*
* ```typescript
* import { TimePickerModule } from 'carbon-components-angular';
* ```
*
* [See demo](../../?path=/story/components-time-picker--simple)
*/
export class TimePicker {
constructor() {
this.invalid = false;
this.hideLabel = false;
this.placeholder = "hh:mm";
this.pattern = "(1[012]|[0-9]):[0-5][0-9]";
this.id = `timepicker-${TimePicker.timePickerCount++}`;
this.disabled = false;
this.maxLength = 5;
/**
* Set to true for a loading select.
*/
this.skeleton = false;
/**
* @deprecated since v5 - Use `cdsLayer` directive instead
*/
this.theme = "dark";
/**
* `sm`, `md` (default), or `lg` select size
*/
this.size = "md";
this.valueChange = new EventEmitter();
/**
* Ensures component is properly styled when used standalone.
*/
this.timepickerClass = true;
this.onChangeHandler = (_) => { };
this.onTouchedHandler = () => { };
}
writeValue(value) {
this.value = value;
}
registerOnChange(callback) {
this.onChangeHandler = callback;
}
registerOnTouched(callback) {
this.onTouchedHandler = callback;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
onChange(event) {
this.onChangeHandler(event.target.value);
this.valueChange.emit(event.target.value);
}
focusOut() {
this.onTouchedHandler();
}
isTemplate(value) {
return value instanceof TemplateRef;
}
}
/**
* Tracks the total number of selects instantiated. Used to generate unique IDs
*/
TimePicker.timePickerCount = 0;
TimePicker.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TimePicker, deps: [], target: i0.ɵɵFactoryTarget.Component });
TimePicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TimePicker, selector: "cds-timepicker, ibm-timepicker", inputs: { invalid: "invalid", invalidText: "invalidText", label: "label", hideLabel: "hideLabel", placeholder: "placeholder", pattern: "pattern", id: "id", disabled: "disabled", value: "value", maxLength: "maxLength", skeleton: "skeleton", theme: "theme", size: "size" }, outputs: { valueChange: "valueChange" }, host: { listeners: { "focusout": "focusOut()" }, properties: { "class.cds--form-item": "this.timepickerClass" } }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: TimePicker,
multi: true
}
], ngImport: i0, template: `
<label
*ngIf="!skeleton && label"
[for]="id"
class="cds--label"
[ngClass]="{
'cds--label--disabled': disabled,
'cds--visually-hidden': hideLabel
}">
<ng-container *ngIf="!isTemplate(label)">{{label}}</ng-container>
<ng-template *ngIf="isTemplate(label)" [ngTemplateOutlet]="label"></ng-template>
</label>
<div
class="cds--time-picker"
[ngClass]="{
'cds--time-picker--invalid' : invalid,
'cds--time-picker--sm': size === 'sm',
'cds--time-picker--md': size === 'md',
'cds--time-picker--lg': size === 'lg',
'cds--time-picker--light': theme === 'light'
}">
<div class="cds--time-picker__input">
<input
[ngClass]="{
'cds--text-input--light': theme === 'light',
'cds--skeleton': skeleton
}"
[value]="value"
[placeholder]="placeholder"
[attr.data-invalid]="invalid ? true : undefined"
[pattern]="pattern"
[attr.id]="id"
[disabled]="disabled"
[attr.maxlength]="maxLength"
(change)="onChange($event)"
type="text"
class="cds--time-picker__input-field cds--text-input">
</div>
<ng-content></ng-content>
</div>
<div *ngIf="invalid" class="cds--form-requirement">
<ng-container *ngIf="!isTemplate(invalidText)">{{invalidText}}</ng-container>
<ng-template *ngIf="isTemplate(invalidText)" [ngTemplateOutlet]="invalidText"></ng-template>
</div>
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TimePicker, decorators: [{
type: Component,
args: [{
selector: "cds-timepicker, ibm-timepicker",
template: `
<label
*ngIf="!skeleton && label"
[for]="id"
class="cds--label"
[ngClass]="{
'cds--label--disabled': disabled,
'cds--visually-hidden': hideLabel
}">
<ng-container *ngIf="!isTemplate(label)">{{label}}</ng-container>
<ng-template *ngIf="isTemplate(label)" [ngTemplateOutlet]="label"></ng-template>
</label>
<div
class="cds--time-picker"
[ngClass]="{
'cds--time-picker--invalid' : invalid,
'cds--time-picker--sm': size === 'sm',
'cds--time-picker--md': size === 'md',
'cds--time-picker--lg': size === 'lg',
'cds--time-picker--light': theme === 'light'
}">
<div class="cds--time-picker__input">
<input
[ngClass]="{
'cds--text-input--light': theme === 'light',
'cds--skeleton': skeleton
}"
[value]="value"
[placeholder]="placeholder"
[attr.data-invalid]="invalid ? true : undefined"
[pattern]="pattern"
[attr.id]="id"
[disabled]="disabled"
[attr.maxlength]="maxLength"
(change)="onChange($event)"
type="text"
class="cds--time-picker__input-field cds--text-input">
</div>
<ng-content></ng-content>
</div>
<div *ngIf="invalid" class="cds--form-requirement">
<ng-container *ngIf="!isTemplate(invalidText)">{{invalidText}}</ng-container>
<ng-template *ngIf="isTemplate(invalidText)" [ngTemplateOutlet]="invalidText"></ng-template>
</div>
`,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: TimePicker,
multi: true
}
]
}]
}], propDecorators: { invalid: [{
type: Input
}], invalidText: [{
type: Input
}], label: [{
type: Input
}], hideLabel: [{
type: Input
}], placeholder: [{
type: Input
}], pattern: [{
type: Input
}], id: [{
type: Input
}], disabled: [{
type: Input
}], value: [{
type: Input
}], maxLength: [{
type: Input
}], skeleton: [{
type: Input
}], theme: [{
type: Input
}], size: [{
type: Input
}], valueChange: [{
type: Output
}], timepickerClass: [{
type: HostBinding,
args: ["class.cds--form-item"]
}], focusOut: [{
type: HostListener,
args: ["focusout"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../src/timepicker/timepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tOutput,\n\tEventEmitter,\n\tHostBinding,\n\tTemplateRef,\n\tHostListener\n} from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from \"@angular/forms\";\n\n/**\n * Get started with importing the module:\n *\n * ```typescript\n * import { TimePickerModule } from 'carbon-components-angular';\n * ```\n *\n * [See demo](../../?path=/story/components-time-picker--simple)\n */\n@Component({\n\tselector: \"cds-timepicker, ibm-timepicker\",\n\ttemplate: `\n\t\t<label\n\t\t*ngIf=\"!skeleton && label\"\n\t\t[for]=\"id\"\n\t\tclass=\"cds--label\"\n\t\t[ngClass]=\"{\n\t\t\t'cds--label--disabled': disabled,\n\t\t\t'cds--visually-hidden': hideLabel\n\t\t}\">\n\t\t\t<ng-container *ngIf=\"!isTemplate(label)\">{{label}}</ng-container>\n\t\t\t<ng-template *ngIf=\"isTemplate(label)\" [ngTemplateOutlet]=\"label\"></ng-template>\n\t\t</label>\n\t\t<div\n\t\t\tclass=\"cds--time-picker\"\n\t\t\t[ngClass]=\"{\n\t\t\t\t'cds--time-picker--invalid' : invalid,\n\t\t\t\t'cds--time-picker--sm': size === 'sm',\n\t\t\t\t'cds--time-picker--md': size === 'md',\n\t\t\t\t'cds--time-picker--lg': size === 'lg',\n\t\t\t\t'cds--time-picker--light': theme === 'light'\n\t\t\t}\">\n\t\t\t<div class=\"cds--time-picker__input\">\n\t\t\t\t<input\n\t\t\t\t\t[ngClass]=\"{\n\t\t\t\t\t\t'cds--text-input--light': theme === 'light',\n\t\t\t\t\t\t'cds--skeleton': skeleton\n\t\t\t\t\t}\"\n\t\t\t\t\t[value]=\"value\"\n\t\t\t\t\t[placeholder]=\"placeholder\"\n\t\t\t\t\t[attr.data-invalid]=\"invalid ? true : undefined\"\n\t\t\t\t\t[pattern]=\"pattern\"\n\t\t\t\t\t[attr.id]=\"id\"\n\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t[attr.maxlength]=\"maxLength\"\n\t\t\t\t\t(change)=\"onChange($event)\"\n\t\t\t\t\ttype=\"text\"\n\t\t\t\t\tclass=\"cds--time-picker__input-field cds--text-input\">\n\t\t\t</div>\n\t\t\t<ng-content></ng-content>\n\t\t</div>\n\t\t<div *ngIf=\"invalid\" class=\"cds--form-requirement\">\n\t\t\t<ng-container *ngIf=\"!isTemplate(invalidText)\">{{invalidText}}</ng-container>\n\t\t\t<ng-template *ngIf=\"isTemplate(invalidText)\" [ngTemplateOutlet]=\"invalidText\"></ng-template>\n\t\t</div>\n\t`,\n\tproviders: [\n\t\t{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: TimePicker,\n\t\t\tmulti: true\n\t\t}\n\t]\n})\nexport class TimePicker implements ControlValueAccessor {\n\t/**\n\t * Tracks the total number of selects instantiated. Used to generate unique IDs\n\t */\n\tstatic timePickerCount = 0;\n\n\t@Input() invalid = false;\n\t@Input() invalidText: string | TemplateRef<any>;\n\t@Input() label: string | TemplateRef<any>;\n\t@Input() hideLabel = false;\n\t@Input() placeholder = \"hh:mm\";\n\t@Input() pattern = \"(1[012]|[0-9]):[0-5][0-9]\";\n\t@Input() id = `timepicker-${TimePicker.timePickerCount++}`;\n\t@Input() disabled = false;\n\t@Input() value: string;\n\t@Input() maxLength = 5;\n\n\t/**\n\t * Set to true for a loading select.\n\t */\n\t@Input() skeleton = false;\n\n\t/**\n\t * @deprecated since v5 - Use `cdsLayer` directive instead\n\t */\n\t@Input() theme: \"light\" | \"dark\" = \"dark\";\n\n\t/**\n\t * `sm`, `md` (default), or `lg` select size\n\t */\n\t@Input() size: \"sm\" | \"md\" | \"lg\" = \"md\";\n\n\t@Output() valueChange: EventEmitter<string> = new EventEmitter();\n\n\t/**\n\t * Ensures component is properly styled when used standalone.\n\t */\n\t@HostBinding(\"class.cds--form-item\") timepickerClass = true;\n\n\twriteValue(value: string) {\n\t\tthis.value = value;\n\t}\n\n\tregisterOnChange(callback: any) {\n\t\tthis.onChangeHandler = callback;\n\t}\n\n\tregisterOnTouched(callback: any) {\n\t\tthis.onTouchedHandler = callback;\n\t}\n\n\tsetDisabledState(isDisabled: boolean) {\n\t\tthis.disabled = isDisabled;\n\t}\n\n\tonChange(event) {\n\t\tthis.onChangeHandler(event.target.value);\n\t\tthis.valueChange.emit(event.target.value);\n\t}\n\n\t@HostListener(\"focusout\")\n\tfocusOut() {\n\t\tthis.onTouchedHandler();\n\t}\n\n\tpublic isTemplate(value) {\n\t\treturn value instanceof TemplateRef;\n\t}\n\n\tprotected onChangeHandler = (_: any) => { };\n\tprotected onTouchedHandler = () => { };\n}\n"]}