@abgov/angular-components
Version:
Government of Alberta - UI components for Angular
132 lines • 14 kB
JavaScript
import { forwardRef, Directive, ElementRef, HostListener } from "@angular/core";
import { NG_VALUE_ACCESSOR } from "@angular/forms";
import * as i0 from "@angular/core";
// @deprecated: Use the new <goab-input .. /> component
export class ValueDirective {
get value() {
return this._value;
}
set value(val) {
this._value = val;
this.onChange(this._value);
this.onTouched();
this.elementRef.nativeElement.value = val;
}
writeValue(value) {
this.value = value;
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this._disabled = isDisabled;
this.elementRef.nativeElement.disabled = isDisabled;
}
constructor(elementRef) {
this.elementRef = elementRef;
this._value = "";
this._disabled = false;
/* eslint-disable @typescript-eslint/no-explicit-any */
this.onChange = () => { };
this.onTouched = () => { };
}
listenForValueChange(value) {
this.value = value;
}
listenForDisabledChange(isDisabled) {
this.setDisabledState(isDisabled);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: ValueDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: ValueDirective, selector: "[goaValue]", host: { listeners: { "_change": "listenForValueChange($event.detail.value)", "disabledChange": "listenForDisabledChange($event.detail.disabled)" } }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => ValueDirective),
multi: true,
}], ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: ValueDirective, decorators: [{
type: Directive,
args: [{
selector: "[goaValue]", providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => ValueDirective),
multi: true,
}],
}]
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { listenForValueChange: [{
type: HostListener,
args: ["_change", ["$event.detail.value"]]
}], listenForDisabledChange: [{
type: HostListener,
args: ["disabledChange", ["$event.detail.disabled"]]
}] } });
export class ValueListDirective {
get value() {
return this._value;
}
set value(val) {
if (val && val !== this._value) {
this._setValue(val);
this.elementRef.nativeElement.value = JSON.stringify(val);
}
}
writeValue(value) {
if (value) {
this.value = value;
}
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
constructor(elementRef) {
this.elementRef = elementRef;
this._value = [];
this.onChange = () => { };
this.onTouched = () => { };
}
listenForValueChange(value) {
if (!value) {
this._setValue(undefined);
return;
}
try {
this.value = JSON.parse(value);
}
catch (e) {
// we still need to trigger the events to prevent any previous valid value to remain set.
const v = value.match(/^[\w\s,]*$/) ? value.split(",") : undefined;
this._setValue(v);
}
}
_setValue(value) {
this._value = value;
this.onChange(value);
this.onTouched();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: ValueListDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: ValueListDirective, selector: "[goaValueList]", host: { listeners: { "_change": "listenForValueChange($event.detail.value)" } }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => ValueListDirective),
multi: true,
}], ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: ValueListDirective, decorators: [{
type: Directive,
args: [{
selector: "[goaValueList]",
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => ValueListDirective),
multi: true,
}],
}]
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { listenForValueChange: [{
type: HostListener,
args: ["_change", ["$event.detail.value"]]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"value-directive.js","sourceRoot":"","sources":["../../../../../libs/angular-components/src/lib/value-directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { forwardRef, Directive, ElementRef, HostListener } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\n// @deprecated: Use the new <goab-input .. /> component\n@Directive({\n  selector: \"[goaValue]\", providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ValueDirective),\n    multi: true,\n  }],\n})\nexport class ValueDirective implements ControlValueAccessor {\n  private _value = \"\";\n  private _disabled = false;\n\n  /* eslint-disable @typescript-eslint/no-explicit-any */\n  onChange: any = () => { /* default implementation */ };\n  onTouched: any = () => { /* default implementation */ };\n\n  get value(): string {\n    return this._value;\n  }\n\n  set value(val: string) {\n    this._value = val;\n    this.onChange(this._value);\n    this.onTouched();\n    this.elementRef.nativeElement.value = val;\n  }\n\n  writeValue(value: string) {\n    this.value = value;\n  }\n\n  registerOnChange(fn: () => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this._disabled = isDisabled;\n    this.elementRef.nativeElement.disabled = isDisabled;\n  }\n\n  constructor(protected elementRef: ElementRef) { }\n\n  @HostListener(\"_change\", [\"$event.detail.value\"])\n  listenForValueChange(value: string) {\n    this.value = value;\n  }\n  @HostListener(\"disabledChange\", [\"$event.detail.disabled\"])\n  listenForDisabledChange(isDisabled: boolean) {\n    this.setDisabledState(isDisabled);\n  }\n}\n\n@Directive({\n  selector: \"[goaValueList]\",\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ValueListDirective),\n    multi: true,\n  }],\n})\nexport class ValueListDirective implements ControlValueAccessor {\n  private _value?: string[] = [];\n\n  onChange: any = () => { };\n  onTouched: any = () => { };\n\n  get value(): string[] | undefined {\n    return this._value;\n  }\n\n  set value(val: string[] | undefined) {\n    if (val && val !== this._value) {\n      this._setValue(val);\n      this.elementRef.nativeElement.value = JSON.stringify(val);\n    }\n  }\n\n  writeValue(value?: string[]) {\n    if (value) {\n      this.value = value;\n    }\n  }\n\n  registerOnChange(fn: () => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  constructor(protected elementRef: ElementRef) { }\n\n  @HostListener(\"_change\", [\"$event.detail.value\"])\n  listenForValueChange(value: string) {\n    if (!value) {\n      this._setValue(undefined);\n      return;\n    }\n\n    try {\n      this.value = JSON.parse(value);\n    } catch (e) {\n      // we still need to trigger the events to prevent any previous valid value to remain set.\n      const v = value.match(/^[\\w\\s,]*$/) ? value.split(\",\") : undefined;\n      this._setValue(v);\n    }\n  }\n\n  _setValue(value?: string[]) {\n    this._value = value;\n    this.onChange(value);\n    this.onTouched();\n  }\n}\n"]}