@hxui/angular
Version:
An Angular library based on the [HXUI design system](https://hxui.io).
170 lines • 28.7 kB
JavaScript
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"]}