UNPKG

@hxui/angular

Version:

An Angular library based on the [HXUI design system](https://hxui.io).

170 lines 28.7 kB
import { Component, EventEmitter, Input, Output, } from '@angular/core'; import { FormBuilder, Validators } from '@angular/forms'; import moment from 'moment'; import { Subscription } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; import * as i2 from "@angular/common"; export class DatepickerIntervalComponent { constructor(_fb) { this._fb = _fb; this.durationOptions = ['day', 'week', 'month', 'year']; this.duration = 'days'; this.increment = 0; this.value$ = new Subscription(); this.update = new EventEmitter(); this.cancel = new EventEmitter(); } ngOnInit() { // date selected from interval if (this.selectedInterval && this.selectedInterval.isSelectedFromInterval && this.selectedInterval.interval) { const intervalArr = this.selectedInterval.interval.split(' '); if (intervalArr && intervalArr.length > 1) { this.increment = parseInt(intervalArr[0], 10); this.duration = this.normaliseDurationString(intervalArr[1]); } // date is typed or calendar picker } else if (this.selectedDate) { const selected = moment(this.selectedDate); const today = moment().startOf('day'); const duration = 'days'; const daysBetween = selected.diff(today, duration); if (daysBetween && daysBetween > 0) { this.increment = daysBetween; this.duration = duration; } } this.onSelectoptions(this.increment, this.duration); this.form = this._fb.group({ number: [this.increment, Validators.min(0)], duration: [this.duration], }); this.onValueChanges(); } ngOnDestroy() { this.value$.unsubscribe(); } onValueChanges() { this.value$ = this.form.valueChanges.subscribe(val => { this.onSelectoptions(val.number, val.duration); }); } /** on cancel of interval form */ onCancel() { this.cancel.emit(); } onSelectoptions(numberValue, durationValue) { this.text = moment().add(numberValue, durationValue); this.dateLabel = this.text.format('ddd DD/MM/YYYY'); this._dueDatestring = this.text.format('YYYY-MM-DD'); } /** on submission of interval form */ onChoose($event) { $event.preventDefault(); // check form is valid if (this.form.valid) { const intervalSubmitted = this.form.value.number.toString() + ' ' + this.normaliseDurationString(this.form.value.duration, 'optional'); const dateSubmitted = new Date(this._dueDatestring); const result = { interval: intervalSubmitted, isSelectedFromInterval: true, date: dateSubmitted, }; // emit result this.update.emit(result); } } /** normalise duration string */ normaliseDurationString(duration, output = 'plural') { const singular = this.durationOptions; const plural = singular.map(val => val + 's'); const optional = singular.map(val => val + '(s)'); const current = currentFormat(duration); let result = [`${output}`][0] || 'days'; if (output === 'singular') { result = toSingular(duration); } else if (output === 'plural') { result = toPlural(duration); } else if (output === 'optional') { result = toOptional(duration); } return result; function currentFormat(str) { if (singular.includes(str)) { return 'singular'; } else if (plural.includes(str)) { return 'plural'; } else if (optional.includes(str)) { return 'optional'; } else { return undefined; } } function toSingular(str) { let result = singular[0]; if (current === 'singular') { result = str; } else if (current === 'plural') { result = str.replace('s', ''); } else if (current === 'optional') { result = str.replace('(s)', ''); } return result; } function toPlural(str) { let result = plural[0]; if (current === 'singular') { result = str + 's'; } else if (current === 'plural') { result = str; } else if (current === 'optional') { result = str.replace('(s)', 's'); } return result; } function toOptional(str) { let result = optional[0]; if (current === 'singular') { result = str + '(s)'; } else if (current === 'plural') { result = str.replace('s', '(s)'); } else if (current === 'optional') { result = str; } return result; } } } DatepickerIntervalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DatepickerIntervalComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); DatepickerIntervalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DatepickerIntervalComponent, selector: "hxa-datepicker-interval", inputs: { selectedDate: "selectedDate", selectedInterval: "selectedInterval" }, outputs: { update: "update", cancel: "cancel" }, host: { classAttribute: "hx-card hxa-datepicker-interval" }, ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onChoose($event)\">\r\n <section class=\"hxa-datepicker-interval__content\">\r\n <fieldset class=\"hxa-datepicker-interval__inputs\">\r\n <input\r\n type=\"number\"\r\n id=\"numberText\"\r\n class=\"hx-input\"\r\n formControlName=\"number\"\r\n min=\"0\"\r\n />\r\n\r\n <select id=\"durationText\" class=\"hx-input\" formControlName=\"duration\">\r\n <option *ngFor=\"let opt of durationOptions\" [value]=\"opt + 's'\">\r\n {{ opt + '(s)' }}\r\n </option>\r\n </select>\r\n\r\n <span>from today</span>\r\n </fieldset>\r\n\r\n <div class=\"hxa-datepicker-interval__output\">\r\n <span>will be </span>\r\n <span class=\"is-text-weight-bolder\">{{ dateLabel }}</span>\r\n </div>\r\n </section>\r\n\r\n <section class=\"hxa-datepicker-interval__footer\">\r\n <button class=\"hx-button\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"submit\" class=\"hx-button is-primary\">Select</button>\r\n </section>\r\n</form>\r\n", styles: [":host.hx-card{border:unset}:host.hx-card:hover,:host.hx-card.is-hovered{box-shadow:none}.hxa-datepicker-interval:host{display:flex;flex-direction:column;width:19rem;height:21rem}.hxa-datepicker-interval:host>form{display:flex;flex-direction:column;font-size:1rem;flex:1 1 auto}.hxa-datepicker-interval__content{display:flex;flex-direction:column;flex:1 1 auto;justify-content:center;padding:.75rem}.hxa-datepicker-interval__inputs{border:none;display:block;padding:0;margin:0 auto 1.25rem}.hxa-datepicker-interval__inputs .hx-input{display:inline-block;width:unset}.hxa-datepicker-interval__inputs .hx-input:first-child{width:2.5rem}.hxa-datepicker-interval__inputs .hx-input:not(:last-child){margin-right:1rem}.hxa-datepicker-interval__output{margin:0 auto}.hxa-datepicker-interval__footer{background-color:#f5f5f5;padding:.75rem;display:flex;justify-content:space-between}\n"], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { type: i1.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DatepickerIntervalComponent, decorators: [{ type: Component, args: [{ selector: 'hxa-datepicker-interval', host: { class: 'hx-card hxa-datepicker-interval', }, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onChoose($event)\">\r\n <section class=\"hxa-datepicker-interval__content\">\r\n <fieldset class=\"hxa-datepicker-interval__inputs\">\r\n <input\r\n type=\"number\"\r\n id=\"numberText\"\r\n class=\"hx-input\"\r\n formControlName=\"number\"\r\n min=\"0\"\r\n />\r\n\r\n <select id=\"durationText\" class=\"hx-input\" formControlName=\"duration\">\r\n <option *ngFor=\"let opt of durationOptions\" [value]=\"opt + 's'\">\r\n {{ opt + '(s)' }}\r\n </option>\r\n </select>\r\n\r\n <span>from today</span>\r\n </fieldset>\r\n\r\n <div class=\"hxa-datepicker-interval__output\">\r\n <span>will be </span>\r\n <span class=\"is-text-weight-bolder\">{{ dateLabel }}</span>\r\n </div>\r\n </section>\r\n\r\n <section class=\"hxa-datepicker-interval__footer\">\r\n <button class=\"hx-button\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"submit\" class=\"hx-button is-primary\">Select</button>\r\n </section>\r\n</form>\r\n", styles: [":host.hx-card{border:unset}:host.hx-card:hover,:host.hx-card.is-hovered{box-shadow:none}.hxa-datepicker-interval:host{display:flex;flex-direction:column;width:19rem;height:21rem}.hxa-datepicker-interval:host>form{display:flex;flex-direction:column;font-size:1rem;flex:1 1 auto}.hxa-datepicker-interval__content{display:flex;flex-direction:column;flex:1 1 auto;justify-content:center;padding:.75rem}.hxa-datepicker-interval__inputs{border:none;display:block;padding:0;margin:0 auto 1.25rem}.hxa-datepicker-interval__inputs .hx-input{display:inline-block;width:unset}.hxa-datepicker-interval__inputs .hx-input:first-child{width:2.5rem}.hxa-datepicker-interval__inputs .hx-input:not(:last-child){margin-right:1rem}.hxa-datepicker-interval__output{margin:0 auto}.hxa-datepicker-interval__footer{background-color:#f5f5f5;padding:.75rem;display:flex;justify-content:space-between}\n"] }] }], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { selectedDate: [{ type: Input }], selectedInterval: [{ type: Input }], update: [{ type: Output }], cancel: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-interval.component.js","sourceRoot":"","sources":["../../../../../projects/hx-ui/src/lib/datepicker/datepicker-interval.component.ts","../../../../../projects/hx-ui/src/lib/datepicker/datepicker-interval.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport moment from 'moment';\r\nimport { Subscription } from 'rxjs';\r\nimport { DatePickerInterval } from './datepicker.model';\r\n\r\n@Component({\r\n  selector: 'hxa-datepicker-interval',\r\n  templateUrl: './datepicker-interval.component.html',\r\n  styleUrls: ['./datepicker-interval.component.scss'],\r\n  host: {\r\n    class: 'hx-card hxa-datepicker-interval',\r\n  },\r\n})\r\nexport class DatepickerIntervalComponent implements OnInit, OnDestroy {\r\n  durationOptions = ['day', 'week', 'month', 'year'];\r\n  duration = 'days';\r\n  increment = 0;\r\n  text: moment.Moment;\r\n  dateLabel: string;\r\n  public _dueDatestring: string;\r\n\r\n  private value$: Subscription = new Subscription();\r\n  form: FormGroup;\r\n\r\n  @Input()\r\n  selectedDate: Date;\r\n\r\n  @Input()\r\n  selectedInterval: DatePickerInterval;\r\n\r\n  @Output()\r\n  update = new EventEmitter<DatePickerInterval & { date: Date }>();\r\n\r\n  @Output()\r\n  cancel = new EventEmitter<void>();\r\n\r\n  constructor(private _fb: FormBuilder) {}\r\n\r\n  ngOnInit(): void {\r\n    // date selected from interval\r\n    if (\r\n      this.selectedInterval &&\r\n      this.selectedInterval.isSelectedFromInterval &&\r\n      this.selectedInterval.interval\r\n    ) {\r\n      const intervalArr = this.selectedInterval.interval.split(' ');\r\n\r\n      if (intervalArr && intervalArr.length > 1) {\r\n        this.increment = parseInt(intervalArr[0], 10);\r\n        this.duration = this.normaliseDurationString(intervalArr[1]);\r\n      }\r\n\r\n      // date is typed or calendar picker\r\n    } else if (this.selectedDate) {\r\n      const selected = moment(this.selectedDate);\r\n      const today = moment().startOf('day');\r\n      const duration = 'days';\r\n\r\n      const daysBetween: number = selected.diff(today, duration);\r\n\r\n      if (daysBetween && daysBetween > 0) {\r\n        this.increment = daysBetween;\r\n        this.duration = duration;\r\n      }\r\n    }\r\n\r\n    this.onSelectoptions(this.increment, this.duration);\r\n\r\n    this.form = this._fb.group({\r\n      number: [this.increment, Validators.min(0)],\r\n      duration: [this.duration],\r\n    });\r\n\r\n    this.onValueChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.value$.unsubscribe();\r\n  }\r\n\r\n  onValueChanges(): void {\r\n    this.value$ = this.form.valueChanges.subscribe(val => {\r\n      this.onSelectoptions(val.number, val.duration);\r\n    });\r\n  }\r\n\r\n  /** on cancel of interval form */\r\n  onCancel(): void {\r\n    this.cancel.emit();\r\n  }\r\n\r\n  onSelectoptions(numberValue: number, durationValue: string): void {\r\n    this.text = moment().add(\r\n      numberValue as moment.DurationInputArg1,\r\n      durationValue as moment.DurationInputArg2\r\n    );\r\n    this.dateLabel = this.text.format('ddd DD/MM/YYYY');\r\n    this._dueDatestring = this.text.format('YYYY-MM-DD');\r\n  }\r\n\r\n  /** on submission of interval form */\r\n  onChoose($event: SubmitEvent) {\r\n    $event.preventDefault();\r\n    // check form is valid\r\n    if (this.form.valid) {\r\n      const intervalSubmitted =\r\n        this.form.value.number.toString() +\r\n        ' ' +\r\n        this.normaliseDurationString(this.form.value.duration, 'optional');\r\n\r\n      const dateSubmitted = new Date(this._dueDatestring);\r\n\r\n      const result = {\r\n        interval: intervalSubmitted,\r\n        isSelectedFromInterval: true,\r\n        date: dateSubmitted,\r\n      };\r\n\r\n      // emit result\r\n      this.update.emit(result);\r\n    }\r\n  }\r\n\r\n  /** normalise duration string */\r\n  normaliseDurationString(\r\n    duration: string,\r\n    output: 'singular' | 'plural' | 'optional' = 'plural'\r\n  ): string {\r\n    const singular = this.durationOptions;\r\n    const plural = singular.map(val => val + 's');\r\n    const optional = singular.map(val => val + '(s)');\r\n\r\n    const current = currentFormat(duration);\r\n\r\n    let result = [`${output}`][0] || 'days';\r\n\r\n    if (output === 'singular') {\r\n      result = toSingular(duration);\r\n    } else if (output === 'plural') {\r\n      result = toPlural(duration);\r\n    } else if (output === 'optional') {\r\n      result = toOptional(duration);\r\n    }\r\n\r\n    return result;\r\n\r\n    function currentFormat(str: string): string | undefined {\r\n      if (singular.includes(str)) {\r\n        return 'singular';\r\n      } else if (plural.includes(str)) {\r\n        return 'plural';\r\n      } else if (optional.includes(str)) {\r\n        return 'optional';\r\n      } else {\r\n        return undefined;\r\n      }\r\n    }\r\n\r\n    function toSingular(str: string): string {\r\n      let result = singular[0];\r\n      if (current === 'singular') {\r\n        result = str;\r\n      } else if (current === 'plural') {\r\n        result = str.replace('s', '');\r\n      } else if (current === 'optional') {\r\n        result = str.replace('(s)', '');\r\n      }\r\n      return result;\r\n    }\r\n\r\n    function toPlural(str: string): string {\r\n      let result = plural[0];\r\n      if (current === 'singular') {\r\n        result = str + 's';\r\n      } else if (current === 'plural') {\r\n        result = str;\r\n      } else if (current === 'optional') {\r\n        result = str.replace('(s)', 's');\r\n      }\r\n      return result;\r\n    }\r\n\r\n    function toOptional(str: string): string {\r\n      let result = optional[0];\r\n      if (current === 'singular') {\r\n        result = str + '(s)';\r\n      } else if (current === 'plural') {\r\n        result = str.replace('s', '(s)');\r\n      } else if (current === 'optional') {\r\n        result = str;\r\n      }\r\n      return result;\r\n    }\r\n  }\r\n}\r\n","<form [formGroup]=\"form\" (ngSubmit)=\"onChoose($event)\">\r\n  <section class=\"hxa-datepicker-interval__content\">\r\n    <fieldset class=\"hxa-datepicker-interval__inputs\">\r\n      <input\r\n        type=\"number\"\r\n        id=\"numberText\"\r\n        class=\"hx-input\"\r\n        formControlName=\"number\"\r\n        min=\"0\"\r\n      />\r\n\r\n      <select id=\"durationText\" class=\"hx-input\" formControlName=\"duration\">\r\n        <option *ngFor=\"let opt of durationOptions\" [value]=\"opt + 's'\">\r\n          {{ opt + '(s)' }}\r\n        </option>\r\n      </select>\r\n\r\n      <span>from today</span>\r\n    </fieldset>\r\n\r\n    <div class=\"hxa-datepicker-interval__output\">\r\n      <span>will be </span>\r\n      <span class=\"is-text-weight-bolder\">{{ dateLabel }}</span>\r\n    </div>\r\n  </section>\r\n\r\n  <section class=\"hxa-datepicker-interval__footer\">\r\n    <button class=\"hx-button\" (click)=\"onCancel()\">Cancel</button>\r\n    <button type=\"submit\" class=\"hx-button is-primary\">Select</button>\r\n  </section>\r\n</form>\r\n"]}