imm-element-ui 0.2.8 → 0.2.9

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.
@@ -8,7 +8,7 @@ import { I18nService } from '../../service/i18n.service';
8
8
  import { fieldUtils } from '../form-field/field-utils';
9
9
  import { generateUniqueId } from '../../share/utils';
10
10
  import { Router } from '@angular/router';
11
- import { shareReplay } from 'rxjs';
11
+ import { isObservable, shareReplay } from 'rxjs';
12
12
  import * as i0 from "@angular/core";
13
13
  import * as i1 from "@angular/common";
14
14
  export class FormComponent {
@@ -84,7 +84,9 @@ export class FormComponent {
84
84
  field.labelMinWidth = this.labelMinWidth;
85
85
  field.interactiveLabel = this.options().interactiveLabel ?? true;
86
86
  field.form = this;
87
- field.hook && this.uniqueHook(field, field.hook);
87
+ if (isObservable(field.hook)) {
88
+ this.uniqueHook(field, field.hook);
89
+ }
88
90
  this.handleFieldControl(field);
89
91
  });
90
92
  }
@@ -218,4 +220,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
218
220
  type: HostListener,
219
221
  args: ['window:resize', ['$event']]
220
222
  }] } });
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.ts","../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.html"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,MAAM,EACN,KAAK,EACL,QAAQ,EACR,YAAY,EAIZ,MAAM,EACN,YAAY,EACZ,SAAS,EACT,MAAM,GACN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,mBAAmB,EAAsB,MAAM,gBAAgB,CAAC;AAChG,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAa,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAEvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAc,WAAW,EAAE,MAAM,MAAM,CAAC;;;AAkB/C,MAAM,OAAO,aAAa;IAyBzB,QAAQ;QACP,IAAI,CAAC,eAAe,EAAE,CAAC;IACxB,CAAC;IAED,YACS,GAAsB,EACtB,QAAkB;QADlB,QAAG,GAAH,GAAG,CAAmB;QACtB,aAAQ,GAAR,QAAQ,CAAU;QA7B3B,WAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAC;QAChC,UAAK,GAAY,KAAK,CAAC;QACvB,YAAO,GAAG,KAAK,CAAc,EAAE,CAAC,CAAC;QACjC,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE;YACtB,SAAS,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,UAAU,CAAC,GAAG,EAAE;oBACf,IAAI,CAAC,eAAe,EAAE,CAAC;gBACxB,CAAC,CAAC,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAClC,UAAK,GAAG,KAAK,EAAO,CAAC;QACrB,WAAM,GAAG,KAAK,EAAU,CAAC;QACzB,aAAQ,GAAQ,EAAE,CAAC;QACnB,iBAAY,GAAQ,EAAE,CAAC;QAEvB,kBAAa,GAAe,EAAE,CAAC;QAC/B,kBAAa,GAAG,MAAM,CAAqB,SAAS,CAAC,CAAC;QAWrD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;QACjE,MAAM,CACL,GAAG,EAAE;YACJ,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;gBACnB,OAAO;YACR,CAAC;YACD,eAAe;YACf,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;oBAChC,IAAI,CAAC,KAAK,CAAC,OAAO;wBAAE,OAAO;oBAC3B,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAI,CAAC,KAAK,SAAS;wBAAE,OAAO;oBACnD,SAAS,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;oBAC9C,CAAC,CAAC,CAAC;gBACJ,CAAC,CAAC,CAAC;YACJ,CAAC;YACD,IAAI,CAAC,QAAQ,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;YACvB,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACrC,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC3B,CAAC;IACH,CAAC;IAED,eAAe;QACd,UAAU,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,eAAe,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACzC,IAAI,CAAC,eAAe,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,WAAW;QACV,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;IAC5D,CAAC;IAED,QAAQ;QACP,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,GAAG,EAAE,CAAC;QAC3B,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,CAAC;YAC1B,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QACzC,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;QAC9C,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAChC,KAAK,CAAC,IAAI,GAAG,gBAAgB,EAAE,CAAC;YAChC,KAAK,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;YACzC,KAAK,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,gBAAgB,IAAI,IAAI,CAAC;YACjE,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;YAClB,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;YACjD,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,QAAQ,CAAC,GAAW;QACnB,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;IAC1D,CAAC;IAED,WAAW,CAAC,MAAmB;QAC9B,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACxB,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;gBACjB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC5B,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,KAAgB;QAClC,MAAM,YAAY,GAAG,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ;YACpD,CAAC,CAAC,IAAI,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC;YACnF,CAAC,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG,IAAI,EAAE,EAAE,YAAY,CAAC,CAAC;QAC/D,KAAK,CAAC,YAAY,GAAG,YAAY,CAAC;QAClC,KAAK,CAAC,YAAY,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACpD,MAAM,WAAW,GAAG,UAAU,CAAC,cAAc,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC3E,IAAI,UAAU,CAAC,aAAa,CAAC,WAAW,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAI,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC;gBAC5E,OAAO;YACR,CAAC;YACD,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,iBAAiB,CAAC,KAAU,EAAE,KAAgB;QAC7C,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAI,CAAC,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAI,CAAC,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;QACpH,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAI,EAAE,KAAK,CAAC,CAAC;QACrC,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC7B,CAAC;IAED,YAAY,CAAC,GAAW,EAAE,KAAU;QACnC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,EAAG,CAAC,OAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACtC,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,MAAM,EAAG,CAAC,OAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,MAAM,EAAG,CAAC,GAAI,CAAC,OAAO,GAAG,UAAU,CAAC,QAAQ,CAChD,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,SAAU,CAAC,EACvC,IAAI,CAAC,KAAK,CACV,CAAC;IACH,CAAC;IAED,oBAAoB;QACnB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAChC,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;gBAC1B,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,KAAK,CAAC,CAAC;gBACvD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;oBAChB,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC,GAAI,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBACzE,CAAC;qBAAM,CAAC;oBACP,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC,GAAI,CAAC,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBACxE,CAAC;YACF,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,QAAQ;QACP,KAAK,IAAI,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC;YAC/C,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;QACrG,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC;IACnC,CAAC;IAED,UAAU,CAAC,KAAgB,EAAE,IAA6C;QACzE,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACxC,CAAC;IAED,WAAW;QACV,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAChC,UAAU,CAAC,sBAAsB,CAChC,KAAK,EACL,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAI,CAAC,EAC1B,CAAC,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAK,CAAC,EAC1E,IAAI,CAAC,aAAa,EAClB,GAAG,EAAE;gBACJ,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC7B,CAAC,EACD,IAAI,CAAC,QAAQ,CACb,CAAC;QACH,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,eAAe;QACd,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC,UAAU,EAAE,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,UAAU,CAAC,CAAC;YAClD,OAAO;QACR,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAClC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IAED,iBAAiB;QAChB,MAAM,WAAW,GAAiB,EAAE,CAAC;QACrC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;QACvD,MAAM,YAAY,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QAC3F,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;IAC/D,CAAC;IAED,cAAc,CAAC,eAA0D,EAAE,WAAyB;QACnG,IAAI,CAAC,eAAe,EAAE,CAAC;YACtB,OAAO;QACR,CAAC;QACD,eAAe,EAAE,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YACtC,MAAM,UAAU,GAAG,SAAS,CAAC,aAAa,EAAE,CAAC;YAC7C,IAAI,UAAU,EAAE,CAAC;gBAChB,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC9B,CAAC;YACD,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,kBAAkB,EAAE,EAAE,WAAW,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,KAAU;QAC5B,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAClC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAE,CAAC;YAClC,IAAI,CAAC,KAAK;gBAAE,OAAO;YACnB,UAAU,CAAC,sBAAsB,CAChC,KAAK,EACL,KAAK,CAAC,GAAG,CAAC,EACV,CAAC,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAK,CAAC,EAC1E,IAAI,CAAC,aAAa,EAClB,GAAG,EAAE;gBACJ,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC7B,CAAC,EACD,IAAI,CAAC,QAAQ,CACb,CAAC;QACH,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,QAAQ;QACP,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAChC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAK,CAAC,EAAE,CAAC;gBAC/C,KAAK,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC;YACnC,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;+GAzOW,aAAa;mGAAb,aAAa,qfAJd,CAAC,QAAQ,CAAC,8DAKP,kBAAkB,gDC3CjC,wIAMA,yDD+BW,YAAY,8BAAE,mBAAmB,+BAAE,kBAAkB;;4FAKnD,aAAa;kBARzB,SAAS;+BACC,aAAa,cACX,IAAI,WACP,CAAC,YAAY,EAAE,mBAAmB,EAAE,kBAAkB,CAAC,aACrD,CAAC,QAAQ,CAAC;6GAKa,eAAe;sBAAhD,YAAY;uBAAC,kBAAkB;gBAwBhC,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n\tComponent,\r\n\teffect,\r\n\tinput,\r\n\tcomputed,\r\n\tViewChildren,\r\n\tQueryList,\r\n\tElementRef,\r\n\tChangeDetectorRef,\r\n\tinject,\r\n\tHostListener,\r\n\tuntracked,\r\n\tsignal,\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormGroup, Validators, ReactiveFormsModule, FormSubmittedEvent } from '@angular/forms';\r\nimport { FieldControl } from '../form-field/field-control';\r\nimport { FormField, FormFieldComponent } from '../form-field/form-field';\r\nimport { DatePipe } from '@angular/common';\r\nimport { I18nService } from '../../service/i18n.service';\r\nimport { fieldUtils } from '../form-field/field-utils';\r\nimport { Upsert } from '../../am/am.component';\r\nimport { generateUniqueId } from '../../share/utils';\r\nimport { Router } from '@angular/router';\r\nimport { Observable, shareReplay } from 'rxjs';\r\nexport interface FormOptions {\r\n\tfields?: FormField[];\r\n\tform?: FormGroup;\r\n\tmainField?: string;\r\n\tlabelWidth?: string;\r\n\tinteractiveLabel?: boolean;\r\n\textra?: any;\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-form',\r\n\tstandalone: true,\r\n\timports: [CommonModule, ReactiveFormsModule, FormFieldComponent],\r\n\tproviders: [DatePipe],\r\n\ttemplateUrl: './form.component.html',\r\n\tstyleUrl: './form.component.scss',\r\n})\r\nexport class FormComponent {\r\n\t@ViewChildren(FormFieldComponent) fieldComponents?: QueryList<FormFieldComponent>;\r\n\trouter: Router = inject(Router);\r\n\tisNew: boolean = false;\r\n\toptions = input<FormOptions>({});\r\n\tfields = computed(() => {\r\n\t\tuntracked(() => {\r\n\t\t\tthis.initForm();\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.reCalcLabelSize();\r\n\t\t\t});\r\n\t\t});\r\n\t\treturn this.options().fields;\r\n\t});\r\n\r\n\ti18nService = inject(I18nService);\r\n\tmodel = input<any>();\r\n\tupsert = input<Upsert>();\r\n\trawModel: any = {};\r\n\tchangedModel: any = {};\r\n\tfieldList!: FormField[];\r\n\thookObservers: Function[] = [];\r\n\tlabelMinWidth = signal<string | undefined>(undefined);\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.reCalcLabelSize();\r\n\t}\r\n\r\n\tconstructor(\r\n\t\tprivate cdr: ChangeDetectorRef,\r\n\t\tprivate datePipe: DatePipe,\r\n\t) {\r\n\t\tthis.router.url.split('/').pop() == 'new' && (this.isNew = true);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tif (!this.model()) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\t// 默认值仅在表单新建时生效\r\n\t\t\t\tif (this.isNew) {\r\n\t\t\t\t\tthis.fieldList.forEach((field) => {\r\n\t\t\t\t\t\tif (!field.default) return;\r\n\t\t\t\t\t\tif (this.model()[field.key!] !== undefined) return;\r\n\t\t\t\t\t\tuntracked(() => {\r\n\t\t\t\t\t\t\tthis.handleValueChange(field.default, field);\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tthis.rawModel = { ...this.model() };\r\n\t\t\t\tthis.changedModel = {};\r\n\t\t\t\tuntracked(() => this.triggerHook());\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t\tthis.i18nService.change.subscribe((res) => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.hookObservers.forEach((unsubscribe) => unsubscribe());\r\n\t}\r\n\r\n\tinitForm() {\r\n\t\tif (!this.options().extra) {\r\n\t\t\tthis.options().extra = {};\r\n\t\t}\r\n\t\tif (!this.options().form) {\r\n\t\t\tthis.options().form = new FormGroup({});\r\n\t\t}\r\n\t\tthis.fieldList = [];\r\n\t\tthis.parseFields(this.options().fields || []);\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfield.uuid = generateUniqueId();\r\n\t\t\tfield.labelMinWidth = this.labelMinWidth;\r\n\t\t\tfield.interactiveLabel = this.options().interactiveLabel ?? true;\r\n\t\t\tfield.form = this;\r\n\t\t\tfield.hook && this.uniqueHook(field, field.hook);\r\n\t\t\tthis.handleFieldControl(field);\r\n\t\t});\r\n\t}\r\n\r\n\tgetField(key: string) {\r\n\t\treturn this.fieldList.find((field) => field.key === key);\r\n\t}\r\n\r\n\tparseFields(fields: FormField[]) {\r\n\t\tfields.forEach((field) => {\r\n\t\t\tif (field.group) {\r\n\t\t\t\tthis.parseFields(field.group);\r\n\t\t\t} else {\r\n\t\t\t\tthis.fieldList.push(field);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\thandleFieldControl(field: FormField) {\r\n\t\tconst fieldControl = fieldUtils.props(field).required\r\n\t\t\t? new FieldControl(null, field.validators ? field.validators : Validators.required)\r\n\t\t\t: new FieldControl(null);\r\n\t\tthis.options().form?.addControl(field.key || '', fieldControl);\r\n\t\tfield.fieldControl = fieldControl;\r\n\t\tfield.fieldControl?.valueChanges.subscribe((value) => {\r\n\t\t\tconst targetValue = fieldUtils.fromFieldValue(field, value, this.datePipe);\r\n\t\t\tif (fieldUtils.isFakedChange(targetValue, this.model()[field.key!], field)) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tthis.handleValueChange(targetValue, field);\r\n\t\t});\r\n\t}\r\n\r\n\thandleValueChange(value: any, field: FormField) {\r\n\t\tthis.model()[field.key!] = value;\r\n\t\tthis.changedModel[field.key!] = { name: fieldUtils.label(field, this.i18nService), value: value, type: field.type };\r\n\t\tthis.handleUpsert(field.key!, value);\r\n\t\tconsole.log('-----handleValueChange', this.upsert());\r\n\t\tthis.handleHideExpression();\r\n\t}\r\n\r\n\thandleUpsert(key: string, value: any) {\r\n\t\tif (this.isNew) {\r\n\t\t\tthis.upsert()!.addData![key] = value;\r\n\t\t} else {\r\n\t\t\tthis.upsert()!.updData![key] = value;\r\n\t\t}\r\n\t\tthis.upsert()!.log!.content = fieldUtils.transLog(\r\n\t\t\tthis.rawModel,\r\n\t\t\tthis.changedModel,\r\n\t\t\tthis.model()[this.options().mainField!],\r\n\t\t\tthis.isNew,\r\n\t\t);\r\n\t}\r\n\r\n\thandleHideExpression() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (field.hideExpression) {\r\n\t\t\t\tfield.hide = field.hideExpression(this.model(), field);\r\n\t\t\t\tif (field.hide) {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].disable({ emitEvent: false });\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].enable({ emitEvent: false });\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tvalidate() {\r\n\t\tfor (let key in this.options().form?.controls) {\r\n\t\t\t!this.options().form?.controls[key]['disabled'] && this.options().form?.controls[key].markAsDirty();\r\n\t\t}\r\n\t\treturn this.options().form?.valid;\r\n\t}\r\n\r\n\tuniqueHook(field: FormField, hook: Observable<(field?: FormField) => void>) {\r\n\t\tfield.hook = hook.pipe(shareReplay(1));\r\n\t}\r\n\r\n\ttriggerHook() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tthis.model()?.[field.key!],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\treCalcLabelSize() {\r\n\t\tif (this.options().labelWidth) {\r\n\t\t\tthis.labelMinWidth.set(this.options().labelWidth);\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tthis.labelMinWidth.set(undefined);\r\n\t\tthis.cdr.detectChanges();\r\n\t\tthis.handleFieldLabels();\r\n\t\tthis.cdr.detectChanges();\r\n\t}\r\n\r\n\thandleFieldLabels() {\r\n\t\tconst fieldLabels: ElementRef[] = [];\r\n\t\tthis.getFieldLabels(this.fieldComponents, fieldLabels);\r\n\t\tconst offsetWidths = fieldLabels.map((fieldLabel) => fieldLabel.nativeElement.offsetWidth);\r\n\t\tthis.labelMinWidth.set(Math.max(...offsetWidths) + 18 + 'px');\r\n\t}\r\n\r\n\tgetFieldLabels(fieldComponents: QueryList<FormFieldComponent> | undefined, fieldLabels: ElementRef[]) {\r\n\t\tif (!fieldComponents) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tfieldComponents?.forEach((component) => {\r\n\t\t\tconst fieldLabel = component.getFieldLabel();\r\n\t\t\tif (fieldLabel) {\r\n\t\t\t\tfieldLabels.push(fieldLabel);\r\n\t\t\t}\r\n\t\t\tthis.getFieldLabels(component.getFieldComponents(), fieldLabels);\r\n\t\t});\r\n\t}\r\n\r\n\ttriggerModelEffect(model: any) {\r\n\t\tObject.keys(model).forEach((key) => {\r\n\t\t\tconst field = this.getField(key)!;\r\n\t\t\tif (!field) return;\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tmodel[key],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\tfinalize() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (['image', 'upload'].includes(field.type!)) {\r\n\t\t\t\tfield.fieldControl?.afterSubmit();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n","@for (field of fields(); track field) {\r\n\t<form-field\r\n\t\tclass=\"w-full\"\r\n\t\t[field]=\"field\">\r\n\t</form-field>\r\n}\r\n"]}
223
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.ts","../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tComponent,\r\n\teffect,\r\n\tinput,\r\n\tcomputed,\r\n\tViewChildren,\r\n\tQueryList,\r\n\tElementRef,\r\n\tChangeDetectorRef,\r\n\tinject,\r\n\tHostListener,\r\n\tuntracked,\r\n\tsignal,\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormGroup, Validators, ReactiveFormsModule, FormSubmittedEvent } from '@angular/forms';\r\nimport { FieldControl } from '../form-field/field-control';\r\nimport { FormField, FormFieldComponent } from '../form-field/form-field';\r\nimport { DatePipe } from '@angular/common';\r\nimport { I18nService } from '../../service/i18n.service';\r\nimport { fieldUtils } from '../form-field/field-utils';\r\nimport { Upsert } from '../../am/am.component';\r\nimport { generateUniqueId } from '../../share/utils';\r\nimport { Router } from '@angular/router';\r\nimport { isObservable, Observable, shareReplay } from 'rxjs';\r\nexport interface FormOptions {\r\n\tfields?: FormField[];\r\n\tform?: FormGroup;\r\n\tmainField?: string;\r\n\tlabelWidth?: string;\r\n\tinteractiveLabel?: boolean;\r\n\textra?: any;\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-form',\r\n\tstandalone: true,\r\n\timports: [CommonModule, ReactiveFormsModule, FormFieldComponent],\r\n\tproviders: [DatePipe],\r\n\ttemplateUrl: './form.component.html',\r\n\tstyleUrl: './form.component.scss',\r\n})\r\nexport class FormComponent {\r\n\t@ViewChildren(FormFieldComponent) fieldComponents?: QueryList<FormFieldComponent>;\r\n\trouter: Router = inject(Router);\r\n\tisNew: boolean = false;\r\n\toptions = input<FormOptions>({});\r\n\tfields = computed(() => {\r\n\t\tuntracked(() => {\r\n\t\t\tthis.initForm();\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.reCalcLabelSize();\r\n\t\t\t});\r\n\t\t});\r\n\t\treturn this.options().fields;\r\n\t});\r\n\r\n\ti18nService = inject(I18nService);\r\n\tmodel = input<any>();\r\n\tupsert = input<Upsert>();\r\n\trawModel: any = {};\r\n\tchangedModel: any = {};\r\n\tfieldList!: FormField[];\r\n\thookObservers: Function[] = [];\r\n\tlabelMinWidth = signal<string | undefined>(undefined);\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.reCalcLabelSize();\r\n\t}\r\n\r\n\tconstructor(\r\n\t\tprivate cdr: ChangeDetectorRef,\r\n\t\tprivate datePipe: DatePipe,\r\n\t) {\r\n\t\tthis.router.url.split('/').pop() == 'new' && (this.isNew = true);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tif (!this.model()) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\t// 默认值仅在表单新建时生效\r\n\t\t\t\tif (this.isNew) {\r\n\t\t\t\t\tthis.fieldList.forEach((field) => {\r\n\t\t\t\t\t\tif (!field.default) return;\r\n\t\t\t\t\t\tif (this.model()[field.key!] !== undefined) return;\r\n\t\t\t\t\t\tuntracked(() => {\r\n\t\t\t\t\t\t\tthis.handleValueChange(field.default, field);\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tthis.rawModel = { ...this.model() };\r\n\t\t\t\tthis.changedModel = {};\r\n\t\t\t\tuntracked(() => this.triggerHook());\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t\tthis.i18nService.change.subscribe((res) => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.hookObservers.forEach((unsubscribe) => unsubscribe());\r\n\t}\r\n\r\n\tinitForm() {\r\n\t\tif (!this.options().extra) {\r\n\t\t\tthis.options().extra = {};\r\n\t\t}\r\n\t\tif (!this.options().form) {\r\n\t\t\tthis.options().form = new FormGroup({});\r\n\t\t}\r\n\t\tthis.fieldList = [];\r\n\t\tthis.parseFields(this.options().fields || []);\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfield.uuid = generateUniqueId();\r\n\t\t\tfield.labelMinWidth = this.labelMinWidth;\r\n\t\t\tfield.interactiveLabel = this.options().interactiveLabel ?? true;\r\n\t\t\tfield.form = this;\r\n\t\t\tif(isObservable(field.hook) ){\r\n\t\t\t\tthis.uniqueHook(field, field.hook);\r\n\t\t\t}\r\n\t\t\tthis.handleFieldControl(field);\r\n\t\t});\r\n\t}\r\n\r\n\tgetField(key: string) {\r\n\t\treturn this.fieldList.find((field) => field.key === key);\r\n\t}\r\n\r\n\tparseFields(fields: FormField[]) {\r\n\t\tfields.forEach((field) => {\r\n\t\t\tif (field.group) {\r\n\t\t\t\tthis.parseFields(field.group);\r\n\t\t\t} else {\r\n\t\t\t\tthis.fieldList.push(field);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\thandleFieldControl(field: FormField) {\r\n\t\tconst fieldControl = fieldUtils.props(field).required\r\n\t\t\t? new FieldControl(null, field.validators ? field.validators : Validators.required)\r\n\t\t\t: new FieldControl(null);\r\n\t\tthis.options().form?.addControl(field.key || '', fieldControl);\r\n\t\tfield.fieldControl = fieldControl;\r\n\t\tfield.fieldControl?.valueChanges.subscribe((value) => {\r\n\t\t\tconst targetValue = fieldUtils.fromFieldValue(field, value, this.datePipe);\r\n\t\t\tif (fieldUtils.isFakedChange(targetValue, this.model()[field.key!], field)) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tthis.handleValueChange(targetValue, field);\r\n\t\t});\r\n\t}\r\n\r\n\thandleValueChange(value: any, field: FormField) {\r\n\t\tthis.model()[field.key!] = value;\r\n\t\tthis.changedModel[field.key!] = { name: fieldUtils.label(field, this.i18nService), value: value, type: field.type };\r\n\t\tthis.handleUpsert(field.key!, value);\r\n\t\tconsole.log('-----handleValueChange', this.upsert());\r\n\t\tthis.handleHideExpression();\r\n\t}\r\n\r\n\thandleUpsert(key: string, value: any) {\r\n\t\tif (this.isNew) {\r\n\t\t\tthis.upsert()!.addData![key] = value;\r\n\t\t} else {\r\n\t\t\tthis.upsert()!.updData![key] = value;\r\n\t\t}\r\n\t\tthis.upsert()!.log!.content = fieldUtils.transLog(\r\n\t\t\tthis.rawModel,\r\n\t\t\tthis.changedModel,\r\n\t\t\tthis.model()[this.options().mainField!],\r\n\t\t\tthis.isNew,\r\n\t\t);\r\n\t}\r\n\r\n\thandleHideExpression() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (field.hideExpression) {\r\n\t\t\t\tfield.hide = field.hideExpression(this.model(), field);\r\n\t\t\t\tif (field.hide) {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].disable({ emitEvent: false });\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].enable({ emitEvent: false });\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tvalidate() {\r\n\t\tfor (let key in this.options().form?.controls) {\r\n\t\t\t!this.options().form?.controls[key]['disabled'] && this.options().form?.controls[key].markAsDirty();\r\n\t\t}\r\n\t\treturn this.options().form?.valid;\r\n\t}\r\n\r\n\tuniqueHook(field: FormField, hook: Observable<(field?: FormField) => void>) {\r\n\t\tfield.hook = hook.pipe(shareReplay(1));\r\n\t}\r\n\r\n\ttriggerHook() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tthis.model()?.[field.key!],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\treCalcLabelSize() {\r\n\t\tif (this.options().labelWidth) {\r\n\t\t\tthis.labelMinWidth.set(this.options().labelWidth);\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tthis.labelMinWidth.set(undefined);\r\n\t\tthis.cdr.detectChanges();\r\n\t\tthis.handleFieldLabels();\r\n\t\tthis.cdr.detectChanges();\r\n\t}\r\n\r\n\thandleFieldLabels() {\r\n\t\tconst fieldLabels: ElementRef[] = [];\r\n\t\tthis.getFieldLabels(this.fieldComponents, fieldLabels);\r\n\t\tconst offsetWidths = fieldLabels.map((fieldLabel) => fieldLabel.nativeElement.offsetWidth);\r\n\t\tthis.labelMinWidth.set(Math.max(...offsetWidths) + 18 + 'px');\r\n\t}\r\n\r\n\tgetFieldLabels(fieldComponents: QueryList<FormFieldComponent> | undefined, fieldLabels: ElementRef[]) {\r\n\t\tif (!fieldComponents) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tfieldComponents?.forEach((component) => {\r\n\t\t\tconst fieldLabel = component.getFieldLabel();\r\n\t\t\tif (fieldLabel) {\r\n\t\t\t\tfieldLabels.push(fieldLabel);\r\n\t\t\t}\r\n\t\t\tthis.getFieldLabels(component.getFieldComponents(), fieldLabels);\r\n\t\t});\r\n\t}\r\n\r\n\ttriggerModelEffect(model: any) {\r\n\t\tObject.keys(model).forEach((key) => {\r\n\t\t\tconst field = this.getField(key)!;\r\n\t\t\tif (!field) return;\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tmodel[key],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\tfinalize() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (['image', 'upload'].includes(field.type!)) {\r\n\t\t\t\tfield.fieldControl?.afterSubmit();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n","@for (field of fields(); track field) {\r\n\t<form-field\r\n\t\tclass=\"w-full\"\r\n\t\t[field]=\"field\">\r\n\t</form-field>\r\n}\r\n"]}
@@ -55,6 +55,14 @@ export class PageFormComponent extends AmComponent {
55
55
  this.isLog = this.modelLog();
56
56
  console.log('model-----', this.isLog, this.modelLog());
57
57
  }, { allowSignalWrites: true });
58
+ effect(() => {
59
+ if (this.statusSteps().length > 0 && !this.id) {
60
+ this.upsertPrm.addData[this.statusKey()] = this.statusSteps()[0]['value'];
61
+ this.getPrm.data = Object.assign(this.getPrm.data || {}, {
62
+ [this.statusKey()]: this.statusSteps()[0]['value']
63
+ });
64
+ }
65
+ }, { allowSignalWrites: true });
58
66
  }
59
67
  ngOnInit() {
60
68
  this.upCb = this.upCb.bind(this);
@@ -107,10 +115,11 @@ export class PageFormComponent extends AmComponent {
107
115
  });
108
116
  }
109
117
  }
110
- getDetail() {
118
+ getDetail(customSteps) {
111
119
  this.web_get(this.getPrm).subscribe(res => {
112
120
  this.updateTitle(res);
113
121
  this.formDisabled() && this.formDisFunc();
122
+ customSteps && customSteps.refreshSteps();
114
123
  });
115
124
  }
116
125
  updateTitle(res) {
@@ -158,8 +167,7 @@ export class PageFormComponent extends AmComponent {
158
167
  };
159
168
  }
160
169
  this.web_write(param).subscribe(res => {
161
- this.getDetail();
162
- customSteps.refreshSteps();
170
+ this.getDetail(customSteps);
163
171
  });
164
172
  }
165
173
  else {
@@ -208,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
208
216
  type: ViewChild,
209
217
  args: ['cForm']
210
218
  }] } });
211
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-form.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.ts","../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { UserHistoryService } from '../service/userHistory.service';\r\nimport { Component, inject, OnInit, ViewChild, input, effect, computed, Input } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { FormComponent,FormOptions } from '../form/form/form.component';\r\nimport { RowSelectorComponent } from '../row-selector/row-selector.component'\r\nimport { LogComponent } from '../log/log.component';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { CrumbActionComponent } from '../crumb-action/crumb-action.component';\r\nimport { StepsComponent,Step } from '../steps/steps.component';\r\nimport { GridComponent, GridOptions } from '../grid/grid/grid.component';\r\nimport { TabsModule } from 'primeng/tabs';\r\nimport { AmComponent, Get, } from '../am/am.component';\r\nimport { Search } from '../am/am.component'\r\nimport { HrefBtnList,GridList } from './page-form.interface';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { PermissionBtn } from './page-form.interface';\r\nimport { formTypeToProps } from './page-form.interface'\r\n@Component({\r\n  selector: 'app-page-form',\r\n  standalone: true,\r\n  imports: [\r\n    ButtonModule,\r\n    ReactiveFormsModule,\r\n    FormComponent,\r\n    LogComponent,\r\n    CrumbActionComponent,\r\n    StepsComponent,\r\n    GridComponent,\r\n    TabsModule,\r\n    RowSelectorComponent,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './page-form.component.html',\r\n  styleUrl: './page-form.component.scss',\r\n  providers:[]\r\n})\r\nexport class PageFormComponent extends AmComponent implements OnInit{\r\n  addVisible = input<boolean>()\r\n  gridList = input<GridList[]>([])\r\n  form = input.required<FormOptions>({})\r\n  getPrmInput = input.required<Get>({})\r\n  statusSteps = input<Step[]>([])\r\n  statusKey = input('status')\r\n  hrefBtnList = input<HrefBtnList[]>([])\r\n  setTitle = input<string>()\r\n  actionList = input<PermissionBtn[]>([])\r\n  modelLog = input<boolean>(false)\r\n  formDisabled = input<Function>()\r\n\r\n  @ViewChild('customGrid') customGrid!: GridComponent;\r\n  @ViewChild('cForm') cForm!: FormComponent\r\n  userHistoryService =  inject(UserHistoryService)\r\n  indexValue = 0\r\n  visible = false\r\n  dialogSearchPrm!: Search\r\n  selectOptions!:GridOptions\r\n  selectData :any[]= []\r\n  pageUrl = ''\r\n  newUrl = ''\r\n  i18n = inject(I18nService)\r\n  authLevel = input<number>(-1)\r\n  constructor(){\r\n    super()\r\n    this.id = Number(this.route.snapshot.paramMap.get('id'))\r\n    this.pageUrl = this.route.snapshot.url.map(segment => segment.path).join('/').replace(/([^\\/]*)$/, \"\")\r\n    this.newUrl = `${this.pageUrl}new`\r\n    effect(() => {\r\n      this.modelName = this.getPrmInput().modelName!\r\n      this.getPrm = {...this.getPrmInput()}\r\n      this.id && (this.getPrm.id = this.id)\r\n      this.id && this.getDetail()\r\n    },{ allowSignalWrites: true })\r\n\r\n    effect(() => {\r\n      this.formOptions = {...this.form()}\r\n    })\r\n    effect(() => {\r\n      this.isLog = this.modelLog()\r\n      console.log('model-----',this.isLog,this.modelLog())\r\n    },{allowSignalWrites:true})\r\n  }\r\n  ngOnInit(): void {\r\n    this.upCb = this.upCb.bind(this)\r\n  }\r\n\r\n  submitForm() :any{\r\n    if(this.cForm.validate()){\r\n      let cb:any = this.id === 0 ? null : this.upCb\r\n      this.upsert(null,cb)\r\n    }\r\n  }\r\n\r\n  delRows(e:any) {\r\n    const gridTab = this.gridList()[this.indexValue]\r\n    const deleteFunc = gridTab.deleteFunc\r\n    const subTable = gridTab.gridOptions.modelName;\r\n\r\n    let prm = { \r\n      modelName: subTable, \r\n      ids:e \r\n    };\r\n    if(!deleteFunc){\r\n      this.web_remove(prm).subscribe((res) => {\r\n        this.get();\r\n      });\r\n    } else {\r\n      deleteFunc().subscribe(() => {\r\n        this.get()\r\n      })\r\n    }\r\n    \r\n  }\r\n  upCb(res?:any){\r\n    if(res.id == 0){\r\n      this.getDetail()\r\n    }else {\r\n      setTimeout(() => {\r\n        let editUrl = `${this.pageUrl}${res.id}`\r\n        this.router.navigate([editUrl])\r\n      }, 1500)\r\n    }\r\n    this.cForm.finalize()\r\n  }\r\n  // TODO 是否需要数据转换回调函数\r\n  onOk(e:any){\r\n    this.gridList()[this.indexValue].selectData = []\r\n    if(e.length > 0){\r\n      let { selectDataCb } = this.gridList()[this.indexValue]\r\n      e.forEach((item:any) => {\r\n        let obj = selectDataCb ? selectDataCb(item): {...item}\r\n        this.gridList()[this.indexValue].selectData!.push(obj)\r\n      })\r\n    } \r\n  }\r\n  getDetail(){\r\n    this.web_get(this.getPrm).subscribe(res => {\r\n      this.updateTitle(res)\r\n      this.formDisabled() && this.formDisFunc()\r\n    })\r\n  }\r\n  updateTitle(res:any){\r\n    // let title = this.setTitle() ? this.setTitle() : ''\r\n    // title !== '' && this.userHistoryService.setLastTitle(title)\r\n    let mainField = this.form().mainField\r\n    let title = res[mainField!]\r\n    this.userHistoryService.setLastTitle(title)\r\n  }\r\n  dataSourceShow(){\r\n    this.dialogSearchPrm = {...this.gridList()[this.indexValue]['searchPrm']!}\r\n    this.selectOptions = this.gridList()[this.indexValue]['selectOptions']!\r\n    console.log('seletc-----',this.selectOptions)\r\n    this.dialogSearchPrm.modelName = this.selectOptions.modelName\r\n    this.visible = true\r\n  }\r\n\r\n  goRun(data:any){\r\n    if(data.idKey){\r\n      let id = this.getPrm.data[data.idKey]\r\n      this.router.navigate([`${data.url}/${id}`])\r\n    } else {\r\n      this.router.navigate([data.url])\r\n    }\r\n  }\r\n\r\n  authClick(btn:any){\r\n    console.log('authClick',btn)\r\n    if(btn.hasOwnProperty('onClick')){\r\n      btn.onClick(this.getPrm.data)\r\n    }\r\n  }\r\n  statusChange(value:any, customSteps: StepsComponent){\r\n    if(this.authLevel() < 4) return;\r\n    if(this.id){\r\n      let param :any= {\r\n        modelName: this.modelName,\r\n        data:{id: this.id, [this.statusKey()]: value}\r\n      }\r\n      if(this.isLog){\r\n        param.logModel = `${this.modelName}Log`\r\n        param.log = {\r\n          pid:this.id,\r\n          content:`[状态] ${this.getPrm.data![this.statusKey()]} -> ${value}`\r\n        }\r\n      }\r\n      this.web_write(param).subscribe(res => {\r\n        this.getDetail()\r\n        customSteps.refreshSteps()\r\n      })\r\n    } else {\r\n      this.getPrm.data = Object.assign(this.getPrm.data||{},{\r\n        [this.statusKey()]:value\r\n      })\r\n      this.upsertPrm.addData![this.statusKey()] = value\r\n      this.cForm.triggerModelEffect({[this.statusKey()]:value})\r\n      customSteps.refreshSteps()\r\n    }\r\n  }\r\n\r\n  formDisFunc(){\r\n    this.formOptions.fields?.forEach((v) => {\r\n      v.group?.forEach((g:any) => {\r\n        let fieldDisabled = g[formTypeToProps[g.type]].disabled || false\r\n        if(this.formDisabled()!(this.getPrm.data) ){\r\n          this.cForm.getField(g.key)?.fieldControl!.disable({emitEvent: false}) \r\n        } else {\r\n          !fieldDisabled && this.cForm.getField(g.key)?.fieldControl!.enable({emitEvent: false}) \r\n        }\r\n      })\r\n    })\r\n  }\r\n}","<div class=\"overflow-hidden\">\r\n  <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n    <app-crumb-action\r\n      [addVisible]=\"addVisible()\"\r\n      [newUrl]=\"newUrl\"\r\n      [isShowCog]=\"true\"\r\n      [outlined]=\"true\"\r\n      [authLevel]=\"authLevel()\"\r\n      [actionList]=\"actionList()\"\r\n      (actionEvent)=\"authClick($event)\"\r\n      (saveEvent)=\"submitForm()\">\r\n    </app-crumb-action>\r\n    <div class=\"hrefBtnList\">\r\n      @if(id){\r\n        @for(btn of hrefBtnList();track btn){\r\n          <p-button \r\n            [variant]=\"btn?.variant\" \r\n            [severity]=\"btn?.severity\" \r\n            class=\"mr-[6px]\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n            (click)=\"goRun(btn)\"\r\n          >\r\n        </p-button>\r\n        }\r\n      }\r\n      \r\n    </div>\r\n    <div></div>\r\n    \r\n  </div>\r\n  <div class=\"flex\">\r\n    <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n      <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n        @for (btn of actionList();let i = $index; track btn) {\r\n          <p-button\r\n            [variant]=\"btn?.variant\"\r\n            [severity]=\"btn?.severity\"\r\n            class=\"mr-[4px]\"\r\n            size=\"small\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n            (click)=\"authClick(btn)\"\r\n            [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n            >\r\n          </p-button>\r\n        }\r\n      </div>\r\n  \r\n      <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n        <custom-steps\r\n          #customSteps\r\n          class=\"w-full\"\r\n          [steps]=\"statusSteps()\"\r\n          [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n          [authLevel]=\"authLevel()\"\r\n          (change)=\"statusChange($event, customSteps)\">\r\n        </custom-steps>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"main flex flex-wrap overflow-y-hidden\">\r\n    <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n      <div class=\"bg-white mx-2 form-panel\">\r\n        <div class=\"p-2 flex-1\">\r\n          <form\r\n            [formGroup]=\"form().form!\">\r\n            <custom-form\r\n              #cForm\r\n              [options]=\"formOptions\"\r\n              [upsert]=\"upsertPrm\"\r\n              [model]=\"getPrm.data??{}\"></custom-form>\r\n          </form>\r\n        </div>\r\n        @if(gridList() && gridList().length > 1){\r\n          <div class=\"relative mb-2\">\r\n            <p-tabs [(value)]=\"indexValue\">\r\n              <p-tablist>\r\n                @for (fchild of gridList();let i = $index; track fchild) {\r\n                  <p-tab [value]=\"i\">\r\n                    {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n                  </p-tab>\r\n                }\r\n              </p-tablist>\r\n            </p-tabs>\r\n          </div>\r\n        }\r\n        @for (grid of gridList(); let i = $index;track grid) {\r\n          <custom-grid\r\n            #customGrid\r\n            [hidden]=\"indexValue !=i \"\r\n            [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n            [upsert]=\"upsertPrm\"\r\n            (deleteEmit)=\"delRows($event)\"\r\n            [addType]=\"grid.subTableSource\"\r\n            (addEmit)=\"dataSourceShow()\"\r\n            [gridOptions]=\"grid.gridOptions\"\r\n            [authLevel]=\"authLevel()\"\r\n            [selectData]=\"grid.selectData\">\r\n          </custom-grid>\r\n        }       \r\n      </div>\r\n    </div>\r\n    <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n      <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n    </div>\r\n  </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-form.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.ts","../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { UserHistoryService } from '../service/userHistory.service';\r\nimport { Component, inject, OnInit, ViewChild, input, effect, computed, Input } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { FormComponent,FormOptions } from '../form/form/form.component';\r\nimport { RowSelectorComponent } from '../row-selector/row-selector.component'\r\nimport { LogComponent } from '../log/log.component';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { CrumbActionComponent } from '../crumb-action/crumb-action.component';\r\nimport { StepsComponent,Step } from '../steps/steps.component';\r\nimport { GridComponent, GridOptions } from '../grid/grid/grid.component';\r\nimport { TabsModule } from 'primeng/tabs';\r\nimport { AmComponent, Get, } from '../am/am.component';\r\nimport { Search } from '../am/am.component'\r\nimport { HrefBtnList,GridList } from './page-form.interface';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { PermissionBtn } from './page-form.interface';\r\nimport { formTypeToProps } from './page-form.interface'\r\n@Component({\r\n  selector: 'app-page-form',\r\n  standalone: true,\r\n  imports: [\r\n    ButtonModule,\r\n    ReactiveFormsModule,\r\n    FormComponent,\r\n    LogComponent,\r\n    CrumbActionComponent,\r\n    StepsComponent,\r\n    GridComponent,\r\n    TabsModule,\r\n    RowSelectorComponent,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './page-form.component.html',\r\n  styleUrl: './page-form.component.scss',\r\n  providers:[]\r\n})\r\nexport class PageFormComponent extends AmComponent implements OnInit{\r\n  addVisible = input<boolean>()\r\n  gridList = input<GridList[]>([])\r\n  form = input.required<FormOptions>({})\r\n  getPrmInput = input.required<Get>({})\r\n  statusSteps = input<Step[]>([])\r\n  statusKey = input('status')\r\n  hrefBtnList = input<HrefBtnList[]>([])\r\n  setTitle = input<string>()\r\n  actionList = input<PermissionBtn[]>([])\r\n  modelLog = input<boolean>(false)\r\n  formDisabled = input<Function>()\r\n\r\n  @ViewChild('customGrid') customGrid!: GridComponent;\r\n  @ViewChild('cForm') cForm!: FormComponent\r\n  userHistoryService =  inject(UserHistoryService)\r\n  indexValue = 0\r\n  visible = false\r\n  dialogSearchPrm!: Search\r\n  selectOptions!:GridOptions\r\n  selectData :any[]= []\r\n  pageUrl = ''\r\n  newUrl = ''\r\n  i18n = inject(I18nService)\r\n  authLevel = input<number>(-1)\r\n  constructor(){\r\n    super()\r\n    this.id = Number(this.route.snapshot.paramMap.get('id'))\r\n    this.pageUrl = this.route.snapshot.url.map(segment => segment.path).join('/').replace(/([^\\/]*)$/, \"\")\r\n    this.newUrl = `${this.pageUrl}new`\r\n    effect(() => {\r\n      this.modelName = this.getPrmInput().modelName!\r\n      this.getPrm = {...this.getPrmInput()}\r\n      this.id && (this.getPrm.id = this.id)\r\n      this.id && this.getDetail()\r\n    },{ allowSignalWrites: true })\r\n\r\n    effect(() => {\r\n      this.formOptions = {...this.form()}\r\n    })\r\n    effect(() => {\r\n      this.isLog = this.modelLog()\r\n      console.log('model-----',this.isLog,this.modelLog())\r\n    },{allowSignalWrites:true})\r\n    effect(() => {\r\n      if(this.statusSteps().length > 0 && !this.id){\r\n        this.upsertPrm.addData![this.statusKey()] = this.statusSteps()[0]['value']\r\n        this.getPrm.data = Object.assign(this.getPrm.data||{},{\r\n          [this.statusKey()]:this.statusSteps()[0]['value']\r\n        })\r\n      }\r\n    },{allowSignalWrites:true})\r\n  }\r\n  ngOnInit(): void {\r\n    this.upCb = this.upCb.bind(this)\r\n  }\r\n\r\n  submitForm() :any{\r\n    if(this.cForm.validate()){\r\n      let cb:any = this.id === 0 ? null : this.upCb\r\n      this.upsert(null,cb)\r\n    }\r\n  }\r\n\r\n  delRows(e:any) {\r\n    const gridTab = this.gridList()[this.indexValue]\r\n    const deleteFunc = gridTab.deleteFunc\r\n    const subTable = gridTab.gridOptions.modelName;\r\n\r\n    let prm = { \r\n      modelName: subTable, \r\n      ids:e \r\n    };\r\n    if(!deleteFunc){\r\n      this.web_remove(prm).subscribe((res) => {\r\n        this.get();\r\n      });\r\n    } else {\r\n      deleteFunc().subscribe(() => {\r\n        this.get()\r\n      })\r\n    }\r\n    \r\n  }\r\n  upCb(res?:any){\r\n    if(res.id == 0){\r\n      this.getDetail()\r\n    }else {\r\n      setTimeout(() => {\r\n        let editUrl = `${this.pageUrl}${res.id}`\r\n        this.router.navigate([editUrl])\r\n      }, 1500)\r\n    }\r\n    this.cForm.finalize()\r\n  }\r\n  // TODO 是否需要数据转换回调函数\r\n  onOk(e:any){\r\n    this.gridList()[this.indexValue].selectData = []\r\n    if(e.length > 0){\r\n      let { selectDataCb } = this.gridList()[this.indexValue]\r\n      e.forEach((item:any) => {\r\n        let obj = selectDataCb ? selectDataCb(item): {...item}\r\n        this.gridList()[this.indexValue].selectData!.push(obj)\r\n      })\r\n    } \r\n  }\r\n  getDetail(customSteps?: StepsComponent){\r\n    this.web_get(this.getPrm).subscribe(res => {\r\n      this.updateTitle(res)\r\n      this.formDisabled() && this.formDisFunc()\r\n      customSteps && customSteps.refreshSteps()\r\n    })\r\n  }\r\n  updateTitle(res:any){\r\n    // let title = this.setTitle() ? this.setTitle() : ''\r\n    // title !== '' && this.userHistoryService.setLastTitle(title)\r\n    let mainField = this.form().mainField\r\n    let title = res[mainField!]\r\n    this.userHistoryService.setLastTitle(title)\r\n  }\r\n  dataSourceShow(){\r\n    this.dialogSearchPrm = {...this.gridList()[this.indexValue]['searchPrm']!}\r\n    this.selectOptions = this.gridList()[this.indexValue]['selectOptions']!\r\n    console.log('seletc-----',this.selectOptions)\r\n    this.dialogSearchPrm.modelName = this.selectOptions.modelName\r\n    this.visible = true\r\n  }\r\n\r\n  goRun(data:any){\r\n    if(data.idKey){\r\n      let id = this.getPrm.data[data.idKey]\r\n      this.router.navigate([`${data.url}/${id}`])\r\n    } else {\r\n      this.router.navigate([data.url])\r\n    }\r\n  }\r\n\r\n  authClick(btn:any){\r\n    console.log('authClick',btn)\r\n    if(btn.hasOwnProperty('onClick')){\r\n      btn.onClick(this.getPrm.data)\r\n    }\r\n  }\r\n  statusChange(value:any, customSteps: StepsComponent){\r\n    if(this.authLevel() < 4) return;\r\n    if(this.id){\r\n      let param :any= {\r\n        modelName: this.modelName,\r\n        data:{id: this.id, [this.statusKey()]: value}\r\n      }\r\n      if(this.isLog){\r\n        param.logModel = `${this.modelName}Log`\r\n        param.log = {\r\n          pid:this.id,\r\n          content:`[状态] ${this.getPrm.data![this.statusKey()]} -> ${value}`\r\n        }\r\n      }\r\n      this.web_write(param).subscribe(res => {\r\n        this.getDetail(customSteps)\r\n      })\r\n    } else {\r\n      this.getPrm.data = Object.assign(this.getPrm.data||{},{\r\n        [this.statusKey()]:value\r\n      })\r\n      this.upsertPrm.addData![this.statusKey()] = value\r\n      this.cForm.triggerModelEffect({[this.statusKey()]:value})\r\n      customSteps.refreshSteps()\r\n    }\r\n  }\r\n\r\n  formDisFunc(){\r\n    this.formOptions.fields?.forEach((v) => {\r\n      v.group?.forEach((g:any) => {\r\n        let fieldDisabled = g[formTypeToProps[g.type]].disabled || false\r\n        if(this.formDisabled()!(this.getPrm.data) ){\r\n          this.cForm.getField(g.key)?.fieldControl!.disable({emitEvent: false}) \r\n        } else {\r\n          !fieldDisabled && this.cForm.getField(g.key)?.fieldControl!.enable({emitEvent: false}) \r\n        }\r\n      })\r\n    })\r\n  }\r\n}","<div class=\"overflow-hidden\">\r\n  <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n    <app-crumb-action\r\n      [addVisible]=\"addVisible()\"\r\n      [newUrl]=\"newUrl\"\r\n      [isShowCog]=\"true\"\r\n      [outlined]=\"true\"\r\n      [authLevel]=\"authLevel()\"\r\n      [actionList]=\"actionList()\"\r\n      (actionEvent)=\"authClick($event)\"\r\n      (saveEvent)=\"submitForm()\">\r\n    </app-crumb-action>\r\n    <div class=\"hrefBtnList\">\r\n      @if(id){\r\n        @for(btn of hrefBtnList();track btn){\r\n          <p-button \r\n            [variant]=\"btn?.variant\" \r\n            [severity]=\"btn?.severity\" \r\n            class=\"mr-[6px]\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n            (click)=\"goRun(btn)\"\r\n          >\r\n        </p-button>\r\n        }\r\n      }\r\n      \r\n    </div>\r\n    <div></div>\r\n    \r\n  </div>\r\n  <div class=\"flex\">\r\n    <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n      <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n        @for (btn of actionList();let i = $index; track btn) {\r\n          <p-button\r\n            [variant]=\"btn?.variant\"\r\n            [severity]=\"btn?.severity\"\r\n            class=\"mr-[4px]\"\r\n            size=\"small\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n            (click)=\"authClick(btn)\"\r\n            [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n            >\r\n          </p-button>\r\n        }\r\n      </div>\r\n  \r\n      <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n        <custom-steps\r\n          #customSteps\r\n          class=\"w-full\"\r\n          [steps]=\"statusSteps()\"\r\n          [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n          [authLevel]=\"authLevel()\"\r\n          (change)=\"statusChange($event, customSteps)\">\r\n        </custom-steps>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"main flex flex-wrap overflow-y-hidden\">\r\n    <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n      <div class=\"bg-white mx-2 form-panel\">\r\n        <div class=\"p-2 flex-1\">\r\n          <form\r\n            [formGroup]=\"form().form!\">\r\n            <custom-form\r\n              #cForm\r\n              [options]=\"formOptions\"\r\n              [upsert]=\"upsertPrm\"\r\n              [model]=\"getPrm.data??{}\"></custom-form>\r\n          </form>\r\n        </div>\r\n        @if(gridList() && gridList().length > 1){\r\n          <div class=\"relative mb-2\">\r\n            <p-tabs [(value)]=\"indexValue\">\r\n              <p-tablist>\r\n                @for (fchild of gridList();let i = $index; track fchild) {\r\n                  <p-tab [value]=\"i\">\r\n                    {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n                  </p-tab>\r\n                }\r\n              </p-tablist>\r\n            </p-tabs>\r\n          </div>\r\n        }\r\n        @for (grid of gridList(); let i = $index;track grid) {\r\n          <custom-grid\r\n            #customGrid\r\n            [hidden]=\"indexValue !=i \"\r\n            [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n            [upsert]=\"upsertPrm\"\r\n            (deleteEmit)=\"delRows($event)\"\r\n            [addType]=\"grid.subTableSource\"\r\n            (addEmit)=\"dataSourceShow()\"\r\n            [gridOptions]=\"grid.gridOptions\"\r\n            [authLevel]=\"authLevel()\"\r\n            [selectData]=\"grid.selectData\">\r\n          </custom-grid>\r\n        }       \r\n      </div>\r\n    </div>\r\n    <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n      <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n    </div>\r\n  </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>"]}
@@ -28,6 +28,7 @@ export class StepsComponent {
28
28
  this.widthList = [];
29
29
  this.START_BUTTON_WIDTH = 32;
30
30
  this.END_BUTTON_WIDTH = 47;
31
+ this.STEP_ITEM_MARGIN = 2;
31
32
  this.startIndex = 0;
32
33
  this.endIndex = 0;
33
34
  this.startSteps = [];
@@ -52,7 +53,7 @@ export class StepsComponent {
52
53
  if (children[i].classList.contains('end-item')) {
53
54
  continue;
54
55
  }
55
- this.widthList.push(children[i].offsetWidth || 0);
56
+ this.widthList.push((children[i].offsetWidth || 0) + this.STEP_ITEM_MARGIN);
56
57
  }
57
58
  }
58
59
  calcMaxWidth() {
@@ -168,7 +169,7 @@ export class StepsComponent {
168
169
  setTimeout(() => {
169
170
  this.alternateWidthList();
170
171
  this.handleSteps();
171
- });
172
+ }, 300);
172
173
  }
173
174
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StepsComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
174
175
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: StepsComponent, isStandalone: true, selector: "custom-steps", inputs: { steps: { classPropertyName: "steps", publicName: "steps", isSignal: true, isRequired: false, transformFunction: null }, current: { classPropertyName: "current", publicName: "current", isSignal: true, isRequired: false, transformFunction: null }, authLevel: { classPropertyName: "authLevel", publicName: "authLevel", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { change: "change" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }, { propertyName: "endBtn", first: true, predicate: ["endBtn"], descendants: true }], ngImport: i0, template: "<div\r\n\t#container\r\n\tclass=\"flex my-1 w-full justify-end\">\r\n\t@for (st of displaySteps(); track st; let i = $index) {\r\n\t\t@if (st.value === 'start') {\r\n\t\t\t<div\r\n\t\t\t\t#startItem\r\n\t\t\t\t[class]=\"getClass(i, ['start-item'])\"\r\n\t\t\t\t(click)=\"showStartSteps($event, startOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#startOp\r\n\t\t\t\t[styleClass]=\"'pop-steps start-steps'\"\r\n\t\t\t\t[appendTo]=\"startItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"startSteps\"\r\n\t\t\t\t\t(onChange)=\"onStartStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else if (st.value === 'end') {\r\n\t\t\t<div\r\n\t\t\t\t#endItem\r\n\t\t\t\t[class]=\"getClass(i, ['end-item'])\"\r\n\t\t\t\t(click)=\"showEndSteps($event, endOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#endOp\r\n\t\t\t\t[styleClass]=\"'pop-steps end-steps'\"\r\n\t\t\t\t[appendTo]=\"endItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"endSteps\"\r\n\t\t\t\t\t(onChange)=\"onEndStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else {\r\n\t\t\t<div\r\n\t\t\t\t[class]=\"getClass(i, [])\"\r\n\t\t\t\t(click)=\"changeStatus(st)\">\r\n\t\t\t\t<span>{{ st.i18nKey ? i18n.fanyi(st.i18nKey) : st.label }}</span>\r\n\t\t\t</div>\r\n\t\t}\r\n\t}\r\n</div>\r\n", styles: ["::ng-deep .pop-steps.p-popover.p-popover-flipped:before{display:none}::ng-deep .pop-steps.p-popover.p-popover-flipped:after{display:none}::ng-deep .pop-steps.p-popover:before{display:none}::ng-deep .pop-steps.p-popover:after{display:none}::ng-deep .pop-steps.p-popover-flipped{margin-top:-5px}::ng-deep .pop-steps .p-popover-content{padding:0}::ng-deep .end-steps.p-popover{margin-top:2.5px;z-index:999;position:absolute!important;left:auto!important;right:0!important;top:100%!important;min-width:125px}::ng-deep .start-steps.p-popover{margin-top:2.5px;z-index:999;position:absolute!important;left:0!important;right:auto!important;top:100%!important;min-width:125px}.step-item{position:relative;height:32px;padding:0 5px;background-color:#e7e9ed}.step-item span{color:#334155c2;white-space:nowrap}.step-item.step-first{padding-left:15px}.step-item.step-last{padding-right:15px}.step-item:not(.step-first){border-left:15px solid transparent;margin-left:2px}.step-item:not(.step-first):before{content:\"\";position:absolute;top:0;left:-15px;width:0;height:0;border-top:15px solid transparent;border-bottom:15px solid transparent;border-left:12px solid white}.step-item:not(.step-last):after{content:\"\";position:absolute;top:0;right:-12px;width:0;height:0;border-top:15px solid transparent;border-bottom:15px solid transparent;border-left:12px solid #e7e9ed;z-index:2}.step-item.step-active{background-color:var(--p-primary-200)}.step-item.step-active span{color:#334155}.step-item.step-active:after{border-left:12px solid var(--p-primary-200)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: ListboxModule }, { kind: "component", type: i1.Listbox, selector: "p-listbox, p-listBox, p-list-box", inputs: ["id", "searchMessage", "emptySelectionMessage", "selectionMessage", "autoOptionFocus", "ariaLabel", "selectOnFocus", "searchLocale", "focusOnHover", "filterMessage", "filterFields", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "scrollHeight", "tabindex", "multiple", "style", "styleClass", "listStyle", "listStyleClass", "readonly", "disabled", "checkbox", "filter", "filterBy", "filterMatchMode", "filterLocale", "metaKeySelection", "dataKey", "showToggleAll", "optionLabel", "optionValue", "optionGroupChildren", "optionGroupLabel", "optionDisabled", "ariaFilterLabel", "filterPlaceHolder", "emptyFilterMessage", "emptyMessage", "group", "options", "filterValue", "selectAll", "striped", "highlightOnSelect", "checkmark"], outputs: ["onChange", "onClick", "onDblClick", "onFilter", "onFocus", "onBlur", "onSelectAllChange", "onLazyLoad"] }, { kind: "component", type: Popover, selector: "p-popover", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }] }); }
@@ -186,4 +187,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
186
187
  type: HostListener,
187
188
  args: ['window:resize', ['$event']]
188
189
  }] } });
189
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/steps/steps.component.ts","../../../../../projects/imm-element-ui/src/lib/steps/steps.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, ElementRef, HostListener, inject, input, output, Renderer2, signal, ViewChild } from '@angular/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ListboxModule } from 'primeng/listbox';\r\nimport { Popover } from 'primeng/popover';\r\nexport interface Step {\r\n\tlabel: string;\r\n\ti18nKey?: string;\r\n\tvalue: number | 'start' | 'end';\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-steps',\r\n\tstandalone: true,\r\n\timports: [FormsModule, ListboxModule, Popover],\r\n\ttemplateUrl: './steps.component.html',\r\n\tstyleUrl: './steps.component.scss',\r\n})\r\nexport class StepsComponent {\r\n\t@ViewChild('container', { static: false }) containerRef!: ElementRef;\r\n\t@ViewChild('endBtn', { static: false }) endBtn!: ElementRef;\r\n\tsteps = input<Step[]>([]);\r\n\tdisplaySteps = computed(() => {\r\n\t\tconst steps = [...this.steps()];\r\n\t\tsteps.unshift({ value: 'start', label: '...' });\r\n\t\tsteps.push({ value: 'end', label: '...' });\r\n\t\treturn steps.filter((step) => !this.excludeValues().includes(step.value));\r\n\t});\r\n\texcludeValues = signal<(number | 'start' | 'end')[]>([]);\r\n\tcurrent = input<number>(2);\r\n\ti18n = inject(I18nService);\r\n\tchange = output<number>();\r\n\tauthLevel = input<number>(-1);\r\n\r\n\twidthList: number[] = [];\r\n\tSTART_BUTTON_WIDTH = 32;\r\n\tEND_BUTTON_WIDTH = 47;\r\n\r\n\tstartIndex = 0;\r\n\tendIndex = 0;\r\n\tstartSteps: Step[] = [];\r\n\tendSteps: Step[] = [];\r\n\tmaxWidth = 0;\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tconstructor(private renderer: Renderer2) {}\r\n\r\n\tngAfterViewInit() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.initWidthList();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tinitWidthList() {\r\n\t\tconst children = this.renderer.parentNode(this.containerRef.nativeElement).children[0].children;\r\n\t\tfor (let i = 0; i < children.length; i++) {\r\n\t\t\tif (!children[i].classList.contains('step-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('start-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('end-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tthis.widthList.push(children[i].offsetWidth || 0);\r\n\t\t}\r\n\t}\r\n\r\n\tcalcMaxWidth() {\r\n\t\tthis.maxWidth = window.innerWidth < 768 ? window.innerWidth * 0.96 : window.innerWidth * 0.42;\r\n\t}\r\n\r\n\tshowStartSteps(event: any, startOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tstartOp.toggle(event);\r\n\t}\r\n\r\n\tshowEndSteps(event: any, endOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tendOp.toggle(event);\r\n\t}\r\n\r\n\tgetClass(i: number, classes: string[]) {\r\n\t\tlet result = ['step-item', 'flex', 'items-center', 'justify-center'];\r\n\t\tresult = result.concat(classes);\r\n\t\tif (this.authLevel() < 4) {\r\n\t\t\tresult.push('cursor-not-allowed');\r\n\t\t} else {\r\n\t\t\tresult.push('cursor-pointer allow-hover');\r\n\t\t}\r\n\t\tconst { value } = this.displaySteps()![i];\r\n\t\tif (i == 0) {\r\n\t\t\tresult.push('step-first');\r\n\t\t} else if (i + 1 == this.displaySteps()?.length) {\r\n\t\t\tresult.push('step-last');\r\n\t\t}\r\n\t\tif (value == this.current()) {\r\n\t\t\tresult.push('step-active');\r\n\t\t\tresult.push('md:flex-none flex-1');\r\n\t\t}\r\n\t\treturn result.join(' ');\r\n\t}\r\n\r\n\tchangeStatus(step: any) {\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonStartStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonEndStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\talternateWidthList() {\r\n\t\tlet index = this.steps().findIndex((s) => s.value === this.current());\r\n\t\tindex = index === -1 ? 0 : index;\r\n\t\tthis.startIndex = index;\r\n\t\tthis.endIndex = index;\r\n\r\n\t\tlet leftIndex = index - 1;\r\n\t\tlet rightIndex = index + 1;\r\n\t\tlet turn = 'right';\r\n\t\tlet totalWidth = this.widthList[index];\r\n\r\n\t\twhile (leftIndex >= 0 || rightIndex < this.widthList.length) {\r\n\t\t\tif (turn === 'right' && rightIndex < this.widthList.length) {\r\n\t\t\t\ttotalWidth += this.widthList[rightIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.endIndex = rightIndex;\r\n\t\t\t\trightIndex++;\r\n\t\t\t\tturn = 'left';\r\n\t\t\t} else if (turn === 'left' && leftIndex >= 0) {\r\n\t\t\t\ttotalWidth += this.widthList[leftIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.startIndex = leftIndex;\r\n\t\t\t\tleftIndex--;\r\n\t\t\t\tturn = 'right';\r\n\t\t\t} else {\r\n\t\t\t\tturn = rightIndex < this.widthList.length ? 'right' : 'left';\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisExceedMaxWidth(totalWidth: number) {\r\n\t\ttotalWidth += this.startIndex === 0 ? 0 : this.START_BUTTON_WIDTH;\r\n\t\ttotalWidth += this.endIndex === this.widthList.length - 1 ? 0 : this.END_BUTTON_WIDTH;\r\n\t\treturn totalWidth >= this.maxWidth;\r\n\t}\r\n\r\n\thandleSteps() {\r\n\t\tconst steps = this.steps();\r\n\t\tconst excludeValues: any[] = [];\r\n\t\tfor (let i = 0; i < steps.length; i++) {\r\n\t\t\tif (i < this.startIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t\tif (i > this.endIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (this.startIndex > 0) {\r\n\t\t\tthis.startSteps = steps.slice(0, this.startIndex);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('start');\r\n\t\t}\r\n\t\tif (this.endIndex < steps.length - 1) {\r\n\t\t\tthis.endSteps = steps.slice(this.endIndex + 1);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('end');\r\n\t\t}\r\n\t\tthis.excludeValues.set(excludeValues);\r\n\t}\r\n\r\n\trefreshSteps() {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.alternateWidthList();\r\n\t\t\tthis.handleSteps();\r\n\t\t});\r\n\t}\r\n}\r\n","<div\r\n\t#container\r\n\tclass=\"flex my-1 w-full justify-end\">\r\n\t@for (st of displaySteps(); track st; let i = $index) {\r\n\t\t@if (st.value === 'start') {\r\n\t\t\t<div\r\n\t\t\t\t#startItem\r\n\t\t\t\t[class]=\"getClass(i, ['start-item'])\"\r\n\t\t\t\t(click)=\"showStartSteps($event, startOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#startOp\r\n\t\t\t\t[styleClass]=\"'pop-steps start-steps'\"\r\n\t\t\t\t[appendTo]=\"startItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"startSteps\"\r\n\t\t\t\t\t(onChange)=\"onStartStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else if (st.value === 'end') {\r\n\t\t\t<div\r\n\t\t\t\t#endItem\r\n\t\t\t\t[class]=\"getClass(i, ['end-item'])\"\r\n\t\t\t\t(click)=\"showEndSteps($event, endOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#endOp\r\n\t\t\t\t[styleClass]=\"'pop-steps end-steps'\"\r\n\t\t\t\t[appendTo]=\"endItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"endSteps\"\r\n\t\t\t\t\t(onChange)=\"onEndStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else {\r\n\t\t\t<div\r\n\t\t\t\t[class]=\"getClass(i, [])\"\r\n\t\t\t\t(click)=\"changeStatus(st)\">\r\n\t\t\t\t<span>{{ st.i18nKey ? i18n.fanyi(st.i18nKey) : st.label }}</span>\r\n\t\t\t</div>\r\n\t\t}\r\n\t}\r\n</div>\r\n"]}
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/steps/steps.component.ts","../../../../../projects/imm-element-ui/src/lib/steps/steps.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, ElementRef, HostListener, inject, input, output, Renderer2, signal, ViewChild } from '@angular/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ListboxModule } from 'primeng/listbox';\r\nimport { Popover } from 'primeng/popover';\r\nexport interface Step {\r\n\tlabel: string;\r\n\ti18nKey?: string;\r\n\tvalue: number | 'start' | 'end';\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-steps',\r\n\tstandalone: true,\r\n\timports: [FormsModule, ListboxModule, Popover],\r\n\ttemplateUrl: './steps.component.html',\r\n\tstyleUrl: './steps.component.scss',\r\n})\r\nexport class StepsComponent {\r\n\t@ViewChild('container', { static: false }) containerRef!: ElementRef;\r\n\t@ViewChild('endBtn', { static: false }) endBtn!: ElementRef;\r\n\tsteps = input<Step[]>([]);\r\n\tdisplaySteps = computed(() => {\r\n\t\tconst steps = [...this.steps()];\r\n\t\tsteps.unshift({ value: 'start', label: '...' });\r\n\t\tsteps.push({ value: 'end', label: '...' });\r\n\t\treturn steps.filter((step) => !this.excludeValues().includes(step.value));\r\n\t});\r\n\texcludeValues = signal<(number | 'start' | 'end')[]>([]);\r\n\tcurrent = input<number>(2);\r\n\ti18n = inject(I18nService);\r\n\tchange = output<number>();\r\n\tauthLevel = input<number>(-1);\r\n\r\n\twidthList: number[] = [];\r\n\tSTART_BUTTON_WIDTH = 32;\r\n\tEND_BUTTON_WIDTH = 47;\r\n\tSTEP_ITEM_MARGIN = 2;\r\n\r\n\tstartIndex = 0;\r\n\tendIndex = 0;\r\n\tstartSteps: Step[] = [];\r\n\tendSteps: Step[] = [];\r\n\tmaxWidth = 0;\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tconstructor(private renderer: Renderer2) {}\r\n\r\n\tngAfterViewInit() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.initWidthList();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tinitWidthList() {\r\n\t\tconst children = this.renderer.parentNode(this.containerRef.nativeElement).children[0].children;\r\n\t\tfor (let i = 0; i < children.length; i++) {\r\n\t\t\tif (!children[i].classList.contains('step-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('start-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('end-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tthis.widthList.push((children[i].offsetWidth || 0) + this.STEP_ITEM_MARGIN);\r\n\t\t}\r\n\t}\r\n\r\n\tcalcMaxWidth() {\r\n\t\tthis.maxWidth = window.innerWidth < 768 ? window.innerWidth * 0.96 : window.innerWidth * 0.42;\r\n\t}\r\n\r\n\tshowStartSteps(event: any, startOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tstartOp.toggle(event);\r\n\t}\r\n\r\n\tshowEndSteps(event: any, endOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tendOp.toggle(event);\r\n\t}\r\n\r\n\tgetClass(i: number, classes: string[]) {\r\n\t\tlet result = ['step-item', 'flex', 'items-center', 'justify-center'];\r\n\t\tresult = result.concat(classes);\r\n\t\tif (this.authLevel() < 4) {\r\n\t\t\tresult.push('cursor-not-allowed');\r\n\t\t} else {\r\n\t\t\tresult.push('cursor-pointer allow-hover');\r\n\t\t}\r\n\t\tconst { value } = this.displaySteps()![i];\r\n\t\tif (i == 0) {\r\n\t\t\tresult.push('step-first');\r\n\t\t} else if (i + 1 == this.displaySteps()?.length) {\r\n\t\t\tresult.push('step-last');\r\n\t\t}\r\n\t\tif (value == this.current()) {\r\n\t\t\tresult.push('step-active');\r\n\t\t\tresult.push('md:flex-none flex-1');\r\n\t\t}\r\n\t\treturn result.join(' ');\r\n\t}\r\n\r\n\tchangeStatus(step: any) {\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonStartStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonEndStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\talternateWidthList() {\r\n\t\tlet index = this.steps().findIndex((s) => s.value === this.current());\r\n\t\tindex = index === -1 ? 0 : index;\r\n\t\tthis.startIndex = index;\r\n\t\tthis.endIndex = index;\r\n\r\n\t\tlet leftIndex = index - 1;\r\n\t\tlet rightIndex = index + 1;\r\n\t\tlet turn = 'right';\r\n\t\tlet totalWidth = this.widthList[index];\r\n\r\n\t\twhile (leftIndex >= 0 || rightIndex < this.widthList.length) {\r\n\t\t\tif (turn === 'right' && rightIndex < this.widthList.length) {\r\n\t\t\t\ttotalWidth += this.widthList[rightIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.endIndex = rightIndex;\r\n\t\t\t\trightIndex++;\r\n\t\t\t\tturn = 'left';\r\n\t\t\t} else if (turn === 'left' && leftIndex >= 0) {\r\n\t\t\t\ttotalWidth += this.widthList[leftIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.startIndex = leftIndex;\r\n\t\t\t\tleftIndex--;\r\n\t\t\t\tturn = 'right';\r\n\t\t\t} else {\r\n\t\t\t\tturn = rightIndex < this.widthList.length ? 'right' : 'left';\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisExceedMaxWidth(totalWidth: number) {\r\n\t\ttotalWidth += this.startIndex === 0 ? 0 : this.START_BUTTON_WIDTH;\r\n\t\ttotalWidth += this.endIndex === this.widthList.length - 1 ? 0 : this.END_BUTTON_WIDTH;\r\n\t\treturn totalWidth >= this.maxWidth;\r\n\t}\r\n\r\n\thandleSteps() {\r\n\t\tconst steps = this.steps();\r\n\t\tconst excludeValues: any[] = [];\r\n\t\tfor (let i = 0; i < steps.length; i++) {\r\n\t\t\tif (i < this.startIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t\tif (i > this.endIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (this.startIndex > 0) {\r\n\t\t\tthis.startSteps = steps.slice(0, this.startIndex);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('start');\r\n\t\t}\r\n\t\tif (this.endIndex < steps.length - 1) {\r\n\t\t\tthis.endSteps = steps.slice(this.endIndex + 1);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('end');\r\n\t\t}\r\n\t\tthis.excludeValues.set(excludeValues);\r\n\t}\r\n\r\n\trefreshSteps() {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.alternateWidthList();\r\n\t\t\tthis.handleSteps();\r\n\t\t},300);\r\n\t}\r\n}\r\n","<div\r\n\t#container\r\n\tclass=\"flex my-1 w-full justify-end\">\r\n\t@for (st of displaySteps(); track st; let i = $index) {\r\n\t\t@if (st.value === 'start') {\r\n\t\t\t<div\r\n\t\t\t\t#startItem\r\n\t\t\t\t[class]=\"getClass(i, ['start-item'])\"\r\n\t\t\t\t(click)=\"showStartSteps($event, startOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#startOp\r\n\t\t\t\t[styleClass]=\"'pop-steps start-steps'\"\r\n\t\t\t\t[appendTo]=\"startItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"startSteps\"\r\n\t\t\t\t\t(onChange)=\"onStartStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else if (st.value === 'end') {\r\n\t\t\t<div\r\n\t\t\t\t#endItem\r\n\t\t\t\t[class]=\"getClass(i, ['end-item'])\"\r\n\t\t\t\t(click)=\"showEndSteps($event, endOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#endOp\r\n\t\t\t\t[styleClass]=\"'pop-steps end-steps'\"\r\n\t\t\t\t[appendTo]=\"endItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"endSteps\"\r\n\t\t\t\t\t(onChange)=\"onEndStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else {\r\n\t\t\t<div\r\n\t\t\t\t[class]=\"getClass(i, [])\"\r\n\t\t\t\t(click)=\"changeStatus(st)\">\r\n\t\t\t\t<span>{{ st.i18nKey ? i18n.fanyi(st.i18nKey) : st.label }}</span>\r\n\t\t\t</div>\r\n\t\t}\r\n\t}\r\n</div>\r\n"]}
@@ -11,7 +11,7 @@ import * as i1$3 from '@angular/common';
11
11
  import { DatePipe, CommonModule, DOCUMENT, isPlatformBrowser, AsyncPipe } from '@angular/common';
12
12
  import * as i2$1 from '@angular/forms';
13
13
  import { FormControl, ReactiveFormsModule, FormGroup, Validators, FormsModule } from '@angular/forms';
14
- import { BehaviorSubject, tap, fromEvent, forkJoin, filter, Observable, of, shareReplay, pipe, lastValueFrom, map as map$1 } from 'rxjs';
14
+ import { BehaviorSubject, tap, fromEvent, forkJoin, filter, Observable, of, shareReplay, pipe, isObservable, lastValueFrom, map as map$1 } from 'rxjs';
15
15
  import * as i1$2 from '@ngx-translate/core';
16
16
  import { TranslatePipe } from '@ngx-translate/core';
17
17
  import * as i2 from 'primeng/inputtext';
@@ -3537,7 +3537,9 @@ class FormComponent {
3537
3537
  field.labelMinWidth = this.labelMinWidth;
3538
3538
  field.interactiveLabel = this.options().interactiveLabel ?? true;
3539
3539
  field.form = this;
3540
- field.hook && this.uniqueHook(field, field.hook);
3540
+ if (isObservable(field.hook)) {
3541
+ this.uniqueHook(field, field.hook);
3542
+ }
3541
3543
  this.handleFieldControl(field);
3542
3544
  });
3543
3545
  }
@@ -6237,6 +6239,7 @@ class StepsComponent {
6237
6239
  this.widthList = [];
6238
6240
  this.START_BUTTON_WIDTH = 32;
6239
6241
  this.END_BUTTON_WIDTH = 47;
6242
+ this.STEP_ITEM_MARGIN = 2;
6240
6243
  this.startIndex = 0;
6241
6244
  this.endIndex = 0;
6242
6245
  this.startSteps = [];
@@ -6261,7 +6264,7 @@ class StepsComponent {
6261
6264
  if (children[i].classList.contains('end-item')) {
6262
6265
  continue;
6263
6266
  }
6264
- this.widthList.push(children[i].offsetWidth || 0);
6267
+ this.widthList.push((children[i].offsetWidth || 0) + this.STEP_ITEM_MARGIN);
6265
6268
  }
6266
6269
  }
6267
6270
  calcMaxWidth() {
@@ -6377,7 +6380,7 @@ class StepsComponent {
6377
6380
  setTimeout(() => {
6378
6381
  this.alternateWidthList();
6379
6382
  this.handleSteps();
6380
- });
6383
+ }, 300);
6381
6384
  }
6382
6385
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StepsComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
6383
6386
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: StepsComponent, isStandalone: true, selector: "custom-steps", inputs: { steps: { classPropertyName: "steps", publicName: "steps", isSignal: true, isRequired: false, transformFunction: null }, current: { classPropertyName: "current", publicName: "current", isSignal: true, isRequired: false, transformFunction: null }, authLevel: { classPropertyName: "authLevel", publicName: "authLevel", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { change: "change" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }, { propertyName: "endBtn", first: true, predicate: ["endBtn"], descendants: true }], ngImport: i0, template: "<div\r\n\t#container\r\n\tclass=\"flex my-1 w-full justify-end\">\r\n\t@for (st of displaySteps(); track st; let i = $index) {\r\n\t\t@if (st.value === 'start') {\r\n\t\t\t<div\r\n\t\t\t\t#startItem\r\n\t\t\t\t[class]=\"getClass(i, ['start-item'])\"\r\n\t\t\t\t(click)=\"showStartSteps($event, startOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#startOp\r\n\t\t\t\t[styleClass]=\"'pop-steps start-steps'\"\r\n\t\t\t\t[appendTo]=\"startItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"startSteps\"\r\n\t\t\t\t\t(onChange)=\"onStartStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else if (st.value === 'end') {\r\n\t\t\t<div\r\n\t\t\t\t#endItem\r\n\t\t\t\t[class]=\"getClass(i, ['end-item'])\"\r\n\t\t\t\t(click)=\"showEndSteps($event, endOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#endOp\r\n\t\t\t\t[styleClass]=\"'pop-steps end-steps'\"\r\n\t\t\t\t[appendTo]=\"endItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"endSteps\"\r\n\t\t\t\t\t(onChange)=\"onEndStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else {\r\n\t\t\t<div\r\n\t\t\t\t[class]=\"getClass(i, [])\"\r\n\t\t\t\t(click)=\"changeStatus(st)\">\r\n\t\t\t\t<span>{{ st.i18nKey ? i18n.fanyi(st.i18nKey) : st.label }}</span>\r\n\t\t\t</div>\r\n\t\t}\r\n\t}\r\n</div>\r\n", styles: ["::ng-deep .pop-steps.p-popover.p-popover-flipped:before{display:none}::ng-deep .pop-steps.p-popover.p-popover-flipped:after{display:none}::ng-deep .pop-steps.p-popover:before{display:none}::ng-deep .pop-steps.p-popover:after{display:none}::ng-deep .pop-steps.p-popover-flipped{margin-top:-5px}::ng-deep .pop-steps .p-popover-content{padding:0}::ng-deep .end-steps.p-popover{margin-top:2.5px;z-index:999;position:absolute!important;left:auto!important;right:0!important;top:100%!important;min-width:125px}::ng-deep .start-steps.p-popover{margin-top:2.5px;z-index:999;position:absolute!important;left:0!important;right:auto!important;top:100%!important;min-width:125px}.step-item{position:relative;height:32px;padding:0 5px;background-color:#e7e9ed}.step-item span{color:#334155c2;white-space:nowrap}.step-item.step-first{padding-left:15px}.step-item.step-last{padding-right:15px}.step-item:not(.step-first){border-left:15px solid transparent;margin-left:2px}.step-item:not(.step-first):before{content:\"\";position:absolute;top:0;left:-15px;width:0;height:0;border-top:15px solid transparent;border-bottom:15px solid transparent;border-left:12px solid white}.step-item:not(.step-last):after{content:\"\";position:absolute;top:0;right:-12px;width:0;height:0;border-top:15px solid transparent;border-bottom:15px solid transparent;border-left:12px solid #e7e9ed;z-index:2}.step-item.step-active{background-color:var(--p-primary-200)}.step-item.step-active span{color:#334155}.step-item.step-active:after{border-left:12px solid var(--p-primary-200)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: ListboxModule }, { kind: "component", type: i1$6.Listbox, selector: "p-listbox, p-listBox, p-list-box", inputs: ["id", "searchMessage", "emptySelectionMessage", "selectionMessage", "autoOptionFocus", "ariaLabel", "selectOnFocus", "searchLocale", "focusOnHover", "filterMessage", "filterFields", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "scrollHeight", "tabindex", "multiple", "style", "styleClass", "listStyle", "listStyleClass", "readonly", "disabled", "checkbox", "filter", "filterBy", "filterMatchMode", "filterLocale", "metaKeySelection", "dataKey", "showToggleAll", "optionLabel", "optionValue", "optionGroupChildren", "optionGroupLabel", "optionDisabled", "ariaFilterLabel", "filterPlaceHolder", "emptyFilterMessage", "emptyMessage", "group", "options", "filterValue", "selectAll", "striped", "highlightOnSelect", "checkmark"], outputs: ["onChange", "onClick", "onDblClick", "onFilter", "onFocus", "onBlur", "onSelectAllChange", "onLazyLoad"] }, { kind: "component", type: Popover, selector: "p-popover", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }] }); }
@@ -6434,6 +6437,14 @@ class PageFormComponent extends AmComponent {
6434
6437
  this.isLog = this.modelLog();
6435
6438
  console.log('model-----', this.isLog, this.modelLog());
6436
6439
  }, { allowSignalWrites: true });
6440
+ effect(() => {
6441
+ if (this.statusSteps().length > 0 && !this.id) {
6442
+ this.upsertPrm.addData[this.statusKey()] = this.statusSteps()[0]['value'];
6443
+ this.getPrm.data = Object.assign(this.getPrm.data || {}, {
6444
+ [this.statusKey()]: this.statusSteps()[0]['value']
6445
+ });
6446
+ }
6447
+ }, { allowSignalWrites: true });
6437
6448
  }
6438
6449
  ngOnInit() {
6439
6450
  this.upCb = this.upCb.bind(this);
@@ -6486,10 +6497,11 @@ class PageFormComponent extends AmComponent {
6486
6497
  });
6487
6498
  }
6488
6499
  }
6489
- getDetail() {
6500
+ getDetail(customSteps) {
6490
6501
  this.web_get(this.getPrm).subscribe(res => {
6491
6502
  this.updateTitle(res);
6492
6503
  this.formDisabled() && this.formDisFunc();
6504
+ customSteps && customSteps.refreshSteps();
6493
6505
  });
6494
6506
  }
6495
6507
  updateTitle(res) {
@@ -6537,8 +6549,7 @@ class PageFormComponent extends AmComponent {
6537
6549
  };
6538
6550
  }
6539
6551
  this.web_write(param).subscribe(res => {
6540
- this.getDetail();
6541
- customSteps.refreshSteps();
6552
+ this.getDetail(customSteps);
6542
6553
  });
6543
6554
  }
6544
6555
  else {