sb-element
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 12.0.1. It is a component library constructed around the SCSS library [Sb-Theming](https://github.com/SeverinBuchser/SbTheming) and supports [Angular Schematics]
111 lines • 17.8 kB
JavaScript
import { Component, Input } from '@angular/core';
import { mixinDisable, mixinFocus, Color, Size } from "../../../core";
import { NG_VALUE_ACCESSOR } from "@angular/forms";
import * as fns from "date-fns";
import { SbDoubleInput } from "../../input";
import { MarkedDates } from "../../../calendar";
import * as i0 from "@angular/core";
import * as i1 from "../../../popper/popper/popper.component";
import * as i2 from "../../../calendar/calendar/calendar.component";
import * as i3 from "../../input/double-input/double-input.component";
import * as i4 from "../../../core/trigger/click-outside-trigger.directive";
import * as i5 from "@angular/forms";
const SbDateRangeInputCore = mixinDisable(mixinFocus(class {
}));
export class SbDateRangeInputComponent extends SbDateRangeInputCore {
constructor() {
super(...arguments);
this.color = Color.PRIMARY;
this.size = Size.MEDIUM;
this.format = 'yyyy-MM-dd';
this.markedDates = new MarkedDates();
this.pickerMarkedDates = new MarkedDates();
this.doubleInputDates = new SbDoubleInput();
this.onChange = () => { };
this.onTouch = () => { };
}
handlePickerSelect(date) {
if (this.pickerMarkedDates.isRangeDays || !this.pickerMarkedDates.start) {
this.pickerMarkedDates = new MarkedDates();
this.pickerMarkedDates.start = date;
}
else {
this.pickerMarkedDates.end = date;
}
if (this.doUpdate(this.pickerMarkedDates)) {
this.pickerMarkedDates.sort();
this.markedDates = this.pickerMarkedDates;
this.updateInput();
this.onChange(this.pickerMarkedDates);
}
}
handleInput(dates) {
const startDateString = dates.first;
const endDateString = dates.second;
var startDate = startDateString ? fns.parseISO(startDateString) : undefined;
var endDate = endDateString ? fns.parseISO(endDateString) : undefined;
const markedDates = new MarkedDates();
if (fns.isValid(startDate)) {
markedDates.start = startDate;
}
if (fns.isValid(endDate)) {
markedDates.end = endDate;
}
if (this.doUpdate(markedDates)) {
markedDates.sort();
this.markedDates = markedDates;
this.onChange(markedDates);
}
}
updateInput() {
if (this.markedDates.start && this.markedDates.end) {
this.doubleInputDates = new SbDoubleInput(fns.format(this.markedDates.start, this.format), fns.format(this.markedDates.end, this.format));
}
}
writeValue(dates) {
if (this.doUpdate(dates)) {
dates.sort();
this.markedDates = dates;
this.updateInput();
}
}
doUpdate(dates) {
if (dates && dates.start && dates.end) {
const isStartDateValid = fns.isValid(dates.start);
const isEndDateValid = fns.isValid(dates.end);
if (isStartDateValid && isEndDateValid) {
return true;
}
}
return false;
}
registerOnChange(fn) { this.onChange = fn; }
registerOnTouched(fn) { this.onTouch = fn; }
onBlur() { this.onTouch(); }
}
SbDateRangeInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbDateRangeInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
SbDateRangeInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: SbDateRangeInputComponent, selector: "sb-input[type=date-range]", inputs: { disabled: "disabled", color: "color", size: "size", format: "format" }, outputs: { focus: "focus", blur: "blur" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SbDateRangeInputComponent,
multi: true
}], usesInheritance: true, ngImport: i0, template: "<sb-popper #dateRangePopper position=\"bottom\">\n <sb-calendar popper\n [color]=\"color\"\n [markedDates]=\"markedDates\"\n (select)=\"handlePickerSelect($event)\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n </sb-calendar>\n <sb-input\n content\n [size]=\"size\"\n [color]=\"color\"\n firstPlaceholder=\"Start\"\n secondPlaceholder=\"End\"\n [prefixIcon]=\"'\\ue878'\"\n type=\"double\"\n [ngModel]=\"doubleInputDates\"\n (ngModelChange)=\"handleInput($event)\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\"\n sbElClickOutsideTrigger\n [triggerable]=\"dateRangePopper\">\n </sb-input>\n</sb-popper>\n", components: [{ type: i1.SbPopperComponent, selector: "sb-popper", inputs: ["visible", "position"], outputs: ["show", "hide"] }, { type: i2.SbCalendarsComponent, selector: "sb-calendar", inputs: ["color", "disabled", "weekDayFormat", "monthFormat", "yearFormat", "monthYearFormat", "selectionMode", "markedDates"], outputs: ["focus", "blur", "select"] }, { type: i3.SbDoubleInputComponent, selector: "sb-input[type=double]", inputs: ["size", "color", "disabled", "firstPlaceholder", "secondPlaceholder", "delimiter", "type", "spellcheck", "prefixIcon", "suffixIcon"], outputs: ["focus", "blur"] }], directives: [{ type: i4.SbClickOutsideTriggerDirective, selector: "[sbElClickOutsideTrigger]", inputs: ["triggerable"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: SbDateRangeInputComponent, decorators: [{
type: Component,
args: [{ selector: 'sb-input[type=date-range]', inputs: [
'disabled'
], outputs: [
'focus',
'blur'
], providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: SbDateRangeInputComponent,
multi: true
}], template: "<sb-popper #dateRangePopper position=\"bottom\">\n <sb-calendar popper\n [color]=\"color\"\n [markedDates]=\"markedDates\"\n (select)=\"handlePickerSelect($event)\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\">\n </sb-calendar>\n <sb-input\n content\n [size]=\"size\"\n [color]=\"color\"\n firstPlaceholder=\"Start\"\n secondPlaceholder=\"End\"\n [prefixIcon]=\"'\\ue878'\"\n type=\"double\"\n [ngModel]=\"doubleInputDates\"\n (ngModelChange)=\"handleInput($event)\"\n (blur)=\"setFocusedState(false)\"\n (focus)=\"setFocusedState(true)\"\n [disabled]=\"disabled\"\n sbElClickOutsideTrigger\n [triggerable]=\"dateRangePopper\">\n </sb-input>\n</sb-popper>\n" }]
}], propDecorators: { color: [{
type: Input
}], size: [{
type: Input
}], format: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-input.component.js","sourceRoot":"","sources":["../../../../../../../sb-element/src/lib/forms/date-input/date-range-input/date-range-input.component.ts","../../../../../../../sb-element/src/lib/forms/date-input/date-range-input/date-range-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { mixinDisable, mixinFocus, Color, Size } from \"../../../core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport * as fns from \"date-fns\";\nimport { SbDoubleInput } from \"../../input\";\nimport { MarkedDates } from \"../../../calendar\";\n\nconst SbDateRangeInputCore = mixinDisable(mixinFocus(class {}));\n\n@Component({\n  selector: 'sb-input[type=date-range]',\n  templateUrl: './date-range-input.component.html',\n  inputs: [\n    'disabled'\n  ],\n  outputs: [\n    'focus',\n    'blur'\n  ],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: SbDateRangeInputComponent,\n    multi: true\n  }]\n})\nexport class SbDateRangeInputComponent extends SbDateRangeInputCore implements ControlValueAccessor {\n\n  @Input()\n  public color: string = Color.PRIMARY;\n\n  @Input()\n  public size: string = Size.MEDIUM;\n\n  @Input()\n  public format: string = 'yyyy-MM-dd';\n\n  public markedDates: MarkedDates = new MarkedDates();\n  private pickerMarkedDates: MarkedDates = new MarkedDates();\n  public doubleInputDates: SbDoubleInput<string> = new SbDoubleInput();\n\n  private onChange: (dates: MarkedDates) => void = () => {};\n  private onTouch: () => void = () => {};\n\n  public handlePickerSelect(date: Date): void {\n    if (this.pickerMarkedDates.isRangeDays || !this.pickerMarkedDates.start) {\n      this.pickerMarkedDates = new MarkedDates();\n      this.pickerMarkedDates.start = date;\n    } else {\n      this.pickerMarkedDates.end = date;\n    }\n    if (this.doUpdate(this.pickerMarkedDates)) {\n      this.pickerMarkedDates.sort();\n      this.markedDates = this.pickerMarkedDates;\n      this.updateInput();\n      this.onChange(this.pickerMarkedDates);\n    }\n  }\n\n  public handleInput(dates: SbDoubleInput<string>): void {\n    const startDateString = dates.first;\n    const endDateString = dates.second;\n\n    var startDate = startDateString ? fns.parseISO(startDateString) : undefined;\n    var endDate = endDateString ? fns.parseISO(endDateString) : undefined;\n\n    const markedDates = new MarkedDates();\n\n    if (fns.isValid(startDate)) {\n      markedDates.start = startDate;\n    }\n\n    if (fns.isValid(endDate)) {\n      markedDates.end = endDate;\n    }\n\n    if (this.doUpdate(markedDates)) {\n      markedDates.sort();\n      this.markedDates = markedDates;\n      this.onChange(markedDates);\n    }\n  }\n\n  private updateInput(): void {\n    if (this.markedDates.start && this.markedDates.end) {\n      this.doubleInputDates = new SbDoubleInput(\n        fns.format(this.markedDates.start, this.format),\n        fns.format(this.markedDates.end, this.format)\n      );\n    }\n  }\n\n  public writeValue(dates: MarkedDates): void {\n    if (this.doUpdate(dates)) {\n      dates.sort();\n      this.markedDates = dates;\n      this.updateInput();\n    }\n  }\n\n  private doUpdate(dates: MarkedDates): boolean {\n    if (dates && dates.start && dates.end) {\n      const isStartDateValid = fns.isValid(dates.start);\n      const isEndDateValid = fns.isValid(dates.end);\n      if (isStartDateValid && isEndDateValid) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  public registerOnChange(fn: (dates: MarkedDates) => void): void { this.onChange = fn }\n  public registerOnTouched(fn: any): void { this.onTouch = fn }\n  protected onBlur(): void { this.onTouch() }\n\n}\n","<sb-popper #dateRangePopper position=\"bottom\">\n  <sb-calendar popper\n    [color]=\"color\"\n    [markedDates]=\"markedDates\"\n    (select)=\"handlePickerSelect($event)\"\n    (blur)=\"setFocusedState(false)\"\n    (focus)=\"setFocusedState(true)\"\n    [disabled]=\"disabled\">\n  </sb-calendar>\n  <sb-input\n    content\n    [size]=\"size\"\n    [color]=\"color\"\n    firstPlaceholder=\"Start\"\n    secondPlaceholder=\"End\"\n    [prefixIcon]=\"'\\ue878'\"\n    type=\"double\"\n    [ngModel]=\"doubleInputDates\"\n    (ngModelChange)=\"handleInput($event)\"\n    (blur)=\"setFocusedState(false)\"\n    (focus)=\"setFocusedState(true)\"\n    [disabled]=\"disabled\"\n    sbElClickOutsideTrigger\n    [triggerable]=\"dateRangePopper\">\n  </sb-input>\n</sb-popper>\n"]}