@mediusinc/mng-commons 3.7.0-rc.0 → 4.0.0-rc.2

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 (55) hide show
  1. package/esm2022/index.mjs +8 -2
  2. package/esm2022/lib/components/action/index.mjs +2 -1
  3. package/esm2022/lib/components/action/table/action-table.component.mjs +164 -0
  4. package/esm2022/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +4 -4
  5. package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +4 -5
  6. package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +3 -3
  7. package/esm2022/lib/components/layoutV2/topbar.component.mjs +2 -7
  8. package/esm2022/lib/components/table/column-filter-full/column-filter-full.component.mjs +466 -0
  9. package/esm2022/lib/components/table/column-value/column-value.component.mjs +87 -0
  10. package/esm2022/lib/components/table/models/table.event.mjs +16 -0
  11. package/esm2022/lib/components/table/models/table.interface.mjs +2 -0
  12. package/esm2022/lib/components/table/table-column-filter-class/table-column-filter-class.pipe.mjs +25 -0
  13. package/esm2022/lib/components/table/table.component.mjs +723 -0
  14. package/esm2022/lib/components/tableview/index.mjs +1 -4
  15. package/esm2022/lib/components/tableview/tableview.component.mjs +6 -7
  16. package/esm2022/lib/descriptors/editor/editor.descriptor.mjs +1 -1
  17. package/esm2022/lib/descriptors/table/table.descriptor.mjs +16 -17
  18. package/esm2022/lib/descriptors/tableview/tableview.descriptor.mjs +1 -1
  19. package/esm2022/lib/utils/tableview.util.mjs +2 -2
  20. package/fesm2022/mediusinc-mng-commons.mjs +2221 -2080
  21. package/fesm2022/mediusinc-mng-commons.mjs.map +1 -1
  22. package/index.d.ts +6 -1
  23. package/lib/components/action/index.d.ts +1 -0
  24. package/lib/components/action/table/action-table.component.d.ts +55 -0
  25. package/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.d.ts +1 -1
  26. package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +1 -1
  27. package/lib/components/layoutV2/topbar.component.d.ts +0 -1
  28. package/lib/components/{tableview/table → table}/column-filter-full/column-filter-full.component.d.ts +2 -2
  29. package/lib/components/{tableview/table → table}/column-value/column-value.component.d.ts +3 -3
  30. package/lib/components/{tableview/table → table}/models/table.interface.d.ts +3 -1
  31. package/lib/components/table/table-column-filter-class/table-column-filter-class.pipe.d.ts +8 -0
  32. package/lib/components/table/table.component.d.ts +125 -0
  33. package/lib/components/tableview/index.d.ts +0 -3
  34. package/lib/components/tableview/tableview.component.d.ts +3 -3
  35. package/lib/descriptors/editor/editor.descriptor.d.ts +1 -1
  36. package/lib/descriptors/table/table.descriptor.d.ts +15 -12
  37. package/lib/descriptors/tableview/tableview.descriptor.d.ts +1 -1
  38. package/package.json +1 -1
  39. package/scss/mng-overrides/_theme_datatable.scss +24 -10
  40. package/scss/v2/theme/theme-base/mng/_mng_theme_datatable.scss +24 -9
  41. package/scss/v2/theme/theme-dark/_variables.scss +24 -12
  42. package/scss/v2/theme/theme-dark/blue/theme.scss +4 -4
  43. package/scss/v2/theme/theme-light/_variables.scss +23 -11
  44. package/scss/v2/theme/theme-light/blue/theme.scss +2 -2
  45. package/esm2022/lib/components/tableview/models/index.mjs +0 -2
  46. package/esm2022/lib/components/tableview/models/table.event.mjs +0 -16
  47. package/esm2022/lib/components/tableview/table/column-filter-full/column-filter-full.component.mjs +0 -467
  48. package/esm2022/lib/components/tableview/table/column-value/column-value.component.mjs +0 -87
  49. package/esm2022/lib/components/tableview/table/models/index.mjs +0 -2
  50. package/esm2022/lib/components/tableview/table/models/table.interface.mjs +0 -2
  51. package/esm2022/lib/components/tableview/table/table.component.mjs +0 -752
  52. package/lib/components/tableview/models/index.d.ts +0 -1
  53. package/lib/components/tableview/table/models/index.d.ts +0 -1
  54. package/lib/components/tableview/table/table.component.d.ts +0 -147
  55. /package/lib/components/{tableview → table}/models/table.event.d.ts +0 -0
package/esm2022/index.mjs CHANGED
@@ -32,7 +32,13 @@ export * from './lib/api/models';
32
32
  // component models
33
33
  export * from './lib/components/action/models';
34
34
  export * from './lib/components/form/models';
35
- export * from './lib/components/tableview/models';
35
+ export * from './lib/components/tableview';
36
+ // table
37
+ export * from './lib/components/table/table.component';
38
+ export * from './lib/components/table/models/table.event';
39
+ export * from './lib/components/table/models/table.interface';
40
+ export * from './lib/components/table/column-filter-full/column-filter-full.component';
41
+ export * from './lib/components/table/column-value/column-value.component';
36
42
  // formly
37
43
  export * from './lib/components/form/formly/models';
38
44
  export * from './lib/components/form/formly';
@@ -64,4 +70,4 @@ export * from './lib/styles';
64
70
  export * from './lib/styles/models';
65
71
  // error
66
72
  export * from './lib/error';
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxTQUFTO0FBQ1QsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxXQUFXO0FBQ1gsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYywwQkFBMEIsQ0FBQztBQUV6QyxtQkFBbUI7QUFDbkIsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxRQUFRO0FBQ1IsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGFBQWEsQ0FBQztBQUU1QixhQUFhO0FBQ2IsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxhQUFhO0FBQ2IsY0FBYyxrQkFBa0IsQ0FBQztBQUVqQyxRQUFRO0FBQ1IsY0FBYyxhQUFhLENBQUM7QUFFNUIsV0FBVztBQUNYLGNBQWMsOEJBQThCLENBQUM7QUFFN0MsYUFBYTtBQUNiLGNBQWMsa0JBQWtCLENBQUM7QUFFakMsbUJBQW1CO0FBQ25CLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLG1DQUFtQyxDQUFDO0FBRWxELFNBQVM7QUFDVCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsOEJBQThCLENBQUM7QUFFN0MsaUJBQWlCO0FBQ2pCLGNBQWMsc0JBQXNCLENBQUM7QUFFckMsY0FBYztBQUNkLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyx5QkFBeUIsQ0FBQztBQUV4QyxpQkFBaUI7QUFDakIsY0FBYyxjQUFjLENBQUM7QUFFN0IsU0FBUztBQUNULGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMscUJBQXFCLENBQUM7QUFFcEMsV0FBVztBQUNYLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxzQkFBc0IsQ0FBQztBQUVyQyxRQUFRO0FBQ1IsY0FBYyxhQUFhLENBQUM7QUFFNUIsVUFBVTtBQUNWLGNBQWMsd0JBQXdCLENBQUM7QUFFdkMsU0FBUztBQUNULGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMscUJBQXFCLENBQUM7QUFFcEMsUUFBUTtBQUNSLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBtbmctY29tbW9uc1xuICovXG5cbi8vIG1vZHVsZVxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHJvdmlkZS1jb21tb25zJztcblxuLy8gc2VydmljZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwaS9zZXJ2aWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2xheW91dC9zZXJ2aWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9wcm92aWRlcnMnO1xuXG4vLyBpbmplY3Rpb24gdG9rZW5zXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy90b2tlbnMnO1xuXG4vLyB1dGlsc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzJztcblxuLy8gY29tcG9uZW50c1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9hY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvZmllbGRzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvd3JhcHBlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9sYXlvdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90YWJsZXZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9wYWdlcyc7XG5cbi8vIGRpcmVjdGl2ZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMnO1xuXG4vLyBwaXBlc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMnO1xuXG4vLyByZWdpc3RyeVxuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVnaXN0cnkvdHlwZS5yZWdpc3RyeSc7XG5cbi8vIGFwaSBtb2RlbHNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwaS9tb2RlbHMnO1xuXG4vLyBjb21wb25lbnQgbW9kZWxzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2FjdGlvbi9tb2RlbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtL21vZGVscyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RhYmxldmlldy9tb2RlbHMnO1xuXG4vLyBmb3JtbHlcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvbW9kZWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHknO1xuXG4vLyBkYXRhIHByb3ZpZGVyc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1wcm92aWRlcnMnO1xuXG4vLyBkZXNjcmlwdG9yc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvbW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvYWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rlc2NyaXB0b3JzL2VkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZXNjcmlwdG9ycy9maWx0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZXNjcmlwdG9ycy90YWJsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZXNjcmlwdG9ycy90YWJsZXZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvdHlwZXMnO1xuXG4vLyBnZW5lcmFsIG1vZGVsc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzJztcblxuLy8gcm91dGVyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yb3V0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcm91dGVyL21vZGVscyc7XG5cbi8vIHNlY3VyaXR5XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWN1cml0eSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWN1cml0eS9tb2RlbCc7XG5cbi8vIHR5cGVzXG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5cbi8vIGhlbHBlcnNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2hlbHBlcnMvY29lcmNpb24nO1xuXG4vLyBzdHlsZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0eWxlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdHlsZXMvbW9kZWxzJztcblxuLy8gZXJyb3JcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Vycm9yJztcbiJdfQ==
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxTQUFTO0FBQ1QsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxXQUFXO0FBQ1gsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYywwQkFBMEIsQ0FBQztBQUV6QyxtQkFBbUI7QUFDbkIsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxRQUFRO0FBQ1IsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGFBQWEsQ0FBQztBQUU1QixhQUFhO0FBQ2IsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxhQUFhO0FBQ2IsY0FBYyxrQkFBa0IsQ0FBQztBQUVqQyxRQUFRO0FBQ1IsY0FBYyxhQUFhLENBQUM7QUFFNUIsV0FBVztBQUNYLGNBQWMsOEJBQThCLENBQUM7QUFFN0MsYUFBYTtBQUNiLGNBQWMsa0JBQWtCLENBQUM7QUFFakMsbUJBQW1CO0FBQ25CLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDRCQUE0QixDQUFDO0FBRTNDLFFBQVE7QUFDUixjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsNERBQTRELENBQUM7QUFFM0UsU0FBUztBQUNULGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyw4QkFBOEIsQ0FBQztBQUU3QyxpQkFBaUI7QUFDakIsY0FBYyxzQkFBc0IsQ0FBQztBQUVyQyxjQUFjO0FBQ2QsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHlCQUF5QixDQUFDO0FBRXhDLGlCQUFpQjtBQUNqQixjQUFjLGNBQWMsQ0FBQztBQUU3QixTQUFTO0FBQ1QsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQyxXQUFXO0FBQ1gsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHNCQUFzQixDQUFDO0FBRXJDLFFBQVE7QUFDUixjQUFjLGFBQWEsQ0FBQztBQUU1QixVQUFVO0FBQ1YsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxTQUFTO0FBQ1QsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQyxRQUFRO0FBQ1IsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG1uZy1jb21tb25zXG4gKi9cblxuLy8gbW9kdWxlXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wcm92aWRlLWNvbW1vbnMnO1xuXG4vLyBzZXJ2aWNlc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL3NlcnZpY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvbGF5b3V0L3NlcnZpY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL3Byb3ZpZGVycyc7XG5cbi8vIGluamVjdGlvbiB0b2tlbnNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL3Rva2Vucyc7XG5cbi8vIHV0aWxzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcGkvdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMnO1xuXG4vLyBjb21wb25lbnRzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2FjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Zvcm0nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtL2Zvcm1seS9maWVsZHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9mb3JtL2Zvcm1seS93cmFwcGVycyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2xheW91dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RhYmxldmlldyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3BhZ2VzJztcblxuLy8gZGlyZWN0aXZlc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcyc7XG5cbi8vIHBpcGVzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcyc7XG5cbi8vIHJlZ2lzdHJ5XG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWdpc3RyeS90eXBlLnJlZ2lzdHJ5JztcblxuLy8gYXBpIG1vZGVsc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpL21vZGVscyc7XG5cbi8vIGNvbXBvbmVudCBtb2RlbHNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvYWN0aW9uL21vZGVscyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Zvcm0vbW9kZWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdGFibGV2aWV3JztcblxuLy8gdGFibGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdGFibGUvdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdGFibGUvbW9kZWxzL3RhYmxlLmV2ZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdGFibGUvbW9kZWxzL3RhYmxlLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RhYmxlL2NvbHVtbi1maWx0ZXItZnVsbC9jb2x1bW4tZmlsdGVyLWZ1bGwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdGFibGUvY29sdW1uLXZhbHVlL2NvbHVtbi12YWx1ZS5jb21wb25lbnQnO1xuXG4vLyBmb3JtbHlcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvbW9kZWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHknO1xuXG4vLyBkYXRhIHByb3ZpZGVyc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1wcm92aWRlcnMnO1xuXG4vLyBkZXNjcmlwdG9yc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvbW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvYWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rlc2NyaXB0b3JzL2VkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZXNjcmlwdG9ycy9maWx0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZXNjcmlwdG9ycy90YWJsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kZXNjcmlwdG9ycy90YWJsZXZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGVzY3JpcHRvcnMvdHlwZXMnO1xuXG4vLyBnZW5lcmFsIG1vZGVsc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzJztcblxuLy8gcm91dGVyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yb3V0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcm91dGVyL21vZGVscyc7XG5cbi8vIHNlY3VyaXR5XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWN1cml0eSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWN1cml0eS9tb2RlbCc7XG5cbi8vIHR5cGVzXG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5cbi8vIGhlbHBlcnNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2hlbHBlcnMvY29lcmNpb24nO1xuXG4vLyBzdHlsZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0eWxlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdHlsZXMvbW9kZWxzJztcblxuLy8gZXJyb3JcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Vycm9yJztcbiJdfQ==
@@ -1,5 +1,6 @@
1
1
  export * from './action.component';
2
2
  export * from './route/action-route.component';
3
3
  export * from './editor/action-editor.component';
4
+ export * from './table/action-table.component';
4
5
  export * from './localization/data-language-dropdown.component';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvYWN0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsaURBQWlELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FjdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yb3V0ZS9hY3Rpb24tcm91dGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZWRpdG9yL2FjdGlvbi1lZGl0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbG9jYWxpemF0aW9uL2RhdGEtbGFuZ3VhZ2UtZHJvcGRvd24uY29tcG9uZW50JztcbiJdfQ==
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvYWN0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxpREFBaUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWN0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JvdXRlL2FjdGlvbi1yb3V0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lZGl0b3IvYWN0aW9uLWVkaXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS9hY3Rpb24tdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbG9jYWxpemF0aW9uL2RhdGEtbGFuZ3VhZ2UtZHJvcGRvd24uY29tcG9uZW50JztcbiJdfQ==
@@ -0,0 +1,164 @@
1
+ import { NgTemplateOutlet } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, QueryList, Type, ViewChild, ViewChildren, inject, signal } from '@angular/core';
3
+ import { ActivatedRoute } from '@angular/router';
4
+ import { Observable, isObservable, of } from 'rxjs';
5
+ import { TableDescriptorInst } from '../../../descriptors/table';
6
+ import { ActionPositionEnum } from '../../../descriptors/types';
7
+ import { MngComponentDirective, MngTemplateDirective } from '../../../directives';
8
+ import { boolean$Attribute } from '../../../helpers/coercion';
9
+ import { MngActionExecutorService, MngViewContainerComponentService } from '../../../services';
10
+ import { StylesUtil } from '../../../styles';
11
+ import { ActionParameters } from '../../action/models';
12
+ import { MngTableComponent } from '../../table/table.component';
13
+ import { MngActionComponent } from '../action.component';
14
+ import * as i0 from "@angular/core";
15
+ export class MngActionTableComponent {
16
+ constructor() {
17
+ this.route = inject(ActivatedRoute);
18
+ this.actionExecutor = inject(MngActionExecutorService);
19
+ this.viewContainerService = inject((MngViewContainerComponentService), { optional: true });
20
+ this.useQueryParams = false;
21
+ // extra features input
22
+ this.selectionMode = 'multiple';
23
+ this.selectionEnabled = false;
24
+ // actions
25
+ this.actions = []; // can be anything
26
+ // event outputs
27
+ this.loadEventEmitter = new EventEmitter();
28
+ this.selectionChangeEventEmitter = new EventEmitter();
29
+ this.captionCmpInstEventEmitter = new EventEmitter();
30
+ this.columnActionCmpInstEventEmitter = new EventEmitter();
31
+ // templates
32
+ this.captionTemplate = signal(undefined);
33
+ this.footerTemplate = signal(undefined);
34
+ // actions
35
+ this.rowClickActions = signal([]);
36
+ this.rowInlineActions = signal([]);
37
+ this.viewContainer = signal(undefined);
38
+ }
39
+ ngOnInit() {
40
+ this.initializeViewContainer();
41
+ // process actions
42
+ const rowClickActions = [];
43
+ const rowInlineActions = [];
44
+ for (const action of this.actions) {
45
+ switch (action.position) {
46
+ case ActionPositionEnum.RowClick:
47
+ rowClickActions.push(action);
48
+ break;
49
+ case ActionPositionEnum.RowInline:
50
+ rowInlineActions.push(action);
51
+ break;
52
+ }
53
+ }
54
+ this.rowClickActions.set(rowClickActions);
55
+ this.rowInlineActions.set(rowInlineActions);
56
+ // define all styles
57
+ if (this.descriptor && !this.columnActionMinWidth) {
58
+ this.columnActionMinWidth = StylesUtil.calculateTableColumnActionWidth(this.descriptor, this.rowInlineActions());
59
+ }
60
+ }
61
+ ngAfterContentInit() {
62
+ this.templates.forEach(template => {
63
+ switch (template.getType()) {
64
+ case 'caption':
65
+ this.captionTemplate.set(template.template);
66
+ break;
67
+ case 'footer':
68
+ this.footerTemplate.set(template.template);
69
+ break;
70
+ }
71
+ });
72
+ }
73
+ ngOnChanges(changes) {
74
+ if (changes['viewContainerInit'] && !changes['viewContainerInit'].firstChange) {
75
+ this.initializeViewContainer();
76
+ }
77
+ }
78
+ reload(emitEvent = false, resetParams = false) {
79
+ this.table.reload(emitEvent, resetParams);
80
+ }
81
+ onCellClick(event) {
82
+ if (this.rowClickActions().length) {
83
+ for (const action of this.rowClickActions()) {
84
+ const idProp = this.descriptor?.trackProperty ?? action?.model?.idProperty;
85
+ const parameters = new ActionParameters(idProp ? event.rowItem[idProp] : undefined, event.rowItem)
86
+ .withRoute(this.route)
87
+ .withViewContainer(this.viewContainer())
88
+ .withSourceComponent(this);
89
+ this.actionExecutor.triggerAction(action, parameters, true);
90
+ }
91
+ }
92
+ }
93
+ onSelectionChange(items) {
94
+ this.selectionChangeEventEmitter.next(items);
95
+ }
96
+ onActionFinish(runResult) {
97
+ if (!runResult.error) {
98
+ this.reload();
99
+ }
100
+ }
101
+ initializeViewContainer() {
102
+ this.viewContainer.set(this.viewContainerInput ?? this.viewContainerService ?? undefined);
103
+ }
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngActionTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
105
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.8", type: MngActionTableComponent, isStandalone: true, selector: "mng-action-table", inputs: { descriptor: "descriptor", items: "items", queryResult: ["queryResult", "queryResult", (value) => (isObservable(value) ? value : of(value))], loading: ["loading", "loading", boolean$Attribute], dataProvider: "dataProvider", useQueryParams: "useQueryParams", selectionMode: "selectionMode", selectionEnabled: "selectionEnabled", globalFilterFields: "globalFilterFields", actions: "actions", viewContainerInput: ["viewContainer", "viewContainerInput"], captionComponent: "captionComponent", columnActionComponent: "columnActionComponent", columnActionMinWidth: "columnActionMinWidth" }, outputs: { loadEventEmitter: "tableLoad", selectionChangeEventEmitter: "selectionChange", captionCmpInstEventEmitter: "captionComponentInstance", columnActionCmpInstEventEmitter: "columnActionComponentInstance" }, queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "table", first: true, predicate: MngTableComponent, descendants: true }, { propertyName: "components", predicate: MngComponentDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<mng-table\n [descriptor]=\"descriptor\"\n [items]=\"items\"\n [queryResult]=\"queryResult\"\n [loading]=\"loading\"\n [dataProvider]=\"dataProvider\"\n [useQueryParams]=\"useQueryParams\"\n [selectionMode]=\"selectionMode\"\n [selectionEnabled]=\"selectionEnabled\"\n [viewContainer]=\"viewContainer()\"\n [globalFilterFields]=\"globalFilterFields\"\n [captionComponent]=\"captionComponent\"\n [columnCustomLastComponent]=\"columnActionComponent\"\n [columnLastMinWidth]=\"columnActionMinWidth\"\n (tableLoad)=\"loadEventEmitter.next($event)\"\n (cellClick)=\"onCellClick($event)\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"captionCmpInstEventEmitter.next($event)\"\n (columnCustomLastComponentInstance)=\"columnActionCmpInstEventEmitter.next($event)\">\n @if (!columnActionComponent && rowInlineActions().length > 0) {\n <ng-template mngTemplate=\"columnCustomLast\" let-item=\"rowItem\" let-idx=\"rowIndex\">\n @for (action of rowInlineActions(); track action.actionNameLong) {\n <mng-action\n [action]=\"action\"\n [item]=\"item\"\n [viewContainer]=\"viewContainer()\"\n [hostComponent]=\"this\"\n [itemId]=\"descriptor.model.idProperty ? item[descriptor.model.idProperty!] : null\"\n [actionData]=\"{itemIndex: idx}\"\n (finish)=\"onActionFinish($event)\">\n </mng-action>\n }\n </ng-template>\n }\n @if (captionTemplate() && !captionComponent) {\n <ng-template mngTemplate=\"caption\">\n <ng-container *ngTemplateOutlet=\"captionTemplate()!\"></ng-container>\n </ng-template>\n }\n @if (footerTemplate()) {\n <ng-template mngTemplate=\"footer\">\n <ng-container *ngTemplateOutlet=\"footerTemplate()!\"></ng-container>\n </ng-template>\n }\n</mng-table>\n", dependencies: [{ kind: "component", type: MngTableComponent, selector: "mng-table", inputs: ["descriptor", "items", "queryResult", "loading", "dataProvider", "useQueryParams", "selectionMode", "selectionEnabled", "columnLastMinWidth", "viewContainer", "captionComponent", "columnCustomLastComponent", "globalFilterFields"], outputs: ["tableLoad", "cellClick", "selectionChange", "captionComponentInstance", "columnCustomLastComponentInstance"] }, { kind: "component", type: MngActionComponent, selector: "mng-action", inputs: ["action", "item", "itemId", "actionData", "queryParam", "dataProvider", "hostComponent", "route", "disabled", "loading", "viewContainer", "selectedItems"], outputs: ["finish"] }, { kind: "directive", type: MngTemplateDirective, selector: "[mngTemplate]", inputs: ["type", "mngTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngActionTableComponent, decorators: [{
108
+ type: Component,
109
+ args: [{ standalone: true, selector: 'mng-action-table', imports: [MngTableComponent, MngActionComponent, MngTemplateDirective, NgTemplateOutlet], changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-table\n [descriptor]=\"descriptor\"\n [items]=\"items\"\n [queryResult]=\"queryResult\"\n [loading]=\"loading\"\n [dataProvider]=\"dataProvider\"\n [useQueryParams]=\"useQueryParams\"\n [selectionMode]=\"selectionMode\"\n [selectionEnabled]=\"selectionEnabled\"\n [viewContainer]=\"viewContainer()\"\n [globalFilterFields]=\"globalFilterFields\"\n [captionComponent]=\"captionComponent\"\n [columnCustomLastComponent]=\"columnActionComponent\"\n [columnLastMinWidth]=\"columnActionMinWidth\"\n (tableLoad)=\"loadEventEmitter.next($event)\"\n (cellClick)=\"onCellClick($event)\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"captionCmpInstEventEmitter.next($event)\"\n (columnCustomLastComponentInstance)=\"columnActionCmpInstEventEmitter.next($event)\">\n @if (!columnActionComponent && rowInlineActions().length > 0) {\n <ng-template mngTemplate=\"columnCustomLast\" let-item=\"rowItem\" let-idx=\"rowIndex\">\n @for (action of rowInlineActions(); track action.actionNameLong) {\n <mng-action\n [action]=\"action\"\n [item]=\"item\"\n [viewContainer]=\"viewContainer()\"\n [hostComponent]=\"this\"\n [itemId]=\"descriptor.model.idProperty ? item[descriptor.model.idProperty!] : null\"\n [actionData]=\"{itemIndex: idx}\"\n (finish)=\"onActionFinish($event)\">\n </mng-action>\n }\n </ng-template>\n }\n @if (captionTemplate() && !captionComponent) {\n <ng-template mngTemplate=\"caption\">\n <ng-container *ngTemplateOutlet=\"captionTemplate()!\"></ng-container>\n </ng-template>\n }\n @if (footerTemplate()) {\n <ng-template mngTemplate=\"footer\">\n <ng-container *ngTemplateOutlet=\"footerTemplate()!\"></ng-container>\n </ng-template>\n }\n</mng-table>\n" }]
110
+ }], propDecorators: { descriptor: [{
111
+ type: Input,
112
+ args: [{ required: true }]
113
+ }], items: [{
114
+ type: Input
115
+ }], queryResult: [{
116
+ type: Input,
117
+ args: [{ transform: (value) => (isObservable(value) ? value : of(value)) }]
118
+ }], loading: [{
119
+ type: Input,
120
+ args: [{ transform: boolean$Attribute }]
121
+ }], dataProvider: [{
122
+ type: Input
123
+ }], useQueryParams: [{
124
+ type: Input
125
+ }], selectionMode: [{
126
+ type: Input
127
+ }], selectionEnabled: [{
128
+ type: Input
129
+ }], globalFilterFields: [{
130
+ type: Input
131
+ }], actions: [{
132
+ type: Input
133
+ }], viewContainerInput: [{
134
+ type: Input,
135
+ args: ['viewContainer']
136
+ }], captionComponent: [{
137
+ type: Input
138
+ }], columnActionComponent: [{
139
+ type: Input
140
+ }], columnActionMinWidth: [{
141
+ type: Input
142
+ }], loadEventEmitter: [{
143
+ type: Output,
144
+ args: ['tableLoad']
145
+ }], selectionChangeEventEmitter: [{
146
+ type: Output,
147
+ args: ['selectionChange']
148
+ }], captionCmpInstEventEmitter: [{
149
+ type: Output,
150
+ args: ['captionComponentInstance']
151
+ }], columnActionCmpInstEventEmitter: [{
152
+ type: Output,
153
+ args: ['columnActionComponentInstance']
154
+ }], templates: [{
155
+ type: ContentChildren,
156
+ args: [MngTemplateDirective]
157
+ }], components: [{
158
+ type: ViewChildren,
159
+ args: [MngComponentDirective]
160
+ }], table: [{
161
+ type: ViewChild,
162
+ args: [MngTableComponent]
163
+ }] } });
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-table.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/action/table/action-table.component.ts","../../../../../../src/lib/components/action/table/action-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {NgTemplateOutlet} from '@angular/common';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n    Type,\n    ViewChild,\n    ViewChildren,\n    WritableSignal,\n    inject,\n    signal\n} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {Observable, isObservable, of} from 'rxjs';\n\nimport {MediusQueryResult} from '../../../api/models';\nimport {ITableDataProvider} from '../../../data-providers';\nimport {ActionDescriptorInst} from '../../../descriptors/action';\nimport {TableDescriptorInst} from '../../../descriptors/table';\nimport {ActionPositionEnum} from '../../../descriptors/types';\nimport {MngComponentDirective, MngTemplateDirective} from '../../../directives';\nimport {boolean$Attribute} from '../../../helpers/coercion';\nimport {IViewContainer} from '../../../models';\nimport {MngActionExecutorService, MngViewContainerComponentService} from '../../../services';\nimport {StylesUtil} from '../../../styles';\nimport {ActionInstance, ActionParameters} from '../../action/models';\nimport {MngTableCellClickEvent, MngTableLoadEvent} from '../../table/models/table.event';\nimport {MngTableComponent} from '../../table/table.component';\nimport {MngActionComponent} from '../action.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-action-table',\n    templateUrl: './action-table.component.html',\n    imports: [MngTableComponent, MngActionComponent, MngTemplateDirective, NgTemplateOutlet],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngActionTableComponent<T = any, S = any> implements OnInit, OnChanges, AfterContentInit {\n    private readonly route = inject(ActivatedRoute);\n    private readonly actionExecutor = inject(MngActionExecutorService);\n    private readonly viewContainerService = inject(MngViewContainerComponentService<T, S>, {optional: true});\n\n    // metadata input\n    @Input({required: true}) public descriptor!: TableDescriptorInst<T>;\n\n    // data source inputs\n    @Input() public items?: Observable<Array<T>> | Array<T>;\n    @Input({transform: (value: unknown) => (isObservable(value) ? (value as Observable<MediusQueryResult<T>>) : of(value as MediusQueryResult<T>))})\n    public queryResult?: Observable<MediusQueryResult<T>>;\n    @Input({transform: boolean$Attribute}) public loading?: Observable<boolean>;\n    @Input() public dataProvider?: ITableDataProvider;\n    @Input() public useQueryParams = false;\n\n    // extra features input\n    @Input() public selectionMode: 'single' | 'multiple' = 'multiple';\n    @Input() public selectionEnabled = false;\n    @Input() public globalFilterFields?: string[];\n\n    // actions\n    @Input() public actions: Array<ActionDescriptorInst<any>> = []; // can be anything\n\n    // component inputs\n    @Input('viewContainer') public viewContainerInput?: IViewContainer<T, S>;\n    @Input() public captionComponent?: Type<any>;\n    @Input() public columnActionComponent?: Type<any>;\n    @Input() public columnActionMinWidth?: number;\n\n    // event outputs\n    @Output('tableLoad') public loadEventEmitter = new EventEmitter<MngTableLoadEvent>();\n    @Output('selectionChange') public selectionChangeEventEmitter = new EventEmitter<Array<T>>();\n    @Output('captionComponentInstance') public captionCmpInstEventEmitter = new EventEmitter<any>();\n    @Output('columnActionComponentInstance') public columnActionCmpInstEventEmitter = new EventEmitter<any>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChildren(MngComponentDirective) public components!: QueryList<MngComponentDirective<any>>;\n    @ViewChild(MngTableComponent) public table!: MngTableComponent;\n\n    // templates\n    public captionTemplate: WritableSignal<TemplateRef<any> | undefined> = signal(undefined);\n    public footerTemplate: WritableSignal<TemplateRef<any> | undefined> = signal(undefined);\n\n    // actions\n    public rowClickActions: WritableSignal<ActionDescriptorInst<T>[]> = signal([]);\n    public rowInlineActions: WritableSignal<ActionDescriptorInst<T>[]> = signal([]);\n\n    public viewContainer: WritableSignal<IViewContainer<T, S> | undefined> = signal(undefined);\n\n    public ngOnInit() {\n        this.initializeViewContainer();\n\n        // process actions\n        const rowClickActions: ActionDescriptorInst<T>[] = [];\n        const rowInlineActions: ActionDescriptorInst<T>[] = [];\n        for (const action of this.actions) {\n            switch (action.position) {\n                case ActionPositionEnum.RowClick:\n                    rowClickActions.push(action);\n                    break;\n                case ActionPositionEnum.RowInline:\n                    rowInlineActions.push(action);\n                    break;\n            }\n        }\n        this.rowClickActions.set(rowClickActions);\n        this.rowInlineActions.set(rowInlineActions);\n\n        // define all styles\n        if (this.descriptor && !this.columnActionMinWidth) {\n            this.columnActionMinWidth = StylesUtil.calculateTableColumnActionWidth(\n                this.descriptor as TableDescriptorInst<any>,\n                this.rowInlineActions() as Array<ActionDescriptorInst<any>>\n            );\n        }\n    }\n\n    public ngAfterContentInit() {\n        this.templates.forEach(template => {\n            switch (template.getType()) {\n                case 'caption':\n                    this.captionTemplate.set(template.template);\n                    break;\n                case 'footer':\n                    this.footerTemplate.set(template.template);\n                    break;\n            }\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['viewContainerInit'] && !changes['viewContainerInit'].firstChange) {\n            this.initializeViewContainer();\n        }\n    }\n\n    public reload(emitEvent = false, resetParams = false) {\n        this.table.reload(emitEvent, resetParams);\n    }\n\n    public onCellClick(event: MngTableCellClickEvent<T>) {\n        if (this.rowClickActions().length) {\n            for (const action of this.rowClickActions()) {\n                const idProp = this.descriptor?.trackProperty ?? action?.model?.idProperty;\n                const parameters = new ActionParameters(idProp ? event.rowItem[idProp as keyof object] : undefined, event.rowItem)\n                    .withRoute(this.route)\n                    .withViewContainer(this.viewContainer())\n                    .withSourceComponent(this);\n                this.actionExecutor.triggerAction(action, parameters, true);\n            }\n        }\n    }\n\n    public onSelectionChange(items: Array<T>) {\n        this.selectionChangeEventEmitter.next(items);\n    }\n\n    public onActionFinish(runResult: ActionInstance<T, S>) {\n        if (!runResult.error) {\n            this.reload();\n        }\n    }\n\n    private initializeViewContainer() {\n        this.viewContainer.set(this.viewContainerInput ?? this.viewContainerService ?? undefined);\n    }\n}\n","<mng-table\n    [descriptor]=\"descriptor\"\n    [items]=\"items\"\n    [queryResult]=\"queryResult\"\n    [loading]=\"loading\"\n    [dataProvider]=\"dataProvider\"\n    [useQueryParams]=\"useQueryParams\"\n    [selectionMode]=\"selectionMode\"\n    [selectionEnabled]=\"selectionEnabled\"\n    [viewContainer]=\"viewContainer()\"\n    [globalFilterFields]=\"globalFilterFields\"\n    [captionComponent]=\"captionComponent\"\n    [columnCustomLastComponent]=\"columnActionComponent\"\n    [columnLastMinWidth]=\"columnActionMinWidth\"\n    (tableLoad)=\"loadEventEmitter.next($event)\"\n    (cellClick)=\"onCellClick($event)\"\n    (selectionChange)=\"onSelectionChange($event)\"\n    (captionComponentInstance)=\"captionCmpInstEventEmitter.next($event)\"\n    (columnCustomLastComponentInstance)=\"columnActionCmpInstEventEmitter.next($event)\">\n    @if (!columnActionComponent && rowInlineActions().length > 0) {\n        <ng-template mngTemplate=\"columnCustomLast\" let-item=\"rowItem\" let-idx=\"rowIndex\">\n            @for (action of rowInlineActions(); track action.actionNameLong) {\n                <mng-action\n                    [action]=\"action\"\n                    [item]=\"item\"\n                    [viewContainer]=\"viewContainer()\"\n                    [hostComponent]=\"this\"\n                    [itemId]=\"descriptor.model.idProperty ? item[descriptor.model.idProperty!] : null\"\n                    [actionData]=\"{itemIndex: idx}\"\n                    (finish)=\"onActionFinish($event)\">\n                </mng-action>\n            }\n        </ng-template>\n    }\n    @if (captionTemplate() && !captionComponent) {\n        <ng-template mngTemplate=\"caption\">\n            <ng-container *ngTemplateOutlet=\"captionTemplate()!\"></ng-container>\n        </ng-template>\n    }\n    @if (footerTemplate()) {\n        <ng-template mngTemplate=\"footer\">\n            <ng-container *ngTemplateOutlet=\"footerTemplate()!\"></ng-container>\n        </ng-template>\n    }\n</mng-table>\n"]}
@@ -16,7 +16,7 @@ import { toObservable } from '../../../../../helpers/coercion';
16
16
  import { MngInternalError } from '../../../../../models';
17
17
  import { MngLoggerService } from '../../../../../services';
18
18
  import { ErrorUtil } from '../../../../../utils';
19
- import { MngTableComponent } from '../../../../tableview';
19
+ import { MngTableComponent } from '../../../../table/table.component';
20
20
  import { MngFormFieldEventComponentSubtype, MngFormFieldEventDialogSubtype, MngFormFieldEventTypeEnum } from '../../../models';
21
21
  import * as i0 from "@angular/core";
22
22
  import * as i1 from "@ngx-translate/core";
@@ -193,7 +193,7 @@ export class MngFormlyFieldLookupDialogComponent extends FieldType {
193
193
  }
194
194
  }
195
195
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngFormlyFieldLookupDialogComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
196
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.8", type: MngFormlyFieldLookupDialogComponent, isStandalone: true, selector: "mng-formly-field-lookup-dialog", viewQueries: [{ propertyName: "mngTable", first: true, predicate: MngTableComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n @if (!props.required && formControl.value && !formControl.disabled) {\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\"></i>\n }\n <button\n pButton\n pRipple\n class=\"mng-dropdown-dialog-search-button\"\n type=\"button\"\n [label]=\"'general.search' | translate: {item: ''}\"\n [disabled]=\"formControl.disabled\"\n (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: props.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n <ng-template pTemplate=\"content\" mngDialogKeydownHandler>\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config.table?.captionComponent\"\n [columnActionComponent]=\"config.table?.columnActionComponent\"\n [viewContainer]=\"viewContainer\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n loadingIcon=\"pi pi-spin pi-spinner\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i2.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i5.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }, { kind: "ngmodule", type: DialogModule }, { kind: "component", type: i7.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: MngTableComponent, selector: "mng-table", inputs: ["descriptor", "items", "queryResult", "loading", "dataProvider", "useQueryParams", "selectionMode", "selectionEnabled", "actions", "isColumnClickable", "viewContainer", "captionComponent", "columnActionComponent", "columnActionMinWidth", "globalFilterFields"], outputs: ["tableLoad", "cellClick", "selectionChange", "captionComponentInstance", "columnActionComponentInstance"] }, { kind: "ngmodule", type: MessagesModule }, { kind: "component", type: i8.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i9.InputText, selector: "[pInputText]" }, { kind: "directive", type: MngDialogKeydownHandlerDirective, selector: "[mngDialogKeydownHandler]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
196
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.8", type: MngFormlyFieldLookupDialogComponent, isStandalone: true, selector: "mng-formly-field-lookup-dialog", viewQueries: [{ propertyName: "mngTable", first: true, predicate: MngTableComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n @if (!props.required && formControl.value && !formControl.disabled) {\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\"></i>\n }\n <button\n pButton\n pRipple\n class=\"mng-dropdown-dialog-search-button\"\n type=\"button\"\n [label]=\"'general.search' | translate: {item: ''}\"\n [disabled]=\"formControl.disabled\"\n (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: props.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n <ng-template pTemplate=\"content\" mngDialogKeydownHandler>\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config.table?.captionComponent\"\n [columnCustomLastComponent]=\"config.table?.columnActionComponent\"\n [viewContainer]=\"viewContainer\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnCustomLastComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n loadingIcon=\"pi pi-spin pi-spinner\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i2.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i5.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }, { kind: "ngmodule", type: DialogModule }, { kind: "component", type: i7.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: MngTableComponent, selector: "mng-table", inputs: ["descriptor", "items", "queryResult", "loading", "dataProvider", "useQueryParams", "selectionMode", "selectionEnabled", "columnLastMinWidth", "viewContainer", "captionComponent", "columnCustomLastComponent", "globalFilterFields"], outputs: ["tableLoad", "cellClick", "selectionChange", "captionComponentInstance", "columnCustomLastComponentInstance"] }, { kind: "ngmodule", type: MessagesModule }, { kind: "component", type: i8.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i9.InputText, selector: "[pInputText]" }, { kind: "directive", type: MngDialogKeydownHandlerDirective, selector: "[mngDialogKeydownHandler]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
197
197
  }
198
198
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngFormlyFieldLookupDialogComponent, decorators: [{
199
199
  type: Component,
@@ -209,9 +209,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
209
209
  MessagesModule,
210
210
  InputTextModule,
211
211
  MngDialogKeydownHandlerDirective
212
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n @if (!props.required && formControl.value && !formControl.disabled) {\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\"></i>\n }\n <button\n pButton\n pRipple\n class=\"mng-dropdown-dialog-search-button\"\n type=\"button\"\n [label]=\"'general.search' | translate: {item: ''}\"\n [disabled]=\"formControl.disabled\"\n (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: props.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n <ng-template pTemplate=\"content\" mngDialogKeydownHandler>\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config.table?.captionComponent\"\n [columnActionComponent]=\"config.table?.columnActionComponent\"\n [viewContainer]=\"viewContainer\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n loadingIcon=\"pi pi-spin pi-spinner\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n" }]
212
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n @if (!props.required && formControl.value && !formControl.disabled) {\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\"></i>\n }\n <button\n pButton\n pRipple\n class=\"mng-dropdown-dialog-search-button\"\n type=\"button\"\n [label]=\"'general.search' | translate: {item: ''}\"\n [disabled]=\"formControl.disabled\"\n (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: props.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n <ng-template pTemplate=\"content\" mngDialogKeydownHandler>\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config.table?.captionComponent\"\n [columnCustomLastComponent]=\"config.table?.columnActionComponent\"\n [viewContainer]=\"viewContainer\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnCustomLastComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n loadingIcon=\"pi pi-spin pi-spinner\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n" }]
213
213
  }], ctorParameters: () => [{ type: i0.Injector }], propDecorators: { mngTable: [{
214
214
  type: ViewChild,
215
215
  args: [MngTableComponent]
216
216
  }] } });
217
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-lookup-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.ts","../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {AfterViewInit, ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit, ViewChild, inject} from '@angular/core';\nimport {FormControl, ReactiveFormsModule} from '@angular/forms';\n\nimport {FieldType, FormlyModule} from '@ngx-formly/core';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Message} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {DialogModule} from 'primeng/dialog';\nimport {InputTextModule} from 'primeng/inputtext';\nimport {MessagesModule} from 'primeng/messages';\nimport {RippleModule} from 'primeng/ripple';\nimport {Observable, ReplaySubject, Subject, Subscription, distinctUntilChanged} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder, MediusQueryResult} from '../../../../../api/models';\nimport {FieldLookupDescriptor} from '../../../../../descriptors/editor';\nimport {FieldLookupConfig} from '../../../../../descriptors/interfaces';\nimport {MngDialogKeydownHandlerDirective} from '../../../../../directives';\nimport {toObservable} from '../../../../../helpers/coercion';\nimport {IViewContainer, MngInternalError} from '../../../../../models';\nimport {MngLoggerService} from '../../../../../services';\nimport {ErrorUtil} from '../../../../../utils';\nimport {MngTableComponent} from '../../../../tableview';\nimport {MngFormEditorComponent} from '../../../editor/form-editor.component';\nimport {MngFormFieldEventComponentSubtype, MngFormFieldEventDialogSubtype, MngFormFieldEventTypeEnum} from '../../../models';\nimport {MngFormlyFieldConfig} from '../../models';\n\n@Component({\n    standalone: true,\n    selector: 'mng-formly-field-lookup-dialog',\n    templateUrl: 'formly-field-lookup-dialog.component.html',\n    imports: [\n        TranslateModule,\n        FormlyModule,\n        ReactiveFormsModule,\n        ButtonModule,\n        RippleModule,\n        DialogModule,\n        AsyncPipe,\n        MngTableComponent,\n        MessagesModule,\n        InputTextModule,\n        MngDialogKeydownHandlerDirective\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldLookupDialogComponent<T, ET> extends FieldType<MngFormlyFieldConfig> implements OnInit, AfterViewInit, OnDestroy {\n    @ViewChild(MngTableComponent) public mngTable?: MngTableComponent<any, any>;\n\n    private readonly logger = inject(MngLoggerService).create('MngFormlyFieldLookupDialogComponent');\n\n    public descriptor!: FieldLookupDescriptor<T, ET>;\n    public config!: FieldLookupConfig;\n    public fieldLabelFormControl: FormControl = new FormControl();\n\n    public itemsSubject: Subject<T> = new ReplaySubject(1);\n    public itemsAsync: Observable<T> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<MediusQueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<MediusQueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedItem: any = null;\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    public viewContainer?: IViewContainer<any, unknown>;\n\n    private lookupDataProviderSubscription?: Subscription;\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.descriptor = this.props.descriptor as FieldLookupDescriptor<T, ET>;\n        this.props.fieldComponent = this;\n        this.subscriptions.push((this.props.formEditorComponent as MngFormEditorComponent<unknown>).viewContainer$.subscribe(value => (this.viewContainer = value)));\n\n        // emit lifecycle event\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this.config = this.descriptor.config as FieldLookupConfig;\n        if (!this.descriptor.dialogTableDataProvider && this.descriptor.dataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.dataProvider.serviceType);\n        }\n\n        // init values\n        this.setFieldLabelValue(this.formControl!.value);\n        const subscription = this.formControl!.valueChanges.pipe(\n            startWith(this.formControl!.value),\n            distinctUntilChanged((prev, curr) => {\n                const compareProp = this.descriptor.dialogTableDescriptor!.trackProperty ?? this.descriptor.dialogTableDescriptor!.model.idProperty;\n                if (compareProp && typeof prev === 'object' && typeof curr === 'object') {\n                    return prev[compareProp] === curr[compareProp];\n                } else {\n                    return prev === curr;\n                }\n            })\n        ).subscribe(v => {\n            this.setFieldLabelValue(v);\n            this.itemsSubject.next(v);\n            this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ValueChange, MngFormlyFieldLookupDialogComponent, this, {\n                value: v\n            });\n\n            if (this.props['onValueChange']) {\n                this.props['onValueChange'](this.field, v);\n            }\n        });\n        this.subscriptions.push(subscription);\n    }\n\n    ngAfterViewInit() {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_VIEW_INIT\n        });\n    }\n\n    ngOnDestroy(): void {\n        // warning: formly calls on destroy before on init\n\n        this.lookupDataProviderSubscription?.unsubscribe();\n        this.subscriptions.forEach(s => s.unsubscribe());\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    openSelectDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = MediusQueryParamBuilder.create(50);\n            if (this.descriptor.dialogTableDescriptor!.hasDefaultSort) {\n                this.descriptor.dialogTableDescriptor!.defaultSortProperty.forEach((p, idx) =>\n                    queryParamBuilder.withSort(p, this.descriptor.dialogTableDescriptor!.defaultSortAsc[idx])\n                );\n            }\n            this.lookupDataProviderSubscription = toObservable(this.descriptor.dataProvider?.lookup(queryParamBuilder.build(), this.dialogDataProviderService)).subscribe({\n                next: res => {\n                    const mqr = new MediusQueryResult<T>();\n                    mqr.pageData = res ?? [];\n                    mqr.allDataCount = res?.length ?? 0;\n                    this.addItemsSubject.next(mqr);\n                    this.dialogAreItemsLoaded = true;\n                    this.dialogIsLoadingSubject.next(false);\n\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupNext',\n                        queryResult: mqr\n                    });\n                },\n                error: err => {\n                    this.dialogIsLoadingSubject.next(false);\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupError',\n                        queryResult: err\n                    });\n\n                    const mngError = ErrorUtil.fromSubscribeError(err, 'MngFormlyFieldLookupDialogComponentError', {\n                        queryParam: queryParamBuilder.build()\n                    });\n                    this.logger.log(mngError, ErrorUtil.getErrorLogLevel(mngError));\n                }\n            });\n        }\n        this.dialogSelectedItem = null;\n        this.isDialogVisible = true;\n\n        this.formControl.markAsTouched();\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: true\n        });\n    }\n\n    onSelectionChange(item: any) {\n        this.dialogSelectedItem = item;\n    }\n\n    onCaptionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_CAPTION_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    onColumnActionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_COLUMN_ACTIONS_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    clear() {\n        this.formControl.setValue(undefined);\n        this.formControl.markAsTouched();\n        this.formControl.markAsDirty();\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: false\n        });\n    }\n\n    addItem() {\n        this.formControl.setValue(this.dialogSelectedItem);\n        this.formControl.markAsDirty();\n        this.formControl.markAsTouched();\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    private setFieldLabelValue(value: T) {\n        if (!value) {\n            this.fieldLabelFormControl.setValue('');\n            return;\n        }\n        if (typeof value === 'object') {\n            const labelProperty = this.descriptor.optionsLabelProperty ?? this.descriptor.dialogTableDescriptor?.model.titleProperty;\n            if (!labelProperty) {\n                throw new MngInternalError('Could not determine label property.', {name: 'MngFormlyFieldLookupDialogError'});\n            }\n            this.fieldLabelFormControl.setValue(value[labelProperty as keyof object]);\n        } else {\n            this.fieldLabelFormControl.setValue(value);\n        }\n    }\n}\n","<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n    <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n    @if (!props.required && formControl.value && !formControl.disabled) {\n        <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\"></i>\n    }\n    <button\n        pButton\n        pRipple\n        class=\"mng-dropdown-dialog-search-button\"\n        type=\"button\"\n        [label]=\"'general.search' | translate: {item: ''}\"\n        [disabled]=\"formControl.disabled\"\n        (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n    [(visible)]=\"isDialogVisible\"\n    [draggable]=\"false\"\n    [header]=\"'general.search' | translate: {item: props.label!}\"\n    [modal]=\"true\"\n    appendTo=\"body\"\n    styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n    <ng-template pTemplate=\"content\" mngDialogKeydownHandler>\n        <mng-table\n            [descriptor]=\"descriptor.dialogTableDescriptor!\"\n            [dataProvider]=\"descriptor.dialogTableDataProvider\"\n            [queryResult]=\"addItemsAsync\"\n            [selectionEnabled]=\"true\"\n            [selectionMode]=\"'single'\"\n            [loading]=\"dialogIsLoading$\"\n            [captionComponent]=\"config.table?.captionComponent\"\n            [columnActionComponent]=\"config.table?.columnActionComponent\"\n            [viewContainer]=\"viewContainer\"\n            (selectionChange)=\"onSelectionChange($event)\"\n            (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n            (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [label]=\"'general.select' | translate\"\n            icon=\"pi pi-check\"\n            class=\"p-button-text\"\n            (click)=\"addItem()\"\n            [loading]=\"(dialogIsLoading$ | async) ?? false\"\n            loadingIcon=\"pi pi-spin pi-spinner\"\n            [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-lookup-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.ts","../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {AfterViewInit, ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit, ViewChild, inject} from '@angular/core';\nimport {FormControl, ReactiveFormsModule} from '@angular/forms';\n\nimport {FieldType, FormlyModule} from '@ngx-formly/core';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Message} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {DialogModule} from 'primeng/dialog';\nimport {InputTextModule} from 'primeng/inputtext';\nimport {MessagesModule} from 'primeng/messages';\nimport {RippleModule} from 'primeng/ripple';\nimport {Observable, ReplaySubject, Subject, Subscription, distinctUntilChanged} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder, MediusQueryResult} from '../../../../../api/models';\nimport {FieldLookupDescriptor} from '../../../../../descriptors/editor';\nimport {FieldLookupConfig} from '../../../../../descriptors/interfaces';\nimport {MngDialogKeydownHandlerDirective} from '../../../../../directives';\nimport {toObservable} from '../../../../../helpers/coercion';\nimport {IViewContainer, MngInternalError} from '../../../../../models';\nimport {MngLoggerService} from '../../../../../services';\nimport {ErrorUtil} from '../../../../../utils';\nimport {MngTableComponent} from '../../../../table/table.component';\nimport {MngFormEditorComponent} from '../../../editor/form-editor.component';\nimport {MngFormFieldEventComponentSubtype, MngFormFieldEventDialogSubtype, MngFormFieldEventTypeEnum} from '../../../models';\nimport {MngFormlyFieldConfig} from '../../models';\n\n@Component({\n    standalone: true,\n    selector: 'mng-formly-field-lookup-dialog',\n    templateUrl: 'formly-field-lookup-dialog.component.html',\n    imports: [\n        TranslateModule,\n        FormlyModule,\n        ReactiveFormsModule,\n        ButtonModule,\n        RippleModule,\n        DialogModule,\n        AsyncPipe,\n        MngTableComponent,\n        MessagesModule,\n        InputTextModule,\n        MngDialogKeydownHandlerDirective\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldLookupDialogComponent<T, ET> extends FieldType<MngFormlyFieldConfig> implements OnInit, AfterViewInit, OnDestroy {\n    @ViewChild(MngTableComponent) public mngTable?: MngTableComponent<any, any>;\n\n    private readonly logger = inject(MngLoggerService).create('MngFormlyFieldLookupDialogComponent');\n\n    public descriptor!: FieldLookupDescriptor<T, ET>;\n    public config!: FieldLookupConfig;\n    public fieldLabelFormControl: FormControl = new FormControl();\n\n    public itemsSubject: Subject<T> = new ReplaySubject(1);\n    public itemsAsync: Observable<T> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<MediusQueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<MediusQueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedItem: any = null;\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    public viewContainer?: IViewContainer<any, unknown>;\n\n    private lookupDataProviderSubscription?: Subscription;\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.descriptor = this.props.descriptor as FieldLookupDescriptor<T, ET>;\n        this.props.fieldComponent = this;\n        this.subscriptions.push((this.props.formEditorComponent as MngFormEditorComponent<unknown>).viewContainer$.subscribe(value => (this.viewContainer = value)));\n\n        // emit lifecycle event\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this.config = this.descriptor.config as FieldLookupConfig;\n        if (!this.descriptor.dialogTableDataProvider && this.descriptor.dataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.dataProvider.serviceType);\n        }\n\n        // init values\n        this.setFieldLabelValue(this.formControl!.value);\n        const subscription = this.formControl!.valueChanges.pipe(\n            startWith(this.formControl!.value),\n            distinctUntilChanged((prev, curr) => {\n                const compareProp = this.descriptor.dialogTableDescriptor!.trackProperty ?? this.descriptor.dialogTableDescriptor!.model.idProperty;\n                if (compareProp && typeof prev === 'object' && typeof curr === 'object') {\n                    return prev[compareProp] === curr[compareProp];\n                } else {\n                    return prev === curr;\n                }\n            })\n        ).subscribe(v => {\n            this.setFieldLabelValue(v);\n            this.itemsSubject.next(v);\n            this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ValueChange, MngFormlyFieldLookupDialogComponent, this, {\n                value: v\n            });\n\n            if (this.props['onValueChange']) {\n                this.props['onValueChange'](this.field, v);\n            }\n        });\n        this.subscriptions.push(subscription);\n    }\n\n    ngAfterViewInit() {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_VIEW_INIT\n        });\n    }\n\n    ngOnDestroy(): void {\n        // warning: formly calls on destroy before on init\n\n        this.lookupDataProviderSubscription?.unsubscribe();\n        this.subscriptions.forEach(s => s.unsubscribe());\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormFieldEventTypeEnum.ComponentLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    openSelectDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = MediusQueryParamBuilder.create(50);\n            if (this.descriptor.dialogTableDescriptor!.hasDefaultSort) {\n                this.descriptor.dialogTableDescriptor!.defaultSortProperty.forEach((p, idx) =>\n                    queryParamBuilder.withSort(p, this.descriptor.dialogTableDescriptor!.defaultSortAsc[idx])\n                );\n            }\n            this.lookupDataProviderSubscription = toObservable(this.descriptor.dataProvider?.lookup(queryParamBuilder.build(), this.dialogDataProviderService)).subscribe({\n                next: res => {\n                    const mqr = new MediusQueryResult<T>();\n                    mqr.pageData = res ?? [];\n                    mqr.allDataCount = res?.length ?? 0;\n                    this.addItemsSubject.next(mqr);\n                    this.dialogAreItemsLoaded = true;\n                    this.dialogIsLoadingSubject.next(false);\n\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupNext',\n                        queryResult: mqr\n                    });\n                },\n                error: err => {\n                    this.dialogIsLoadingSubject.next(false);\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupError',\n                        queryResult: err\n                    });\n\n                    const mngError = ErrorUtil.fromSubscribeError(err, 'MngFormlyFieldLookupDialogComponentError', {\n                        queryParam: queryParamBuilder.build()\n                    });\n                    this.logger.log(mngError, ErrorUtil.getErrorLogLevel(mngError));\n                }\n            });\n        }\n        this.dialogSelectedItem = null;\n        this.isDialogVisible = true;\n\n        this.formControl.markAsTouched();\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: true\n        });\n    }\n\n    onSelectionChange(item: any) {\n        this.dialogSelectedItem = item;\n    }\n\n    onCaptionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_CAPTION_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    onColumnActionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_COLUMN_ACTIONS_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    clear() {\n        this.formControl.setValue(undefined);\n        this.formControl.markAsTouched();\n        this.formControl.markAsDirty();\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DialogLifecycle, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: false\n        });\n    }\n\n    addItem() {\n        this.formControl.setValue(this.dialogSelectedItem);\n        this.formControl.markAsDirty();\n        this.formControl.markAsTouched();\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    private setFieldLabelValue(value: T) {\n        if (!value) {\n            this.fieldLabelFormControl.setValue('');\n            return;\n        }\n        if (typeof value === 'object') {\n            const labelProperty = this.descriptor.optionsLabelProperty ?? this.descriptor.dialogTableDescriptor?.model.titleProperty;\n            if (!labelProperty) {\n                throw new MngInternalError('Could not determine label property.', {name: 'MngFormlyFieldLookupDialogError'});\n            }\n            this.fieldLabelFormControl.setValue(value[labelProperty as keyof object]);\n        } else {\n            this.fieldLabelFormControl.setValue(value);\n        }\n    }\n}\n","<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n    <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n    @if (!props.required && formControl.value && !formControl.disabled) {\n        <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\"></i>\n    }\n    <button\n        pButton\n        pRipple\n        class=\"mng-dropdown-dialog-search-button\"\n        type=\"button\"\n        [label]=\"'general.search' | translate: {item: ''}\"\n        [disabled]=\"formControl.disabled\"\n        (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n    [(visible)]=\"isDialogVisible\"\n    [draggable]=\"false\"\n    [header]=\"'general.search' | translate: {item: props.label!}\"\n    [modal]=\"true\"\n    appendTo=\"body\"\n    styleClass=\"p-fluid mng-dialog mng-formly-field-lookup-dialog\">\n    <ng-template pTemplate=\"content\" mngDialogKeydownHandler>\n        <mng-table\n            [descriptor]=\"descriptor.dialogTableDescriptor!\"\n            [dataProvider]=\"descriptor.dialogTableDataProvider\"\n            [queryResult]=\"addItemsAsync\"\n            [selectionEnabled]=\"true\"\n            [selectionMode]=\"'single'\"\n            [loading]=\"dialogIsLoading$\"\n            [captionComponent]=\"config.table?.captionComponent\"\n            [columnCustomLastComponent]=\"config.table?.columnActionComponent\"\n            [viewContainer]=\"viewContainer\"\n            (selectionChange)=\"onSelectionChange($event)\"\n            (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n            (columnCustomLastComponentInstance)=\"onColumnActionCmpInst($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [label]=\"'general.select' | translate\"\n            icon=\"pi pi-check\"\n            class=\"p-button-text\"\n            (click)=\"addItem()\"\n            [loading]=\"(dialogIsLoading$ | async) ?? false\"\n            loadingIcon=\"pi pi-spin pi-spinner\"\n            [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}