ngx-numeric-range-form-field
Version:
Angular material numeric range form field
191 lines • 26.1 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, Self, SkipSelf } from '@angular/core';
import { ErrorStateMatcher } from '@angular/material/core';
import { MatFormFieldControl } from '@angular/material/form-field';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { NumericRangeStateMatcher } from '../form/numeric-range-state-matcher';
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
import * as i2 from "../form/numeric-range-form.service";
import * as i3 from "@angular/material/input";
export class NumericRangeFormFieldControlComponent {
static { this.nextId = 0; }
get value() {
return this.formGroup.getRawValue();
}
set value(value) {
this.formGroup.patchValue(value);
this.stateChanges.next();
}
get placeholder() {
return this._placeholder;
}
set placeholder(value) {
this._placeholder = value;
this.stateChanges.next();
}
get shouldLabelFloat() {
return true;
}
get empty() {
return !this.value.minimum && !this.value.maximum;
}
get errorState() {
return this.numericRangeErrorMatcher.isErrorState(this.ngControl.control, this.formGroup);
}
get minimumControl() {
return this.formService.minimumControl;
}
get maximumControl() {
return this.formService.maximumControl;
}
constructor(ngControl, formService) {
this.ngControl = ngControl;
this.formService = formService;
this.readonly = false;
this.minReadonly = false;
this.maxReadonly = false;
this.blurred = new EventEmitter();
this.enterPressed = new EventEmitter();
this.numericRangeChanged = new EventEmitter();
this.userAriaDescribedBy = '';
this.id = `numeric-range-form-control-id-${NumericRangeFormFieldControlComponent.nextId++}`;
this.formGroup = this.formService.formGroup;
this.stateChanges = new Subject();
this.focused = false;
this.controlType = 'numeric-range-form-control';
this.numericRangeErrorMatcher = new NumericRangeStateMatcher();
this.unsubscribe$ = new Subject();
this.onTouched = () => { };
this.ngControl.valueAccessor = this;
}
ngOnChanges(changes) {
if (changes.dynamicSyncValidators) {
this.formService.setDynamicValidators(this.dynamicSyncValidators);
}
}
ngOnInit() {
this.formService.setSyncValidators(this.ngControl.control.validator);
this.formService.setAsyncValidators(this.ngControl.control.asyncValidator);
this.ngControl.control.setValidators([this.validate.bind(this)]);
this.ngControl.control.updateValueAndValidity({ emitEvent: false });
}
ngDoCheck() {
this.formGroup.markAllAsTouched();
}
ngOnDestroy() {
this.stateChanges.complete();
this.unsubscribe$.next();
this.unsubscribe$.complete();
}
writeValue(value) {
value === null
? this.formGroup.reset()
: this.formGroup.setValue(value, { emitEvent: false });
}
registerOnChange(fn) {
this.formGroup.valueChanges
.pipe(takeUntil(this.unsubscribe$))
.subscribe(fn);
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
isDisabled ? this.formGroup.disable() : this.formGroup.enable();
this.stateChanges.next();
}
setDescribedByIds(ids) {
this.userAriaDescribedBy = ids.join(' ');
}
onContainerClick(event) { }
validate(control) {
return control.errors;
}
onEnterPressed() {
if (!this.formGroup.errors &&
!this.minimumControl.errors &&
!this.maximumControl.errors) {
this.enterPressed.emit();
}
}
onBlur() {
this.onTouched();
this.blurred.emit();
}
onRangeValuesChanged() {
this.formGroup.errors ||
this.minimumControl.errors ||
this.maximumControl.errors
? this.numericRangeChanged.emit(null)
: this.numericRangeChanged.emit(this.formGroup.getRawValue());
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: NumericRangeFormFieldControlComponent, deps: [{ token: i1.NgControl, self: true }, { token: i2.NumericRangeFormService, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: NumericRangeFormFieldControlComponent, selector: "ngx-numeric-range-form-field-control", inputs: { value: "value", placeholder: "placeholder", minPlaceholder: "minPlaceholder", maxPlaceholder: "maxPlaceholder", readonly: "readonly", minReadonly: "minReadonly", maxReadonly: "maxReadonly", required: "required", disabled: "disabled", errorStateMatcher: "errorStateMatcher", autofilled: "autofilled", dynamicSyncValidators: "dynamicSyncValidators" }, outputs: { blurred: "blurred", enterPressed: "enterPressed", numericRangeChanged: "numericRangeChanged" }, host: { properties: { "class.floated": "this.shouldLabelFloat", "attr.aria-describedby": "this.userAriaDescribedBy", "id": "this.id" } }, providers: [
{
provide: MatFormFieldControl,
useExisting: NumericRangeFormFieldControlComponent
},
{
provide: ErrorStateMatcher,
useClass: NumericRangeStateMatcher
}
], usesOnChanges: true, ngImport: i0, template: "<input\n\t(blur)=\"onBlur()\"\n\t(change)=\"onRangeValuesChanged()\"\n\t(keyup.enter)=\"onEnterPressed()\"\n\t[readonly]=\"readonly || minReadonly\"\n\t[formControl]=\"minimumControl\"\n\tmatInput\n\t[placeholder]=\"minPlaceholder\"\n\ttype=\"number\"\n/>\n<span class=\"spacer\">–</span>\n<input\n\t(blur)=\"onBlur()\"\n\t(change)=\"onRangeValuesChanged()\"\n\t(keyup.enter)=\"onEnterPressed()\"\n\t[formControl]=\"maximumControl\"\n\t[readonly]=\"readonly || maxReadonly\"\n\tmatInput\n\t[placeholder]=\"maxPlaceholder\"\n\ttype=\"number\"\n/>\n", styles: [":host{display:flex;align-items:center}:host .spacer{padding:0 10px 0 0;cursor:context-menu}:host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}:host input:read-only{color:#00000080;cursor:initial}\n"], dependencies: [{ kind: "directive", 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]" }, { kind: "directive", type: i1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: NumericRangeFormFieldControlComponent, decorators: [{
type: Component,
args: [{ selector: 'ngx-numeric-range-form-field-control', providers: [
{
provide: MatFormFieldControl,
useExisting: NumericRangeFormFieldControlComponent
},
{
provide: ErrorStateMatcher,
useClass: NumericRangeStateMatcher
}
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<input\n\t(blur)=\"onBlur()\"\n\t(change)=\"onRangeValuesChanged()\"\n\t(keyup.enter)=\"onEnterPressed()\"\n\t[readonly]=\"readonly || minReadonly\"\n\t[formControl]=\"minimumControl\"\n\tmatInput\n\t[placeholder]=\"minPlaceholder\"\n\ttype=\"number\"\n/>\n<span class=\"spacer\">–</span>\n<input\n\t(blur)=\"onBlur()\"\n\t(change)=\"onRangeValuesChanged()\"\n\t(keyup.enter)=\"onEnterPressed()\"\n\t[formControl]=\"maximumControl\"\n\t[readonly]=\"readonly || maxReadonly\"\n\tmatInput\n\t[placeholder]=\"maxPlaceholder\"\n\ttype=\"number\"\n/>\n", styles: [":host{display:flex;align-items:center}:host .spacer{padding:0 10px 0 0;cursor:context-menu}:host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}:host input:read-only{color:#00000080;cursor:initial}\n"] }]
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
type: Self
}] }, { type: i2.NumericRangeFormService, decorators: [{
type: SkipSelf
}] }], propDecorators: { value: [{
type: Input
}], placeholder: [{
type: Input
}], minPlaceholder: [{
type: Input
}], maxPlaceholder: [{
type: Input
}], readonly: [{
type: Input
}], minReadonly: [{
type: Input
}], maxReadonly: [{
type: Input
}], required: [{
type: Input
}], disabled: [{
type: Input
}], errorStateMatcher: [{
type: Input
}], autofilled: [{
type: Input
}], dynamicSyncValidators: [{
type: Input
}], blurred: [{
type: Output
}], enterPressed: [{
type: Output
}], numericRangeChanged: [{
type: Output
}], shouldLabelFloat: [{
type: HostBinding,
args: ['class.floated']
}], userAriaDescribedBy: [{
type: HostBinding,
args: ['attr.aria-describedby']
}], id: [{
type: HostBinding
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"numeric-range-form-field-control.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-numeric-range-form-field/src/lib/control/numeric-range-form-field-control.component.ts","../../../../../projects/ngx-numeric-range-form-field/src/lib/control/numeric-range-form-field-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tDoCheck,\n\tEventEmitter,\n\tHostBinding,\n\tInput,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOutput,\n\tSelf,\n\tSimpleChanges,\n\tSkipSelf\n} from '@angular/core';\nimport {\n\tAbstractControl,\n\tControlValueAccessor,\n\tFormControl,\n\tNgControl,\n\tValidator,\n\tValidatorFn\n} from '@angular/forms';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n\tINumericRange,\n\tNumericRangeFormGroup\n} from '../form/model/numeric-range-field.model';\nimport { NumericRangeFormService } from '../form/numeric-range-form.service';\nimport { NumericRangeStateMatcher } from '../form/numeric-range-state-matcher';\n\n@Component({\n\tselector: 'ngx-numeric-range-form-field-control',\n\ttemplateUrl: './numeric-range-form-field-control.component.html',\n\tstyleUrls: ['./numeric-range-form-field-control.component.scss'],\n\tproviders: [\n\t\t{\n\t\t\tprovide: MatFormFieldControl,\n\t\t\tuseExisting: NumericRangeFormFieldControlComponent\n\t\t},\n\t\t{\n\t\t\tprovide: ErrorStateMatcher,\n\t\t\tuseClass: NumericRangeStateMatcher\n\t\t}\n\t],\n\tchangeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NumericRangeFormFieldControlComponent\n\timplements\n\t\tOnChanges,\n\t\tOnInit,\n\t\tDoCheck,\n\t\tOnDestroy,\n\t\tMatFormFieldControl<INumericRange>,\n\t\tControlValueAccessor,\n\t\tValidator\n{\n\tstatic nextId = 0;\n\n\tget value() {\n\t\treturn this.formGroup.getRawValue();\n\t}\n\n\t@Input()\n\tset value(value: INumericRange) {\n\t\tthis.formGroup.patchValue(value);\n\t\tthis.stateChanges.next();\n\t}\n\n\tget placeholder(): string {\n\t\treturn this._placeholder;\n\t}\n\n\t@Input() set placeholder(value: string) {\n\t\tthis._placeholder = value;\n\t\tthis.stateChanges.next();\n\t}\n\n\t@Input() minPlaceholder: string;\n\t@Input() maxPlaceholder: string;\n\t@Input() readonly = false;\n\t@Input() minReadonly = false;\n\t@Input() maxReadonly = false;\n\t@Input() required: boolean;\n\t@Input() disabled: boolean;\n\t@Input() errorStateMatcher: ErrorStateMatcher;\n\t@Input() autofilled?: boolean;\n\t@Input() dynamicSyncValidators: ValidatorFn | ValidatorFn[];\n\n\t@Output() blurred = new EventEmitter<void>();\n\t@Output() enterPressed = new EventEmitter<void>();\n\t@Output() numericRangeChanged = new EventEmitter<INumericRange>();\n\n\t@HostBinding('class.floated')\n\tget shouldLabelFloat(): boolean {\n\t\treturn true;\n\t}\n\n\t@HostBinding('attr.aria-describedby')\n\tuserAriaDescribedBy = '';\n\n\t@HostBinding()\n\tid = `numeric-range-form-control-id-${NumericRangeFormFieldControlComponent.nextId++}`;\n\n\tget empty(): boolean {\n\t\treturn !this.value.minimum && !this.value.maximum;\n\t}\n\n\tget errorState() {\n\t\treturn this.numericRangeErrorMatcher.isErrorState(\n\t\t\tthis.ngControl.control as FormControl,\n\t\t\tthis.formGroup\n\t\t);\n\t}\n\n\tget minimumControl(): FormControl<number> {\n\t\treturn this.formService.minimumControl;\n\t}\n\n\tget maximumControl(): FormControl<number> {\n\t\treturn this.formService.maximumControl;\n\t}\n\n\tformGroup: NumericRangeFormGroup = this.formService.formGroup;\n\n\tstateChanges = new Subject<void>();\n\n\tfocused = false;\n\n\tcontrolType = 'numeric-range-form-control';\n\n\tnumericRangeErrorMatcher = new NumericRangeStateMatcher();\n\n\tprivate unsubscribe$ = new Subject<void>();\n\n\tprivate _placeholder: string;\n\n\tonTouched = () => {};\n\n\tconstructor(\n\t\t@Self() public ngControl: NgControl,\n\t\t@SkipSelf() private formService: NumericRangeFormService\n\t) {\n\t\tthis.ngControl.valueAccessor = this;\n\t}\n\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tif (changes.dynamicSyncValidators) {\n\t\t\tthis.formService.setDynamicValidators(this.dynamicSyncValidators);\n\t\t}\n\t}\n\n\tngOnInit(): void {\n\t\tthis.formService.setSyncValidators(this.ngControl.control.validator);\n\t\tthis.formService.setAsyncValidators(this.ngControl.control.asyncValidator);\n\n\t\tthis.ngControl.control.setValidators([this.validate.bind(this)]);\n\t\tthis.ngControl.control.updateValueAndValidity({ emitEvent: false });\n\t}\n\n\tngDoCheck(): void {\n\t\tthis.formGroup.markAllAsTouched();\n\t}\n\n\tngOnDestroy(): void {\n\t\tthis.stateChanges.complete();\n\t\tthis.unsubscribe$.next();\n\t\tthis.unsubscribe$.complete();\n\t}\n\n\twriteValue(value: INumericRange): void {\n\t\tvalue === null\n\t\t\t? this.formGroup.reset()\n\t\t\t: this.formGroup.setValue(value, { emitEvent: false });\n\t}\n\n\tregisterOnChange(fn: any): void {\n\t\tthis.formGroup.valueChanges\n\t\t\t.pipe(takeUntil(this.unsubscribe$))\n\t\t\t.subscribe(fn);\n\t}\n\n\tregisterOnTouched(fn: any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState?(isDisabled: boolean): void {\n\t\tthis.disabled = isDisabled;\n\t\tisDisabled ? this.formGroup.disable() : this.formGroup.enable();\n\n\t\tthis.stateChanges.next();\n\t}\n\n\tsetDescribedByIds(ids: string[]): void {\n\t\tthis.userAriaDescribedBy = ids.join(' ');\n\t}\n\n\tonContainerClick(event: MouseEvent): void {}\n\n\tvalidate(control: AbstractControl) {\n\t\treturn control.errors;\n\t}\n\n\tonEnterPressed(): void {\n\t\tif (\n\t\t\t!this.formGroup.errors &&\n\t\t\t!this.minimumControl.errors &&\n\t\t\t!this.maximumControl.errors\n\t\t) {\n\t\t\tthis.enterPressed.emit();\n\t\t}\n\t}\n\n\tonBlur(): void {\n\t\tthis.onTouched();\n\t\tthis.blurred.emit();\n\t}\n\n\tonRangeValuesChanged(): void {\n\t\tthis.formGroup.errors ||\n\t\tthis.minimumControl.errors ||\n\t\tthis.maximumControl.errors\n\t\t\t? this.numericRangeChanged.emit(null)\n\t\t\t: this.numericRangeChanged.emit(this.formGroup.getRawValue());\n\t}\n}\n","<input\n\t(blur)=\"onBlur()\"\n\t(change)=\"onRangeValuesChanged()\"\n\t(keyup.enter)=\"onEnterPressed()\"\n\t[readonly]=\"readonly || minReadonly\"\n\t[formControl]=\"minimumControl\"\n\tmatInput\n\t[placeholder]=\"minPlaceholder\"\n\ttype=\"number\"\n/>\n<span class=\"spacer\">&ndash;</span>\n<input\n\t(blur)=\"onBlur()\"\n\t(change)=\"onRangeValuesChanged()\"\n\t(keyup.enter)=\"onEnterPressed()\"\n\t[formControl]=\"maximumControl\"\n\t[readonly]=\"readonly || maxReadonly\"\n\tmatInput\n\t[placeholder]=\"maxPlaceholder\"\n\ttype=\"number\"\n/>\n"]}