ets-fe-ng-sdk 17.0.308 → 17.0.310

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.
Files changed (34) hide show
  1. package/esm2022/lib/Reusables/reusable-comps/find-item/find-item.component.mjs +2 -2
  2. package/esm2022/lib/Shared/components/btn/btn.model.mjs +1 -1
  3. package/esm2022/lib/Shared/components/btn/btn.service.mjs +168 -164
  4. package/esm2022/lib/Shared/components/editable-text-case/editable-text-case.component.mjs +2 -2
  5. package/esm2022/lib/Shared/components/file-upload/file-upload.component.mjs +17 -5
  6. package/esm2022/lib/Shared/components/form-generator/form-generator.base.component.mjs +1 -1
  7. package/esm2022/lib/Shared/components/form-generator/form-generator.component.mjs +3 -3
  8. package/esm2022/lib/Shared/components/input/day-hour-min-input/day-hour-min-input.component.mjs +1 -1
  9. package/esm2022/lib/Shared/components/input/input-base.component.mjs +6 -2
  10. package/esm2022/lib/Shared/components/input/input-basic.component.mjs +3 -7
  11. package/esm2022/lib/Shared/components/input/input-control.component.mjs +3 -3
  12. package/esm2022/lib/Shared/components/input/input-td-rf.component.mjs +3 -3
  13. package/esm2022/lib/Shared/components/input/input.component.mjs +3 -3
  14. package/esm2022/lib/Shared/components/input/validation-message/validation-message.component.mjs +6 -10
  15. package/esm2022/lib/Shared/components/input-table/input-table.component.mjs +2 -2
  16. package/esm2022/lib/Shared/components/table-input/table-input-row/table-input-row.component.mjs +2 -2
  17. package/esm2022/lib/Shared/components/table-plain/table-plain.component.mjs +2 -2
  18. package/esm2022/lib/Shared/components/webcam-media/webcam-media.component.mjs +266 -0
  19. package/esm2022/public-api.mjs +2 -1
  20. package/fesm2022/ets-fe-ng-sdk.mjs +548 -283
  21. package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
  22. package/lib/Services/utility.service.d.ts +1 -1
  23. package/lib/Shared/components/btn/btn.component.d.ts +1 -1
  24. package/lib/Shared/components/btn/btn.model.d.ts +1 -1
  25. package/lib/Shared/components/btn/btn.service.d.ts +7 -0
  26. package/lib/Shared/components/file-upload/file-upload.component.d.ts +9 -3
  27. package/lib/Shared/components/form-generator/form-generator.base.component.d.ts +2 -0
  28. package/lib/Shared/components/info-dialog/info-dialog.component.d.ts +1 -1
  29. package/lib/Shared/components/input/input-base.component.d.ts +3 -1
  30. package/lib/Shared/components/input/input-basic.component.d.ts +1 -3
  31. package/lib/Shared/components/input/validation-message/validation-message.component.d.ts +3 -3
  32. package/lib/Shared/components/webcam-media/webcam-media.component.d.ts +88 -0
  33. package/package.json +1 -1
  34. package/public-api.d.ts +1 -0
@@ -1,6 +1,6 @@
1
1
  import { Injectable } from '@angular/core';
2
2
  import { faPaperPlane } from '@fortawesome/free-regular-svg-icons';
3
- import { faArrowLeft, faArrowRight, faCheck, faClone, faCogs, faDownload, faEdit, faEye, faFile, faFileExport, faFileImport, faHistory, faListAlt, faLock, faMoneyCheck, faPen, faPenFancy, faPlus, faRecycle, faSave, faSearch, faSlidersH, faTrash, faUnlock, faFilter, faUpload, faUserShield, faHome, faUsers, faBellSlash, faInfoCircle, faTruck, faTag, faReceipt, faBank, faArrowsH, faPlay, faPercent, faCancel, faCircleExclamation, faHandshake, faTable, faSpoon, } from '@fortawesome/free-solid-svg-icons';
3
+ import { faArrowLeft, faArrowRight, faCheck, faClone, faCogs, faDownload, faEdit, faEye, faFile, faFileExport, faFileImport, faHistory, faListAlt, faLock, faMoneyCheck, faPen, faPenFancy, faPlus, faRecycle, faSave, faSearch, faSlidersH, faTrash, faUnlock, faFilter, faUpload, faUserShield, faHome, faUsers, faBellSlash, faInfoCircle, faTruck, faTag, faReceipt, faBank, faArrowsH, faPlay, faPercent, faCancel, faCircleExclamation, faHandshake, faTable, faSpoon, faStop, faPause, } from '@fortawesome/free-solid-svg-icons';
4
4
  import { EUA } from '../../../Reusables/reusable-pages/user-activity/ua-extras/user-activity.model';
5
5
  import { FormGroup } from '@angular/forms';
6
6
  import { merge, take, tap, timer } from 'rxjs';
@@ -43,169 +43,173 @@ export class BtnService {
43
43
  _mclass: 'btn btn-lg btn-success w-100',
44
44
  },
45
45
  };
46
- this.getIcon = (iconType) => {
47
- const index = {
48
- add: {
49
- icon: faPlus,
50
- },
51
- adjust: {
52
- icon: faSlidersH,
53
- },
54
- calendar: {
55
- iconString: 'fas fa-calendar-alt',
56
- },
57
- cash: {
58
- icon: faMoneyCheck,
59
- },
60
- cancel: {
61
- icon: faCancel,
62
- },
63
- checked: {
64
- icon: faCheck,
65
- },
66
- checklist: {
67
- icon: faListAlt,
68
- },
69
- clone: {
70
- icon: faClone,
71
- },
72
- close: {
73
- iconString: 'fa fa-close',
74
- },
75
- cogs: {
76
- icon: faCogs,
77
- },
78
- delete: {
79
- icon: faTrash,
80
- },
81
- download: {
82
- icon: faDownload,
83
- },
84
- dropdown: {
85
- iconPosition: 'right',
86
- iconString: 'fa fa-chevron-down',
87
- },
88
- edit: {
89
- icon: faEdit,
90
- },
91
- export: {
92
- icon: faFileExport,
93
- },
94
- file: {
95
- icon: faFile,
96
- },
97
- filter: {
98
- icon: faFilter,
99
- },
100
- generate: {
101
- icon: faPenFancy,
102
- },
103
- guard: {
104
- icon: faUserShield,
105
- },
106
- access: {
107
- icon: faUserShield,
108
- },
109
- history: {
110
- icon: faHistory,
111
- },
112
- home: {
113
- icon: faHome,
114
- },
115
- import: {
116
- icon: faFileImport,
117
- },
118
- info: {
119
- icon: faInfoCircle,
120
- },
121
- link: {
122
- iconString: 'fas fa-chain',
123
- },
124
- lock: {
125
- icon: faLock,
126
- },
127
- next: {
128
- icon: faArrowRight,
129
- iconPosition: 'right',
130
- },
131
- pen: {
132
- icon: faPen,
133
- },
134
- post: {
135
- icon: faPaperPlane,
136
- },
137
- previous: {
138
- icon: faArrowLeft,
139
- },
140
- renew: {
141
- icon: faRecycle,
142
- },
143
- save: {
144
- icon: faSave,
145
- },
146
- search: {
147
- icon: faSearch,
148
- },
149
- show: {
150
- icon: faEye,
151
- },
152
- view: {
153
- icon: faEye,
154
- },
155
- snooze: {
156
- icon: faBellSlash,
157
- },
158
- upload: {
159
- icon: faUpload,
160
- },
161
- unlock: {
162
- icon: faUnlock,
163
- },
164
- users: {
165
- icon: faUsers,
166
- },
167
- recycle: {
168
- icon: faRecycle,
169
- },
170
- refresh: {
171
- iconString: 'fa fa-refresh',
172
- },
173
- truck: {
174
- icon: faTruck,
175
- },
176
- tag: {
177
- icon: faTag,
178
- },
179
- receipt: {
180
- icon: faReceipt,
181
- },
182
- bank: {
183
- icon: faBank,
184
- },
185
- arrowh: {
186
- icon: faArrowsH,
187
- },
188
- play: {
189
- icon: faPlay,
190
- },
191
- percent: {
192
- icon: faPercent,
193
- },
194
- shake: {
195
- icon: faHandshake,
196
- },
197
- error: {
198
- icon: faCircleExclamation,
199
- },
200
- table: {
201
- icon: faTable,
202
- },
203
- spoon: {
204
- icon: faSpoon,
205
- },
206
- };
207
- return index[iconType];
46
+ this.buttonIconIndex = {
47
+ add: {
48
+ icon: faPlus,
49
+ },
50
+ adjust: {
51
+ icon: faSlidersH,
52
+ },
53
+ calendar: {
54
+ iconString: 'fas fa-calendar-alt',
55
+ },
56
+ cash: {
57
+ icon: faMoneyCheck,
58
+ },
59
+ cancel: {
60
+ icon: faCancel,
61
+ },
62
+ checked: {
63
+ icon: faCheck,
64
+ },
65
+ checklist: {
66
+ icon: faListAlt,
67
+ },
68
+ clone: {
69
+ icon: faClone,
70
+ },
71
+ close: {
72
+ iconString: 'fa fa-close',
73
+ },
74
+ cogs: {
75
+ icon: faCogs,
76
+ },
77
+ delete: {
78
+ icon: faTrash,
79
+ },
80
+ download: {
81
+ icon: faDownload,
82
+ },
83
+ dropdown: {
84
+ iconPosition: 'right',
85
+ iconString: 'fa fa-chevron-down',
86
+ },
87
+ edit: {
88
+ icon: faEdit,
89
+ },
90
+ export: {
91
+ icon: faFileExport,
92
+ },
93
+ file: {
94
+ icon: faFile,
95
+ },
96
+ filter: {
97
+ icon: faFilter,
98
+ },
99
+ generate: {
100
+ icon: faPenFancy,
101
+ },
102
+ guard: {
103
+ icon: faUserShield,
104
+ },
105
+ access: {
106
+ icon: faUserShield,
107
+ },
108
+ history: {
109
+ icon: faHistory,
110
+ },
111
+ home: {
112
+ icon: faHome,
113
+ },
114
+ import: {
115
+ icon: faFileImport,
116
+ },
117
+ info: {
118
+ icon: faInfoCircle,
119
+ },
120
+ link: {
121
+ iconString: 'fas fa-chain',
122
+ },
123
+ lock: {
124
+ icon: faLock,
125
+ },
126
+ next: {
127
+ icon: faArrowRight,
128
+ iconPosition: 'right',
129
+ },
130
+ pause: {
131
+ icon: faPause,
132
+ },
133
+ pen: {
134
+ icon: faPen,
135
+ },
136
+ post: {
137
+ icon: faPaperPlane,
138
+ },
139
+ previous: {
140
+ icon: faArrowLeft,
141
+ },
142
+ renew: {
143
+ icon: faRecycle,
144
+ },
145
+ save: {
146
+ icon: faSave,
147
+ },
148
+ search: {
149
+ icon: faSearch,
150
+ },
151
+ show: {
152
+ icon: faEye,
153
+ },
154
+ view: {
155
+ icon: faEye,
156
+ },
157
+ snooze: {
158
+ icon: faBellSlash,
159
+ },
160
+ upload: {
161
+ icon: faUpload,
162
+ },
163
+ unlock: {
164
+ icon: faUnlock,
165
+ },
166
+ users: {
167
+ icon: faUsers,
168
+ },
169
+ recycle: {
170
+ icon: faRecycle,
171
+ },
172
+ refresh: {
173
+ iconString: 'fa fa-refresh',
174
+ },
175
+ stop: {
176
+ icon: faStop,
177
+ },
178
+ truck: {
179
+ icon: faTruck,
180
+ },
181
+ tag: {
182
+ icon: faTag,
183
+ },
184
+ receipt: {
185
+ icon: faReceipt,
186
+ },
187
+ bank: {
188
+ icon: faBank,
189
+ },
190
+ arrowh: {
191
+ icon: faArrowsH,
192
+ },
193
+ play: {
194
+ icon: faPlay,
195
+ },
196
+ percent: {
197
+ icon: faPercent,
198
+ },
199
+ shake: {
200
+ icon: faHandshake,
201
+ },
202
+ error: {
203
+ icon: faCircleExclamation,
204
+ },
205
+ table: {
206
+ icon: faTable,
207
+ },
208
+ spoon: {
209
+ icon: faSpoon,
210
+ },
208
211
  };
212
+ this.getIcon = (iconType) => this.buttonIconIndex[iconType];
209
213
  this.defaultType = 'secondary';
210
214
  this.setFormState = (btn) => {
211
215
  btn.checkFormStateSub?.unsubscribe();
@@ -295,4 +299,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
295
299
  providedIn: 'root',
296
300
  }]
297
301
  }], ctorParameters: () => [{ type: i1.UserActivityService }] });
298
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"btn.service.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/btn/btn.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { faPaperPlane } from '@fortawesome/free-regular-svg-icons';\nimport {\n  faArrowLeft,\n  faArrowRight,\n  faCheck,\n  faClone,\n  faCogs,\n  faDownload,\n  faEdit,\n  faEye,\n  faFile,\n  faFileExport,\n  faFileImport,\n  faHistory,\n  faListAlt,\n  faLock,\n  faMoneyCheck,\n  faPen,\n  faPenFancy,\n  faPlus,\n  faRecycle,\n  faSave,\n  faSearch,\n  faSlidersH,\n  faTrash,\n  faUnlock,\n  faFilter,\n  faUpload,\n  faUserShield,\n  faHome,\n  faUsers,\n  faBellSlash,\n  faInfoCircle,\n  faTruck,\n  faTag,\n  faReceipt,\n  faBank,\n  faArrowsH,\n  faPlay,\n  faLink,\n  faPercent,\n  faCancel,\n  faCircleExclamation,\n  faHandshake,\n  faTable,\n  faSpoon,\n  IconDefinition,\n} from '@fortawesome/free-solid-svg-icons';\nimport { BtnComponent } from './btn.component';\nimport { BtnType, IconType } from './btn.model';\nimport { UserActivityService } from '../../../Reusables/reusable-pages/user-activity/ua-extras/user-activity.service';\nimport { EUA } from '../../../Reusables/reusable-pages/user-activity/ua-extras/user-activity.model';\nimport { AbstractControl, FormGroup } from '@angular/forms';\nimport { debounceTime, merge, take, tap, timeInterval, timer } from 'rxjs';\nimport { cloneDeep } from 'lodash-es';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class BtnService {\n  btnClassConfig: BtnClass = {\n    ['primary']: {\n      _mclass: 'btn btn-primary btn-lg w-100',\n    },\n    ['secondary']: {\n      _mclass: 'btn btn-outline-primary btn-clone btn-lg w-100',\n    },\n    ['outline']: {\n      _mclass: 'btn btn-outline-primary btn-lg w-100',\n    },\n    ['clear']: {\n      _mclass: 'btn w-100',\n    },\n    ['dark-outline']: {\n      _mclass: 'btn btn-outline-dark btn-lg w-100',\n    },\n    ['outline-nm']: {\n      _mclass: 'btn btn-outline-primary w-100',\n    },\n    ['dark']: {\n      _mclass: 'btn btn-dark btn-lg w-100',\n    },\n    ['danger']: {\n      _mclass: 'btn btn-danger btn-lg w-100',\n    },\n    ['danger-outline']: {\n      _mclass: 'btn btn-outline-danger btn-lg w-100',\n    },\n    ['close']: { _mclass: 'btn btn-lg  text-danger', _icon: 'close' },\n    ['success']: {\n      _mclass: 'btn btn-lg btn-success w-100',\n    },\n  };\n  constructor(public uaS: UserActivityService) {}\n  getIcon = (iconType: IconType) => {\n    const index: {\n      [k in IconType]?: {\n        icon?: IconDefinition;\n        iconString?: string;\n        iconPosition?: 'right' | 'left';\n      };\n    } = {\n      add: {\n        icon: faPlus,\n      },\n      adjust: {\n        icon: faSlidersH,\n      },\n      calendar: {\n        iconString: 'fas fa-calendar-alt',\n      },\n      cash: {\n        icon: faMoneyCheck,\n      },\n      cancel: {\n        icon: faCancel,\n      },\n      checked: {\n        icon: faCheck,\n      },\n      checklist: {\n        icon: faListAlt,\n      },\n      clone: {\n        icon: faClone,\n      },\n      close: {\n        iconString: 'fa fa-close',\n      },\n      cogs: {\n        icon: faCogs,\n      },\n      delete: {\n        icon: faTrash,\n      },\n      download: {\n        icon: faDownload,\n      },\n      dropdown: {\n        iconPosition: 'right',\n        iconString: 'fa fa-chevron-down',\n      },\n      edit: {\n        icon: faEdit,\n      },\n      export: {\n        icon: faFileExport,\n      },\n      file: {\n        icon: faFile,\n      },\n      filter: {\n        icon: faFilter,\n      },\n      generate: {\n        icon: faPenFancy,\n      },\n      guard: {\n        icon: faUserShield,\n      },\n      access: {\n        icon: faUserShield,\n      },\n      history: {\n        icon: faHistory,\n      },\n      home: {\n        icon: faHome,\n      },\n      import: {\n        icon: faFileImport,\n      },\n      info: {\n        icon: faInfoCircle,\n      },\n      link: {\n        iconString: 'fas fa-chain',\n      },\n      lock: {\n        icon: faLock,\n      },\n      next: {\n        icon: faArrowRight,\n        iconPosition: 'right',\n      },\n      pen: {\n        icon: faPen,\n      },\n      post: {\n        icon: faPaperPlane,\n      },\n      previous: {\n        icon: faArrowLeft,\n      },\n      renew: {\n        icon: faRecycle,\n      },\n      save: {\n        icon: faSave,\n      },\n      search: {\n        icon: faSearch,\n      },\n      show: {\n        icon: faEye,\n      },\n      view: {\n        icon: faEye,\n      },\n      snooze: {\n        icon: faBellSlash,\n      },\n      upload: {\n        icon: faUpload,\n      },\n      unlock: {\n        icon: faUnlock,\n      },\n      users: {\n        icon: faUsers,\n      },\n      recycle: {\n        icon: faRecycle,\n      },\n      refresh: {\n        iconString: 'fa fa-refresh',\n      },\n      truck: {\n        icon: faTruck,\n      },\n      tag: {\n        icon: faTag,\n      },\n      receipt: {\n        icon: faReceipt,\n      },\n      bank: {\n        icon: faBank,\n      },\n      arrowh: {\n        icon: faArrowsH,\n      },\n      play: {\n        icon: faPlay,\n      },\n      percent: {\n        icon: faPercent,\n      },\n      shake: {\n        icon: faHandshake,\n      },\n      error: {\n        icon: faCircleExclamation,\n      },\n      table: {\n        icon: faTable,\n      },\n      spoon: {\n        icon: faSpoon,\n      },\n    };\n    return index[iconType];\n  };\n\n  getType(v: BtnType) {\n    return this.btnClassConfig[v] || { _type: 'primary' };\n  }\n  defaultType: BtnType = 'secondary';\n\n  logClick(btn: BtnComponent) {\n    console.log('btn.extractText', btn.extractText, btn);\n    if (btn.excludeLogging) return;\n    this.uaS.add({\n      code: EUA.clicked,\n      activityDescription: btn.extractText,\n    });\n  }\n\n  setFormState = (btn: BtnComponent) => {\n    btn.checkFormStateSub?.unsubscribe();\n    btn.checkFormStateSub = timer(0, 1000)\n      .pipe(take(3))\n      .subscribe(() => {\n        // btn.counter?.set(btn.counter() + 1);\n        btn.formState.set(\n          cloneDeep({\n            pending: btn.form?.pending,\n            dirty: btn.form?.dirty,\n            invalid: btn.form?.invalid,\n            pristine: btn.form?.pristine,\n            valid: btn.form?.valid,\n          }),\n        );\n      });\n  };\n\n  setFormsState = (btn: BtnComponent) => {\n    btn.checkFormsStateSub?.unsubscribe();\n    btn.checkFormsStateSub = timer(0, 1000)\n      .pipe(take(3))\n      .subscribe(() => { \n        const fs = {\n          pending: true,\n          dirty: true,\n          invalid: true,\n          pristine: true,\n          valid: true,\n        };\n        btn.forms?.forEach((x) => {\n          if (!x.pending) fs.pending = x.pending;\n          if (!x.dirty) fs.dirty = x.dirty;\n          if (!x.invalid) fs.invalid = x.invalid;\n          if (!x.pristine) fs.pristine = x.pristine;\n          if (!x.valid) fs.valid = x.valid;\n        });\n        btn.formsState.set(fs);\n      });\n  };\n\n  checkForm(btn: BtnComponent) {\n    if (btn.isDisabled() && btn.form) {\n      btn.form.markAllAsTouched();\n      const form = btn.form;\n      console.log(form);\n      if (form instanceof FormGroup) {\n        console.log(\n          Object.keys(form.controls)\n            .filter((x) => !form.controls[x].valid)\n            .map((x) => form.controls[x]),\n        );\n      }\n    }\n    if (btn.isDisabled() && btn.forms) {\n      btn.forms.forEach((form) => form.markAllAsTouched());\n      // this.cdr.detectChanges();\n      console.log(btn.forms);\n    }\n  }\n  // protected debouncerArray = [200].concat(new Array(3).fill(1).map((x, i) => (i + 1) * 1000));\n\n  handleForm = (form: AbstractControl, btn: BtnComponent) =>\n    form.statusChanges\n      .pipe(\n        tap((r) => this.setFormState(btn)),\n        // tap((r) => this.setFormState(form, btn)),\n\n        // debounceTime(200),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n      )\n      .subscribe(() => {});\n\n  handleForms = (v: AbstractControl[], btn: BtnComponent) =>\n    merge(v.map((f) => f.statusChanges))\n      .pipe(\n        tap((r) => this.setFormsState(btn)),\n\n        // debounceTime(200),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n      )\n      .subscribe(() => {});\n}\n\ntype BtnClass = { [k in BtnType]: { _mclass?: string; _icon?: IconType; _type?: BtnType } };\n"]}
302
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"btn.service.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/btn/btn.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { faPaperPlane } from '@fortawesome/free-regular-svg-icons';\nimport {\n  faArrowLeft,\n  faArrowRight,\n  faCheck,\n  faClone,\n  faCogs,\n  faDownload,\n  faEdit,\n  faEye,\n  faFile,\n  faFileExport,\n  faFileImport,\n  faHistory,\n  faListAlt,\n  faLock,\n  faMoneyCheck,\n  faPen,\n  faPenFancy,\n  faPlus,\n  faRecycle,\n  faSave,\n  faSearch,\n  faSlidersH,\n  faTrash,\n  faUnlock,\n  faFilter,\n  faUpload,\n  faUserShield,\n  faHome,\n  faUsers,\n  faBellSlash,\n  faInfoCircle,\n  faTruck,\n  faTag,\n  faReceipt,\n  faBank,\n  faArrowsH,\n  faPlay,\n  faLink,\n  faPercent,\n  faCancel,\n  faCircleExclamation,\n  faHandshake,\n  faTable,\n  faSpoon,\n  IconDefinition,\n  faBox,\n  faStop,\n  faPause,\n} from '@fortawesome/free-solid-svg-icons';\nimport { BtnComponent } from './btn.component';\nimport { BtnType, IconType } from './btn.model';\nimport { UserActivityService } from '../../../Reusables/reusable-pages/user-activity/ua-extras/user-activity.service';\nimport { EUA } from '../../../Reusables/reusable-pages/user-activity/ua-extras/user-activity.model';\nimport { AbstractControl, FormGroup } from '@angular/forms';\nimport { debounceTime, merge, take, tap, timeInterval, timer } from 'rxjs';\nimport { cloneDeep } from 'lodash-es';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class BtnService {\n  btnClassConfig: BtnClass = {\n    ['primary']: {\n      _mclass: 'btn btn-primary btn-lg w-100',\n    },\n    ['secondary']: {\n      _mclass: 'btn btn-outline-primary btn-clone btn-lg w-100',\n    },\n    ['outline']: {\n      _mclass: 'btn btn-outline-primary btn-lg w-100',\n    },\n    ['clear']: {\n      _mclass: 'btn w-100',\n    },\n    ['dark-outline']: {\n      _mclass: 'btn btn-outline-dark btn-lg w-100',\n    },\n    ['outline-nm']: {\n      _mclass: 'btn btn-outline-primary w-100',\n    },\n    ['dark']: {\n      _mclass: 'btn btn-dark btn-lg w-100',\n    },\n    ['danger']: {\n      _mclass: 'btn btn-danger btn-lg w-100',\n    },\n    ['danger-outline']: {\n      _mclass: 'btn btn-outline-danger btn-lg w-100',\n    },\n    ['close']: { _mclass: 'btn btn-lg  text-danger', _icon: 'close' },\n    ['success']: {\n      _mclass: 'btn btn-lg btn-success w-100',\n    },\n  };\n  buttonIconIndex: {\n    [k in IconType]?: {\n      icon?: IconDefinition;\n      iconString?: string;\n      iconPosition?: 'right' | 'left';\n    };\n  } = {\n    add: {\n      icon: faPlus,\n    },\n    adjust: {\n      icon: faSlidersH,\n    },\n    calendar: {\n      iconString: 'fas fa-calendar-alt',\n    },\n    cash: {\n      icon: faMoneyCheck,\n    },\n    cancel: {\n      icon: faCancel,\n    },\n    checked: {\n      icon: faCheck,\n    },\n    checklist: {\n      icon: faListAlt,\n    },\n    clone: {\n      icon: faClone,\n    },\n    close: {\n      iconString: 'fa fa-close',\n    },\n    cogs: {\n      icon: faCogs,\n    },\n    delete: {\n      icon: faTrash,\n    },\n    download: {\n      icon: faDownload,\n    },\n    dropdown: {\n      iconPosition: 'right',\n      iconString: 'fa fa-chevron-down',\n    },\n    edit: {\n      icon: faEdit,\n    },\n    export: {\n      icon: faFileExport,\n    },\n    file: {\n      icon: faFile,\n    },\n    filter: {\n      icon: faFilter,\n    },\n    generate: {\n      icon: faPenFancy,\n    },\n    guard: {\n      icon: faUserShield,\n    },\n    access: {\n      icon: faUserShield,\n    },\n    history: {\n      icon: faHistory,\n    },\n    home: {\n      icon: faHome,\n    },\n    import: {\n      icon: faFileImport,\n    },\n    info: {\n      icon: faInfoCircle,\n    },\n    link: {\n      iconString: 'fas fa-chain',\n    },\n    lock: {\n      icon: faLock,\n    },\n    next: {\n      icon: faArrowRight,\n      iconPosition: 'right',\n    },\n    pause: {\n      icon: faPause,\n    },\n    pen: {\n      icon: faPen,\n    },\n    post: {\n      icon: faPaperPlane,\n    },\n    previous: {\n      icon: faArrowLeft,\n    },\n    renew: {\n      icon: faRecycle,\n    },\n    save: {\n      icon: faSave,\n    },\n    search: {\n      icon: faSearch,\n    },\n    show: {\n      icon: faEye,\n    },\n    view: {\n      icon: faEye,\n    },\n    snooze: {\n      icon: faBellSlash,\n    },\n    upload: {\n      icon: faUpload,\n    },\n    unlock: {\n      icon: faUnlock,\n    },\n    users: {\n      icon: faUsers,\n    },\n    recycle: {\n      icon: faRecycle,\n    },\n    refresh: {\n      iconString: 'fa fa-refresh',\n    },\n    stop: {\n      icon: faStop,\n    },\n    truck: {\n      icon: faTruck,\n    },\n    tag: {\n      icon: faTag,\n    },\n    receipt: {\n      icon: faReceipt,\n    },\n    bank: {\n      icon: faBank,\n    },\n    arrowh: {\n      icon: faArrowsH,\n    },\n    play: {\n      icon: faPlay,\n    },\n    percent: {\n      icon: faPercent,\n    },\n    shake: {\n      icon: faHandshake,\n    },\n    error: {\n      icon: faCircleExclamation,\n    },\n    table: {\n      icon: faTable,\n    },\n    spoon: {\n      icon: faSpoon,\n    },\n  };\n  constructor(public uaS: UserActivityService) {}\n  getIcon = (iconType: IconType) => this.buttonIconIndex[iconType];\n\n  getType(v: BtnType) {\n    return this.btnClassConfig[v] || { _type: 'primary' };\n  }\n  defaultType: BtnType = 'secondary';\n\n  logClick(btn: BtnComponent) {\n    console.log('btn.extractText', btn.extractText, btn);\n    if (btn.excludeLogging) return;\n    this.uaS.add({\n      code: EUA.clicked,\n      activityDescription: btn.extractText,\n    });\n  }\n\n  setFormState = (btn: BtnComponent) => {\n    btn.checkFormStateSub?.unsubscribe();\n    btn.checkFormStateSub = timer(0, 1000)\n      .pipe(take(3))\n      .subscribe(() => {\n        // btn.counter?.set(btn.counter() + 1);\n        btn.formState.set(\n          cloneDeep({\n            pending: btn.form?.pending,\n            dirty: btn.form?.dirty,\n            invalid: btn.form?.invalid,\n            pristine: btn.form?.pristine,\n            valid: btn.form?.valid,\n          }),\n        );\n      });\n  };\n\n  setFormsState = (btn: BtnComponent) => {\n    btn.checkFormsStateSub?.unsubscribe();\n    btn.checkFormsStateSub = timer(0, 1000)\n      .pipe(take(3))\n      .subscribe(() => {\n        const fs = {\n          pending: true,\n          dirty: true,\n          invalid: true,\n          pristine: true,\n          valid: true,\n        };\n        btn.forms?.forEach((x) => {\n          if (!x.pending) fs.pending = x.pending;\n          if (!x.dirty) fs.dirty = x.dirty;\n          if (!x.invalid) fs.invalid = x.invalid;\n          if (!x.pristine) fs.pristine = x.pristine;\n          if (!x.valid) fs.valid = x.valid;\n        });\n        btn.formsState.set(fs);\n      });\n  };\n\n  checkForm(btn: BtnComponent) {\n    if (btn.isDisabled() && btn.form) {\n      btn.form.markAllAsTouched();\n      const form = btn.form;\n      console.log(form);\n      if (form instanceof FormGroup) {\n        console.log(\n          Object.keys(form.controls)\n            .filter((x) => !form.controls[x].valid)\n            .map((x) => form.controls[x]),\n        );\n      }\n    }\n    if (btn.isDisabled() && btn.forms) {\n      btn.forms.forEach((form) => form.markAllAsTouched());\n      // this.cdr.detectChanges();\n      console.log(btn.forms);\n    }\n  }\n  // protected debouncerArray = [200].concat(new Array(3).fill(1).map((x, i) => (i + 1) * 1000));\n\n  handleForm = (form: AbstractControl, btn: BtnComponent) =>\n    form.statusChanges\n      .pipe(\n        tap((r) => this.setFormState(btn)),\n        // tap((r) => this.setFormState(form, btn)),\n\n        // debounceTime(200),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormState(form, btn)),\n      )\n      .subscribe(() => {});\n\n  handleForms = (v: AbstractControl[], btn: BtnComponent) =>\n    merge(v.map((f) => f.statusChanges))\n      .pipe(\n        tap((r) => this.setFormsState(btn)),\n\n        // debounceTime(200),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n\n        // debounceTime(1000),\n        // tap(() => this.setFormsState(v, btn)),\n      )\n      .subscribe(() => {});\n}\n\ntype BtnClass = { [k in BtnType]: { _mclass?: string; _icon?: IconType; _type?: BtnType } };\n"]}
@@ -24,7 +24,7 @@ export class EditableTextCaseComponent {
24
24
  }
25
25
  }
26
26
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditableTextCaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
27
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.1", type: EditableTextCaseComponent, isStandalone: true, selector: "app-editable-text-case", inputs: { action: "action", coloredLbl: "coloredLbl", coloredVal: "coloredVal", form: "form", formatter: "formatter", hint: "hint", valueHint: "valueHint", label: "label", light: "light", mini: "mini", name: "name", route: "route", routeFunc: "routeFunc", showEditing: "showEditing", stacked: "stacked", type: "type", value: "value", wrapLabel: "wrapLabel" }, ngImport: i0, template: "<div class=\"row align-items-center\">\n <label\n [matTooltip]=\"hint\"\n class=\"col-md-{{\n stacked ? '12 pb-0' : mini ? 'auto' : ''\n }} m-0 hide-scroll-x\"\n [ngClass]=\"{\n 'text-primary': coloredLbl,\n light,\n 'overflow-x-auto': wrapLabel\n }\"\n >\n {{ label | appTranslate | async }}\n </label>\n <div class=\"{{ stacked ? 'col-12' : 'col-md' }} position-relative\">\n <div class=\"row align-items-center\">\n @if (editing) {\n <div class=\"col-9 pe-0\">\n <app-input-basic\n [form]=\"form\"\n [stacked]=\"true\"\n [showLabel]=\"false\"\n [name]=\"name\"\n [type]=\"type\"\n >\n </app-input-basic>\n </div>\n <div class=\"col-auto\">\n <i\n (click)=\"reset()\"\n class=\"ps-1 pointer fas fa-undo-alt text-danger\"\n ></i>\n </div>\n } @else {\n <a\n [matTooltip]=\"valueHint\"\n [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n !stacked ? 'auto' : showEditing ? '9' : '12'\n }} lbl\"\n >\n <div class=\"hide-scroll-x overflow-x-auto\">\n {{ (value | valueFormatter: formatter | async) || \"-\" }}\n </div>\n </a>\n <div class=\"col-auto\" *ngIf=\"showEditing\">\n <i\n (click)=\"unreset()\"\n class=\"ps-1 pointer fas fa-pencil-alt {{\n !coloredVal ? '' : 'text-primary'\n }}\"\n ></i>\n </div>\n }\n <ng-template #elseTemplate>\n <a\n [matTooltip]=\"valueHint\"\n [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n !stacked ? 'auto' : showEditing ? '9' : '12'\n }} lbl\"\n >\n <div class=\"hide-scroll-x overflow-x-auto\">\n {{ (value | valueFormatter: formatter | async) || \"-\" }}\n </div>\n </a>\n @if (showEditing) {\n <div class=\"col-auto\">\n <i\n (click)=\"unreset()\"\n class=\"ps-1 pointer fas fa-pencil-alt {{\n !coloredVal ? '' : 'text-primary'\n }}\"\n ></i>\n </div>\n }\n </ng-template>\n </div>\n </div>\n</div>\n", styles: [".lbl{display:flex;align-items:center}.light{font-weight:500}.fas{font-size:.7rem}\n"], dependencies: [{ kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: InputBasicComponent, selector: "app-input-basic,app-input", inputs: ["accept", "autocomplete", "input", "contextData", "decimalPoints", "files", "hide", "hint", "labelLink", "lblCl", "light", "loading", "minLength", "maxLength", "multiple", "optionsFunc", "theme", "vms", "xsmall", "setCurrentDate", "options", "mvalue"], outputs: ["mSelectOptionChange", "mSelectedOptionLabel"] }, { kind: "directive", type: MrouterLinkirective, selector: "[mrouterLink]", inputs: ["mrouterLink", "mrouterLinkActivatedRoute", "mqueryParams", "isPhone", "isEmail"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: FunctionCaller1, name: "functionCaller1" }, { kind: "pipe", type: TranslatePipe, name: "appTranslate" }, { kind: "pipe", type: ValueFormatterPipe, name: "valueFormatter" }] }); }
27
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.1", type: EditableTextCaseComponent, isStandalone: true, selector: "app-editable-text-case", inputs: { action: "action", coloredLbl: "coloredLbl", coloredVal: "coloredVal", form: "form", formatter: "formatter", hint: "hint", valueHint: "valueHint", label: "label", light: "light", mini: "mini", name: "name", route: "route", routeFunc: "routeFunc", showEditing: "showEditing", stacked: "stacked", type: "type", value: "value", wrapLabel: "wrapLabel" }, ngImport: i0, template: "<div class=\"row align-items-center\">\n <label\n [matTooltip]=\"hint\"\n class=\"col-md-{{\n stacked ? '12 pb-0' : mini ? 'auto' : ''\n }} m-0 hide-scroll-x\"\n [ngClass]=\"{\n 'text-primary': coloredLbl,\n light,\n 'overflow-x-auto': wrapLabel\n }\"\n >\n {{ label | appTranslate | async }}\n </label>\n <div class=\"{{ stacked ? 'col-12' : 'col-md' }} position-relative\">\n <div class=\"row align-items-center\">\n @if (editing) {\n <div class=\"col-9 pe-0\">\n <app-input-basic\n [form]=\"form\"\n [stacked]=\"true\"\n [showLabel]=\"false\"\n [name]=\"name\"\n [type]=\"type\"\n >\n </app-input-basic>\n </div>\n <div class=\"col-auto\">\n <i\n (click)=\"reset()\"\n class=\"ps-1 pointer fas fa-undo-alt text-danger\"\n ></i>\n </div>\n } @else {\n <a\n [matTooltip]=\"valueHint\"\n [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n !stacked ? 'auto' : showEditing ? '9' : '12'\n }} lbl\"\n >\n <div class=\"hide-scroll-x overflow-x-auto\">\n {{ (value | valueFormatter: formatter | async) || \"-\" }}\n </div>\n </a>\n <div class=\"col-auto\" *ngIf=\"showEditing\">\n <i\n (click)=\"unreset()\"\n class=\"ps-1 pointer fas fa-pencil-alt {{\n !coloredVal ? '' : 'text-primary'\n }}\"\n ></i>\n </div>\n }\n <ng-template #elseTemplate>\n <a\n [matTooltip]=\"valueHint\"\n [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n !stacked ? 'auto' : showEditing ? '9' : '12'\n }} lbl\"\n >\n <div class=\"hide-scroll-x overflow-x-auto\">\n {{ (value | valueFormatter: formatter | async) || \"-\" }}\n </div>\n </a>\n @if (showEditing) {\n <div class=\"col-auto\">\n <i\n (click)=\"unreset()\"\n class=\"ps-1 pointer fas fa-pencil-alt {{\n !coloredVal ? '' : 'text-primary'\n }}\"\n ></i>\n </div>\n }\n </ng-template>\n </div>\n </div>\n</div>\n", styles: [".lbl{display:flex;align-items:center}.light{font-weight:500}.fas{font-size:.7rem}\n"], dependencies: [{ kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: InputBasicComponent, selector: "app-input-basic,app-input", inputs: ["accept", "autocomplete", "input", "contextData", "decimalPoints", "files", "hide", "hint", "labelLink", "lblCl", "light", "loading", "multiple", "optionsFunc", "theme", "vms", "xsmall", "setCurrentDate", "options", "mvalue"], outputs: ["mSelectOptionChange", "mSelectedOptionLabel"] }, { kind: "directive", type: MrouterLinkirective, selector: "[mrouterLink]", inputs: ["mrouterLink", "mrouterLinkActivatedRoute", "mqueryParams", "isPhone", "isEmail"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: FunctionCaller1, name: "functionCaller1" }, { kind: "pipe", type: TranslatePipe, name: "appTranslate" }, { kind: "pipe", type: ValueFormatterPipe, name: "valueFormatter" }] }); }
28
28
  }
29
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditableTextCaseComponent, decorators: [{
30
30
  type: Component,
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
76
76
  }], wrapLabel: [{
77
77
  type: Input
78
78
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editable-text-case.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/editable-text-case/editable-text-case.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/editable-text-case/editable-text-case.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,MAAM,eAAe,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC/E,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;;;AAoB7D,MAAM,OAAO,yBAAyB;IAoBpC;QAFS,cAAS,GAAY,IAAI,CAAC;IAEpB,CAAC;IAEhB,QAAQ,KAAU,CAAC;IACnB,KAAK;QACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACD,OAAO;QACL,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,EAAE,CAAC;SACf;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;IACH,CAAC;8GAhCU,yBAAyB;kGAAzB,yBAAyB,0bC3BtC,48EAgFA,4IDhEI,gBAAgB,6TAChB,OAAO,oFACP,IAAI,6FACJ,mBAAmB,sYACnB,mBAAmB,iJACnB,SAAS,yCACT,eAAe,mDACf,aAAa,gDACb,kBAAkB;;2FAGT,yBAAyB;kBAjBrC,SAAS;+BACE,wBAAwB,cAGtB,IAAI,WACP;wBACP,gBAAgB;wBAChB,OAAO;wBACP,IAAI;wBACJ,mBAAmB;wBACnB,mBAAmB;wBACnB,SAAS;wBACT,eAAe;wBACf,aAAa;wBACb,kBAAkB;qBACnB;wDAGQ,MAAM;sBAAd,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { FunctionCaller1, ValueFormatterPipe } from '../../pipes/utility.pipe';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { MrouterLinkirective } from '../../directives/index.directive';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { NgClass, NgIf, AsyncPipe } from '@angular/common';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { InputType } from '../../models/index.model';\n\n@Component({\n  selector: 'app-editable-text-case',\n  templateUrl: './editable-text-case.component.html',\n  styleUrls: ['./editable-text-case.component.scss'],\n  standalone: true,\n  imports: [\n    MatTooltipModule,\n    NgClass,\n    NgIf,\n    InputBasicComponent,\n    MrouterLinkirective,\n    AsyncPipe,\n    FunctionCaller1,\n    TranslatePipe,\n    ValueFormatterPipe,\n  ],\n})\nexport class EditableTextCaseComponent implements OnInit {\n  @Input() action: any;\n  @Input() coloredLbl: boolean;\n  @Input() coloredVal: boolean;\n  @Input() form: any;\n  @Input() formatter: (item) => string | Promise<string> | Observable<string>;\n  @Input() hint: string;\n  @Input() valueHint: string;\n  @Input() label: string;\n  @Input() light: boolean;\n  @Input() mini: boolean;\n  @Input() name: string;\n  @Input() route: string;\n  @Input() routeFunc: (item) => Promise<string> | Observable<string>;\n  @Input() showEditing: boolean;\n  @Input() stacked: boolean;\n  @Input() type: InputType;\n  @Input() value: any;\n  @Input() wrapLabel: boolean = true;\n  editing: boolean;\n  constructor() {}\n\n  ngOnInit(): void {}\n  reset() {\n    this.editing = false;\n  }\n  unreset() {\n    if (this.action) {\n      this.action();\n    } else {\n      this.editing = true;\n    }\n  }\n}\n","<div class=\"row align-items-center\">\n  <label\n    [matTooltip]=\"hint\"\n    class=\"col-md-{{\n      stacked ? '12 pb-0' : mini ? 'auto' : ''\n    }} m-0 hide-scroll-x\"\n    [ngClass]=\"{\n      'text-primary': coloredLbl,\n      light,\n      'overflow-x-auto': wrapLabel\n    }\"\n  >\n    {{ label | appTranslate | async }}\n  </label>\n  <div class=\"{{ stacked ? 'col-12' : 'col-md' }} position-relative\">\n    <div class=\"row align-items-center\">\n      @if (editing) {\n        <div class=\"col-9 pe-0\">\n          <app-input-basic\n            [form]=\"form\"\n            [stacked]=\"true\"\n            [showLabel]=\"false\"\n            [name]=\"name\"\n            [type]=\"type\"\n          >\n          </app-input-basic>\n        </div>\n        <div class=\"col-auto\">\n          <i\n            (click)=\"reset()\"\n            class=\"ps-1 pointer fas fa-undo-alt text-danger\"\n          ></i>\n        </div>\n      } @else {\n        <a\n          [matTooltip]=\"valueHint\"\n          [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n          class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n            !stacked ? 'auto' : showEditing ? '9' : '12'\n          }} lbl\"\n        >\n          <div class=\"hide-scroll-x overflow-x-auto\">\n            {{ (value | valueFormatter: formatter | async) || \"-\" }}\n          </div>\n        </a>\n        <div class=\"col-auto\" *ngIf=\"showEditing\">\n          <i\n            (click)=\"unreset()\"\n            class=\"ps-1 pointer fas fa-pencil-alt {{\n              !coloredVal ? '' : 'text-primary'\n            }}\"\n          ></i>\n        </div>\n      }\n      <ng-template #elseTemplate>\n        <a\n          [matTooltip]=\"valueHint\"\n          [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n          class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n            !stacked ? 'auto' : showEditing ? '9' : '12'\n          }} lbl\"\n        >\n          <div class=\"hide-scroll-x overflow-x-auto\">\n            {{ (value | valueFormatter: formatter | async) || \"-\" }}\n          </div>\n        </a>\n        @if (showEditing) {\n          <div class=\"col-auto\">\n            <i\n              (click)=\"unreset()\"\n              class=\"ps-1 pointer fas fa-pencil-alt {{\n                !coloredVal ? '' : 'text-primary'\n              }}\"\n            ></i>\n          </div>\n        }\n      </ng-template>\n    </div>\n  </div>\n</div>\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editable-text-case.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/editable-text-case/editable-text-case.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/editable-text-case/editable-text-case.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,MAAM,eAAe,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC/E,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;;;AAoB7D,MAAM,OAAO,yBAAyB;IAoBpC;QAFS,cAAS,GAAY,IAAI,CAAC;IAEpB,CAAC;IAEhB,QAAQ,KAAU,CAAC;IACnB,KAAK;QACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACD,OAAO;QACL,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,EAAE,CAAC;SACf;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;IACH,CAAC;8GAhCU,yBAAyB;kGAAzB,yBAAyB,0bC3BtC,48EAgFA,4IDhEI,gBAAgB,6TAChB,OAAO,oFACP,IAAI,6FACJ,mBAAmB,4WACnB,mBAAmB,iJACnB,SAAS,yCACT,eAAe,mDACf,aAAa,gDACb,kBAAkB;;2FAGT,yBAAyB;kBAjBrC,SAAS;+BACE,wBAAwB,cAGtB,IAAI,WACP;wBACP,gBAAgB;wBAChB,OAAO;wBACP,IAAI;wBACJ,mBAAmB;wBACnB,mBAAmB;wBACnB,SAAS;wBACT,eAAe;wBACf,aAAa;wBACb,kBAAkB;qBACnB;wDAGQ,MAAM;sBAAd,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { FunctionCaller1, ValueFormatterPipe } from '../../pipes/utility.pipe';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { MrouterLinkirective } from '../../directives/index.directive';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { NgClass, NgIf, AsyncPipe } from '@angular/common';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { InputType } from '../../models/index.model';\n\n@Component({\n  selector: 'app-editable-text-case',\n  templateUrl: './editable-text-case.component.html',\n  styleUrls: ['./editable-text-case.component.scss'],\n  standalone: true,\n  imports: [\n    MatTooltipModule,\n    NgClass,\n    NgIf,\n    InputBasicComponent,\n    MrouterLinkirective,\n    AsyncPipe,\n    FunctionCaller1,\n    TranslatePipe,\n    ValueFormatterPipe,\n  ],\n})\nexport class EditableTextCaseComponent implements OnInit {\n  @Input() action: any;\n  @Input() coloredLbl: boolean;\n  @Input() coloredVal: boolean;\n  @Input() form: any;\n  @Input() formatter: (item) => string | Promise<string> | Observable<string>;\n  @Input() hint: string;\n  @Input() valueHint: string;\n  @Input() label: string;\n  @Input() light: boolean;\n  @Input() mini: boolean;\n  @Input() name: string;\n  @Input() route: string;\n  @Input() routeFunc: (item) => Promise<string> | Observable<string>;\n  @Input() showEditing: boolean;\n  @Input() stacked: boolean;\n  @Input() type: InputType;\n  @Input() value: any;\n  @Input() wrapLabel: boolean = true;\n  editing: boolean;\n  constructor() {}\n\n  ngOnInit(): void {}\n  reset() {\n    this.editing = false;\n  }\n  unreset() {\n    if (this.action) {\n      this.action();\n    } else {\n      this.editing = true;\n    }\n  }\n}\n","<div class=\"row align-items-center\">\n  <label\n    [matTooltip]=\"hint\"\n    class=\"col-md-{{\n      stacked ? '12 pb-0' : mini ? 'auto' : ''\n    }} m-0 hide-scroll-x\"\n    [ngClass]=\"{\n      'text-primary': coloredLbl,\n      light,\n      'overflow-x-auto': wrapLabel\n    }\"\n  >\n    {{ label | appTranslate | async }}\n  </label>\n  <div class=\"{{ stacked ? 'col-12' : 'col-md' }} position-relative\">\n    <div class=\"row align-items-center\">\n      @if (editing) {\n        <div class=\"col-9 pe-0\">\n          <app-input-basic\n            [form]=\"form\"\n            [stacked]=\"true\"\n            [showLabel]=\"false\"\n            [name]=\"name\"\n            [type]=\"type\"\n          >\n          </app-input-basic>\n        </div>\n        <div class=\"col-auto\">\n          <i\n            (click)=\"reset()\"\n            class=\"ps-1 pointer fas fa-undo-alt text-danger\"\n          ></i>\n        </div>\n      } @else {\n        <a\n          [matTooltip]=\"valueHint\"\n          [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n          class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n            !stacked ? 'auto' : showEditing ? '9' : '12'\n          }} lbl\"\n        >\n          <div class=\"hide-scroll-x overflow-x-auto\">\n            {{ (value | valueFormatter: formatter | async) || \"-\" }}\n          </div>\n        </a>\n        <div class=\"col-auto\" *ngIf=\"showEditing\">\n          <i\n            (click)=\"unreset()\"\n            class=\"ps-1 pointer fas fa-pencil-alt {{\n              !coloredVal ? '' : 'text-primary'\n            }}\"\n          ></i>\n        </div>\n      }\n      <ng-template #elseTemplate>\n        <a\n          [matTooltip]=\"valueHint\"\n          [mrouterLink]=\"route || (routeFunc | functionCaller1: value | async)\"\n          class=\"{{ !coloredVal ? '' : 'text-primary' }} col-{{\n            !stacked ? 'auto' : showEditing ? '9' : '12'\n          }} lbl\"\n        >\n          <div class=\"hide-scroll-x overflow-x-auto\">\n            {{ (value | valueFormatter: formatter | async) || \"-\" }}\n          </div>\n        </a>\n        @if (showEditing) {\n          <div class=\"col-auto\">\n            <i\n              (click)=\"unreset()\"\n              class=\"ps-1 pointer fas fa-pencil-alt {{\n                !coloredVal ? '' : 'text-primary'\n              }}\"\n            ></i>\n          </div>\n        }\n      </ng-template>\n    </div>\n  </div>\n</div>\n"]}