@acorex/platform 18.1.3 → 18.1.4
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.
- package/common/lib/schema/widgets/text/largetext-widget-edit.component.d.ts +1 -1
- package/esm2022/common/lib/schema/widgets/text/largetext-widget-edit.component.mjs +15 -16
- package/esm2022/layout/builder/lib/builder/widget.types.mjs +1 -2
- package/esm2022/layout/entity/lib/widgets/lookup-widget/lookup-widget-edit.component.mjs +22 -5
- package/esm2022/layouts/lib/admin/entity-layout/workflows/delete-entity.workflow.mjs +2 -1
- package/esm2022/themes/default/lib/layouts/entity-layouts/entity-detail-list-view/entity-detail-list-view.component.mjs +3 -3
- package/esm2022/themes/shared/lib/comments/comment-list-view.component.mjs +44 -20
- package/esm2022/widgets/lib/widgets/editors/contact/contact-widget-edit.component.mjs +11 -10
- package/esm2022/widgets/lib/widgets/editors/large-text/large-text-widget-edit.component.mjs +32 -22
- package/esm2022/widgets/lib/widgets/editors/select/select-box-widget-edit.component.mjs +23 -11
- package/fesm2022/{acorex-platform-common-largetext-widget-edit.component-CrqPJ58V.mjs → acorex-platform-common-largetext-widget-edit.component-DD7S5j12.mjs} +15 -16
- package/fesm2022/acorex-platform-common-largetext-widget-edit.component-DD7S5j12.mjs.map +1 -0
- package/fesm2022/acorex-platform-common.mjs +1 -1
- package/fesm2022/acorex-platform-layout-builder.mjs +0 -1
- package/fesm2022/acorex-platform-layout-builder.mjs.map +1 -1
- package/fesm2022/acorex-platform-layout-entity.mjs +20 -3
- package/fesm2022/acorex-platform-layout-entity.mjs.map +1 -1
- package/fesm2022/acorex-platform-layouts.mjs +1 -0
- package/fesm2022/acorex-platform-layouts.mjs.map +1 -1
- package/fesm2022/acorex-platform-themes-default.mjs +2 -2
- package/fesm2022/acorex-platform-themes-default.mjs.map +1 -1
- package/fesm2022/acorex-platform-themes-shared.mjs +43 -19
- package/fesm2022/acorex-platform-themes-shared.mjs.map +1 -1
- package/fesm2022/acorex-platform-widgets.mjs +80 -59
- package/fesm2022/acorex-platform-widgets.mjs.map +1 -1
- package/package.json +19 -19
- package/themes/shared/README.md +2 -3
- package/themes/shared/lib/comments/comment-list-view.component.d.ts +3 -2
- package/widgets/lib/widgets/editors/contact/contact-widget-edit.component.d.ts +1 -1
- package/widgets/lib/widgets/editors/large-text/large-text-widget-edit.component.d.ts +1 -3
- package/widgets/lib/widgets/editors/select/select-box-widget-edit.component.d.ts +2 -0
- package/fesm2022/acorex-platform-common-largetext-widget-edit.component-CrqPJ58V.mjs.map +0 -1
|
@@ -9,7 +9,7 @@ import { AXTranslationModule } from '@acorex/core/translation';
|
|
|
9
9
|
import { AXValidationModule, AXValidationService } from '@acorex/core/validation';
|
|
10
10
|
import { AXPWidgetComponent } from '@acorex/platform/layout/builder';
|
|
11
11
|
import { CommonModule } from '@angular/common';
|
|
12
|
-
import { ChangeDetectionStrategy, Component, HostBinding, computed, inject
|
|
12
|
+
import { ChangeDetectionStrategy, Component, HostBinding, computed, inject } from '@angular/core';
|
|
13
13
|
import { FormsModule } from '@angular/forms';
|
|
14
14
|
import { popupComponent } from './popup-component';
|
|
15
15
|
import * as i0 from "@angular/core";
|
|
@@ -32,7 +32,15 @@ export class AXPContactWidgetEditComponent extends AXPWidgetComponent {
|
|
|
32
32
|
this.hasIcon = computed(() => this.options()['hasIcon']);
|
|
33
33
|
this.disabled = computed(() => this.options()['disabled']);
|
|
34
34
|
this.placeholder = computed(() => this.options()['placeholder'] ?? `Enter ${this.type()} ...`);
|
|
35
|
-
this.format =
|
|
35
|
+
this.format = computed(() => {
|
|
36
|
+
if (this.hasIcon() || this.hasLabel()) {
|
|
37
|
+
return 'object';
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
return 'string';
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
this.internalValue = computed(() => this.valueToArray());
|
|
36
44
|
this.popup = inject(AXPopupService);
|
|
37
45
|
this.dataSource = new AXDataSource({
|
|
38
46
|
pageSize: this.labelList().length,
|
|
@@ -46,7 +54,6 @@ export class AXPContactWidgetEditComponent extends AXPWidgetComponent {
|
|
|
46
54
|
return Promise.resolve(this.labelList().find((i) => i === key));
|
|
47
55
|
},
|
|
48
56
|
});
|
|
49
|
-
this.internalValue = computed(() => this.valueToArray());
|
|
50
57
|
this.validationService = inject(AXValidationService);
|
|
51
58
|
this._validationRules = [];
|
|
52
59
|
this.itemToArray = (item) => {
|
|
@@ -153,12 +160,6 @@ export class AXPContactWidgetEditComponent extends AXPWidgetComponent {
|
|
|
153
160
|
this._validationRules = v;
|
|
154
161
|
}
|
|
155
162
|
valueToArray() {
|
|
156
|
-
if (this.hasIcon() || this.hasLabel()) {
|
|
157
|
-
this.format.set('object');
|
|
158
|
-
}
|
|
159
|
-
else {
|
|
160
|
-
this.format.set('string');
|
|
161
|
-
}
|
|
162
163
|
const value = this.getValue();
|
|
163
164
|
if (Array.isArray(value)) {
|
|
164
165
|
return value.map((item) => this.itemToArray(item));
|
|
@@ -321,4 +322,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
321
322
|
type: HostBinding,
|
|
322
323
|
args: ['class']
|
|
323
324
|
}] } });
|
|
324
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contact-widget-edit.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/platform/widgets/src/lib/widgets/editors/contact/contact-widget-edit.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXButtonModule } from '@acorex/components/button';\nimport { AXDataSource, AXValueChangedEvent } from '@acorex/components/common';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXFormModule } from '@acorex/components/form';\nimport { AXPopupConfig, AXPopupService } from '@acorex/components/popup';\nimport { AXSelectBoxModule } from '@acorex/components/select-box';\nimport { AXTextBoxModule } from '@acorex/components/text-box';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXValidationModule, AXValidationService } from '@acorex/core/validation';\nimport { AXPValidationRules } from '@acorex/platform/core';\nimport { AXPWidgetComponent } from '@acorex/platform/layout/builder';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  Signal,\n  WritableSignal,\n  computed,\n  inject,\n  signal,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { AXPContactDataType } from './contact.type';\nimport { popupComponent } from './popup-component';\n\n@Component({\n  template: `<div class=\"lg:ax-grid lg:ax-grid-cols-12 lg:ax-gap-4\">\n    @for(item of internalValue();track $index) {\n    <ax-text-box\n      [ngModel]=\"item.value\"\n      (onValueChanged)=\"handleValueChange($event, $index)\"\n      type=\"text\"\n      name=\"value\"\n      [placeholder]=\"placeholder()\"\n      [ngClass]=\"generateClasses('value')\"\n      [disabled]=\"disabled()\"\n    >\n      @for (validation of validationRules; track $index) {\n      <ax-validation-rule\n        [rule]=\"validation.rule\"\n        [message]=\"validation.options?.message\"\n        [options]=\"validation.options\"\n      ></ax-validation-rule>\n      }\n    </ax-text-box>\n    @if(hasLabel()){\n    <ax-select-box\n      [dataSource]=\"dataSource\"\n      [ngModel]=\"item.label\"\n      [disabled]=\"disabled()\"\n      (onValueChanged)=\"handleValueChange($event, $index)\"\n      placeholder=\"{{ 'selectbox.popover.title' | translate | async }}\"\n      name=\"label\"\n      [ngClass]=\"generateClasses('label')\"\n    >\n    </ax-select-box>\n    } @if(multiple()){\n    <ax-button\n      [disabled]=\"disabled()\"\n      look=\"twotone\"\n      color=\"danger\"\n      (onClick)=\"deleteItem($index)\"\n      class=\"ax-col-start-12 ax-col-end-13 ax-justify-self-end\"\n    >\n      <ax-icon icon=\"fa-regular fa-xmark\"></ax-icon>\n    </ax-button>\n    } } @if(multiple()){\n\n    <ax-button\n      [text]=\"internalValue().length == 0 ? 'Add New' : 'Add Another'\"\n      [disabled]=\"disabled()\"\n      look=\"twotone\"\n      (onClick)=\"addItem()\"\n      class=\"ax-col-start-6 ax-col-end-13 lg:ax-col-start-8 xl:ax-col-start-10 \"\n    >\n      <ax-prefix>\n        <ax-icon class=\"fa-solid fa-add\"></ax-icon>\n      </ax-prefix>\n    </ax-button>\n    }\n  </div> `,\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    AXSelectBoxModule,\n    AXFormModule,\n    AXButtonModule,\n    AXDecoratorModule,\n    AXSelectBoxModule,\n    AXTextBoxModule,\n    AXValidationModule,\n    AXTranslationModule,\n  ],\n  inputs: [],\n})\nexport class AXPContactWidgetEditComponent extends AXPWidgetComponent<\n  string | string[] | AXPContactDataType | AXPContactDataType[] | undefined\n> {\n  //properties\n  protected type = computed<'link' | 'phone' | 'email'>(\n    () => (this.options()['type']?.id as 'link' | 'phone' | 'email') ?? 'email'\n  );\n  protected labelList = computed<string[]>(() => this.options()['labelList'] || ['primary', 'secondary', 'Add New']);\n  protected hasLabel = computed<boolean>(() => this.options()['hasLabel'] as boolean);\n  protected multiple = computed<boolean>(() => this.options()['multiple'] as boolean);\n  protected hasIcon = computed<boolean>(() => this.options()['hasIcon'] as boolean);\n  protected disabled = computed<boolean>(() => this.options()['disabled'] as boolean);\n  protected placeholder = computed<string>(\n    () => (this.options()['placeholder'] as string) ?? `Enter ${this.type()} ...`\n  );\n\n  private format: WritableSignal<undefined | 'object' | 'string'> = signal(undefined);\n\n  constructor() {\n    super();\n  }\n  private popup: AXPopupService = inject(AXPopupService);\n  protected dataSource = new AXDataSource({\n    pageSize: this.labelList().length,\n    load: (e) => {\n      return Promise.resolve({\n        items: this.labelList().slice(e.skip, (e.skip ?? 0) + (e.take ?? 0)),\n        total: this.labelList().length,\n      });\n    },\n    byKey: (key) => {\n      return Promise.resolve(this.labelList().find((i) => i === key));\n    },\n  });\n  protected internalValue: Signal<AXPContactDataType[]> = computed(() => this.valueToArray());\n\n  protected addItem() {\n    const newValues: AXPContactDataType[] = [...this.internalValue(), this.emptyValue()];\n    this.setValue(this.setFormatedValue(newValues));\n  }\n\n  protected deleteItem(deletedIndex: number) {\n    const newValues = this.internalValue().filter((_, index) => index != deletedIndex);\n    this.setValue(this.setFormatedValue(newValues));\n  }\n  protected async handleValueChange(e: AXValueChangedEvent, selectedIndex: number) {\n    let { name, value, isUserInteraction } = e;\n    if (isUserInteraction) {\n      if (e.name === 'label') {\n        if (e.value === 'Add New') {\n          const options: AXPopupConfig = {\n            title: 'Enter Label...',\n            // header: false,\n            // footer: true,\n            size: 'sm',\n            draggable: true,\n            // hasBackdrop: true,\n            // closeButton: true,\n            // closeOnBackdropClick: true,\n          };\n          const newValue = await this.popup.open(popupComponent, { ...options }).then((e) => e.data);\n          value = newValue.value;\n          this.labelList().pop();\n          this.labelList().push(value, 'Add New');\n          this.dataSource.refresh();\n        }\n      }\n      const newValues = this.internalValue().map((item, index) =>\n        selectedIndex === index ? { ...item, [name as string]: value } : item\n      );\n      if (this.multiple()) {\n        this.setValue(this.setFormatedValue(newValues));\n      } else this.setValue(this.setFormatedValue(newValues[0]));\n    }\n  }\n  protected generateClasses(element: 'value' | 'label'): string | any {\n    if (this.multiple()) {\n      if (this.hasLabel()) {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-13 lg:ax-col-end-7';\n        } else {\n          return 'ax-col-start-1 ax-col-end-11 lg:ax-col-start-7 lg:ax-col-end-12 ';\n        }\n      } else {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-12';\n        }\n      }\n    } else {\n      if (this.hasLabel()) {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-13 lg:ax-col-end-7';\n        } else {\n          return 'ax-col-start-1 ax-col-end-13 lg:ax-col-start-7 lg:ax-col-end-13';\n        }\n      } else {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-13';\n        }\n      }\n    }\n  }\n  protected validationService = inject(AXValidationService);\n  private _validationRules: AXPValidationRules = [];\n  public get validationRules(): AXPValidationRules {\n    return this._validationRules;\n  }\n  public set validationRules(v: AXPValidationRules) {\n    this._validationRules = v;\n  }\n  private valueToArray(): AXPContactDataType[] {\n    if (this.hasIcon() || this.hasLabel()) {\n      this.format.set('object');\n    } else {\n      this.format.set('string');\n    }\n    const value = this.getValue();\n    if (Array.isArray(value)) {\n      return value.map((item) => this.itemToArray(item));\n    } else {\n      return [this.itemToArray(value ?? '')];\n    }\n  }\n  private itemToArray = (item: AXPContactDataType | string): AXPContactDataType => {\n    if (typeof item === 'object')\n      return {\n        value: item?.value ?? '',\n        label: this.hasLabel() ? item?.label || this.labelList()[0] : undefined,\n        icon: this.hasIcon() ? item?.icon || this.chooseIcon() : undefined,\n      };\n    else\n      return {\n        value: item,\n        label: this.hasLabel() ? this.labelList()[0] : undefined,\n        icon: this.hasIcon() ? this.chooseIcon() : undefined,\n      };\n  };\n  private emptyValue(): AXPContactDataType {\n    return {\n      value: '',\n    };\n  }\n\n  setFormatedValue(\n    items: AXPContactDataType | AXPContactDataType[]\n  ): string | string[] | AXPContactDataType | AXPContactDataType[] {\n    if (this.format() === 'string') {\n      return Array.isArray(items) ? items.map((x) => x.value) : items.value;\n    } else {\n      return items;\n    }\n  }\n\n  private chooseIcon = (): string => {\n    switch (this.type()) {\n      case 'email':\n        return 'fa-link';\n      case 'link':\n        return 'fa-envelope';\n      case 'phone':\n        return 'fa-phone';\n      default:\n        return 'fa-info';\n    }\n  };\n\n  @HostBinding('class')\n  private get __class(): string {\n    const cls: any = {};\n    cls[`ax-block`] = true;\n    cls[`ax-flex-1`] = true;\n    return cls;\n  }\n}\n"]}
|
|
325
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contact-widget-edit.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/platform/widgets/src/lib/widgets/editors/contact/contact-widget-edit.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAuB,MAAM,2BAA2B,CAAC;AAC9E,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAiB,cAAc,EAAE,MAAM,0BAA0B,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAElF,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAU,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1G,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;;AA0EnD,MAAM,OAAO,6BAA8B,SAAQ,kBAElD;IAwBC;QACE,KAAK,EAAE,CAAC;QAxBV,YAAY;QACF,SAAI,GAAG,QAAQ,CACvB,GAAG,EAAE,CAAE,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,EAAE,EAAiC,IAAI,OAAO,CAC5E,CAAC;QACQ,cAAS,GAAG,QAAQ,CAAW,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC;QACzG,aAAQ,GAAG,QAAQ,CAAU,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,UAAU,CAAY,CAAC,CAAC;QAC1E,aAAQ,GAAG,QAAQ,CAAU,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,UAAU,CAAY,CAAC,CAAC;QAC1E,YAAO,GAAG,QAAQ,CAAU,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,SAAS,CAAY,CAAC,CAAC;QACxE,aAAQ,GAAG,QAAQ,CAAU,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,UAAU,CAAY,CAAC,CAAC;QAC1E,gBAAW,GAAG,QAAQ,CAC9B,GAAG,EAAE,CAAE,IAAI,CAAC,OAAO,EAAE,CAAC,aAAa,CAAY,IAAI,SAAS,IAAI,CAAC,IAAI,EAAE,MAAM,CAC9E,CAAC;QAEM,WAAM,GAAG,QAAQ,CAAsB,GAAG,EAAE;YAClD,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACtC,OAAO,QAAQ,CAAC;YAClB,CAAC;iBAAM,CAAC;gBACN,OAAO,QAAQ,CAAC;YAClB,CAAC;QACH,CAAC,CAAC,CAAC;QAEO,kBAAa,GAAiC,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAKpF,UAAK,GAAmB,MAAM,CAAC,cAAc,CAAC,CAAC;QAC7C,eAAU,GAAG,IAAI,YAAY,CAAC;YACtC,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,MAAM;YACjC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE;gBACV,OAAO,OAAO,CAAC,OAAO,CAAC;oBACrB,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;oBACpE,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,MAAM;iBAC/B,CAAC,CAAC;YACL,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YAClE,CAAC;SACF,CAAC,CAAC;QAoEO,sBAAiB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClD,qBAAgB,GAAuB,EAAE,CAAC;QAe1C,gBAAW,GAAG,CAAC,IAAiC,EAAsB,EAAE;YAC9E,IAAI,OAAO,IAAI,KAAK,QAAQ;gBAC1B,OAAO;oBACL,KAAK,EAAE,IAAI,EAAE,KAAK,IAAI,EAAE;oBACxB,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;oBACvE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,SAAS;iBACnE,CAAC;;gBAEF,OAAO;oBACL,KAAK,EAAE,IAAI;oBACX,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;oBACxD,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,SAAS;iBACrD,CAAC;QACN,CAAC,CAAC;QAiBM,eAAU,GAAG,GAAW,EAAE;YAChC,QAAQ,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;gBACpB,KAAK,OAAO;oBACV,OAAO,SAAS,CAAC;gBACnB,KAAK,MAAM;oBACT,OAAO,aAAa,CAAC;gBACvB,KAAK,OAAO;oBACV,OAAO,UAAU,CAAC;gBACpB;oBACE,OAAO,SAAS,CAAC;YACrB,CAAC;QACH,CAAC,CAAC;IA1IF,CAAC;IAeS,OAAO;QACf,MAAM,SAAS,GAAyB,CAAC,GAAG,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QACrF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,CAAC;IAES,UAAU,CAAC,YAAoB;QACvC,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,YAAY,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,CAAC;IACS,KAAK,CAAC,iBAAiB,CAAC,CAAsB,EAAE,aAAqB;QAC7E,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,iBAAiB,EAAE,GAAG,CAAC,CAAC;QAC3C,IAAI,iBAAiB,EAAE,CAAC;YACtB,IAAI,CAAC,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;gBACvB,IAAI,CAAC,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;oBAC1B,MAAM,OAAO,GAAkB;wBAC7B,KAAK,EAAE,gBAAgB;wBACvB,iBAAiB;wBACjB,gBAAgB;wBAChB,IAAI,EAAE,IAAI;wBACV,SAAS,EAAE,IAAI;wBACf,qBAAqB;wBACrB,qBAAqB;wBACrB,8BAA8B;qBAC/B,CAAC;oBACF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;oBAC3F,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;oBACvB,IAAI,CAAC,SAAS,EAAE,CAAC,GAAG,EAAE,CAAC;oBACvB,IAAI,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;oBACxC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;gBAC5B,CAAC;YACH,CAAC;YACD,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CACzD,aAAa,KAAK,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,IAAc,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CACtE,CAAC;YACF,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC;YAClD,CAAC;;gBAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IACS,eAAe,CAAC,OAA0B;QAClD,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YACpB,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACpB,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;oBACxB,OAAO,8CAA8C,CAAC;gBACxD,CAAC;qBAAM,CAAC;oBACN,OAAO,kEAAkE,CAAC;gBAC5E,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;oBACxB,OAAO,8BAA8B,CAAC;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACpB,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;oBACxB,OAAO,8CAA8C,CAAC;gBACxD,CAAC;qBAAM,CAAC;oBACN,OAAO,iEAAiE,CAAC;gBAC3E,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;oBACxB,OAAO,8BAA8B,CAAC;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAGD,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IACD,IAAW,eAAe,CAAC,CAAqB;QAC9C,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;IAC5B,CAAC;IACO,YAAY;QAClB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;QACrD,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAeO,UAAU;QAChB,OAAO;YACL,KAAK,EAAE,EAAE;SACV,CAAC;IACJ,CAAC;IAED,gBAAgB,CACd,KAAgD;QAEhD,IAAI,IAAI,CAAC,MAAM,EAAE,KAAK,QAAQ,EAAE,CAAC;YAC/B,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC;QACxE,CAAC;aAAM,CAAC;YACN,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAeD,IACY,OAAO;QACjB,MAAM,GAAG,GAAQ,EAAE,CAAC;QACpB,GAAG,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC;QACvB,GAAG,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC;QACxB,OAAO,GAAG,CAAC;IACb,CAAC;8GA9KU,6BAA6B;kGAA7B,6BAA6B,kJAvE9B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAsDF,2DAIN,YAAY,iLACZ,WAAW,8VACX,iBAAiB,yiBACjB,YAAY,iKACZ,cAAc,uZACd,iBAAiB,uVAEjB,eAAe,qbACf,kBAAkB,8BAClB,mBAAmB;;2FAIV,6BAA6B;kBAxEzC,SAAS;mBAAC;oBACT,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAsDF;oBACR,UAAU,EAAE,IAAI;oBAChB,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,OAAO,EAAE;wBACP,YAAY;wBACZ,WAAW;wBACX,iBAAiB;wBACjB,YAAY;wBACZ,cAAc;wBACd,iBAAiB;wBACjB,iBAAiB;wBACjB,eAAe;wBACf,kBAAkB;wBAClB,mBAAmB;qBACpB;oBACD,MAAM,EAAE,EAAE;iBACX;wDA0Ka,OAAO;sBADlB,WAAW;uBAAC,OAAO","sourcesContent":["import { AXButtonModule } from '@acorex/components/button';\nimport { AXDataSource, AXValueChangedEvent } from '@acorex/components/common';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXFormModule } from '@acorex/components/form';\nimport { AXPopupConfig, AXPopupService } from '@acorex/components/popup';\nimport { AXSelectBoxModule } from '@acorex/components/select-box';\nimport { AXTextBoxModule } from '@acorex/components/text-box';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXValidationModule, AXValidationService } from '@acorex/core/validation';\nimport { AXPValidationRules } from '@acorex/platform/core';\nimport { AXPWidgetComponent } from '@acorex/platform/layout/builder';\nimport { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, HostBinding, Signal, computed, inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { AXPContactDataType } from './contact.type';\nimport { popupComponent } from './popup-component';\n\n@Component({\n  template: `<div class=\"lg:ax-grid lg:ax-grid-cols-12 lg:ax-gap-4\">\n    @for(item of internalValue();track $index) {\n    <ax-text-box\n      [ngModel]=\"item.value\"\n      (onValueChanged)=\"handleValueChange($event, $index)\"\n      type=\"text\"\n      name=\"value\"\n      [placeholder]=\"placeholder()\"\n      [ngClass]=\"generateClasses('value')\"\n      [disabled]=\"disabled()\"\n    >\n      @for (validation of validationRules; track $index) {\n      <ax-validation-rule\n        [rule]=\"validation.rule\"\n        [message]=\"validation.options?.message\"\n        [options]=\"validation.options\"\n      ></ax-validation-rule>\n      }\n    </ax-text-box>\n    @if(hasLabel()){\n    <ax-select-box\n      [dataSource]=\"dataSource\"\n      [ngModel]=\"item.label\"\n      [disabled]=\"disabled()\"\n      (onValueChanged)=\"handleValueChange($event, $index)\"\n      placeholder=\"{{ 'selectbox.popover.title' | translate | async }}\"\n      name=\"label\"\n      [ngClass]=\"generateClasses('label')\"\n    >\n    </ax-select-box>\n    } @if(multiple()){\n    <ax-button\n      [disabled]=\"disabled()\"\n      look=\"twotone\"\n      color=\"danger\"\n      (onClick)=\"deleteItem($index)\"\n      class=\"ax-col-start-12 ax-col-end-13 ax-justify-self-end\"\n    >\n      <ax-icon icon=\"fa-regular fa-xmark\"></ax-icon>\n    </ax-button>\n    } } @if(multiple()){\n\n    <ax-button\n      [text]=\"internalValue().length == 0 ? 'Add New' : 'Add Another'\"\n      [disabled]=\"disabled()\"\n      look=\"twotone\"\n      (onClick)=\"addItem()\"\n      class=\"ax-col-start-6 ax-col-end-13 lg:ax-col-start-8 xl:ax-col-start-10 \"\n    >\n      <ax-prefix>\n        <ax-icon class=\"fa-solid fa-add\"></ax-icon>\n      </ax-prefix>\n    </ax-button>\n    }\n  </div> `,\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    AXSelectBoxModule,\n    AXFormModule,\n    AXButtonModule,\n    AXDecoratorModule,\n    AXSelectBoxModule,\n    AXTextBoxModule,\n    AXValidationModule,\n    AXTranslationModule,\n  ],\n  inputs: [],\n})\nexport class AXPContactWidgetEditComponent extends AXPWidgetComponent<\n  string | string[] | AXPContactDataType | AXPContactDataType[] | undefined\n> {\n  //properties\n  protected type = computed<'link' | 'phone' | 'email'>(\n    () => (this.options()['type']?.id as 'link' | 'phone' | 'email') ?? 'email'\n  );\n  protected labelList = computed<string[]>(() => this.options()['labelList'] || ['primary', 'secondary', 'Add New']);\n  protected hasLabel = computed<boolean>(() => this.options()['hasLabel'] as boolean);\n  protected multiple = computed<boolean>(() => this.options()['multiple'] as boolean);\n  protected hasIcon = computed<boolean>(() => this.options()['hasIcon'] as boolean);\n  protected disabled = computed<boolean>(() => this.options()['disabled'] as boolean);\n  protected placeholder = computed<string>(\n    () => (this.options()['placeholder'] as string) ?? `Enter ${this.type()} ...`\n  );\n\n  private format = computed<'object' | 'string'>(() => {\n    if (this.hasIcon() || this.hasLabel()) {\n      return 'object';\n    } else {\n      return 'string';\n    }\n  });\n\n  protected internalValue: Signal<AXPContactDataType[]> = computed(() => this.valueToArray());\n\n  constructor() {\n    super();\n  }\n  private popup: AXPopupService = inject(AXPopupService);\n  protected dataSource = new AXDataSource({\n    pageSize: this.labelList().length,\n    load: (e) => {\n      return Promise.resolve({\n        items: this.labelList().slice(e.skip, (e.skip ?? 0) + (e.take ?? 0)),\n        total: this.labelList().length,\n      });\n    },\n    byKey: (key) => {\n      return Promise.resolve(this.labelList().find((i) => i === key));\n    },\n  });\n\n  protected addItem() {\n    const newValues: AXPContactDataType[] = [...this.internalValue(), this.emptyValue()];\n    this.setValue(this.setFormatedValue(newValues));\n  }\n\n  protected deleteItem(deletedIndex: number) {\n    const newValues = this.internalValue().filter((_, index) => index != deletedIndex);\n    this.setValue(this.setFormatedValue(newValues));\n  }\n  protected async handleValueChange(e: AXValueChangedEvent, selectedIndex: number) {\n    let { name, value, isUserInteraction } = e;\n    if (isUserInteraction) {\n      if (e.name === 'label') {\n        if (e.value === 'Add New') {\n          const options: AXPopupConfig = {\n            title: 'Enter Label...',\n            // header: false,\n            // footer: true,\n            size: 'sm',\n            draggable: true,\n            // hasBackdrop: true,\n            // closeButton: true,\n            // closeOnBackdropClick: true,\n          };\n          const newValue = await this.popup.open(popupComponent, { ...options }).then((e) => e.data);\n          value = newValue.value;\n          this.labelList().pop();\n          this.labelList().push(value, 'Add New');\n          this.dataSource.refresh();\n        }\n      }\n      const newValues = this.internalValue().map((item, index) =>\n        selectedIndex === index ? { ...item, [name as string]: value } : item\n      );\n      if (this.multiple()) {\n        this.setValue(this.setFormatedValue(newValues));\n      } else this.setValue(this.setFormatedValue(newValues[0]));\n    }\n  }\n  protected generateClasses(element: 'value' | 'label'): string | any {\n    if (this.multiple()) {\n      if (this.hasLabel()) {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-13 lg:ax-col-end-7';\n        } else {\n          return 'ax-col-start-1 ax-col-end-11 lg:ax-col-start-7 lg:ax-col-end-12 ';\n        }\n      } else {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-12';\n        }\n      }\n    } else {\n      if (this.hasLabel()) {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-13 lg:ax-col-end-7';\n        } else {\n          return 'ax-col-start-1 ax-col-end-13 lg:ax-col-start-7 lg:ax-col-end-13';\n        }\n      } else {\n        if (element === 'value') {\n          return 'ax-col-start-1 ax-col-end-13';\n        }\n      }\n    }\n  }\n  protected validationService = inject(AXValidationService);\n  private _validationRules: AXPValidationRules = [];\n  public get validationRules(): AXPValidationRules {\n    return this._validationRules;\n  }\n  public set validationRules(v: AXPValidationRules) {\n    this._validationRules = v;\n  }\n  private valueToArray(): AXPContactDataType[] {\n    const value = this.getValue();\n    if (Array.isArray(value)) {\n      return value.map((item) => this.itemToArray(item));\n    } else {\n      return [this.itemToArray(value ?? '')];\n    }\n  }\n  private itemToArray = (item: AXPContactDataType | string): AXPContactDataType => {\n    if (typeof item === 'object')\n      return {\n        value: item?.value ?? '',\n        label: this.hasLabel() ? item?.label || this.labelList()[0] : undefined,\n        icon: this.hasIcon() ? item?.icon || this.chooseIcon() : undefined,\n      };\n    else\n      return {\n        value: item,\n        label: this.hasLabel() ? this.labelList()[0] : undefined,\n        icon: this.hasIcon() ? this.chooseIcon() : undefined,\n      };\n  };\n  private emptyValue(): AXPContactDataType {\n    return {\n      value: '',\n    };\n  }\n\n  setFormatedValue(\n    items: AXPContactDataType | AXPContactDataType[]\n  ): string | string[] | AXPContactDataType | AXPContactDataType[] {\n    if (this.format() === 'string') {\n      return Array.isArray(items) ? items.map((x) => x.value) : items.value;\n    } else {\n      return items;\n    }\n  }\n\n  private chooseIcon = (): string => {\n    switch (this.type()) {\n      case 'email':\n        return 'fa-link';\n      case 'link':\n        return 'fa-envelope';\n      case 'phone':\n        return 'fa-phone';\n      default:\n        return 'fa-info';\n    }\n  };\n\n  @HostBinding('class')\n  private get __class(): string {\n    const cls: any = {};\n    cls[`ax-block`] = true;\n    cls[`ax-flex-1`] = true;\n    return cls;\n  }\n}\n"]}
|
|
@@ -13,17 +13,11 @@ import * as i4 from "@acorex/components/text-area";
|
|
|
13
13
|
export class AXPLargeTextWidgetEditComponent extends AXPWidgetComponent {
|
|
14
14
|
constructor() {
|
|
15
15
|
super(...arguments);
|
|
16
|
-
this.multiple = computed(() => this.options()[
|
|
17
|
-
this.disabled = computed(() => this.options()[
|
|
18
|
-
this.clearButton = computed(() => this.options()[
|
|
19
|
-
this.placeholder = computed(() => this.options()[
|
|
20
|
-
this.
|
|
21
|
-
}
|
|
22
|
-
get validationRules() {
|
|
23
|
-
return this._validationRules;
|
|
24
|
-
}
|
|
25
|
-
set validationRules(v) {
|
|
26
|
-
this._validationRules = v;
|
|
16
|
+
this.multiple = computed(() => this.options()['multiple']);
|
|
17
|
+
this.disabled = computed(() => this.options()['disabled']);
|
|
18
|
+
this.clearButton = computed(() => this.options()['clearButton'] ?? true);
|
|
19
|
+
this.placeholder = computed(() => this.options()['placeholder']);
|
|
20
|
+
this.validationRules = computed(() => this.options()['validationRules'] ?? []);
|
|
27
21
|
}
|
|
28
22
|
get __class() {
|
|
29
23
|
const cls = {};
|
|
@@ -33,12 +27,20 @@ export class AXPLargeTextWidgetEditComponent extends AXPWidgetComponent {
|
|
|
33
27
|
}
|
|
34
28
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPLargeTextWidgetEditComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
29
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPLargeTextWidgetEditComponent, isStandalone: true, selector: "axp-large-text-box-widget", inputs: { disabled: "disabled", clearButton: "clearButton" }, host: { properties: { "class": "this.__class" } }, usesInheritance: true, ngImport: i0, template: `
|
|
36
|
-
<ax-text-area
|
|
30
|
+
<ax-text-area
|
|
31
|
+
[disabled]="disabled()"
|
|
32
|
+
[ngModel]="getValue()"
|
|
33
|
+
(ngModelChange)="setValue($event)"
|
|
34
|
+
[placeholder]="placeholder()"
|
|
35
|
+
>
|
|
37
36
|
@if(clearButton()){
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
|
|
37
|
+
<ax-clear-button></ax-clear-button>
|
|
38
|
+
} @for (validation of validationRules(); track $index) {
|
|
39
|
+
<ax-validation-rule
|
|
40
|
+
[rule]="validation.rule"
|
|
41
|
+
[message]="validation.options?.message"
|
|
42
|
+
[options]="validation.options"
|
|
43
|
+
></ax-validation-rule>
|
|
42
44
|
}
|
|
43
45
|
</ax-text-area>
|
|
44
46
|
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i1.AXDecoratorClearButtonComponent, selector: "ax-clear-button", inputs: ["icon"] }, { kind: "ngmodule", type: FormsModule }, { 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: AXFormModule }, { kind: "directive", type: i3.AXValidationRuleDirective, selector: "ax-validation-rule", inputs: ["rule", "options", "message"] }, { kind: "ngmodule", type: AXTextAreaModule }, { kind: "component", type: i4.AXTextAreaComponent, selector: "ax-text-area", inputs: ["disabled", "tabIndex", "readonly", "value", "state", "name", "placeholder", "maxLength", "look", "rows", "allowResize", "showCounter"], outputs: ["onBlur", "onFocus", "valueChange", "stateChange", "onValueChanged", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
@@ -48,12 +50,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
48
50
|
args: [{
|
|
49
51
|
selector: 'axp-large-text-box-widget',
|
|
50
52
|
template: `
|
|
51
|
-
<ax-text-area
|
|
53
|
+
<ax-text-area
|
|
54
|
+
[disabled]="disabled()"
|
|
55
|
+
[ngModel]="getValue()"
|
|
56
|
+
(ngModelChange)="setValue($event)"
|
|
57
|
+
[placeholder]="placeholder()"
|
|
58
|
+
>
|
|
52
59
|
@if(clearButton()){
|
|
53
|
-
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
|
|
60
|
+
<ax-clear-button></ax-clear-button>
|
|
61
|
+
} @for (validation of validationRules(); track $index) {
|
|
62
|
+
<ax-validation-rule
|
|
63
|
+
[rule]="validation.rule"
|
|
64
|
+
[message]="validation.options?.message"
|
|
65
|
+
[options]="validation.options"
|
|
66
|
+
></ax-validation-rule>
|
|
57
67
|
}
|
|
58
68
|
</ax-text-area>
|
|
59
69
|
`,
|
|
@@ -66,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
66
76
|
type: HostBinding,
|
|
67
77
|
args: ['class']
|
|
68
78
|
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFyZ2UtdGV4dC13aWRnZXQtZWRpdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsYXRmb3JtL3dpZGdldHMvc3JjL2xpYi93aWRnZXRzL2VkaXRvcnMvbGFyZ2UtdGV4dC9sYXJnZS10ZXh0LXdpZGdldC1lZGl0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFaEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDckUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7OztBQTJCN0MsTUFBTSxPQUFPLCtCQUFnQyxTQUFRLGtCQUEwQjtJQXpCL0U7O1FBMEJZLGFBQVEsR0FBRyxRQUFRLENBQVUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLFVBQVUsQ0FBWSxDQUFDLENBQUM7UUFDMUUsYUFBUSxHQUFHLFFBQVEsQ0FBVSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsVUFBVSxDQUFZLENBQUMsQ0FBQztRQUMxRSxnQkFBVyxHQUFHLFFBQVEsQ0FBVSxHQUFHLEVBQUUsQ0FBRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsYUFBYSxDQUFhLElBQUksSUFBSSxDQUFDLENBQUM7UUFDMUYsZ0JBQVcsR0FBRyxRQUFRLENBQVMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBVyxDQUFDLENBQUM7UUFFOUUsb0JBQWUsR0FBRyxRQUFRLENBQ2xDLEdBQUcsRUFBRSxDQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBd0IsSUFBSSxFQUFFLENBQ3RFLENBQUM7S0FTSDtJQVBDLElBQ1ksT0FBTztRQUNqQixNQUFNLEdBQUcsR0FBUSxFQUFFLENBQUM7UUFDcEIsR0FBRyxDQUFDLFVBQVUsQ0FBQyxHQUFHLElBQUksQ0FBQztRQUN2QixHQUFHLENBQUMsV0FBVyxDQUFDLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQzs4R0FoQlUsK0JBQStCO2tHQUEvQiwrQkFBK0IsNk5BdkJoQzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQlQsMkRBR1MsWUFBWSw4QkFBRSxpQkFBaUIsOElBQUUsV0FBVyw4VkFBRSxZQUFZLGlLQUFFLGdCQUFnQjs7MkZBRzNFLCtCQUErQjtrQkF6QjNDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCVDtvQkFDRCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLGdCQUFnQixDQUFDO29CQUN2RixNQUFNLEVBQUUsQ0FBQyxVQUFVLEVBQUUsYUFBYSxDQUFDO2lCQUNwQzs4QkFZYSxPQUFPO3NCQURsQixXQUFXO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWERlY29yYXRvck1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9kZWNvcmF0b3JzJztcbmltcG9ydCB7IEFYRm9ybU1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9mb3JtJztcbmltcG9ydCB7IEFYVGV4dEFyZWFNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvdGV4dC1hcmVhJztcbmltcG9ydCB7IEFYUFZhbGlkYXRpb25SdWxlcyB9IGZyb20gJ0BhY29yZXgvcGxhdGZvcm0vY29yZSc7XG5pbXBvcnQgeyBBWFBXaWRnZXRDb21wb25lbnQgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL2xheW91dC9idWlsZGVyJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgSG9zdEJpbmRpbmcgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdheHAtbGFyZ2UtdGV4dC1ib3gtd2lkZ2V0JyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8YXgtdGV4dC1hcmVhXG4gICAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWQoKVwiXG4gICAgICBbbmdNb2RlbF09XCJnZXRWYWx1ZSgpXCJcbiAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInNldFZhbHVlKCRldmVudClcIlxuICAgICAgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyKClcIlxuICAgID5cbiAgICAgIEBpZihjbGVhckJ1dHRvbigpKXtcbiAgICAgIDxheC1jbGVhci1idXR0b24+PC9heC1jbGVhci1idXR0b24+XG4gICAgICB9IEBmb3IgKHZhbGlkYXRpb24gb2YgdmFsaWRhdGlvblJ1bGVzKCk7IHRyYWNrICRpbmRleCkge1xuICAgICAgPGF4LXZhbGlkYXRpb24tcnVsZVxuICAgICAgICBbcnVsZV09XCJ2YWxpZGF0aW9uLnJ1bGVcIlxuICAgICAgICBbbWVzc2FnZV09XCJ2YWxpZGF0aW9uLm9wdGlvbnM/Lm1lc3NhZ2VcIlxuICAgICAgICBbb3B0aW9uc109XCJ2YWxpZGF0aW9uLm9wdGlvbnNcIlxuICAgICAgPjwvYXgtdmFsaWRhdGlvbi1ydWxlPlxuICAgICAgfVxuICAgIDwvYXgtdGV4dC1hcmVhPlxuICBgLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQVhEZWNvcmF0b3JNb2R1bGUsIEZvcm1zTW9kdWxlLCBBWEZvcm1Nb2R1bGUsIEFYVGV4dEFyZWFNb2R1bGVdLFxuICBpbnB1dHM6IFsnZGlzYWJsZWQnLCAnY2xlYXJCdXR0b24nXSxcbn0pXG5leHBvcnQgY2xhc3MgQVhQTGFyZ2VUZXh0V2lkZ2V0RWRpdENvbXBvbmVudCBleHRlbmRzIEFYUFdpZGdldENvbXBvbmVudDxzdHJpbmc+IHtcbiAgcHJvdGVjdGVkIG11bHRpcGxlID0gY29tcHV0ZWQ8Ym9vbGVhbj4oKCkgPT4gdGhpcy5vcHRpb25zKClbJ211bHRpcGxlJ10gYXMgYm9vbGVhbik7XG4gIHByb3RlY3RlZCBkaXNhYmxlZCA9IGNvbXB1dGVkPGJvb2xlYW4+KCgpID0+IHRoaXMub3B0aW9ucygpWydkaXNhYmxlZCddIGFzIGJvb2xlYW4pO1xuICBwcm90ZWN0ZWQgY2xlYXJCdXR0b24gPSBjb21wdXRlZDxib29sZWFuPigoKSA9PiAodGhpcy5vcHRpb25zKClbJ2NsZWFyQnV0dG9uJ10gYXMgYm9vbGVhbikgPz8gdHJ1ZSk7XG4gIHByb3RlY3RlZCBwbGFjZWhvbGRlciA9IGNvbXB1dGVkPHN0cmluZz4oKCkgPT4gdGhpcy5vcHRpb25zKClbJ3BsYWNlaG9sZGVyJ10gYXMgc3RyaW5nKTtcblxuICBwcm90ZWN0ZWQgdmFsaWRhdGlvblJ1bGVzID0gY29tcHV0ZWQ8QVhQVmFsaWRhdGlvblJ1bGVzPihcbiAgICAoKSA9PiAodGhpcy5vcHRpb25zKClbJ3ZhbGlkYXRpb25SdWxlcyddIGFzIEFYUFZhbGlkYXRpb25SdWxlcykgPz8gW11cbiAgKTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgcHJpdmF0ZSBnZXQgX19jbGFzcygpOiBzdHJpbmcge1xuICAgIGNvbnN0IGNsczogYW55ID0ge307XG4gICAgY2xzW2BheC1ibG9ja2BdID0gdHJ1ZTtcbiAgICBjbHNbYGF4LWZsZXgtMWBdID0gdHJ1ZTtcbiAgICByZXR1cm4gY2xzO1xuICB9XG59XG4iXX0=
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AXDataSource, convertArrayToDataSource } from '@acorex/components/common';
|
|
2
2
|
import { AXDecoratorModule } from '@acorex/components/decorators';
|
|
3
|
+
import { AXFormModule } from '@acorex/components/form';
|
|
3
4
|
import { AXSelectBoxComponent, AXSelectBoxModule } from '@acorex/components/select-box';
|
|
4
5
|
import { AXPWidgetComponent } from '@acorex/platform/layout/builder';
|
|
5
6
|
import { CommonModule } from '@angular/common';
|
|
@@ -8,11 +9,13 @@ import { FormsModule } from '@angular/forms';
|
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@angular/forms";
|
|
10
11
|
import * as i2 from "@acorex/components/select-box";
|
|
11
|
-
import * as i3 from "@acorex/components/
|
|
12
|
+
import * as i3 from "@acorex/components/form";
|
|
13
|
+
import * as i4 from "@acorex/components/decorators";
|
|
12
14
|
export class AXPSelectBoxWidgetEditComponent extends AXPWidgetComponent {
|
|
13
15
|
constructor() {
|
|
14
16
|
super(...arguments);
|
|
15
17
|
this.multiple = computed(() => this.options()['multiple']);
|
|
18
|
+
this.validationRules = computed(() => this.options()['validationRules'] ?? []);
|
|
16
19
|
this.dataSource = computed(() => {
|
|
17
20
|
const rawValue = this.options()['dataSource'];
|
|
18
21
|
if (rawValue instanceof AXDataSource) {
|
|
@@ -62,12 +65,17 @@ export class AXPSelectBoxWidgetEditComponent extends AXPWidgetComponent {
|
|
|
62
65
|
[multiple]="multiple()"
|
|
63
66
|
(onValueChanged)="handleValueChange($event)"
|
|
64
67
|
>
|
|
65
|
-
@if(hasClearButton())
|
|
66
|
-
|
|
67
|
-
|
|
68
|
+
@if(hasClearButton()) {
|
|
69
|
+
<ax-clear-button></ax-clear-button>
|
|
70
|
+
} @for (validation of validationRules(); track $index) {
|
|
71
|
+
<ax-validation-rule
|
|
72
|
+
[rule]="validation.rule"
|
|
73
|
+
[message]="validation.options?.message"
|
|
74
|
+
[options]="validation.options"
|
|
75
|
+
></ax-validation-rule>
|
|
68
76
|
}
|
|
69
77
|
</ax-select-box>
|
|
70
|
-
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: AXSelectBoxModule }, { kind: "component", type: i2.AXSelectBoxComponent, selector: "ax-select-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "minValue", "maxValue", "value", "state", "name", "id", "type", "look", "multiple", "valueField", "textField", "textTemplate", "dataSource", "caption", "itemTemplate", "selectedTemplate", "emptyTemplate", "loadingTemplate", "dropdownWidth"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange", "onOpened", "onClosed"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type:
|
|
78
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: AXSelectBoxModule }, { kind: "component", type: i2.AXSelectBoxComponent, selector: "ax-select-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "minValue", "maxValue", "value", "state", "name", "id", "type", "look", "multiple", "valueField", "textField", "textTemplate", "dataSource", "caption", "itemTemplate", "selectedTemplate", "emptyTemplate", "loadingTemplate", "dropdownWidth"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange", "onOpened", "onClosed"] }, { kind: "ngmodule", type: AXFormModule }, { kind: "directive", type: i3.AXValidationRuleDirective, selector: "ax-validation-rule", inputs: ["rule", "options", "message"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i4.AXDecoratorClearButtonComponent, selector: "ax-clear-button", inputs: ["icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
71
79
|
}
|
|
72
80
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPSelectBoxWidgetEditComponent, decorators: [{
|
|
73
81
|
type: Component,
|
|
@@ -85,16 +93,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
85
93
|
[multiple]="multiple()"
|
|
86
94
|
(onValueChanged)="handleValueChange($event)"
|
|
87
95
|
>
|
|
88
|
-
@if(hasClearButton())
|
|
89
|
-
|
|
90
|
-
|
|
96
|
+
@if(hasClearButton()) {
|
|
97
|
+
<ax-clear-button></ax-clear-button>
|
|
98
|
+
} @for (validation of validationRules(); track $index) {
|
|
99
|
+
<ax-validation-rule
|
|
100
|
+
[rule]="validation.rule"
|
|
101
|
+
[message]="validation.options?.message"
|
|
102
|
+
[options]="validation.options"
|
|
103
|
+
></ax-validation-rule>
|
|
91
104
|
}
|
|
92
105
|
</ax-select-box>
|
|
93
106
|
`,
|
|
94
107
|
standalone: true,
|
|
95
108
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
96
|
-
imports: [CommonModule, FormsModule, AXSelectBoxModule, AXDecoratorModule],
|
|
97
|
-
inputs: [],
|
|
109
|
+
imports: [CommonModule, FormsModule, AXSelectBoxModule, AXFormModule, AXDecoratorModule],
|
|
98
110
|
}]
|
|
99
111
|
}], propDecorators: { selectbox: [{
|
|
100
112
|
type: ViewChild,
|
|
@@ -103,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
103
115
|
type: HostBinding,
|
|
104
116
|
args: ['class']
|
|
105
117
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWJveC13aWRnZXQtZWRpdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsYXRmb3JtL3dpZGdldHMvc3JjL2xpYi93aWRnZXRzL2VkaXRvcnMvc2VsZWN0L3NlbGVjdC1ib3gtd2lkZ2V0LWVkaXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQXVCLHdCQUF3QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDeEcsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBRXhGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JHLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7O0FBK0I3QyxNQUFNLE9BQU8sK0JBQWdDLFNBQVEsa0JBQXVCO0lBN0I1RTs7UUFpQ1ksYUFBUSxHQUFHLFFBQVEsQ0FBVSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsVUFBVSxDQUFZLENBQUMsQ0FBQztRQUUxRSxvQkFBZSxHQUFHLFFBQVEsQ0FDbEMsR0FBRyxFQUFFLENBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUF3QixJQUFJLEVBQUUsQ0FDdEUsQ0FBQztRQUVRLGVBQVUsR0FBRyxRQUFRLENB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bnZlcnRBcnJheVRvRGF0YVNvdXJjZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHsgQVhEZWNvcmF0b3JNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvZGVjb3JhdG9ycyc7XG5pbXBvcnQgeyBBWEZvcm1Nb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvZm9ybSc7XG5pbXBvcnQgeyBBWFNlbGVjdEJveENvbXBvbmVudCwgQVhTZWxlY3RCb3hNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvc2VsZWN0LWJveCc7XG5pbXBvcnQgeyBBWFBWYWxpZGF0aW9uUnVsZXMgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL2NvcmUnO1xuaW1wb3J0IHsgQVhQV2lkZ2V0Q29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9wbGF0Zm9ybS9sYXlvdXQvYnVpbGRlcic7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIFZpZXdDaGlsZCwgY29tcHV0ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdheHAtc2VsZWN0LWJveC13aWRnZXQtZWRpdCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGF4LXNlbGVjdC1ib3hcbiAgICAgICNkZFxuICAgICAgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyKClcIlxuICAgICAgW2RhdGFTb3VyY2VdPVwiZGF0YVNvdXJjZSgpXCJcbiAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZCgpXCJcbiAgICAgIFt2YWx1ZUZpZWxkXT1cInZhbHVlRmllbGQoKVwiXG4gICAgICBbdGV4dEZpZWxkXT1cInRleHRGaWVsZCgpXCJcbiAgICAgIFtuZ01vZGVsXT1cImdldFZhbHVlKClcIlxuICAgICAgW211bHRpcGxlXT1cIm11bHRpcGxlKClcIlxuICAgICAgKG9uVmFsdWVDaGFuZ2VkKT1cImhhbmRsZVZhbHVlQ2hhbmdlKCRldmVudClcIlxuICAgID5cbiAgICAgIEBpZihoYXNDbGVhckJ1dHRvbigpKSB7XG4gICAgICA8YXgtY2xlYXItYnV0dG9uPjwvYXgtY2xlYXItYnV0dG9uPlxuICAgICAgfSBAZm9yICh2YWxpZGF0aW9uIG9mIHZhbGlkYXRpb25SdWxlcygpOyB0cmFjayAkaW5kZXgpIHtcbiAgICAgIDxheC12YWxpZGF0aW9uLXJ1bGVcbiAgICAgICAgW3J1bGVdPVwidmFsaWRhdGlvbi5ydWxlXCJcbiAgICAgICAgW21lc3NhZ2VdPVwidmFsaWRhdGlvbi5vcHRpb25zPy5tZXNzYWdlXCJcbiAgICAgICAgW29wdGlvbnNdPVwidmFsaWRhdGlvbi5vcHRpb25zXCJcbiAgICAgID48L2F4LXZhbGlkYXRpb24tcnVsZT5cbiAgICAgIH1cbiAgICA8L2F4LXNlbGVjdC1ib3g+XG4gIGAsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSwgQVhTZWxlY3RCb3hNb2R1bGUsIEFYRm9ybU1vZHVsZSwgQVhEZWNvcmF0b3JNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBBWFBTZWxlY3RCb3hXaWRnZXRFZGl0Q29tcG9uZW50IGV4dGVuZHMgQVhQV2lkZ2V0Q29tcG9uZW50PGFueT4ge1xuICBAVmlld0NoaWxkKEFYU2VsZWN0Qm94Q29tcG9uZW50KVxuICBwcml2YXRlIHNlbGVjdGJveCE6IEFYU2VsZWN0Qm94Q29tcG9uZW50O1xuXG4gIHByb3RlY3RlZCBtdWx0aXBsZSA9IGNvbXB1dGVkPGJvb2xlYW4+KCgpID0+IHRoaXMub3B0aW9ucygpWydtdWx0aXBsZSddIGFzIGJvb2xlYW4pO1xuXG4gIHByb3RlY3RlZCB2YWxpZGF0aW9uUnVsZXMgPSBjb21wdXRlZDxBWFBWYWxpZGF0aW9uUnVsZXM+KFxuICAgICgpID0+ICh0aGlzLm9wdGlvbnMoKVsndmFsaWRhdGlvblJ1bGVzJ10gYXMgQVhQVmFsaWRhdGlvblJ1bGVzKSA/PyBbXVxuICApO1xuXG4gIHByb3RlY3RlZCBkYXRhU291cmNlID0gY29tcHV0ZWQ8QVhEYXRhU291cmNlPigoKSA9PiB7XG4gICAgY29uc3QgcmF3VmFsdWUgPSB0aGlzLm9wdGlvbnMoKVsnZGF0YVNvdXJjZSddO1xuICAgIGlmIChyYXdWYWx1ZSBpbnN0YW5jZW9mIEFYRGF0YVNvdXJjZSkge1xuICAgICAgcmV0dXJuIHJhd1ZhbHVlO1xuICAgIH0gZWxzZSBpZiAoQXJyYXkuaXNBcnJheShyYXdWYWx1ZSkpIHtcbiAgICAgIHJldHVybiBjb252ZXJ0QXJyYXlUb0RhdGFTb3VyY2UocmF3VmFsdWUpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY29udmVydEFycmF5VG9EYXRhU291cmNlKFtdKTtcbiAgICB9XG4gIH0pO1xuXG4gIHByb3RlY3RlZCB2YWx1ZUZpZWxkID0gY29tcHV0ZWQ8c3RyaW5nPigoKSA9PiAodGhpcy5vcHRpb25zKClbJ3ZhbHVlRmllbGQnXSBhcyBzdHJpbmcpID8/ICdpZCcpO1xuICBwcm90ZWN0ZWQgdGV4dEZpZWxkID0gY29tcHV0ZWQ8c3RyaW5nPigoKSA9PiAodGhpcy5vcHRpb25zKClbJ3RleHRGaWVsZCddIGFzIHN0cmluZykgPz8gJ3RpdGxlJyk7XG4gIHByb3RlY3RlZCBkaXNhYmxlZCA9IGNvbXB1dGVkPGJvb2xlYW4+KCgpID0+IHRoaXMub3B0aW9ucygpWydkaXNhYmxlZCddIGFzIGJvb2xlYW4pO1xuICBwcm90ZWN0ZWQgcGxhY2Vob2xkZXIgPSBjb21wdXRlZDxzdHJpbmc+KCgpID0+ICh0aGlzLm9wdGlvbnMoKVsncGxhY2Vob2xkZXInXSBhcyBzdHJpbmcpID8/ICcnKTtcbiAgcHJvdGVjdGVkIGhhc0NsZWFyQnV0dG9uID0gY29tcHV0ZWQ8Ym9vbGVhbj4oKCkgPT4gdGhpcy5vcHRpb25zKClbJ2hhc0NsZWFyQnV0dG9uJ10gYXMgYm9vbGVhbik7XG5cbiAgcHJvdGVjdGVkIGhhbmRsZVZhbHVlQ2hhbmdlKGU6IEFYVmFsdWVDaGFuZ2VkRXZlbnQpIHtcbiAgICBpZiAoZS5pc1VzZXJJbnRlcmFjdGlvbikge1xuICAgICAgdGhpcy5zZXRWYWx1ZSgoZS5jb21wb25lbnQgYXMgQVhTZWxlY3RCb3hDb21wb25lbnQpLnNlbGVjdGVkSXRlbXNbMF0pO1xuICAgIH1cbiAgfVxuXG4gIHJlZnJlc2goKSB7XG4gICAgdGhpcy5zZWxlY3Rib3g/LnJlZnJlc2goKTtcbiAgfVxuXG4gIGNsZWFyKCkge1xuICAgIHRoaXMuc2VsZWN0Ym94Py5yZXNldCh0cnVlKTtcbiAgICB0aGlzLnNlbGVjdGJveD8ucmVmcmVzaCgpO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIHByaXZhdGUgZ2V0IF9fY2xhc3MoKTogc3RyaW5nIHtcbiAgICBjb25zdCBjbHM6IGFueSA9IHt9O1xuICAgIGNsc1tgYXgtYmxvY2tgXSA9IHRydWU7XG4gICAgY2xzW2BheC1mbGV4LTFgXSA9IHRydWU7XG4gICAgcmV0dXJuIGNscztcbiAgfVxufVxuIl19
|
|
@@ -3,11 +3,11 @@ import * as i3 from '@acorex/components/form';
|
|
|
3
3
|
import { AXFormModule } from '@acorex/components/form';
|
|
4
4
|
import * as i1 from '@acorex/components/text-area';
|
|
5
5
|
import { AXTextAreaModule } from '@acorex/components/text-area';
|
|
6
|
-
import { AXPWidgetEditBase } from './acorex-platform-common.mjs';
|
|
7
6
|
import * as i0 from '@angular/core';
|
|
8
7
|
import { Component } from '@angular/core';
|
|
9
8
|
import * as i2 from '@angular/forms';
|
|
10
9
|
import { FormsModule } from '@angular/forms';
|
|
10
|
+
import { AXPWidgetEditBase } from './acorex-platform-common.mjs';
|
|
11
11
|
import '@acorex/components/popup';
|
|
12
12
|
import '@acorex/core/date-time';
|
|
13
13
|
import '@angular/router';
|
|
@@ -32,30 +32,29 @@ import 'rxjs/operators';
|
|
|
32
32
|
|
|
33
33
|
class AXPLargeTextWidgetEditComponent extends AXPWidgetEditBase {
|
|
34
34
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPLargeTextWidgetEditComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPLargeTextWidgetEditComponent, isStandalone: true, selector: "axp-largetext-widget-edit",
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPLargeTextWidgetEditComponent, isStandalone: true, selector: "axp-largetext-widget-edit", usesInheritance: true, ngImport: i0, template: `
|
|
36
|
+
<ax-text-area [(ngModel)]="value">
|
|
37
|
+
@for(vl of validations;track $index) {
|
|
38
|
+
<ax-validation-rule [rule]="vl.rule" [options]="vl.options"></ax-validation-rule>
|
|
39
|
+
}
|
|
40
|
+
</ax-text-area>
|
|
41
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: AXTextAreaModule }, { kind: "component", type: i1.AXTextAreaComponent, selector: "ax-text-area", inputs: ["disabled", "tabIndex", "readonly", "value", "state", "name", "placeholder", "maxLength", "look", "rows", "allowResize", "showCounter"], outputs: ["onBlur", "onFocus", "valueChange", "stateChange", "onValueChanged", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }, { kind: "ngmodule", type: FormsModule }, { 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: AXDecoratorModule }, { kind: "ngmodule", type: AXFormModule }, { kind: "directive", type: i3.AXValidationRuleDirective, selector: "ax-validation-rule", inputs: ["rule", "options", "message"] }] }); }
|
|
42
42
|
}
|
|
43
43
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPLargeTextWidgetEditComponent, decorators: [{
|
|
44
44
|
type: Component,
|
|
45
45
|
args: [{
|
|
46
46
|
selector: 'axp-largetext-widget-edit',
|
|
47
47
|
template: `
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
48
|
+
<ax-text-area [(ngModel)]="value">
|
|
49
|
+
@for(vl of validations;track $index) {
|
|
50
|
+
<ax-validation-rule [rule]="vl.rule" [options]="vl.options"></ax-validation-rule>
|
|
51
|
+
}
|
|
52
|
+
</ax-text-area>
|
|
53
|
+
`,
|
|
54
54
|
standalone: true,
|
|
55
55
|
imports: [AXTextAreaModule, FormsModule, AXDecoratorModule, AXFormModule],
|
|
56
|
-
inputs: ['width']
|
|
57
56
|
}]
|
|
58
57
|
}] });
|
|
59
58
|
|
|
60
59
|
export { AXPLargeTextWidgetEditComponent };
|
|
61
|
-
//# sourceMappingURL=acorex-platform-common-largetext-widget-edit.component-
|
|
60
|
+
//# sourceMappingURL=acorex-platform-common-largetext-widget-edit.component-DD7S5j12.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-platform-common-largetext-widget-edit.component-DD7S5j12.mjs","sources":["../../../../libs/platform/common/src/lib/schema/widgets/text/largetext-widget-edit.component.ts"],"sourcesContent":["import { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXFormModule } from '@acorex/components/form';\nimport { AXTextAreaModule } from '@acorex/components/text-area';\nimport { Component } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { AXPWidgetEditBase } from '../../widget/widget-base';\n\n@Component({\n selector: 'axp-largetext-widget-edit',\n template: `\n <ax-text-area [(ngModel)]=\"value\">\n @for(vl of validations;track $index) {\n <ax-validation-rule [rule]=\"vl.rule\" [options]=\"vl.options\"></ax-validation-rule>\n }\n </ax-text-area>\n `,\n standalone: true,\n imports: [AXTextAreaModule, FormsModule, AXDecoratorModule, AXFormModule],\n})\nexport class AXPLargeTextWidgetEditComponent extends AXPWidgetEditBase<string> {}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmBM,MAAO,+BAAgC,SAAQ,iBAAyB,CAAA;8GAAjE,+BAA+B,EAAA,IAAA,EAAA,IAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;AAA/B,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,+BAA+B,EAVhC,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,2BAAA,EAAA,eAAA,EAAA,IAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAAA,CAAA;;;;;;AAMT,EAAA,CAAA,EAAA,QAAA,EAAA,IAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAES,gBAAgB,EAAE,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,mBAAA,EAAA,QAAA,EAAA,cAAA,EAAA,MAAA,EAAA,CAAA,UAAA,EAAA,UAAA,EAAA,UAAA,EAAA,OAAA,EAAA,OAAA,EAAA,MAAA,EAAA,aAAA,EAAA,WAAA,EAAA,MAAA,EAAA,MAAA,EAAA,aAAA,EAAA,aAAA,CAAA,EAAA,OAAA,EAAA,CAAA,QAAA,EAAA,SAAA,EAAA,aAAA,EAAA,aAAA,EAAA,gBAAA,EAAA,gBAAA,EAAA,gBAAA,EAAA,WAAA,EAAA,SAAA,EAAA,YAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,WAAW,EAAE,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,2CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,qDAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,UAAA,EAAA,SAAA,EAAA,gBAAA,CAAA,EAAA,OAAA,EAAA,CAAA,eAAA,CAAA,EAAA,QAAA,EAAA,CAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,iBAAiB,8BAAE,YAAY,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,yBAAA,EAAA,QAAA,EAAA,oBAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,SAAA,EAAA,SAAA,CAAA,EAAA,CAAA,EAAA,CAAA,CAAA,EAAA;;2FAE7D,+BAA+B,EAAA,UAAA,EAAA,CAAA;kBAZ3C,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,QAAQ,EAAE,2BAA2B;AACrC,oBAAA,QAAQ,EAAE,CAAA;;;;;;AAMT,EAAA,CAAA;AACD,oBAAA,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,gBAAgB,EAAE,WAAW,EAAE,iBAAiB,EAAE,YAAY,CAAC;AAC1E,iBAAA,CAAA;;;;;"}
|
|
@@ -1831,7 +1831,7 @@ class AXPCommonWidgetModule {
|
|
|
1831
1831
|
name: widgetSchemas.largetext,
|
|
1832
1832
|
component: {
|
|
1833
1833
|
edit: {
|
|
1834
|
-
component: () => import('./acorex-platform-common-largetext-widget-edit.component-
|
|
1834
|
+
component: () => import('./acorex-platform-common-largetext-widget-edit.component-DD7S5j12.mjs').then((c) => c.AXPLargeTextWidgetEditComponent),
|
|
1835
1835
|
},
|
|
1836
1836
|
column: {
|
|
1837
1837
|
options: {
|
|
@@ -256,7 +256,6 @@ class AXPWidgetComponent extends AXPLayoutElement {
|
|
|
256
256
|
this.options = this._options.asReadonly();
|
|
257
257
|
this.contextService = inject(AXPLayoutBuilderService);
|
|
258
258
|
this.rawValue = computed(() => {
|
|
259
|
-
debugger;
|
|
260
259
|
return this._fullPath ? get(this.contextService.context, this._fullPath) : null;
|
|
261
260
|
});
|
|
262
261
|
this.onReady = new Subject();
|