UNPKG

@xui/components

Version:

xUI Components for Angular

86 lines 16.5 kB
import { booleanAttribute, ChangeDetectionStrategy, Component, computed, effect, Inject, input, model, Optional, Self, signal } from '@angular/core'; import { NgControl } from '@angular/forms'; import { TranslateService } from '@ngx-translate/core'; import { INPUT_GROUP_ACCESSOR } from './input.types'; import { INPUT_MODULE, XuiConfigService } from '../config'; import * as i0 from "@angular/core"; import * as i1 from "../config"; import * as i2 from "@ngx-translate/core"; import * as i3 from "@angular/forms"; import * as i4 from "@angular/common"; export class XuiInput { get errorMessage() { const msg = this.control?.getError('message'); return this.translation.instant(msg); } constructor(configService, translation, group, control) { this.configService = configService; this.translation = translation; this.group = group; this.control = control; this._moduleName = INPUT_MODULE; this._disabled = signal(false); this.value = model(); this.placeholder = input(); this.color = input('light'); this.size = input('large'); this.type = input('text'); this.dataList = input(); this.disabled = input(undefined, { transform: booleanAttribute }); this.readOnly = input(false, { transform: booleanAttribute }); this._styles = computed(() => { const ret = { 'x-input': true, 'x-input-error': this._showError }; ret[`x-input-${this.color()}`] = true; ret[`x-input-${this.group?.size() ?? this.size()}`] = true; return ret; }); if (this.control) { this.control.valueAccessor = this; } effect(() => this.disabled() && this._disabled.set(this.disabled()), { allowSignalWrites: true }); effect(() => this.value() != undefined && this.onChange?.(this.value())); } get _showError() { if (!this.control) { return false; } const invalid = !!this.control.invalid; const { dirty, touched } = this.control; return invalid ? (dirty ?? false) || (touched ?? false) : false; } writeValue(source) { this.value.set(source); } registerOnChange(onChange) { this.onChange = onChange; } registerOnTouched(onTouched) { this._onTouched = onTouched; } setDisabledState(isDisabled) { this._disabled.set(isDisabled); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: XuiInput, deps: [{ token: i1.XuiConfigService }, { token: i2.TranslateService }, { token: INPUT_GROUP_ACCESSOR, optional: true }, { token: i3.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: XuiInput, selector: "xui-input", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, dataList: { classPropertyName: "dataList", publicName: "dataList", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, readOnly: { classPropertyName: "readOnly", publicName: "readOnly", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange" }, host: { listeners: { "focusout": "_onTouched?.()" } }, ngImport: i0, template: "<div [ngClass]=\"_styles()\" [class.x-input-error]=\"_showError\">\n <ng-content select=\"[xuiPrefix]\" />\n <input\n [tabindex]=\"_disabled() ? -1 : 0\"\n [disabled]=\"_disabled()\"\n [readOnly]=\"readOnly()\"\n [type]=\"type()\"\n [placeholder]=\"placeholder() ?? ''\"\n [(ngModel)]=\"value\"\n list=\"list\"\n />\n <ng-content select=\"[xuiPostfix]\" />\n</div>\n\n<div class=\"x-input-error-text\" *ngIf=\"_showError\">\n <ng-container *ngIf=\"control?.hasError('message')\">{{ errorMessage }}</ng-container>\n <ng-container *ngIf=\"control?.hasError('required')\">This field is required!</ng-container>\n <ng-container *ngIf=\"control?.hasError('email')\">Email expected</ng-container>\n</div>\n\n<datalist id=\"list\" *ngIf=\"dataList()\">\n @for (item of dataList(); track item) {\n <option [value]=\"item\"></option>\n }\n</datalist>\n", dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: XuiInput, decorators: [{ type: Component, args: [{ selector: 'xui-input', changeDetection: ChangeDetectionStrategy.OnPush, host: { '(focusout)': '_onTouched?.()' }, template: "<div [ngClass]=\"_styles()\" [class.x-input-error]=\"_showError\">\n <ng-content select=\"[xuiPrefix]\" />\n <input\n [tabindex]=\"_disabled() ? -1 : 0\"\n [disabled]=\"_disabled()\"\n [readOnly]=\"readOnly()\"\n [type]=\"type()\"\n [placeholder]=\"placeholder() ?? ''\"\n [(ngModel)]=\"value\"\n list=\"list\"\n />\n <ng-content select=\"[xuiPostfix]\" />\n</div>\n\n<div class=\"x-input-error-text\" *ngIf=\"_showError\">\n <ng-container *ngIf=\"control?.hasError('message')\">{{ errorMessage }}</ng-container>\n <ng-container *ngIf=\"control?.hasError('required')\">This field is required!</ng-container>\n <ng-container *ngIf=\"control?.hasError('email')\">Email expected</ng-container>\n</div>\n\n<datalist id=\"list\" *ngIf=\"dataList()\">\n @for (item of dataList(); track item) {\n <option [value]=\"item\"></option>\n }\n</datalist>\n" }] }], ctorParameters: () => [{ type: i1.XuiConfigService }, { type: i2.TranslateService }, { type: undefined, decorators: [{ type: Inject, args: [INPUT_GROUP_ACCESSOR] }, { type: Optional }] }, { type: i3.NgControl, decorators: [{ type: Self }, { type: Optional }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.js","sourceRoot":"","sources":["../../../../../libs/xui/src/input/input.ts","../../../../../libs/xui/src/input/input.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  effect,\n  Inject,\n  input,\n  model,\n  Optional,\n  Self,\n  signal\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { TranslateService } from '@ngx-translate/core';\nimport { INPUT_GROUP_ACCESSOR, InputColor, InputGroupAccessor, InputSize, InputType } from './input.types';\nimport { INPUT_MODULE, XuiConfigService } from '../config';\n\n@Component({\n  selector: 'xui-input',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: 'input.html',\n  host: {\n    '(focusout)': '_onTouched?.()'\n  }\n})\nexport class XuiInput implements ControlValueAccessor {\n  private readonly _moduleName = INPUT_MODULE;\n\n  private onChange?: (source: string | null) => void;\n  _onTouched?: () => void;\n  _disabled = signal(false);\n\n  value = model<string>();\n  placeholder = input<string>();\n  color = input<InputColor>('light');\n  size = input<InputSize>('large');\n  type = input<InputType>('text');\n  dataList = input<string[] | null>();\n  disabled = input<boolean | undefined, string | boolean>(undefined, {\n    transform: booleanAttribute\n  });\n  readOnly = input(false, { transform: booleanAttribute });\n\n  _styles = computed(() => {\n    const ret: { [klass: string]: boolean } = {\n      'x-input': true,\n      'x-input-error': this._showError\n    };\n\n    ret[`x-input-${this.color()}`] = true;\n    ret[`x-input-${this.group?.size() ?? this.size()}`] = true;\n    return ret;\n  });\n\n  get errorMessage() {\n    const msg = this.control?.getError('message');\n    return this.translation.instant(msg);\n  }\n\n  constructor(\n    private configService: XuiConfigService,\n    private translation: TranslateService,\n    @Inject(INPUT_GROUP_ACCESSOR) @Optional() private group: InputGroupAccessor,\n    @Self() @Optional() public control?: NgControl\n  ) {\n    if (this.control) {\n      this.control.valueAccessor = this;\n    }\n\n    effect(() => this.disabled() && this._disabled.set(this.disabled()!), { allowSignalWrites: true });\n    effect(() => this.value() != undefined && this.onChange?.(this.value()!));\n  }\n\n  get _showError(): boolean {\n    if (!this.control) {\n      return false;\n    }\n\n    const invalid = !!this.control.invalid;\n    const { dirty, touched } = this.control;\n    return invalid ? (dirty ?? false) || (touched ?? false) : false;\n  }\n\n  writeValue(source: string) {\n    this.value.set(source);\n  }\n\n  registerOnChange(onChange: (source: string | null) => void) {\n    this.onChange = onChange;\n  }\n\n  registerOnTouched(onTouched: () => void) {\n    this._onTouched = onTouched;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this._disabled.set(isDisabled);\n  }\n}\n","<div [ngClass]=\"_styles()\" [class.x-input-error]=\"_showError\">\n  <ng-content select=\"[xuiPrefix]\" />\n  <input\n    [tabindex]=\"_disabled() ? -1 : 0\"\n    [disabled]=\"_disabled()\"\n    [readOnly]=\"readOnly()\"\n    [type]=\"type()\"\n    [placeholder]=\"placeholder() ?? ''\"\n    [(ngModel)]=\"value\"\n    list=\"list\"\n  />\n  <ng-content select=\"[xuiPostfix]\" />\n</div>\n\n<div class=\"x-input-error-text\" *ngIf=\"_showError\">\n  <ng-container *ngIf=\"control?.hasError('message')\">{{ errorMessage }}</ng-container>\n  <ng-container *ngIf=\"control?.hasError('required')\">This field is required!</ng-container>\n  <ng-container *ngIf=\"control?.hasError('email')\">Email expected</ng-container>\n</div>\n\n<datalist id=\"list\" *ngIf=\"dataList()\">\n  @for (item of dataList(); track item) {\n    <option [value]=\"item\"></option>\n  }\n</datalist>\n"]}