ngx-sumax-erp-components 0.0.1

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 (142) hide show
  1. package/README.md +24 -0
  2. package/esm2022/lib/date-picker/CustomDatePickerFormat.mjs +43 -0
  3. package/esm2022/lib/date-picker/CustomDatePickerI18n.mjs +50 -0
  4. package/esm2022/lib/date-picker/date-picker.component.mjs +366 -0
  5. package/esm2022/lib/date-picker/date-picker.mjs +3 -0
  6. package/esm2022/lib/date-picker/date-picker.module.mjs +69 -0
  7. package/esm2022/lib/date-picker/date-picker.service.mjs +68 -0
  8. package/esm2022/lib/date-time-picker/date-time-picker.component.mjs +311 -0
  9. package/esm2022/lib/date-time-picker/date-time-picker.mjs +3 -0
  10. package/esm2022/lib/date-time-picker/date-time-picker.module.mjs +76 -0
  11. package/esm2022/lib/date-time-picker/date-time-picker.service.mjs +64 -0
  12. package/esm2022/lib/date-time-picker-editable/date-time-picker-editable.component.mjs +1140 -0
  13. package/esm2022/lib/date-time-picker-editable/date-time-picker-editable.module.mjs +93 -0
  14. package/esm2022/lib/date-time-picker-editable/date-time-picker-editable.service.mjs +85 -0
  15. package/esm2022/lib/dialog-ag-grid-search/dialog-ag-grid-search.component.mjs +283 -0
  16. package/esm2022/lib/dialog-ag-grid-search/dialog-ag-grid-search.module.mjs +23 -0
  17. package/esm2022/lib/error-message/error-message.component.mjs +24 -0
  18. package/esm2022/lib/error-message/error-message.module.mjs +19 -0
  19. package/esm2022/lib/input-number/input-number.component.mjs +351 -0
  20. package/esm2022/lib/input-number/input-number.mjs +3 -0
  21. package/esm2022/lib/input-number/input-number.module.mjs +65 -0
  22. package/esm2022/lib/input-number/input-number.service.mjs +68 -0
  23. package/esm2022/lib/input-text/input-text.component.mjs +345 -0
  24. package/esm2022/lib/input-text/input-text.mjs +3 -0
  25. package/esm2022/lib/input-text/input-text.module.mjs +73 -0
  26. package/esm2022/lib/input-text/input-text.service.mjs +96 -0
  27. package/esm2022/lib/ng-select-multiple/ng-select-multiple.component.mjs +375 -0
  28. package/esm2022/lib/ng-select-multiple/ng-select-multiple.mjs +3 -0
  29. package/esm2022/lib/ng-select-multiple/ng-select-multiple.module.mjs +69 -0
  30. package/esm2022/lib/ng-select-multiple/ng-select-multiple.service.mjs +96 -0
  31. package/esm2022/lib/ng-select-simple/ng-select-simple.component.mjs +461 -0
  32. package/esm2022/lib/ng-select-simple/ng-select-simple.mjs +3 -0
  33. package/esm2022/lib/ng-select-simple/ng-select-simple.module.mjs +53 -0
  34. package/esm2022/lib/ng-select-simple/ng-select-simple.service.mjs +138 -0
  35. package/esm2022/lib/sc-ag-grid/cell-editors/container-shared/container-shared.component.mjs +144 -0
  36. package/esm2022/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayCustom.component.mjs +27 -0
  37. package/esm2022/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayDefault.component.mjs +22 -0
  38. package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-button/sc-cell-render-button.component.mjs +242 -0
  39. package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-checkbox-list/sc-cell-render-checkbox-list.component.mjs +62 -0
  40. package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-config.mjs +27 -0
  41. package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-select/sc-cell-render-select.component.mjs +70 -0
  42. package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-toggle/sc-cell-render-toggle.component.mjs +45 -0
  43. package/esm2022/lib/sc-ag-grid/directives/scAgGrid.directive.mjs +25 -0
  44. package/esm2022/lib/sc-ag-grid/index.mjs +14 -0
  45. package/esm2022/lib/sc-ag-grid/input-search/input-search.component.mjs +20 -0
  46. package/esm2022/lib/sc-ag-grid/input-search/input-search.module.mjs +31 -0
  47. package/esm2022/lib/sc-ag-grid/sc-ag-grid-customizable/sc-ag-grid-customizable.component.mjs +564 -0
  48. package/esm2022/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.component.mjs +80 -0
  49. package/esm2022/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.module.mjs +31 -0
  50. package/esm2022/lib/sc-ag-grid/sc-ag-grid.module.mjs +118 -0
  51. package/esm2022/lib/sc-ag-grid/sc-grid.uitl.mjs +10 -0
  52. package/esm2022/lib/sc-wizard/sc-wizard.component.mjs +75 -0
  53. package/esm2022/lib/sc-wizard/sc-wizard.module.mjs +44 -0
  54. package/esm2022/lib/text-area/text-area.component.mjs +272 -0
  55. package/esm2022/lib/text-area/text-area.mjs +3 -0
  56. package/esm2022/lib/text-area/text-area.module.mjs +60 -0
  57. package/esm2022/lib/text-area/text-area.service.mjs +54 -0
  58. package/esm2022/lib/tooltip-message/tooltip-message.component.mjs +25 -0
  59. package/esm2022/lib/tooltip-message/tooltip-message.module.mjs +21 -0
  60. package/esm2022/lib/utils/DateTimeModel.mjs +56 -0
  61. package/esm2022/lib/utils/DateTimePickerEditable.mjs +3 -0
  62. package/esm2022/lib/utils/DateUtil.mjs +196 -0
  63. package/esm2022/lib/utils/INgSelect.mjs +2 -0
  64. package/esm2022/lib/utils/IScAgGrid.mjs +7 -0
  65. package/esm2022/lib/utils/ScWizardBase.mjs +14 -0
  66. package/esm2022/lib/utils/SharedComponentsUtil.mjs +38 -0
  67. package/esm2022/lib/utils/ValidateUtil.mjs +18 -0
  68. package/esm2022/lib/utils/message-util.service.mjs +75 -0
  69. package/esm2022/ngx-sumax-erp-components.mjs +5 -0
  70. package/esm2022/public-api.mjs +33 -0
  71. package/fesm2022/ngx-sumax-erp-components.mjs +7045 -0
  72. package/fesm2022/ngx-sumax-erp-components.mjs.map +1 -0
  73. package/index.d.ts +5 -0
  74. package/lib/date-picker/CustomDatePickerFormat.d.ts +11 -0
  75. package/lib/date-picker/CustomDatePickerI18n.d.ts +25 -0
  76. package/lib/date-picker/date-picker.component.d.ts +108 -0
  77. package/lib/date-picker/date-picker.d.ts +10 -0
  78. package/lib/date-picker/date-picker.module.d.ts +18 -0
  79. package/lib/date-picker/date-picker.service.d.ts +22 -0
  80. package/lib/date-time-picker/date-time-picker.component.d.ts +96 -0
  81. package/lib/date-time-picker/date-time-picker.d.ts +9 -0
  82. package/lib/date-time-picker/date-time-picker.module.d.ts +18 -0
  83. package/lib/date-time-picker/date-time-picker.service.d.ts +20 -0
  84. package/lib/date-time-picker-editable/date-time-picker-editable.component.d.ts +118 -0
  85. package/lib/date-time-picker-editable/date-time-picker-editable.module.d.ts +16 -0
  86. package/lib/date-time-picker-editable/date-time-picker-editable.service.d.ts +27 -0
  87. package/lib/dialog-ag-grid-search/dialog-ag-grid-search.component.d.ts +82 -0
  88. package/lib/dialog-ag-grid-search/dialog-ag-grid-search.module.d.ts +13 -0
  89. package/lib/error-message/error-message.component.d.ts +13 -0
  90. package/lib/error-message/error-message.module.d.ts +9 -0
  91. package/lib/input-number/input-number.component.d.ts +74 -0
  92. package/lib/input-number/input-number.d.ts +10 -0
  93. package/lib/input-number/input-number.module.d.ts +17 -0
  94. package/lib/input-number/input-number.service.d.ts +22 -0
  95. package/lib/input-text/input-text.component.d.ts +85 -0
  96. package/lib/input-text/input-text.d.ts +17 -0
  97. package/lib/input-text/input-text.module.d.ts +18 -0
  98. package/lib/input-text/input-text.service.d.ts +35 -0
  99. package/lib/ng-select-multiple/ng-select-multiple.component.d.ts +83 -0
  100. package/lib/ng-select-multiple/ng-select-multiple.d.ts +14 -0
  101. package/lib/ng-select-multiple/ng-select-multiple.module.d.ts +17 -0
  102. package/lib/ng-select-multiple/ng-select-multiple.service.d.ts +30 -0
  103. package/lib/ng-select-simple/ng-select-simple.component.d.ts +124 -0
  104. package/lib/ng-select-simple/ng-select-simple.d.ts +20 -0
  105. package/lib/ng-select-simple/ng-select-simple.module.d.ts +17 -0
  106. package/lib/ng-select-simple/ng-select-simple.service.d.ts +42 -0
  107. package/lib/sc-ag-grid/cell-editors/container-shared/container-shared.component.d.ts +61 -0
  108. package/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayCustom.component.d.ts +10 -0
  109. package/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayDefault.component.d.ts +9 -0
  110. package/lib/sc-ag-grid/cell-render/sc-cell-render-button/sc-cell-render-button.component.d.ts +49 -0
  111. package/lib/sc-ag-grid/cell-render/sc-cell-render-checkbox-list/sc-cell-render-checkbox-list.component.d.ts +11 -0
  112. package/lib/sc-ag-grid/cell-render/sc-cell-render-config.d.ts +20 -0
  113. package/lib/sc-ag-grid/cell-render/sc-cell-render-select/sc-cell-render-select.component.d.ts +16 -0
  114. package/lib/sc-ag-grid/cell-render/sc-cell-render-toggle/sc-cell-render-toggle.component.d.ts +16 -0
  115. package/lib/sc-ag-grid/directives/scAgGrid.directive.d.ts +10 -0
  116. package/lib/sc-ag-grid/index.d.ts +13 -0
  117. package/lib/sc-ag-grid/input-search/input-search.component.d.ts +11 -0
  118. package/lib/sc-ag-grid/input-search/input-search.module.d.ts +9 -0
  119. package/lib/sc-ag-grid/sc-ag-grid-customizable/sc-ag-grid-customizable.component.d.ts +191 -0
  120. package/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.component.d.ts +25 -0
  121. package/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.module.d.ts +9 -0
  122. package/lib/sc-ag-grid/sc-ag-grid.module.d.ts +32 -0
  123. package/lib/sc-ag-grid/sc-grid.uitl.d.ts +5 -0
  124. package/lib/sc-wizard/sc-wizard.component.d.ts +38 -0
  125. package/lib/sc-wizard/sc-wizard.module.d.ts +13 -0
  126. package/lib/text-area/text-area.component.d.ts +66 -0
  127. package/lib/text-area/text-area.d.ts +8 -0
  128. package/lib/text-area/text-area.module.d.ts +16 -0
  129. package/lib/text-area/text-area.service.d.ts +18 -0
  130. package/lib/tooltip-message/tooltip-message.component.d.ts +13 -0
  131. package/lib/tooltip-message/tooltip-message.module.d.ts +11 -0
  132. package/lib/utils/DateTimeModel.d.ts +16 -0
  133. package/lib/utils/DateTimePickerEditable.d.ts +13 -0
  134. package/lib/utils/DateUtil.d.ts +37 -0
  135. package/lib/utils/INgSelect.d.ts +6 -0
  136. package/lib/utils/IScAgGrid.d.ts +65 -0
  137. package/lib/utils/ScWizardBase.d.ts +9 -0
  138. package/lib/utils/SharedComponentsUtil.d.ts +6 -0
  139. package/lib/utils/ValidateUtil.d.ts +4 -0
  140. package/lib/utils/message-util.service.d.ts +10 -0
  141. package/package.json +32 -0
  142. package/public-api.d.ts +29 -0
@@ -0,0 +1,96 @@
1
+ import { Inject, Injectable } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class InputTextService {
4
+ constructor(format = "M", showLabel = true, btnEnable = false, bold = false, textRight = false, validatorMessage = false, tooltipMessage = true, submitted = true, validatorAlert = false, controlCharClearReplace = false, replaceRegex = {}, clearRegex = '') {
5
+ this.format = format;
6
+ this.showLabel = showLabel;
7
+ this.btnEnable = btnEnable;
8
+ this.bold = bold;
9
+ this.textRight = textRight;
10
+ this.validatorMessage = validatorMessage;
11
+ this.tooltipMessage = tooltipMessage;
12
+ this.submitted = submitted;
13
+ this.validatorAlert = validatorAlert;
14
+ this.controlCharClearReplace = controlCharClearReplace;
15
+ this.replaceRegex = replaceRegex;
16
+ this.clearRegex = clearRegex;
17
+ }
18
+ getFormat() {
19
+ return this.format;
20
+ }
21
+ getShowLabel() {
22
+ return this.showLabel;
23
+ }
24
+ getBtnEnable() {
25
+ return this.btnEnable;
26
+ }
27
+ getBold() {
28
+ return this.bold;
29
+ }
30
+ getTextRight() {
31
+ return this.textRight;
32
+ }
33
+ getValidatorMessage() {
34
+ return this.validatorMessage;
35
+ }
36
+ getTooltipMessage() {
37
+ return this.tooltipMessage;
38
+ }
39
+ getSubmitted() {
40
+ return this.submitted;
41
+ }
42
+ getValidatorAlert() {
43
+ return this.validatorAlert;
44
+ }
45
+ getControlCharClearReplace() {
46
+ return this.controlCharClearReplace;
47
+ }
48
+ getReplaceRegex() {
49
+ return this.replaceRegex;
50
+ }
51
+ getClearRegex() {
52
+ return this.clearRegex;
53
+ }
54
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: InputTextService, deps: [{ token: "INPUT_TEXT_FORMAT" }, { token: "INPUT_TEXT_SHOW_LABEL" }, { token: "INPUT_TEXT_BTN_ENABLE" }, { token: "INPUT_TEXT_BOLD" }, { token: "INPUT_TEXT_TEXT_RIGHT" }, { token: "INPUT_TEXT_VALIDATOR_MESSAGE" }, { token: "INPUT_TEXT_TOOLTIP_MESSAGE" }, { token: "INPUT_TEXT_SUBMITTED" }, { token: "INPUT_TEXT_VALIDATOR_ALERT" }, { token: "INPUT_TEXT_CONTROL_CLEAR_REPLACE_REGEX" }, { token: "INPUT_TEXT_REPLACE_REGEX" }, { token: "INPUT_TEXT_CLEAR_REGEX" }], target: i0.ɵɵFactoryTarget.Injectable }); }
55
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: InputTextService }); }
56
+ }
57
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: InputTextService, decorators: [{
58
+ type: Injectable
59
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
60
+ type: Inject,
61
+ args: ["INPUT_TEXT_FORMAT"]
62
+ }] }, { type: undefined, decorators: [{
63
+ type: Inject,
64
+ args: ["INPUT_TEXT_SHOW_LABEL"]
65
+ }] }, { type: undefined, decorators: [{
66
+ type: Inject,
67
+ args: ["INPUT_TEXT_BTN_ENABLE"]
68
+ }] }, { type: undefined, decorators: [{
69
+ type: Inject,
70
+ args: ["INPUT_TEXT_BOLD"]
71
+ }] }, { type: undefined, decorators: [{
72
+ type: Inject,
73
+ args: ["INPUT_TEXT_TEXT_RIGHT"]
74
+ }] }, { type: undefined, decorators: [{
75
+ type: Inject,
76
+ args: ["INPUT_TEXT_VALIDATOR_MESSAGE"]
77
+ }] }, { type: undefined, decorators: [{
78
+ type: Inject,
79
+ args: ["INPUT_TEXT_TOOLTIP_MESSAGE"]
80
+ }] }, { type: undefined, decorators: [{
81
+ type: Inject,
82
+ args: ["INPUT_TEXT_SUBMITTED"]
83
+ }] }, { type: undefined, decorators: [{
84
+ type: Inject,
85
+ args: ["INPUT_TEXT_VALIDATOR_ALERT"]
86
+ }] }, { type: undefined, decorators: [{
87
+ type: Inject,
88
+ args: ["INPUT_TEXT_CONTROL_CLEAR_REPLACE_REGEX"]
89
+ }] }, { type: undefined, decorators: [{
90
+ type: Inject,
91
+ args: ["INPUT_TEXT_REPLACE_REGEX"]
92
+ }] }, { type: undefined, decorators: [{
93
+ type: Inject,
94
+ args: ["INPUT_TEXT_CLEAR_REGEX"]
95
+ }] }] });
96
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXN1bWF4LWVycC1jb21wb25lbnQvc3JjL2xpYi9pbnB1dC10ZXh0L2lucHV0LXRleHQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJbkQsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQixZQUN1QyxTQUFpQixHQUFHLEVBQ2hCLFlBQXFCLElBQUksRUFDekIsWUFBcUIsS0FBSyxFQUNoQyxPQUFnQixLQUFLLEVBQ2YsWUFBcUIsS0FBSyxFQUNuQixtQkFBNEIsS0FBSyxFQUNuQyxpQkFBMEIsSUFBSSxFQUNwQyxZQUFxQixJQUFJLEVBQ25CLGlCQUEwQixLQUFLLEVBQ25CLDBCQUFtQyxLQUFLLEVBQ3RELGVBQXVDLEVBQUUsRUFDM0MsYUFBcUIsRUFBRTtRQVg1QixXQUFNLEdBQU4sTUFBTSxDQUFjO1FBQ2hCLGNBQVMsR0FBVCxTQUFTLENBQWdCO1FBQ3pCLGNBQVMsR0FBVCxTQUFTLENBQWlCO1FBQ2hDLFNBQUksR0FBSixJQUFJLENBQWlCO1FBQ2YsY0FBUyxHQUFULFNBQVMsQ0FBaUI7UUFDbkIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFpQjtRQUNuQyxtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDcEMsY0FBUyxHQUFULFNBQVMsQ0FBZ0I7UUFDbkIsbUJBQWMsR0FBZCxjQUFjLENBQWlCO1FBQ25CLDRCQUF1QixHQUF2Qix1QkFBdUIsQ0FBaUI7UUFDdEQsaUJBQVksR0FBWixZQUFZLENBQTZCO1FBQzNDLGVBQVUsR0FBVixVQUFVLENBQWE7SUFDaEUsQ0FBQztJQUVHLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQUNNLFlBQVk7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFDTSxZQUFZO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBQ00sT0FBTztRQUNaLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0lBQ00sWUFBWTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUNNLG1CQUFtQjtRQUN4QixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUMvQixDQUFDO0lBQ00saUJBQWlCO1FBQ3RCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUM3QixDQUFDO0lBQ00sWUFBWTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUNNLGlCQUFpQjtRQUN0QixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDN0IsQ0FBQztJQUNNLDBCQUEwQjtRQUMvQixPQUFPLElBQUksQ0FBQyx1QkFBdUIsQ0FBQztJQUN0QyxDQUFDO0lBQ00sZUFBZTtRQUNwQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztJQUNNLGFBQWE7UUFDbEIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7K0dBbkRVLGdCQUFnQixrQkFFakIsbUJBQW1CLGFBQ25CLHVCQUF1QixhQUN2Qix1QkFBdUIsYUFDdkIsaUJBQWlCLGFBQ2pCLHVCQUF1QixhQUN2Qiw4QkFBOEIsYUFDOUIsNEJBQTRCLGFBQzVCLHNCQUFzQixhQUN0Qiw0QkFBNEIsYUFDNUIsd0NBQXdDLGFBQ3hDLDBCQUEwQixhQUMxQix3QkFBd0I7bUhBYnZCLGdCQUFnQjs7NEZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVTs7MEJBR04sTUFBTTsyQkFBQyxtQkFBbUI7OzBCQUMxQixNQUFNOzJCQUFDLHVCQUF1Qjs7MEJBQzlCLE1BQU07MkJBQUMsdUJBQXVCOzswQkFDOUIsTUFBTTsyQkFBQyxpQkFBaUI7OzBCQUN4QixNQUFNOzJCQUFDLHVCQUF1Qjs7MEJBQzlCLE1BQU07MkJBQUMsOEJBQThCOzswQkFDckMsTUFBTTsyQkFBQyw0QkFBNEI7OzBCQUNuQyxNQUFNOzJCQUFDLHNCQUFzQjs7MEJBQzdCLE1BQU07MkJBQUMsNEJBQTRCOzswQkFDbkMsTUFBTTsyQkFBQyx3Q0FBd0M7OzBCQUMvQyxNQUFNOzJCQUFDLDBCQUEwQjs7MEJBQ2pDLE1BQU07MkJBQUMsd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgRm9ybWF0IH0gZnJvbSBcIi4vaW5wdXQtdGV4dFwiO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgSW5wdXRUZXh0U2VydmljZSB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBASW5qZWN0KFwiSU5QVVRfVEVYVF9GT1JNQVRcIikgcHJpdmF0ZSBmb3JtYXQ6IEZvcm1hdCA9IFwiTVwiLFxyXG4gICAgQEluamVjdChcIklOUFVUX1RFWFRfU0hPV19MQUJFTFwiKSBwcml2YXRlIHNob3dMYWJlbDogYm9vbGVhbiA9IHRydWUsXHJcbiAgICBASW5qZWN0KFwiSU5QVVRfVEVYVF9CVE5fRU5BQkxFXCIpIHByaXZhdGUgYnRuRW5hYmxlOiBib29sZWFuID0gZmFsc2UsXHJcbiAgICBASW5qZWN0KFwiSU5QVVRfVEVYVF9CT0xEXCIpIHByaXZhdGUgYm9sZDogYm9vbGVhbiA9IGZhbHNlLFxyXG4gICAgQEluamVjdChcIklOUFVUX1RFWFRfVEVYVF9SSUdIVFwiKSBwcml2YXRlIHRleHRSaWdodDogYm9vbGVhbiA9IGZhbHNlLFxyXG4gICAgQEluamVjdChcIklOUFVUX1RFWFRfVkFMSURBVE9SX01FU1NBR0VcIikgcHJpdmF0ZSB2YWxpZGF0b3JNZXNzYWdlOiBib29sZWFuID0gZmFsc2UsXHJcbiAgICBASW5qZWN0KFwiSU5QVVRfVEVYVF9UT09MVElQX01FU1NBR0VcIikgcHJpdmF0ZSB0b29sdGlwTWVzc2FnZTogYm9vbGVhbiA9IHRydWUsXHJcbiAgICBASW5qZWN0KFwiSU5QVVRfVEVYVF9TVUJNSVRURURcIikgcHJpdmF0ZSBzdWJtaXR0ZWQ6IGJvb2xlYW4gPSB0cnVlLFxyXG4gICAgQEluamVjdChcIklOUFVUX1RFWFRfVkFMSURBVE9SX0FMRVJUXCIpIHByaXZhdGUgdmFsaWRhdG9yQWxlcnQ6IGJvb2xlYW4gPSBmYWxzZSxcclxuICAgIEBJbmplY3QoXCJJTlBVVF9URVhUX0NPTlRST0xfQ0xFQVJfUkVQTEFDRV9SRUdFWFwiKSBwcml2YXRlIGNvbnRyb2xDaGFyQ2xlYXJSZXBsYWNlOiBib29sZWFuID0gZmFsc2UsXHJcbiAgICBASW5qZWN0KFwiSU5QVVRfVEVYVF9SRVBMQUNFX1JFR0VYXCIpIHByaXZhdGUgcmVwbGFjZVJlZ2V4OiB7W2tleTpzdHJpbmddOiBzdHJpbmd9ID0ge30sXHJcbiAgICBASW5qZWN0KFwiSU5QVVRfVEVYVF9DTEVBUl9SRUdFWFwiKSBwcml2YXRlIGNsZWFyUmVnZXg6IHN0cmluZyA9ICcnXHJcbiAgKSB7fVxyXG5cclxuICBwdWJsaWMgZ2V0Rm9ybWF0KCk6IEZvcm1hdCB7XHJcbiAgICByZXR1cm4gdGhpcy5mb3JtYXQ7XHJcbiAgfVxyXG4gIHB1YmxpYyBnZXRTaG93TGFiZWwoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5zaG93TGFiZWw7XHJcbiAgfVxyXG4gIHB1YmxpYyBnZXRCdG5FbmFibGUoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5idG5FbmFibGU7XHJcbiAgfVxyXG4gIHB1YmxpYyBnZXRCb2xkKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMuYm9sZDtcclxuICB9XHJcbiAgcHVibGljIGdldFRleHRSaWdodCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLnRleHRSaWdodDtcclxuICB9XHJcbiAgcHVibGljIGdldFZhbGlkYXRvck1lc3NhZ2UoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy52YWxpZGF0b3JNZXNzYWdlO1xyXG4gIH1cclxuICBwdWJsaWMgZ2V0VG9vbHRpcE1lc3NhZ2UoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy50b29sdGlwTWVzc2FnZTtcclxuICB9XHJcbiAgcHVibGljIGdldFN1Ym1pdHRlZCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLnN1Ym1pdHRlZDtcclxuICB9XHJcbiAgcHVibGljIGdldFZhbGlkYXRvckFsZXJ0KCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMudmFsaWRhdG9yQWxlcnQ7XHJcbiAgfVxyXG4gIHB1YmxpYyBnZXRDb250cm9sQ2hhckNsZWFyUmVwbGFjZSgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLmNvbnRyb2xDaGFyQ2xlYXJSZXBsYWNlO1xyXG4gIH1cclxuICBwdWJsaWMgZ2V0UmVwbGFjZVJlZ2V4KCk6IHtba2V5OnN0cmluZ106IHN0cmluZ30ge1xyXG4gICAgcmV0dXJuIHRoaXMucmVwbGFjZVJlZ2V4O1xyXG4gIH1cclxuICBwdWJsaWMgZ2V0Q2xlYXJSZWdleCgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuY2xlYXJSZWdleDtcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,375 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, forwardRef } from '@angular/core';
2
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { isObservable } from 'rxjs';
4
+ import { shareReplay } from 'rxjs/operators';
5
+ import { SharedComponentsUtil } from '../utils/SharedComponentsUtil';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../utils/message-util.service";
8
+ import * as i2 from "./ng-select-multiple.service";
9
+ import * as i3 from "@angular/common";
10
+ import * as i4 from "@angular/forms";
11
+ import * as i5 from "../error-message/error-message.component";
12
+ import * as i6 from "../tooltip-message/tooltip-message.component";
13
+ import * as i7 from "@ng-select/ng-select";
14
+ import * as i8 from "@angular/material/checkbox";
15
+ import * as i9 from "@angular/material/tooltip";
16
+ export class NgSelectMultipleComponent {
17
+ constructor(cdrf, messageUtilService, ngSelectMultipleService) {
18
+ this.cdrf = cdrf;
19
+ this.messageUtilService = messageUtilService;
20
+ this.ngSelectMultipleService = ngSelectMultipleService;
21
+ this.onChange = (_) => { };
22
+ this.onTouched = () => { };
23
+ this.onValidationChange = () => { };
24
+ this.showlimit = 2;
25
+ this.showLabel = true;
26
+ this.label = null;
27
+ this.autocomplete = "no-autocomplete-ng-select";
28
+ this.Header = true;
29
+ this.Footer = true;
30
+ this.required = false;
31
+ this.disabled = false;
32
+ this.readonly = false;
33
+ this.openWhenFocus = false;
34
+ this.markFirst = false;
35
+ this.labelInfo = false;
36
+ this.textLabelInfo = '';
37
+ this.validatorMessage = false;
38
+ this.tooltipMessage = true;
39
+ this.validatorAlert = false;
40
+ this.submitted = true;
41
+ this.refresh = false;
42
+ this.isForFilter = true;
43
+ this.appendTo = "body";
44
+ this.Language = {
45
+ Selected: 'Seleccionados',
46
+ SelectAll: 'TODOS',
47
+ UnselectAll: 'NINGUNO',
48
+ All: 'TODOS'
49
+ };
50
+ this.virtualScroll = true;
51
+ this.loading = true;
52
+ this.loadingText = "Cargando...";
53
+ //EVENTS
54
+ this.onNext = new EventEmitter();
55
+ this.onBack = new EventEmitter();
56
+ this.change = new EventEmitter();
57
+ this.blur = new EventEmitter();
58
+ this.onfocus = new EventEmitter();
59
+ this.onrefresh = new EventEmitter();
60
+ this.sharedComponentsUtil = new SharedComponentsUtil();
61
+ this.checkedAll = false;
62
+ this.checkedIndeterminate = false;
63
+ this.subscriptions = [];
64
+ this.focus = () => {
65
+ this.ngSelectMultiple.focus();
66
+ if (this.openWhenFocus) {
67
+ this.ngSelectMultiple.open();
68
+ }
69
+ };
70
+ this.close = () => {
71
+ this.ngSelectMultiple.close();
72
+ };
73
+ this.showlimit = this.ngSelectMultipleService.getShowlimit();
74
+ this.Header = this.ngSelectMultipleService.getHeader();
75
+ this.Footer = this.ngSelectMultipleService.getFooter();
76
+ this.validatorMessage = this.ngSelectMultipleService.getValidatorMessage();
77
+ this.tooltipMessage = this.ngSelectMultipleService.getTooltipMessage();
78
+ this.openWhenFocus = this.ngSelectMultipleService.getOpenWhenFocus();
79
+ this.submitted = this.ngSelectMultipleService.getSubmitted();
80
+ this.validatorAlert = this.ngSelectMultipleService.getValidatorAlert();
81
+ this.appendTo = this.ngSelectMultipleService.getAppendTo();
82
+ this.loadingText = this.ngSelectMultipleService.getLoadingText();
83
+ this.markFirst = this.ngSelectMultipleService.getMarkFirst();
84
+ this.virtualScroll = this.ngSelectMultipleService.getVirtualScroll();
85
+ }
86
+ ngOnDestroy() {
87
+ this.subscriptions.forEach(s => s.unsubscribe());
88
+ }
89
+ validate(control) {
90
+ this.controls = control;
91
+ return null;
92
+ }
93
+ registerOnValidatorChange(fn) {
94
+ this.onValidationChange = fn;
95
+ }
96
+ ngOnChanges(changes) {
97
+ if (changes['items']) {
98
+ this.loading = true;
99
+ if (isObservable(this.items)) {
100
+ this.carga();
101
+ // this.setAll();
102
+ // this.items$ = this.items.pipe(finalize(() => {
103
+ // this.loading = false;
104
+ // this.cdrf.markForCheck();
105
+ // })).subscribe(res => {
106
+ // this.cdrf.markForCheck();
107
+ // })
108
+ }
109
+ else {
110
+ this.all = this.items;
111
+ this.loading = false;
112
+ }
113
+ }
114
+ if (changes['submitted']) {
115
+ if (this.controls !== undefined && changes['submitted'].currentValue) {
116
+ this.controls.markAsDirty();
117
+ this.controls.markAsTouched();
118
+ }
119
+ }
120
+ }
121
+ async carga() {
122
+ this.all = await new Promise((resolve, reject) => {
123
+ this.items = this.items.pipe(shareReplay({ refCount: true }));
124
+ const subscription = this.items.subscribe(res => {
125
+ resolve(res);
126
+ });
127
+ this.subscriptions.push(subscription);
128
+ });
129
+ this.loading = false;
130
+ }
131
+ checkIfObservable(items) {
132
+ if (isObservable(items))
133
+ return true;
134
+ else
135
+ return false;
136
+ }
137
+ eventFocus(e) {
138
+ this.onfocus.emit(e);
139
+ if (this.openWhenFocus) {
140
+ this.ngSelectMultiple.open();
141
+ }
142
+ }
143
+ eventBlur(e) {
144
+ this.onTouched();
145
+ this.onValidationChange();
146
+ this.blur.emit(e);
147
+ }
148
+ onRefresh() {
149
+ this.onrefresh.emit();
150
+ }
151
+ ngOnInit() {
152
+ if (isObservable(this.items)) {
153
+ //this.setAll();
154
+ }
155
+ else {
156
+ this.all = this.items;
157
+ }
158
+ }
159
+ setAll() {
160
+ const subscription = this.items.subscribe(res => {
161
+ this.all = res;
162
+ });
163
+ this.subscriptions.push(subscription);
164
+ }
165
+ writeValue(value) {
166
+ if (value) {
167
+ this._value = value;
168
+ }
169
+ else {
170
+ this._value = [];
171
+ }
172
+ }
173
+ registerOnChange(fn) {
174
+ this.onChange = fn;
175
+ }
176
+ registerOnTouched(fn) {
177
+ this.onTouched = fn;
178
+ }
179
+ setDisabledState(isDisabled) {
180
+ this.disabled = isDisabled;
181
+ }
182
+ selectAll(e) {
183
+ if (e.checked) {
184
+ this.writeValue(this.all);
185
+ if (this.isForFilter) {
186
+ this.onChange(null);
187
+ }
188
+ else {
189
+ this.onChange(this.all);
190
+ }
191
+ }
192
+ else {
193
+ this.writeValue([]);
194
+ this.onChange([]);
195
+ }
196
+ this.checkedIndeterminate = false;
197
+ this.ngSelectMultiple.focus();
198
+ this.cdrf.markForCheck;
199
+ }
200
+ eventChange(e) {
201
+ if (e.length == this.all.length) {
202
+ this.checkedAll = true;
203
+ this.checkedIndeterminate = false;
204
+ }
205
+ else if (e.length == 0) {
206
+ this.checkedAll = false;
207
+ this.checkedIndeterminate = false;
208
+ }
209
+ else {
210
+ this.checkedAll = false;
211
+ this.checkedIndeterminate = true;
212
+ }
213
+ this.writeValue(e);
214
+ this.onChange(e);
215
+ this.change.emit(e);
216
+ }
217
+ rightKeyUp() {
218
+ this.ngSelectMultiple.close();
219
+ if (!this.disabled) {
220
+ let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);
221
+ if (validator.error) {
222
+ this.messageUtilService.getMessageError("000046", "Error", validator.message);
223
+ return;
224
+ }
225
+ }
226
+ if (this.next != undefined) {
227
+ if (this.next.disabled || this.next.readonly) {
228
+ if (this.nextIsDisable != undefined) {
229
+ this.nextIsDisable.focus();
230
+ }
231
+ }
232
+ else {
233
+ this.next.focus();
234
+ }
235
+ }
236
+ else {
237
+ if (this.nextIsDisable != undefined) {
238
+ this.nextIsDisable.focus();
239
+ }
240
+ else {
241
+ this.onNext.emit();
242
+ }
243
+ }
244
+ }
245
+ leftKeyUp() {
246
+ this.ngSelectMultiple.close();
247
+ if (!this.disabled) {
248
+ let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);
249
+ if (validator.error) {
250
+ this.messageUtilService.getMessageError("000046", "Error", validator.message);
251
+ return;
252
+ }
253
+ }
254
+ if (this.back != undefined) {
255
+ if (this.back.disabled || this.back.readonly) {
256
+ if (this.backIsDisable != undefined) {
257
+ this.backIsDisable.focus();
258
+ }
259
+ }
260
+ else {
261
+ this.back.focus();
262
+ }
263
+ }
264
+ else {
265
+ if (this.backIsDisable != undefined) {
266
+ this.backIsDisable.focus();
267
+ }
268
+ else {
269
+ this.onBack.emit();
270
+ }
271
+ }
272
+ }
273
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: NgSelectMultipleComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.MessageUtilService }, { token: i2.NgSelectMultipleService }], target: i0.ɵɵFactoryTarget.Component }); }
274
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: NgSelectMultipleComponent, selector: "ng-select-multiple", inputs: { items: "items", showlimit: "showlimit", showLabel: "showLabel", label: "label", autocomplete: "autocomplete", Header: "Header", Footer: "Footer", required: "required", next: "next", nextIsDisable: "nextIsDisable", back: "back", backIsDisable: "backIsDisable", disabled: "disabled", readonly: "readonly", openWhenFocus: "openWhenFocus", markFirst: "markFirst", labelInfo: "labelInfo", textLabelInfo: "textLabelInfo", validatorMessage: "validatorMessage", tooltipMessage: "tooltipMessage", validatorAlert: "validatorAlert", submitted: "submitted", refresh: "refresh", isForFilter: "isForFilter", appendTo: "appendTo", Language: "Language", virtualScroll: "virtualScroll", loading: "loading", loadingText: "loadingText" }, outputs: { onNext: "onNext", onBack: "onBack", change: "change", blur: "blur", onfocus: "onfocus", onrefresh: "onrefresh" }, providers: [
275
+ {
276
+ provide: NG_VALUE_ACCESSOR,
277
+ useExisting: forwardRef(() => NgSelectMultipleComponent),
278
+ multi: true
279
+ },
280
+ {
281
+ provide: NG_VALIDATORS,
282
+ useExisting: forwardRef(() => NgSelectMultipleComponent),
283
+ multi: true,
284
+ }
285
+ ], viewQueries: [{ propertyName: "ngSelectMultiple", first: true, predicate: ["ngSelectMultiple"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"label != null && label != '' && showLabel\" class=\"d-flex sumax-label mb-0 p-0\"\r\n ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis\">{{ label }}</span>\r\n <span *ngIf=\"required\" class=\"ml-1\" [class.text-danger]=\"controls?.errors != null\"> *</span>\r\n <span *ngIf=\"labelInfo\">\r\n <i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n </span>\r\n</label>\r\n\r\n<div\r\n [class.input-icon]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n [class.refresh]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted && refresh\"\r\n [class.right]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n <div class=\"d-flex\">\r\n <div class=\"position-relative\" [class.app-ng-selec-container]=\"refresh\" [class.w-100]=\"!refresh\">\r\n <!-- tooltip-message es el icono de error -->\r\n <tooltip-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [submitted]=\"submitted\"\r\n [tooltipMessage]=\"tooltipMessage\"></tooltip-message>\r\n <ng-select\r\n #ngSelectMultiple\r\n [class]=\"refresh ? 'app-ng-select' : 'w-100'\"\r\n [items]=\"$any(checkIfObservable(items) ? (items | async) : items)\"\r\n [(ngModel)]=\"_value\"\r\n [readonly]=\"disabled || readonly\"\r\n (change)=\"eventChange($event)\"\r\n (focus)=\"eventFocus($event)\"\r\n (blur)=\"eventBlur($event)\"\r\n [virtualScroll]=\"virtualScroll\"\r\n [multiple]=\"true\"\r\n placeholder=\"Seleccionar\"\r\n [closeOnSelect]=\"false\"\r\n [appendTo]=\"appendTo\"\r\n [inputAttrs]=\"{ autocomplete: autocomplete }\"\r\n [markFirst]=\"markFirst\"\r\n (keyup.ArrowLeft)=\"leftKeyUp()\"\r\n (keyup.ArrowRight)=\"rightKeyUp()\"\r\n [loading]=\"loading\"\r\n [loadingText]=\"loadingText\"\r\n [clearSearchOnAdd]=\"true\"\r\n [class.ng-select-invalid]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n [class.ng-select-touched]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n <ng-template ng-header-tmp *ngIf=\"Header\">\r\n <mat-checkbox\r\n class=\"ng-multiselect-checkbox\"\r\n [color]=\"'primary'\"\r\n [(ngModel)]=\"checkedAll\"\r\n [indeterminate]=\"checkedIndeterminate\"\r\n (change)=\"selectAll($event)\">\r\n <span *ngIf=\"!checkedAll\">{{ Language.SelectAll }}</span>\r\n <span *ngIf=\"checkedAll\">{{ Language.UnselectAll }}</span>\r\n </mat-checkbox>\r\n </ng-template>\r\n\r\n <ng-template\r\n ng-multi-label-tmp\r\n let-items=\"items\"\r\n let-clear=\"clear\"\r\n *ngIf=\"$any(checkIfObservable(items) ? (items | async) : items)?.length != _value.length\">\r\n <div class=\"ng-value\" *ngFor=\"let item of items | slice: 0 : showlimit\">\r\n <span class=\"ng-value-label\"> {{ $any(item).label }}</span>\r\n <span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">\u00D7</span>\r\n </div>\r\n <div class=\"ng-value\" *ngIf=\"items.length > showlimit\">\r\n <span class=\"ng-value-label\">+{{ items.length - showlimit }}</span>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n <mat-checkbox class=\"ng-multiselect-checkbox\" id=\"item-{{ index }}\" color=\"primary\" [checked]=\"item$.selected\">\r\n <span data-toggle=\"tooltip\" title=\"{{ item.label }}\">{{ item.label }}</span>\r\n </mat-checkbox>\r\n </ng-template>\r\n\r\n <ng-template\r\n ng-multi-label-tmp\r\n let-items=\"items\"\r\n let-clear=\"clear\"\r\n *ngIf=\"$any(checkIfObservable(items) ? (items | async) : items)?.length == _value.length\">\r\n <div class=\"ng-value\">\r\n <span class=\"ng-value-label\">{{ Language.All }}</span>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template ng-footer-tmp *ngIf=\"Footer\"> {{ Language.Selected }}: {{ _value.length }} </ng-template>\r\n </ng-select>\r\n </div>\r\n <div class=\"app-ng-select-button bd-highlight\" *ngIf=\"refresh\">\r\n <button\r\n *ngIf=\"refresh\"\r\n type=\"button\"\r\n [disabled]=\"disabled || readonly\"\r\n class=\"btn btn-info p-0 rounded-0 h-100\"\r\n (click)=\"onRefresh()\">\r\n <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Refrescar'\" matTooltipClass=\"bg-info\">refresh</mat-icon> -->\r\n <i class=\"fa fa-refresh text-white px-1\" [matTooltip]=\"'Refrescar'\" matTooltipClass=\"bg-info\"></i>\r\n </button>\r\n </div>\r\n <ng-content select=\"[more-buttons]\"></ng-content>\r\n </div>\r\n</div>\r\n\r\n<!-- error-message es el mansaje que aparece abajo del componente -->\r\n<error-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [tooltipMessage]=\"tooltipMessage\"\r\n [submitted]=\"submitted\"></error-message>\r\n", styles: ["ng-select-simple{display:block}.sumax-label{color:#646c9a!important}.input-icon tooltip-message{color:#ccc;position:absolute;z-index:3;font-size:16px;text-align:center;right:9px;top:50%;transform:translateY(-50%)}.input-icon.right>.form-control{padding-right:33px;padding-left:12px}.upperCase .ng-select-container .ng-value-container .ng-input>input{text-transform:uppercase}.app-ng-select-button{width:34px}.app-ng-select-button button{width:100%}.app-ng-selec-container{width:calc(100% - 34px)}.app-ng-select-action{width:20%}.app-ng-select-action button{width:50%}.overflow-box{padding:5px;height:100px;border:1px solid #999;overflow:hidden}.ng-dropdown-panel{width:auto!important;max-width:550px;min-width:100%}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.errorMessageComponent, selector: "error-message", inputs: ["tooltipMessage", "validatorMessage", "controls", "label", "submitted"] }, { kind: "component", type: i6.tooltipMessageComponent, selector: "tooltip-message", inputs: ["tooltipMessage", "validatorMessage", "controls", "label", "submitted"] }, { kind: "component", type: i7.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i7.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "directive", type: i7.NgMultiLabelTemplateDirective, selector: "[ng-multi-label-tmp]" }, { kind: "directive", type: i7.NgHeaderTemplateDirective, selector: "[ng-header-tmp]" }, { kind: "directive", type: i7.NgFooterTemplateDirective, selector: "[ng-footer-tmp]" }, { kind: "component", type: i8.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.SlicePipe, name: "slice" }] }); }
286
+ }
287
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: NgSelectMultipleComponent, decorators: [{
288
+ type: Component,
289
+ args: [{ selector: 'ng-select-multiple', providers: [
290
+ {
291
+ provide: NG_VALUE_ACCESSOR,
292
+ useExisting: forwardRef(() => NgSelectMultipleComponent),
293
+ multi: true
294
+ },
295
+ {
296
+ provide: NG_VALIDATORS,
297
+ useExisting: forwardRef(() => NgSelectMultipleComponent),
298
+ multi: true,
299
+ }
300
+ ], template: "<label *ngIf=\"label != null && label != '' && showLabel\" class=\"d-flex sumax-label mb-0 p-0\"\r\n ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis\">{{ label }}</span>\r\n <span *ngIf=\"required\" class=\"ml-1\" [class.text-danger]=\"controls?.errors != null\"> *</span>\r\n <span *ngIf=\"labelInfo\">\r\n <i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n </span>\r\n</label>\r\n\r\n<div\r\n [class.input-icon]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n [class.refresh]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted && refresh\"\r\n [class.right]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n <div class=\"d-flex\">\r\n <div class=\"position-relative\" [class.app-ng-selec-container]=\"refresh\" [class.w-100]=\"!refresh\">\r\n <!-- tooltip-message es el icono de error -->\r\n <tooltip-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [submitted]=\"submitted\"\r\n [tooltipMessage]=\"tooltipMessage\"></tooltip-message>\r\n <ng-select\r\n #ngSelectMultiple\r\n [class]=\"refresh ? 'app-ng-select' : 'w-100'\"\r\n [items]=\"$any(checkIfObservable(items) ? (items | async) : items)\"\r\n [(ngModel)]=\"_value\"\r\n [readonly]=\"disabled || readonly\"\r\n (change)=\"eventChange($event)\"\r\n (focus)=\"eventFocus($event)\"\r\n (blur)=\"eventBlur($event)\"\r\n [virtualScroll]=\"virtualScroll\"\r\n [multiple]=\"true\"\r\n placeholder=\"Seleccionar\"\r\n [closeOnSelect]=\"false\"\r\n [appendTo]=\"appendTo\"\r\n [inputAttrs]=\"{ autocomplete: autocomplete }\"\r\n [markFirst]=\"markFirst\"\r\n (keyup.ArrowLeft)=\"leftKeyUp()\"\r\n (keyup.ArrowRight)=\"rightKeyUp()\"\r\n [loading]=\"loading\"\r\n [loadingText]=\"loadingText\"\r\n [clearSearchOnAdd]=\"true\"\r\n [class.ng-select-invalid]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n [class.ng-select-touched]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n <ng-template ng-header-tmp *ngIf=\"Header\">\r\n <mat-checkbox\r\n class=\"ng-multiselect-checkbox\"\r\n [color]=\"'primary'\"\r\n [(ngModel)]=\"checkedAll\"\r\n [indeterminate]=\"checkedIndeterminate\"\r\n (change)=\"selectAll($event)\">\r\n <span *ngIf=\"!checkedAll\">{{ Language.SelectAll }}</span>\r\n <span *ngIf=\"checkedAll\">{{ Language.UnselectAll }}</span>\r\n </mat-checkbox>\r\n </ng-template>\r\n\r\n <ng-template\r\n ng-multi-label-tmp\r\n let-items=\"items\"\r\n let-clear=\"clear\"\r\n *ngIf=\"$any(checkIfObservable(items) ? (items | async) : items)?.length != _value.length\">\r\n <div class=\"ng-value\" *ngFor=\"let item of items | slice: 0 : showlimit\">\r\n <span class=\"ng-value-label\"> {{ $any(item).label }}</span>\r\n <span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">\u00D7</span>\r\n </div>\r\n <div class=\"ng-value\" *ngIf=\"items.length > showlimit\">\r\n <span class=\"ng-value-label\">+{{ items.length - showlimit }}</span>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n <mat-checkbox class=\"ng-multiselect-checkbox\" id=\"item-{{ index }}\" color=\"primary\" [checked]=\"item$.selected\">\r\n <span data-toggle=\"tooltip\" title=\"{{ item.label }}\">{{ item.label }}</span>\r\n </mat-checkbox>\r\n </ng-template>\r\n\r\n <ng-template\r\n ng-multi-label-tmp\r\n let-items=\"items\"\r\n let-clear=\"clear\"\r\n *ngIf=\"$any(checkIfObservable(items) ? (items | async) : items)?.length == _value.length\">\r\n <div class=\"ng-value\">\r\n <span class=\"ng-value-label\">{{ Language.All }}</span>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template ng-footer-tmp *ngIf=\"Footer\"> {{ Language.Selected }}: {{ _value.length }} </ng-template>\r\n </ng-select>\r\n </div>\r\n <div class=\"app-ng-select-button bd-highlight\" *ngIf=\"refresh\">\r\n <button\r\n *ngIf=\"refresh\"\r\n type=\"button\"\r\n [disabled]=\"disabled || readonly\"\r\n class=\"btn btn-info p-0 rounded-0 h-100\"\r\n (click)=\"onRefresh()\">\r\n <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Refrescar'\" matTooltipClass=\"bg-info\">refresh</mat-icon> -->\r\n <i class=\"fa fa-refresh text-white px-1\" [matTooltip]=\"'Refrescar'\" matTooltipClass=\"bg-info\"></i>\r\n </button>\r\n </div>\r\n <ng-content select=\"[more-buttons]\"></ng-content>\r\n </div>\r\n</div>\r\n\r\n<!-- error-message es el mansaje que aparece abajo del componente -->\r\n<error-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [tooltipMessage]=\"tooltipMessage\"\r\n [submitted]=\"submitted\"></error-message>\r\n", styles: ["ng-select-simple{display:block}.sumax-label{color:#646c9a!important}.input-icon tooltip-message{color:#ccc;position:absolute;z-index:3;font-size:16px;text-align:center;right:9px;top:50%;transform:translateY(-50%)}.input-icon.right>.form-control{padding-right:33px;padding-left:12px}.upperCase .ng-select-container .ng-value-container .ng-input>input{text-transform:uppercase}.app-ng-select-button{width:34px}.app-ng-select-button button{width:100%}.app-ng-selec-container{width:calc(100% - 34px)}.app-ng-select-action{width:20%}.app-ng-select-action button{width:50%}.overflow-box{padding:5px;height:100px;border:1px solid #999;overflow:hidden}.ng-dropdown-panel{width:auto!important;max-width:550px;min-width:100%}\n"] }]
301
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.MessageUtilService }, { type: i2.NgSelectMultipleService }], propDecorators: { ngSelectMultiple: [{
302
+ type: ViewChild,
303
+ args: ['ngSelectMultiple']
304
+ }], items: [{
305
+ type: Input
306
+ }], showlimit: [{
307
+ type: Input
308
+ }], showLabel: [{
309
+ type: Input
310
+ }], label: [{
311
+ type: Input
312
+ }], autocomplete: [{
313
+ type: Input
314
+ }], Header: [{
315
+ type: Input
316
+ }], Footer: [{
317
+ type: Input
318
+ }], required: [{
319
+ type: Input
320
+ }], next: [{
321
+ type: Input
322
+ }], nextIsDisable: [{
323
+ type: Input
324
+ }], back: [{
325
+ type: Input
326
+ }], backIsDisable: [{
327
+ type: Input
328
+ }], disabled: [{
329
+ type: Input
330
+ }], readonly: [{
331
+ type: Input
332
+ }], openWhenFocus: [{
333
+ type: Input
334
+ }], markFirst: [{
335
+ type: Input
336
+ }], labelInfo: [{
337
+ type: Input
338
+ }], textLabelInfo: [{
339
+ type: Input
340
+ }], validatorMessage: [{
341
+ type: Input
342
+ }], tooltipMessage: [{
343
+ type: Input
344
+ }], validatorAlert: [{
345
+ type: Input
346
+ }], submitted: [{
347
+ type: Input
348
+ }], refresh: [{
349
+ type: Input
350
+ }], isForFilter: [{
351
+ type: Input
352
+ }], appendTo: [{
353
+ type: Input
354
+ }], Language: [{
355
+ type: Input
356
+ }], virtualScroll: [{
357
+ type: Input
358
+ }], loading: [{
359
+ type: Input
360
+ }], loadingText: [{
361
+ type: Input
362
+ }], onNext: [{
363
+ type: Output
364
+ }], onBack: [{
365
+ type: Output
366
+ }], change: [{
367
+ type: Output
368
+ }], blur: [{
369
+ type: Output
370
+ }], onfocus: [{
371
+ type: Output
372
+ }], onrefresh: [{
373
+ type: Output
374
+ }] } });
375
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-select-multiple.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sumax-erp-component/src/lib/ng-select-multiple/ng-select-multiple.component.ts","../../../../../projects/ngx-sumax-erp-component/src/lib/ng-select-multiple/ng-select-multiple.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, ViewChild, forwardRef } from '@angular/core';\r\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { Observable, Subscription, isObservable } from 'rxjs';\r\nimport { shareReplay } from 'rxjs/operators';\r\nimport { NgSelectMultipleService } from './ng-select-multiple.service';\r\nimport { SharedComponentsUtil } from '../utils/SharedComponentsUtil';\r\nimport { MessageUtilService } from '../utils/message-util.service';\r\n\r\n@Component({\r\n  selector: 'ng-select-multiple',\r\n  templateUrl: './ng-select-multiple.component.html',\r\n  styleUrls: ['./ng-select-multiple.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => NgSelectMultipleComponent),\r\n      multi: true\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => NgSelectMultipleComponent),\r\n      multi: true,\r\n    }\r\n  ]\r\n})\r\nexport class NgSelectMultipleComponent implements OnInit, OnChanges, OnDestroy {\r\n\r\n\r\n  @ViewChild('ngSelectMultiple') ngSelectMultiple!: NgSelectComponent;\r\n\r\n  onChange = (_: any) => { };\r\n  onTouched = () => { };\r\n  onValidationChange = () => { };\r\n\r\n  @Input() items!: Observable<any[]>;\r\n  @Input() showlimit: number = 2;\r\n  @Input() showLabel: boolean = true;\r\n  @Input() label: any = null;\r\n  @Input() autocomplete: string = \"no-autocomplete-ng-select\";\r\n  @Input() Header: boolean = true;\r\n  @Input() Footer: boolean = true;\r\n  @Input() required: boolean = false;\r\n  @Input() next: any;\r\n  @Input() nextIsDisable: any;\r\n  @Input() back: any;\r\n  @Input() backIsDisable: any;\r\n  @Input() disabled: boolean = false;\r\n  @Input() readonly: boolean = false;\r\n  @Input() openWhenFocus: boolean = false;\r\n  @Input() markFirst: boolean = false;\r\n  @Input() labelInfo: boolean = false;\r\n  @Input() textLabelInfo: string = '';\r\n  @Input() validatorMessage: boolean = false;\r\n  @Input() tooltipMessage: boolean = true;\r\n  @Input() validatorAlert: boolean = false;\r\n  @Input() submitted: boolean = true;\r\n  @Input() refresh: boolean = false;\r\n  @Input() isForFilter: boolean = true;\r\n  @Input() appendTo: any = \"body\"\r\n  @Input() Language: any = {\r\n    Selected: 'Seleccionados',\r\n    SelectAll: 'TODOS',\r\n    UnselectAll: 'NINGUNO',\r\n    All: 'TODOS'\r\n  };\r\n  @Input() virtualScroll: boolean = true;\r\n\r\n  @Input() loading: boolean = true;\r\n  @Input() loadingText: string = \"Cargando...\";\r\n\r\n  //EVENTS\r\n  @Output() onNext: EventEmitter<any> = new EventEmitter();\r\n  @Output() onBack: EventEmitter<any> = new EventEmitter();\r\n  @Output() change: EventEmitter<any> = new EventEmitter();\r\n  @Output() blur: EventEmitter<any> = new EventEmitter();\r\n  @Output() onfocus: EventEmitter<any> = new EventEmitter();\r\n  @Output() onrefresh: EventEmitter<any> = new EventEmitter();\r\n  sharedComponentsUtil = new SharedComponentsUtil();\r\n\r\n  _value: any;\r\n  controls: any;\r\n  all: any;\r\n  checkedAll = false;\r\n  checkedIndeterminate = false;\r\n\r\n  private subscriptions: Subscription[] = [];\r\n\r\n  constructor(\r\n    private cdrf: ChangeDetectorRef,\r\n    private messageUtilService: MessageUtilService,\r\n    private ngSelectMultipleService: NgSelectMultipleService\r\n  ) {\r\n    this.showlimit = this.ngSelectMultipleService.getShowlimit();\r\n    this.Header = this.ngSelectMultipleService.getHeader();\r\n    this.Footer = this.ngSelectMultipleService.getFooter();\r\n    this.validatorMessage = this.ngSelectMultipleService.getValidatorMessage();\r\n    this.tooltipMessage = this.ngSelectMultipleService.getTooltipMessage();\r\n    this.openWhenFocus = this.ngSelectMultipleService.getOpenWhenFocus();\r\n    this.submitted = this.ngSelectMultipleService.getSubmitted();\r\n    this.validatorAlert = this.ngSelectMultipleService.getValidatorAlert();\r\n    this.appendTo = this.ngSelectMultipleService.getAppendTo();\r\n    this.loadingText = this.ngSelectMultipleService.getLoadingText();\r\n    this.markFirst = this.ngSelectMultipleService.getMarkFirst();\r\n    this.virtualScroll = this.ngSelectMultipleService.getVirtualScroll();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.forEach(s => s.unsubscribe());\r\n  }\r\n\r\n  validate(control: AbstractControl): ValidationErrors | any {\r\n    this.controls = control;\r\n    return null;\r\n  }\r\n\r\n  registerOnValidatorChange?(fn: () => void): void {\r\n    this.onValidationChange = fn;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['items']) {\r\n      this.loading = true;\r\n      if (isObservable(this.items)) {\r\n        this.carga();\r\n        // this.setAll();\r\n        // this.items$ = this.items.pipe(finalize(() => {\r\n        //   this.loading = false;\r\n        //   this.cdrf.markForCheck();\r\n        // })).subscribe(res => {\r\n        //   this.cdrf.markForCheck();\r\n        // })\r\n      } else {\r\n        this.all = this.items;\r\n        this.loading = false;\r\n      }\r\n    }\r\n    if (changes['submitted']) {\r\n      if (this.controls !== undefined && changes['submitted'].currentValue) {\r\n        this.controls.markAsDirty();\r\n        this.controls.markAsTouched();\r\n      }\r\n    }\r\n  }\r\n\r\n  async carga() {\r\n    this.all = await new Promise((resolve, reject) => {\r\n      this.items = this.items.pipe(shareReplay({ refCount: true }));\r\n      const subscription = this.items.subscribe(res => {\r\n        resolve(res);\r\n      });\r\n      this.subscriptions.push(subscription);\r\n    });\r\n    this.loading = false;\r\n  }\r\n\r\n  checkIfObservable(items: any) {\r\n    if (isObservable(items))\r\n      return true;\r\n    else\r\n      return false;\r\n  }\r\n\r\n  eventFocus(e: any) {\r\n    this.onfocus.emit(e);\r\n    if (this.openWhenFocus) {\r\n      this.ngSelectMultiple.open();\r\n    }\r\n  }\r\n\r\n  eventBlur(e: any) {\r\n    this.onTouched();\r\n    this.onValidationChange();\r\n    this.blur.emit(e);\r\n  }\r\n\r\n  focus = () => {\r\n    this.ngSelectMultiple.focus();\r\n    if (this.openWhenFocus) {\r\n      this.ngSelectMultiple.open();\r\n    }\r\n  }\r\n  onRefresh() {\r\n    this.onrefresh.emit();\r\n  }\r\n\r\n  close = () => {\r\n    this.ngSelectMultiple.close();\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n    if (isObservable(this.items)) {\r\n      //this.setAll();\r\n    }\r\n    else {\r\n      this.all = this.items;\r\n    }\r\n  }\r\n  setAll() {\r\n    const subscription = this.items.subscribe(res => {\r\n      this.all = res;\r\n    });\r\n    this.subscriptions.push(subscription);\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (value) {\r\n      this._value = value;\r\n    } else {\r\n      this._value = [];\r\n    }\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  selectAll(e: any) {\r\n    if (e.checked) {\r\n      this.writeValue(this.all);\r\n      if(this.isForFilter){\r\n        this.onChange(null);\r\n      }else{\r\n        this.onChange(this.all);\r\n      }\r\n    } else {\r\n      this.writeValue([]);\r\n      this.onChange([]);\r\n    }\r\n    this.checkedIndeterminate = false;\r\n    this.ngSelectMultiple.focus();\r\n    this.cdrf.markForCheck;\r\n  }\r\n\r\n  eventChange(e: any) {\r\n    if (e.length == this.all.length) {\r\n      this.checkedAll = true;\r\n      this.checkedIndeterminate = false;\r\n    } else if (e.length == 0) {\r\n      this.checkedAll = false;\r\n      this.checkedIndeterminate = false;\r\n    } else {\r\n      this.checkedAll = false;\r\n      this.checkedIndeterminate = true;\r\n    }\r\n    this.writeValue(e);\r\n    this.onChange(e);\r\n    this.change.emit(e);\r\n\r\n  }\r\n\r\n  rightKeyUp() {\r\n    this.ngSelectMultiple.close();\r\n    if (!this.disabled) {\r\n      let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);\r\n      if (validator.error) {\r\n        this.messageUtilService.getMessageError(\"000046\", \"Error\", validator.message);\r\n        return;\r\n      }\r\n    }\r\n    if (this.next != undefined) {\r\n      if (this.next.disabled || this.next.readonly) {\r\n        if (this.nextIsDisable != undefined) {\r\n          this.nextIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.next.focus();\r\n      }\r\n    } else {\r\n      if (this.nextIsDisable != undefined) {\r\n        this.nextIsDisable.focus();\r\n      } else {\r\n        this.onNext.emit();\r\n      }\r\n    }\r\n  }\r\n\r\n  leftKeyUp() {\r\n    this.ngSelectMultiple.close();\r\n    if (!this.disabled) {\r\n      let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);\r\n      if (validator.error) {\r\n        this.messageUtilService.getMessageError(\"000046\", \"Error\", validator.message);\r\n        return;\r\n      }\r\n    }\r\n    if (this.back != undefined) {\r\n      if (this.back.disabled || this.back.readonly) {\r\n        if (this.backIsDisable != undefined) {\r\n          this.backIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.back.focus();\r\n      }\r\n    } else {\r\n      if (this.backIsDisable != undefined) {\r\n        this.backIsDisable.focus();\r\n      } else {\r\n        this.onBack.emit();\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n","<label *ngIf=\"label != null && label != '' && showLabel\" class=\"d-flex sumax-label mb-0 p-0\"\r\n  ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis\">{{ label }}</span>\r\n  <span *ngIf=\"required\" class=\"ml-1\" [class.text-danger]=\"controls?.errors != null\"> *</span>\r\n  <span *ngIf=\"labelInfo\">\r\n    <i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n  </span>\r\n</label>\r\n\r\n<div\r\n  [class.input-icon]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n  [class.refresh]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted && refresh\"\r\n  [class.right]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n  <div class=\"d-flex\">\r\n    <div class=\"position-relative\" [class.app-ng-selec-container]=\"refresh\" [class.w-100]=\"!refresh\">\r\n      <!-- tooltip-message es el icono de error -->\r\n      <tooltip-message\r\n        [label]=\"label\"\r\n        [controls]=\"controls\"\r\n        [validatorMessage]=\"validatorMessage\"\r\n        [submitted]=\"submitted\"\r\n        [tooltipMessage]=\"tooltipMessage\"></tooltip-message>\r\n      <ng-select\r\n        #ngSelectMultiple\r\n        [class]=\"refresh ? 'app-ng-select' : 'w-100'\"\r\n        [items]=\"$any(checkIfObservable(items) ? (items | async) : items)\"\r\n        [(ngModel)]=\"_value\"\r\n        [readonly]=\"disabled || readonly\"\r\n        (change)=\"eventChange($event)\"\r\n        (focus)=\"eventFocus($event)\"\r\n        (blur)=\"eventBlur($event)\"\r\n        [virtualScroll]=\"virtualScroll\"\r\n        [multiple]=\"true\"\r\n        placeholder=\"Seleccionar\"\r\n        [closeOnSelect]=\"false\"\r\n        [appendTo]=\"appendTo\"\r\n        [inputAttrs]=\"{ autocomplete: autocomplete }\"\r\n        [markFirst]=\"markFirst\"\r\n        (keyup.ArrowLeft)=\"leftKeyUp()\"\r\n        (keyup.ArrowRight)=\"rightKeyUp()\"\r\n        [loading]=\"loading\"\r\n        [loadingText]=\"loadingText\"\r\n        [clearSearchOnAdd]=\"true\"\r\n        [class.ng-select-invalid]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n        [class.ng-select-touched]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n        <ng-template ng-header-tmp *ngIf=\"Header\">\r\n          <mat-checkbox\r\n            class=\"ng-multiselect-checkbox\"\r\n            [color]=\"'primary'\"\r\n            [(ngModel)]=\"checkedAll\"\r\n            [indeterminate]=\"checkedIndeterminate\"\r\n            (change)=\"selectAll($event)\">\r\n            <span *ngIf=\"!checkedAll\">{{ Language.SelectAll }}</span>\r\n            <span *ngIf=\"checkedAll\">{{ Language.UnselectAll }}</span>\r\n          </mat-checkbox>\r\n        </ng-template>\r\n\r\n        <ng-template\r\n          ng-multi-label-tmp\r\n          let-items=\"items\"\r\n          let-clear=\"clear\"\r\n          *ngIf=\"$any(checkIfObservable(items) ? (items | async) : items)?.length != _value.length\">\r\n          <div class=\"ng-value\" *ngFor=\"let item of items | slice: 0 : showlimit\">\r\n            <span class=\"ng-value-label\"> {{ $any(item).label }}</span>\r\n            <span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n          </div>\r\n          <div class=\"ng-value\" *ngIf=\"items.length > showlimit\">\r\n            <span class=\"ng-value-label\">+{{ items.length - showlimit }}</span>\r\n          </div>\r\n        </ng-template>\r\n\r\n        <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n          <mat-checkbox class=\"ng-multiselect-checkbox\" id=\"item-{{ index }}\" color=\"primary\" [checked]=\"item$.selected\">\r\n            <span data-toggle=\"tooltip\" title=\"{{ item.label }}\">{{ item.label }}</span>\r\n          </mat-checkbox>\r\n        </ng-template>\r\n\r\n        <ng-template\r\n          ng-multi-label-tmp\r\n          let-items=\"items\"\r\n          let-clear=\"clear\"\r\n          *ngIf=\"$any(checkIfObservable(items) ? (items | async) : items)?.length == _value.length\">\r\n          <div class=\"ng-value\">\r\n            <span class=\"ng-value-label\">{{ Language.All }}</span>\r\n          </div>\r\n        </ng-template>\r\n\r\n        <ng-template ng-footer-tmp *ngIf=\"Footer\"> {{ Language.Selected }}: {{ _value.length }} </ng-template>\r\n      </ng-select>\r\n    </div>\r\n    <div class=\"app-ng-select-button bd-highlight\" *ngIf=\"refresh\">\r\n      <button\r\n        *ngIf=\"refresh\"\r\n        type=\"button\"\r\n        [disabled]=\"disabled || readonly\"\r\n        class=\"btn btn-info p-0 rounded-0 h-100\"\r\n        (click)=\"onRefresh()\">\r\n        <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Refrescar'\" matTooltipClass=\"bg-info\">refresh</mat-icon> -->\r\n        <i class=\"fa fa-refresh text-white px-1\" [matTooltip]=\"'Refrescar'\" matTooltipClass=\"bg-info\"></i>\r\n      </button>\r\n    </div>\r\n    <ng-content select=\"[more-buttons]\"></ng-content>\r\n  </div>\r\n</div>\r\n\r\n<!-- error-message es el mansaje que aparece abajo del componente -->\r\n<error-message\r\n  [label]=\"label\"\r\n  [controls]=\"controls\"\r\n  [validatorMessage]=\"validatorMessage\"\r\n  [tooltipMessage]=\"tooltipMessage\"\r\n  [submitted]=\"submitted\"></error-message>\r\n"]}
@@ -0,0 +1,3 @@
1
+ export class NgSelectMultiple {
2
+ }
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctc2VsZWN0LW11bHRpcGxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXN1bWF4LWVycC1jb21wb25lbnQvc3JjL2xpYi9uZy1zZWxlY3QtbXVsdGlwbGUvbmctc2VsZWN0LW11bHRpcGxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxnQkFBZ0I7Q0FhNUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgTmdTZWxlY3RNdWx0aXBsZSB7XHJcbiAgc2hvd2xpbWl0PzogbnVtYmVyO1xyXG4gIEhlYWRlcj86IGJvb2xlYW47XHJcbiAgRm9vdGVyPzogYm9vbGVhbjtcclxuICB2YWxpZGF0b3JNZXNzYWdlPzogYm9vbGVhbjtcclxuICB0b29sdGlwTWVzc2FnZT86IGJvb2xlYW47XHJcbiAgb3BlbldoZW5Gb2N1cz86IGJvb2xlYW47XHJcbiAgc3VibWl0dGVkPzogYm9vbGVhbjtcclxuICB2YWxpZGF0b3JBbGVydD86IGJvb2xlYW47XHJcbiAgYXBwZW5kVG8/OiBzdHJpbmc7XHJcbiAgbG9hZGluZ1RleHQ/OiBzdHJpbmc7XHJcbiAgbWFya0ZpcnN0PzogYm9vbGVhbjtcclxuICB2aXJ0dWFsU2Nyb2xsPzogYm9vbGVhbjtcclxufVxyXG4iXX0=