tuain-ng-forms-lib 17.1.22 → 17.1.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,4 @@
1
- import { Component, signal, Input } from '@angular/core';
1
+ import { Component, signal, Input, model } from '@angular/core';
2
2
  import { ElementComponent } from './layout/element.component';
3
3
  import * as i0 from "@angular/core";
4
4
  const CUSTOM_ATTRIBUTES = 'customAttributes';
@@ -36,8 +36,10 @@ export class FieldComponent extends ElementComponent {
36
36
  tooltip = signal('');
37
37
  validateOnServer = signal(false);
38
38
  visibleLabel = signal(true);
39
- value; // Valor del componente relacionado con el campo (pueden diferir en formato y tipo)
39
+ // value: any; // Valor del componente relacionado con el campo (pueden diferir en formato y tipo)
40
+ value = model(); // Valor del componente relacionado con el campo (pueden diferir en formato y tipo)
40
41
  field = null;
42
+ // field = input.required<FieldDescriptor>();
41
43
  updatePropagatedAttributes() {
42
44
  this.updatePieceAttributes(this.field, signaledAttributes);
43
45
  }
@@ -70,15 +72,15 @@ export class FieldComponent extends ElementComponent {
70
72
  this.start();
71
73
  }
72
74
  updateValue() {
73
- this.value = this.field?.value;
75
+ this.value.set(this.field?.value);
74
76
  }
75
77
  onInputChange() { setTimeout(() => this.field?.notifyEditionPartial(), 50); }
76
78
  onChangeContent() { setTimeout(() => this.field?.notifyEditionFinish(), 50); }
77
79
  onShowInfo(detail = null) { setTimeout(() => this.field?.notifyEditionDetailRequest(detail), 50); }
78
80
  focus() { }
79
- updateObject(widgetUpdate = true) { this.field?.setValue(this.value, widgetUpdate); }
81
+ updateObject(widgetUpdate = true) { this.field?.setValue(this.value(), widgetUpdate); }
80
82
  inputChanged() {
81
- this.field?.setValue(this.value);
83
+ this.field?.setValue(this.value());
82
84
  this.onChangeContent();
83
85
  }
84
86
  inputTyped() {
@@ -86,7 +88,7 @@ export class FieldComponent extends ElementComponent {
86
88
  this.onInputChange();
87
89
  }
88
90
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
89
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FieldComponent, selector: "lib-field", inputs: { field: "field" }, usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true });
91
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FieldComponent, selector: "lib-field", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, field: { classPropertyName: "field", publicName: "field", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange" }, usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true });
90
92
  }
91
93
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FieldComponent, decorators: [{
92
94
  type: Component,
@@ -97,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
97
99
  }], propDecorators: { field: [{
98
100
  type: Input
99
101
  }] } });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../../projects/tuain-ng-forms-lib/src/lib/components/elements/field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, OnInit, Input, AfterViewInit } from '@angular/core';\nimport { FieldDescriptor } from '../../classes/forms/field';\nimport { ElementComponent } from './layout/element.component'\n\nconst CUSTOM_ATTRIBUTES = 'customAttributes';\n\nconst signaledAttributes = ['captureType', 'errorCode', 'errorMessage', 'errorType', 'defaultValue',\n  'defaultEditable', 'alignment', 'code', 'info', 'required', 'title', 'type', 'format', 'options',\n  'hasChanged', 'maxLength', 'maxValue', 'minLength', 'minValue', 'onValidation', 'outputOnly',\n  'placeholder', 'tooltip', 'validateOnServer', 'visibleLabel', 'visible', 'disabled', 'value',\n];\n\nconst VALUE = 'value';\nconst FOCUS = 'focus';\n@Component({\n  selector: 'lib-field',\n  template: `<ng-content></ng-content>`\n})\nexport class FieldComponent extends ElementComponent implements AfterViewInit {\n  // Atributos propagados desde el campo\n  captureType: any = signal<string>('');\n  errorCode: any = signal<string>('');\n  errorMessage: any = signal<string>('');\n  errorType: any = signal<string>('');\n  defaultValue: any = signal<any>(null);\n  defaultEditable: any = signal<boolean>(false);\n  alignment: any = signal<string>('');\n  code: any = signal<string>('');\n  info: any = signal<any>(null);\n  required: any = signal<boolean>(false);\n  title: any = signal<string>('');\n  type: any = signal<string>('');\n  format: any = signal<any>(null);\n  options: any = signal<any[]>([]);\n  hasChanged: any = signal<boolean>(false);\n  minLength: any = signal<number>(0);\n  maxLength: any = signal<number>(0);\n  minValue: any = signal<any>(null);\n  maxValue: any = signal<any>(null);\n  onValidation: any = signal<boolean>(false);\n  outputOnly: any = signal<boolean>(false);\n  placeholder: any = signal<string>('');\n  tooltip: any = signal<string>('');\n  validateOnServer: any = signal<boolean>(false);\n  visibleLabel: any = signal<boolean>(true);\n\n  value: any;  // Valor del componente relacionado con el campo (pueden diferir en formato y tipo)\n  @Input() field: FieldDescriptor | null = null;\n\n  updatePropagatedAttributes() {\n    this.updatePieceAttributes(this.field, signaledAttributes)\n  }\n\n  ngAfterViewInit() {\n    if (!this.field) { return; }\n    this.field.widget = this;\n    this.formConfig = this.field?._formConfig;\n    this.updatePropagatedAttributes();\n    this.updateValue();\n    this.replaceCustomAttributes(this.field?.customAttributes);\n    this.field?.attributeChange.subscribe(event => {\n      const { name: attribute, value = null } = event ?? {};\n      const attributeParts = attribute?.split('.') ?? [];\n      if (attribute === VALUE) {\n        this.updateValue();\n      } else if (attribute === FOCUS) {\n        this.focus();\n      } else if (signaledAttributes.includes(attribute)) {\n        this.updatePieceAttribute(signaledAttributes, attribute, value);\n      } else if (attributeParts?.length > 1 && attributeParts?.[0] === CUSTOM_ATTRIBUTES) {\n        const subAttribute = attributeParts?.[1] ?? null;\n        this.updateCustomAttribute(subAttribute, value);\n      }\n    });\n    this.start();\n  }\n\n  updateValue() {\n    this.value = this.field?.value;\n  }\n\n  onInputChange() { setTimeout(() => this.field?.notifyEditionPartial(), 50); }\n  onChangeContent() { setTimeout(() => this.field?.notifyEditionFinish(), 50); }\n  onShowInfo(detail = null) { setTimeout(() => this.field?.notifyEditionDetailRequest(detail), 50); }\n\n  focus() { }\n\n  updateObject(widgetUpdate = true) { this.field?.setValue(this.value, widgetUpdate); }\n\n  inputChanged() {\n    this.field?.setValue(this.value);\n    this.onChangeContent();\n  }\n\n  inputTyped() {\n    this.updateObject(false);\n    this.onInputChange();\n  }\n}\n"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../../projects/tuain-ng-forms-lib/src/lib/components/elements/field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, Input, input, model, AfterViewInit } from '@angular/core';\nimport { FieldDescriptor } from '../../classes/forms/field';\nimport { ElementComponent } from './layout/element.component'\n\nconst CUSTOM_ATTRIBUTES = 'customAttributes';\n\nconst signaledAttributes = ['captureType', 'errorCode', 'errorMessage', 'errorType', 'defaultValue',\n  'defaultEditable', 'alignment', 'code', 'info', 'required', 'title', 'type', 'format', 'options',\n  'hasChanged', 'maxLength', 'maxValue', 'minLength', 'minValue', 'onValidation', 'outputOnly',\n  'placeholder', 'tooltip', 'validateOnServer', 'visibleLabel', 'visible', 'disabled', 'value',\n];\n\nconst VALUE = 'value';\nconst FOCUS = 'focus';\n@Component({\n  selector: 'lib-field',\n  template: `<ng-content></ng-content>`\n})\nexport class FieldComponent extends ElementComponent implements AfterViewInit {\n  // Atributos propagados desde el campo\n  captureType: any = signal<string>('');\n  errorCode: any = signal<string>('');\n  errorMessage: any = signal<string>('');\n  errorType: any = signal<string>('');\n  defaultValue: any = signal<any>(null);\n  defaultEditable: any = signal<boolean>(false);\n  alignment: any = signal<string>('');\n  code: any = signal<string>('');\n  info: any = signal<any>(null);\n  required: any = signal<boolean>(false);\n  title: any = signal<string>('');\n  type: any = signal<string>('');\n  format: any = signal<any>(null);\n  options: any = signal<any[]>([]);\n  hasChanged: any = signal<boolean>(false);\n  minLength: any = signal<number>(0);\n  maxLength: any = signal<number>(0);\n  minValue: any = signal<any>(null);\n  maxValue: any = signal<any>(null);\n  onValidation: any = signal<boolean>(false);\n  outputOnly: any = signal<boolean>(false);\n  placeholder: any = signal<string>('');\n  tooltip: any = signal<string>('');\n  validateOnServer: any = signal<boolean>(false);\n  visibleLabel: any = signal<boolean>(true);\n\n  // value: any;  // Valor del componente relacionado con el campo (pueden diferir en formato y tipo)\n  value = model<any>();  // Valor del componente relacionado con el campo (pueden diferir en formato y tipo)\n  @Input() field: FieldDescriptor | null = null;\n  // field = input.required<FieldDescriptor>();\n\n  updatePropagatedAttributes() {\n    this.updatePieceAttributes(this.field, signaledAttributes)\n  }\n\n  ngAfterViewInit() {\n    if (!this.field) { return; }\n    this.field.widget = this;\n    this.formConfig = this.field?._formConfig;\n    this.updatePropagatedAttributes();\n    this.updateValue();\n    this.replaceCustomAttributes(this.field?.customAttributes);\n    this.field?.attributeChange.subscribe(event => {\n      const { name: attribute, value = null } = event ?? {};\n      const attributeParts = attribute?.split('.') ?? [];\n      if (attribute === VALUE) {\n        this.updateValue();\n      } else if (attribute === FOCUS) {\n        this.focus();\n      } else if (signaledAttributes.includes(attribute)) {\n        this.updatePieceAttribute(signaledAttributes, attribute, value);\n      } else if (attributeParts?.length > 1 && attributeParts?.[0] === CUSTOM_ATTRIBUTES) {\n        const subAttribute = attributeParts?.[1] ?? null;\n        this.updateCustomAttribute(subAttribute, value);\n      }\n    });\n    this.start();\n  }\n\n  updateValue() {\n    this.value.set(this.field?.value);\n  }\n\n  onInputChange() { setTimeout(() => this.field?.notifyEditionPartial(), 50); }\n  onChangeContent() { setTimeout(() => this.field?.notifyEditionFinish(), 50); }\n  onShowInfo(detail = null) { setTimeout(() => this.field?.notifyEditionDetailRequest(detail), 50); }\n\n  focus() { }\n\n  updateObject(widgetUpdate = true) { this.field?.setValue(this.value(), widgetUpdate); }\n\n  inputChanged() {\n    this.field?.setValue(this.value());\n    this.onChangeContent();\n  }\n\n  inputTyped() {\n    this.updateObject(false);\n    this.onInputChange();\n  }\n}\n"]}