@candidosales/material-time-picker
Version:
Time Picker for Angular
119 lines • 17.5 kB
JavaScript
import { Component, EventEmitter, Input, Output, ViewEncapsulation, } from "@angular/core";
import { Utils } from "../utils";
import { WTimeDialogComponent } from "../w-time-dialog/w-time-dialog.component";
import { MatIcon } from "@angular/material/icon";
import { MatInput } from "@angular/material/input";
import { MatFormField, MatLabel, MatSuffix } from "@angular/material/form-field";
import * as i0 from "@angular/core";
import * as i1 from "@angular/material/dialog";
export class MaterialTimePickerComponent {
constructor(dialog) {
this.dialog = dialog;
this.label = "Hour";
this.appearance = "fill";
this.change = new EventEmitter();
}
ngOnInit() {
if (!this.userTime) {
this.userTime = {
hour: 0,
minute: 0,
meriden: "PM",
format: 24,
};
}
}
time() {
if (!this.userTime) {
return "";
}
let meriden = `${this.userTime.meriden}`;
if (this.userTime.format === 24) {
meriden = "";
}
let hour = `${this.userTime.hour}`;
if (this.userTime.hour === 24) {
hour = "00";
}
if (this.userTime.minute === 0) {
return `${hour}:00 ${meriden}`;
}
else if (this.userTime.minute < 10) {
const tt = "0" + String(this.userTime.minute);
return `${hour}:${tt} ${meriden}`;
}
else {
return `${hour}:${this.userTime.minute} ${meriden}`;
}
}
showPicker() {
const dialogRef = this.dialog.open(WTimeDialogComponent, {
data: {
time: {
hour: this.userTime.hour,
minute: this.userTime.minute,
meriden: this.userTime.meriden,
format: this.userTime.format,
},
color: this.color,
revertLabel: this.revertLabel,
submitLabel: this.submitLabel,
},
});
dialogRef.afterClosed().subscribe((result) => {
// result will be update userTime object or -1 or undefined (closed dialog w/o clicking cancel)
if (result === undefined) {
return;
}
else if (result !== -1) {
this.userTime = result;
const hour = result.hour;
const minute = result.minute;
const dataEvent = {
hour: Utils.formatHour(result.format, hour),
minute: Utils.formatMinute(minute),
meriden: this.userTime.meriden,
format: this.userTime.format,
};
this.emitChange(dataEvent);
}
});
return false;
}
emitChange(data) {
this.change.emit(data);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: MaterialTimePickerComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: MaterialTimePickerComponent, isStandalone: true, selector: "material-timepicker", inputs: { label: "label", appearance: "appearance", userTime: "userTime", color: "color", revertLabel: "revertLabel", submitLabel: "submitLabel", disabled: "disabled", readonly: "readonly", classFormField: "classFormField" }, outputs: { change: "change" }, ngImport: i0, template: "<div class=\"d-flex flex-row w-mat-timepicker\">\n <mat-form-field class=\"d-flex {{classFormField}}\" class=\"timeContainer\" appearance=\"{{appearance}}\">\n <mat-label>{{ label }}</mat-label>\n <input matInput class=\"timeInput\" placeholder=\"Select time\" id=\"time_Control\" name=\"time_Control\" [value]=\"time()\" [disabled]=\"disabled\" [readonly]=\"readonly\">\n <mat-icon matSuffix (click)=\"showPicker()\">access_time</mat-icon>\n </mat-form-field>\n</div>\n", styles: [".d-flex{display:flex}.flex-row{flex-direction:row}.flex-column{flex-direction:column}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.align-items-end{align-items:end}@media (min-width: 768px){.flex-md-row{flex-direction:row}.flex-md-column{flex-direction:column}}.time-picker-button{padding:0;margin:0;min-width:44px}.mat-mdc-form-field-flex{display:inline-flex;align-items:center;box-sizing:border-box;width:100%}\n"], dependencies: [{ kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: MaterialTimePickerComponent, decorators: [{
type: Component,
args: [{ selector: "material-timepicker", encapsulation: ViewEncapsulation.None, standalone: true, imports: [
MatFormField,
MatLabel,
MatInput,
MatIcon,
MatSuffix,
], template: "<div class=\"d-flex flex-row w-mat-timepicker\">\n <mat-form-field class=\"d-flex {{classFormField}}\" class=\"timeContainer\" appearance=\"{{appearance}}\">\n <mat-label>{{ label }}</mat-label>\n <input matInput class=\"timeInput\" placeholder=\"Select time\" id=\"time_Control\" name=\"time_Control\" [value]=\"time()\" [disabled]=\"disabled\" [readonly]=\"readonly\">\n <mat-icon matSuffix (click)=\"showPicker()\">access_time</mat-icon>\n </mat-form-field>\n</div>\n", styles: [".d-flex{display:flex}.flex-row{flex-direction:row}.flex-column{flex-direction:column}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.align-items-end{align-items:end}@media (min-width: 768px){.flex-md-row{flex-direction:row}.flex-md-column{flex-direction:column}}.time-picker-button{padding:0;margin:0;min-width:44px}.mat-mdc-form-field-flex{display:inline-flex;align-items:center;box-sizing:border-box;width:100%}\n"] }]
}], ctorParameters: () => [{ type: i1.MatDialog }], propDecorators: { label: [{
type: Input
}], appearance: [{
type: Input
}], userTime: [{
type: Input
}], color: [{
type: Input
}], revertLabel: [{
type: Input
}], submitLabel: [{
type: Input
}], disabled: [{
type: Input
}], readonly: [{
type: Input
}], classFormField: [{
type: Input
}], change: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-timepicker.component.js","sourceRoot":"","sources":["../../../../../projects/material-time-picker/src/lib/material-timepicker/material-timepicker.component.ts","../../../../../projects/material-time-picker/src/lib/material-timepicker/material-timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { ITime } from \"../w-clock/w-clock.component\";\nimport { MatDialog } from \"@angular/material/dialog\";\nimport { Utils } from \"../utils\";\nimport { WTimeDialogComponent } from \"../w-time-dialog/w-time-dialog.component\";\nimport { MatIcon } from \"@angular/material/icon\";\nimport { MatInput } from \"@angular/material/input\";\nimport { MatFormField, MatLabel, MatSuffix } from \"@angular/material/form-field\";\n\n@Component({\n    selector: \"material-timepicker\",\n    styleUrls: [\"./material-timepicker.component.scss\"],\n    templateUrl: \"./material-timepicker.component.html\",\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [\n        MatFormField,\n        MatLabel,\n        MatInput,\n        MatIcon,\n        MatSuffix,\n    ],\n})\nexport class MaterialTimePickerComponent implements OnInit {\n  @Input() label = \"Hour\";\n  @Input() appearance = \"fill\";\n  @Input() userTime: ITime;\n  @Input() color: string;\n  @Input() revertLabel: string;\n  @Input() submitLabel: string;\n  @Input() disabled: boolean;\n  @Input() readonly: boolean;\n  /**\n   * Class to put in the form-field\n   */\n  @Input() classFormField: string;\n\n  @Output() change: EventEmitter<ITime> = new EventEmitter<ITime>();\n\n  constructor(private dialog: MatDialog) {}\n\n  ngOnInit() {\n    if (!this.userTime) {\n      this.userTime = {\n        hour: 0,\n        minute: 0,\n        meriden: \"PM\",\n        format: 24,\n      };\n    }\n  }\n\n  time(): string {\n    if (!this.userTime) {\n      return \"\";\n    }\n\n    let meriden = `${this.userTime.meriden}`;\n    if (this.userTime.format === 24) {\n      meriden = \"\";\n    }\n\n    let hour = `${this.userTime.hour}`;\n    if (this.userTime.hour === 24) {\n      hour = \"00\";\n    }\n\n    if (this.userTime.minute === 0) {\n      return `${hour}:00 ${meriden}`;\n    } else if (this.userTime.minute < 10) {\n      const tt = \"0\" + String(this.userTime.minute);\n      return `${hour}:${tt} ${meriden}`;\n    } else {\n      return `${hour}:${this.userTime.minute} ${meriden}`;\n    }\n  }\n\n  showPicker() {\n    const dialogRef = this.dialog.open(WTimeDialogComponent, {\n      data: {\n        time: {\n          hour: this.userTime.hour,\n          minute: this.userTime.minute,\n          meriden: this.userTime.meriden,\n          format: this.userTime.format,\n        },\n        color: this.color,\n        revertLabel: this.revertLabel,\n        submitLabel: this.submitLabel,\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result: ITime | -1) => {\n      // result will be update userTime object or -1 or undefined (closed dialog w/o clicking cancel)\n      if (result === undefined) {\n        return;\n      } else if (result !== -1) {\n        this.userTime = result;\n\n        const hour = result.hour;\n        const minute = result.minute;\n\n        const dataEvent = {\n          hour: Utils.formatHour(result.format, hour),\n          minute: Utils.formatMinute(minute),\n          meriden: this.userTime.meriden,\n          format: this.userTime.format,\n        };\n        this.emitChange(dataEvent);\n      }\n    });\n    return false;\n  }\n\n  private emitChange(data) {\n    this.change.emit(data);\n  }\n}\n","<div class=\"d-flex flex-row w-mat-timepicker\">\n  <mat-form-field class=\"d-flex {{classFormField}}\" class=\"timeContainer\" appearance=\"{{appearance}}\">\n      <mat-label>{{ label }}</mat-label>\n      <input matInput class=\"timeInput\" placeholder=\"Select time\" id=\"time_Control\" name=\"time_Control\" [value]=\"time()\" [disabled]=\"disabled\" [readonly]=\"readonly\">\n      <mat-icon matSuffix (click)=\"showPicker()\">access_time</mat-icon>\n  </mat-form-field>\n</div>\n"]}