@xui/components
Version:
xUI Components for Angular
77 lines • 15.9 kB
JavaScript
import { booleanAttribute, ChangeDetectionStrategy, Component, computed, effect, input, model, Optional, Self, signal } from '@angular/core';
import { FormsModule, NgControl } from '@angular/forms';
import { TranslateModule, TranslateService } from '@ngx-translate/core';
import { CommonModule } from '@angular/common';
import { XuiFocusModule } from '../utils/focus.service';
import * as i0 from "@angular/core";
import * as i1 from "@ngx-translate/core";
import * as i2 from "@angular/forms";
import * as i3 from "@angular/common";
export class XuiTextarea {
get errorMessage() {
const msg = this.control?.getError('message');
return this.translation.instant(msg);
}
constructor(translation, control) {
this.translation = translation;
this.control = control;
this._disabled = signal(false);
this.value = model();
this.placeholder = input();
this.color = input('light');
this.size = input('normal');
this.rows = input(3);
this.maxLength = input();
this.disabled = input(undefined, {
transform: booleanAttribute
});
this.readOnly = input(false, { transform: booleanAttribute });
this._worldCount = computed(() => (this.maxLength() ?? 0) - (this.value()?.length ?? 0));
this._styles = computed(() => {
const ret = {
'x-textarea': true,
'x-textarea-disabled': this._disabled()
};
ret[`x-textarea-${this.color()}`] = 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: XuiTextarea, deps: [{ token: i1.TranslateService }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.1", type: XuiTextarea, isStandalone: true, selector: "xui-textarea", 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 }, rows: { classPropertyName: "rows", publicName: "rows", isSignal: true, isRequired: false, transformFunction: null }, maxLength: { classPropertyName: "maxLength", publicName: "maxLength", 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-textarea-error]=\"_showError\">\n <textarea\n [disabled]=\"_disabled()\"\n [readOnly]=\"readOnly()\"\n [(ngModel)]=\"value\"\n [rows]=\"rows()\"\n [placeholder]=\"placeholder() ?? ''\"\n [maxLength]=\"maxLength() ?? 524288\"\n [tabindex]=\"_disabled() ? -1 : 0\"\n ></textarea>\n\n <div *ngIf=\"maxLength()\" class=\"x-textarea-word-counter\">{{ _worldCount() }}</div>\n</div>\n\n<div class=\"x-textarea-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", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: XuiFocusModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: XuiTextarea, decorators: [{
type: Component,
args: [{ standalone: true, imports: [CommonModule, FormsModule, TranslateModule, XuiFocusModule], selector: 'xui-textarea', changeDetection: ChangeDetectionStrategy.OnPush, host: {
'(focusout)': '_onTouched?.()'
}, template: "<div [ngClass]=\"_styles()\" [class.x-textarea-error]=\"_showError\">\n <textarea\n [disabled]=\"_disabled()\"\n [readOnly]=\"readOnly()\"\n [(ngModel)]=\"value\"\n [rows]=\"rows()\"\n [placeholder]=\"placeholder() ?? ''\"\n [maxLength]=\"maxLength() ?? 524288\"\n [tabindex]=\"_disabled() ? -1 : 0\"\n ></textarea>\n\n <div *ngIf=\"maxLength()\" class=\"x-textarea-word-counter\">{{ _worldCount() }}</div>\n</div>\n\n<div class=\"x-textarea-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" }]
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.NgControl, decorators: [{
type: Self
}, {
type: Optional
}] }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.js","sourceRoot":"","sources":["../../../../../libs/xui/src/textarea/textarea.ts","../../../../../libs/xui/src/textarea/textarea.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  effect,\n  input,\n  model,\n  Optional,\n  Self,\n  signal\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { TranslateModule, TranslateService } from '@ngx-translate/core';\nimport { TextareaColor, TextareaSize } from './textarea.types';\nimport { CommonModule } from '@angular/common';\nimport { XuiFocusModule } from '../utils/focus.service';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, FormsModule, TranslateModule, XuiFocusModule],\n  selector: 'xui-textarea',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: 'textarea.html',\n  host: {\n    '(focusout)': '_onTouched?.()'\n  }\n})\nexport class XuiTextarea implements ControlValueAccessor {\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<TextareaColor>('light');\n  size = input<TextareaSize>('normal');\n  rows = input(3);\n  maxLength = input<number>();\n  disabled = input<boolean | undefined, string | boolean>(undefined, {\n    transform: booleanAttribute\n  });\n  readOnly = input(false, { transform: booleanAttribute });\n\n  _worldCount = computed(() => ((this.maxLength() as number) ?? 0) - (this.value()?.length ?? 0));\n  _styles = computed(() => {\n    const ret: { [klass: string]: boolean } = {\n      'x-textarea': true,\n      'x-textarea-disabled': this._disabled()\n    };\n\n    ret[`x-textarea-${this.color()}`] = 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 translation: TranslateService,\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-textarea-error]=\"_showError\">\n  <textarea\n    [disabled]=\"_disabled()\"\n    [readOnly]=\"readOnly()\"\n    [(ngModel)]=\"value\"\n    [rows]=\"rows()\"\n    [placeholder]=\"placeholder() ?? ''\"\n    [maxLength]=\"maxLength() ?? 524288\"\n    [tabindex]=\"_disabled() ? -1 : 0\"\n  ></textarea>\n\n  <div *ngIf=\"maxLength()\" class=\"x-textarea-word-counter\">{{ _worldCount() }}</div>\n</div>\n\n<div class=\"x-textarea-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"]}