awing-library 2.1.146-beta → 2.1.146

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 (213) hide show
  1. package/lib/ACM-AXN/AuthenticationProfile/Container.js +4 -4
  2. package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.js +2 -2
  3. package/lib/ACM-AXN/Campaign/Container.js +52 -54
  4. package/lib/ACM-AXN/Campaign/Container.test.js +1 -3
  5. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.d.ts +8 -1
  6. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.js +27 -3
  7. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.d.ts +17 -0
  8. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.js +121 -0
  9. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.d.ts +1 -0
  10. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.js +219 -0
  11. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.d.ts +2 -0
  12. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.js +306 -0
  13. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.d.ts +1 -0
  14. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.js +230 -0
  15. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.d.ts +1 -0
  16. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.js +123 -0
  17. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.d.ts +1 -0
  18. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.js +253 -0
  19. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabInfomation.js +21 -5
  20. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.d.ts +1 -1
  21. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.js +47 -78
  22. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.d.ts +2 -1
  23. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +2 -2
  24. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.js +2 -1
  25. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.js +2 -1
  26. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +19 -42
  27. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +298 -96
  28. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +3 -0
  29. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +119 -54
  30. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +1 -1
  31. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +46 -8
  32. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +8 -6
  33. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +1 -1
  34. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.d.ts +9 -0
  35. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.js +56 -0
  36. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +5 -1
  37. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.d.ts +12 -0
  38. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +23 -8
  39. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.js +3 -3
  40. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +63 -12
  41. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +1 -0
  42. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +17 -4
  43. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +10 -0
  44. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +4 -1
  45. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +1 -0
  46. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +3 -2
  47. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +6 -2
  48. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +31 -29
  49. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +1 -1
  50. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +1 -1
  51. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetOS/container.js +2 -2
  52. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +1 -1
  53. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +5 -5
  54. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +44 -33
  55. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +3 -13
  56. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +45 -20
  57. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +3 -2
  58. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +3 -2
  59. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
  60. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +5 -1
  61. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +172 -59
  62. package/lib/ACM-AXN/Campaign/Enum.d.ts +24 -6
  63. package/lib/ACM-AXN/Campaign/Enum.js +30 -11
  64. package/lib/ACM-AXN/Campaign/Types.d.ts +53 -5
  65. package/lib/ACM-AXN/Campaign/Utils.d.ts +6 -1
  66. package/lib/ACM-AXN/Campaign/Utils.js +50 -3
  67. package/lib/ACM-AXN/Campaign/index.js +2 -2
  68. package/lib/ACM-AXN/CampaignPlan/Container.js +4 -6
  69. package/lib/ACM-AXN/CampaignPlan/Detail.js +3 -3
  70. package/lib/ACM-AXN/CampaignPlan/Filter.js +3 -3
  71. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +14 -10
  72. package/lib/ACM-AXN/CampaignSchedule/Components/EnhancedPagination/index.js +3 -2
  73. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +5 -7
  74. package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +4 -4
  75. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +5 -4
  76. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +1 -2
  77. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +1 -5
  78. package/lib/ACM-AXN/Common/Constant.d.ts +3 -0
  79. package/lib/ACM-AXN/Common/Constant.js +2 -0
  80. package/lib/ACM-AXN/Common/Enum.d.ts +8 -3
  81. package/lib/ACM-AXN/Common/Enum.js +19 -4
  82. package/lib/ACM-AXN/Common/Types.d.ts +5 -0
  83. package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
  84. package/lib/ACM-AXN/GeoFencing/component.js +7 -7
  85. package/lib/ACM-AXN/GeoFencing/interface.d.ts +1 -2
  86. package/lib/ACM-AXN/Holiday/FormHoliday.js +1 -0
  87. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.d.ts +0 -5
  88. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +7 -90
  89. package/lib/ACM-AXN/Notifications/NotificationPopover/index.d.ts +0 -5
  90. package/lib/ACM-AXN/Notifications/Types.d.ts +2 -0
  91. package/lib/ACM-AXN/Page/Constant.js +2 -0
  92. package/lib/ACM-AXN/Page/Container.js +3 -3
  93. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.d.ts +6 -0
  94. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.js +63 -0
  95. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.d.ts +11 -2
  96. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +16 -12
  97. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/TrackingCode.js +1 -1
  98. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/Utils.js +1 -1
  99. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/index.js +1 -0
  100. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.d.ts +1 -9
  101. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.js +0 -9
  102. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewContent.js +11 -44
  103. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
  104. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +39 -61
  105. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +29 -32
  106. package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +6 -6
  107. package/lib/ACM-AXN/Page/CreateOrEdit/index.js +19 -4
  108. package/lib/ACM-AXN/Page/Import/index.js +2 -2
  109. package/lib/ACM-AXN/Page/Types.d.ts +3 -0
  110. package/lib/ACM-AXN/Page/enums.d.ts +5 -0
  111. package/lib/ACM-AXN/Page/enums.js +7 -1
  112. package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
  113. package/lib/ACM-AXN/PlaceFilter/DataTable/component/index.js +2 -5
  114. package/lib/ACM-AXN/PlaceFilter/Input/component/index.js +1 -2
  115. package/lib/ACM-AXN/PlaceFilter/Tag/component/TagChip.js +1 -1
  116. package/lib/ACM-AXN/PlaceFilter/interface.d.ts +1 -0
  117. package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +16 -16
  118. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +14 -9
  119. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +19 -18
  120. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +16 -6
  121. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +17 -10
  122. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
  123. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +30 -51
  124. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
  125. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
  126. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
  127. package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +16 -36
  128. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +5 -5
  129. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +13 -10
  130. package/lib/ACM-AXN/Statistics/ControlPanel.js +17 -5
  131. package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
  132. package/lib/ACM-AXN/Statistics/Enums.js +1 -0
  133. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +1 -0
  134. package/lib/ACM-AXN/StatisticsByProvince/DataTable.js +1 -1
  135. package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +4 -4
  136. package/lib/ACM-AXN/Template/Container.js +2 -2
  137. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
  138. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
  139. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +2 -2
  140. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +56 -37
  141. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
  142. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
  143. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
  144. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
  145. package/lib/ACM-AXN/Template/CreateOrEdit/index.js +8 -4
  146. package/lib/ACM-AXN/Template/Import.js +2 -2
  147. package/lib/ACM-AXN/Template/Types.d.ts +9 -9
  148. package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
  149. package/lib/ACM-AXN/ViewTemplate/Preview.js +5 -6
  150. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +23 -11
  151. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
  152. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
  153. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +42 -129
  154. package/lib/ACM-AXN/ViewTemplate/common.d.ts +2 -1
  155. package/lib/ACM-AXN/ViewTemplate/common.js +47 -7
  156. package/lib/ACM-AXN/ViewTemplate/container.js +8 -2
  157. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +3 -1
  158. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +18 -28
  159. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +2 -0
  160. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +1 -1
  161. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +17 -1
  162. package/lib/ACM-AXN/index.d.ts +1 -0
  163. package/lib/ACM-AXN/index.js +1 -0
  164. package/lib/AWING/AsyncAutocomplete/index.js +2 -2
  165. package/lib/AWING/BasicDataForm/BasicDataForm.js +9 -6
  166. package/lib/AWING/BasicDataForm/interface.d.ts +3 -0
  167. package/lib/AWING/Chart/BarLineComponent.js +20 -24
  168. package/lib/AWING/Chart/PieComponent.d.ts +3 -4
  169. package/lib/AWING/Chart/PieComponent.js +16 -16
  170. package/lib/AWING/Chart/Styles.js +51 -16
  171. package/lib/AWING/DataForm/DataInput.js +105 -23
  172. package/lib/AWING/DataForm/interface.d.ts +2 -0
  173. package/lib/AWING/DataGrid/index.js +8 -13
  174. package/lib/AWING/DateRangePicker/component.js +80 -32
  175. package/lib/AWING/DateRangePicker/configDate.d.ts +1 -2
  176. package/lib/AWING/DateRangePicker/configDate.js +12 -12
  177. package/lib/AWING/DateRangePicker/interface.d.ts +1 -0
  178. package/lib/AWING/Form/useForm.js +3 -2
  179. package/lib/AWING/GoogleMap/GGMap.d.ts +3 -0
  180. package/lib/AWING/GoogleMap/GGMap.js +256 -0
  181. package/lib/AWING/GoogleMap/index.d.ts +4 -0
  182. package/lib/AWING/GoogleMap/index.js +41 -0
  183. package/lib/AWING/GoogleMap/interface.d.ts +21 -0
  184. package/lib/AWING/GoogleMap/interface.js +2 -0
  185. package/lib/AWING/GoogleMap/utils.d.ts +25 -0
  186. package/lib/AWING/GoogleMap/utils.js +135 -0
  187. package/lib/AWING/GroupTable/GroupTable.js +2 -2
  188. package/lib/AWING/GroupTable/component.d.ts +1 -0
  189. package/lib/AWING/GroupTable/component.js +2 -2
  190. package/lib/AWING/NumberFormat/index.d.ts +3 -1
  191. package/lib/AWING/NumberFormat/index.js +2 -2
  192. package/lib/AWING/PageManagement/PageManagement.js +4 -3
  193. package/lib/AWING/Pagination/index.js +11 -3
  194. package/lib/AWING/index.d.ts +1 -0
  195. package/lib/AWING/index.js +1 -0
  196. package/lib/AWING/ultis/validation.d.ts +1 -0
  197. package/lib/AWING/ultis/validation.js +25 -6
  198. package/lib/Commons/Components/ClassicDrawer.js +5 -4
  199. package/lib/Commons/Components/HighlightedCode/MarkdownElement.js +6 -1
  200. package/lib/Commons/Hooks/usePath.js +3 -3
  201. package/lib/Utils/Helpers.d.ts +4 -3
  202. package/lib/Utils/Helpers.js +54 -23
  203. package/lib/i18n.js +31 -2
  204. package/lib/translate/en/translation.json +131 -71
  205. package/lib/translate/id/translation.json +893 -0
  206. package/lib/translate/ind/translation.json +893 -0
  207. package/lib/translate/ja/translation.json +893 -0
  208. package/lib/translate/lao/translation.json +893 -0
  209. package/lib/translate/mys/translation.json +893 -0
  210. package/lib/translate/phl/translation.json +893 -0
  211. package/lib/translate/th/translation.json +893 -0
  212. package/lib/translate/vi/translation.json +91 -31
  213. package/package.json +9 -4
@@ -77,7 +77,6 @@ var jsx_runtime_1 = require("react/jsx-runtime");
77
77
  /* eslint-disable testing-library/no-node-access */
78
78
  /* eslint-disable testing-library/no-container */
79
79
  /* eslint-disable testing-library/no-wait-for-side-effects */
80
- require("@testing-library/jest-dom/extend-expect");
81
80
  var react_1 = require("@testing-library/react");
82
81
  var Parameter_1 = __importDefault(require("./Parameter"));
83
82
  var Utils = __importStar(require("./Utils"));
@@ -111,27 +110,6 @@ var rows = [
111
110
  isRequired: true,
112
111
  childrens: [],
113
112
  },
114
- {
115
- id: '14896',
116
- templateId: '4671435926616395650',
117
- fieldName: 'video_inbanner_2',
118
- fieldType: 'object',
119
- defaultValue: null,
120
- labelName: 'File banner nền video',
121
- isRequired: true,
122
- childrens: [
123
- {
124
- id: '148967',
125
- templateId: '4671435926616395650',
126
- fieldName: 'video_inbanner_2',
127
- fieldType: 'image',
128
- defaultValue: null,
129
- labelName: 'File banner nền video',
130
- isRequired: true,
131
- childrens: [],
132
- },
133
- ],
134
- },
135
113
  {
136
114
  id: '148961',
137
115
  templateId: '4671435926616395650',
@@ -154,13 +132,11 @@ var rows = [
154
132
  ],
155
133
  },
156
134
  ];
157
- var props = {
158
- handleSetParameter: function (fn) {
159
- return fn(rows);
160
- },
161
- };
162
135
  describe('Template Infomation Tab Component', function () {
163
- beforeAll(function () { });
136
+ beforeAll(function () {
137
+ ;
138
+ Utils.enhancedUpdate.mockImplementation(utils.enhancedUpdate);
139
+ });
164
140
  var renderUi = function () {
165
141
  return (0, react_1.render)((0, jsx_runtime_1.jsx)(recoil_1.RecoilRoot, { initializeState: function (_a) {
166
142
  var set = _a.set;
@@ -170,33 +146,62 @@ describe('Template Infomation Tab Component', function () {
170
146
  it('renders without crashing', function () {
171
147
  renderUi();
172
148
  });
173
- it('trigger add rows', function () {
174
- var updateSpy = jest.spyOn(props, 'handleSetParameter');
175
- renderUi();
176
- var addBtn = react_1.screen.getByRole('button', { name: /button-add/i });
177
- react_1.fireEvent.click(addBtn);
178
- expect(updateSpy).toBeCalled();
179
- // expect(addBtn).toBeInTheDocument()
180
- });
149
+ it('trigger add rows', function () { return __awaiter(void 0, void 0, void 0, function () {
150
+ var addBtn;
151
+ return __generator(this, function (_a) {
152
+ switch (_a.label) {
153
+ case 0:
154
+ renderUi();
155
+ addBtn = react_1.screen.getByRole('button', { name: /button-add/i });
156
+ react_1.fireEvent.click(addBtn);
157
+ return [4 /*yield*/, (0, react_1.waitFor)(function () {
158
+ expect(react_1.screen.getAllByText('image')[0]).toBeInTheDocument();
159
+ })];
160
+ case 1:
161
+ _a.sent();
162
+ return [2 /*return*/];
163
+ }
164
+ });
165
+ }); });
166
+ it('trigger add Object Children', function () { return __awaiter(void 0, void 0, void 0, function () {
167
+ var addBtn;
168
+ return __generator(this, function (_a) {
169
+ switch (_a.label) {
170
+ case 0:
171
+ renderUi();
172
+ addBtn = react_1.screen.getAllByTitle('Common.Add');
173
+ addBtn.forEach(function (btn) {
174
+ react_1.fireEvent.click(btn);
175
+ });
176
+ return [4 /*yield*/, (0, react_1.waitFor)(function () {
177
+ expect(react_1.screen.getAllByText('image')[0]).toBeInTheDocument();
178
+ })];
179
+ case 1:
180
+ _a.sent();
181
+ return [2 /*return*/];
182
+ }
183
+ });
184
+ }); });
181
185
  it('trigger edit cell', function () { return __awaiter(void 0, void 0, void 0, function () {
182
- var updateSpy, container, labelNameInput, fieldTypeInput;
186
+ var container, labelNameInput, fieldTypeInput;
183
187
  return __generator(this, function (_a) {
184
188
  switch (_a.label) {
185
189
  case 0:
186
- updateSpy = jest.spyOn(props, 'handleSetParameter');
187
190
  container = renderUi().container;
188
- labelNameInput = container.querySelector("input[name=\"labelName--148961-148967s\"]");
189
- fieldTypeInput = container.querySelector("input[name=\"fieldType--148961-148967s\"]");
191
+ labelNameInput = container.querySelector("input[name=\"labelName-148961-148967s\"]");
192
+ fieldTypeInput = container.querySelector("input[name=\"fieldType-148961-148967s\"]");
190
193
  react_1.fireEvent.change(labelNameInput, {
191
194
  target: { value: 'fieldInput-change' },
192
195
  });
193
196
  react_1.fireEvent.change(fieldTypeInput, {
194
197
  target: { value: 'video' },
195
198
  });
199
+ // expect(screen.getAllByText('color')[0]).toBeInTheDocument()
196
200
  return [4 /*yield*/, (0, react_1.waitFor)(function () {
197
- expect(updateSpy).toBeCalledTimes(1);
201
+ expect(Utils.enhancedUpdate).toBeCalledTimes(3);
198
202
  })];
199
203
  case 1:
204
+ // expect(screen.getAllByText('color')[0]).toBeInTheDocument()
200
205
  _a.sent();
201
206
  return [2 /*return*/];
202
207
  }
@@ -205,16 +210,22 @@ describe('Template Infomation Tab Component', function () {
205
210
  it('Remove row', function () { return __awaiter(void 0, void 0, void 0, function () {
206
211
  var removeBtn;
207
212
  return __generator(this, function (_a) {
208
- ;
209
- Utils.enhancedUpdate.mockImplementation(utils.enhancedUpdate);
210
- renderUi();
211
- removeBtn = react_1.screen.getAllByRole('button', {
212
- name: /Common.Delete/i,
213
- });
214
- removeBtn.forEach(function (btn) {
215
- react_1.fireEvent.click(btn);
216
- });
217
- return [2 /*return*/];
213
+ switch (_a.label) {
214
+ case 0:
215
+ renderUi();
216
+ removeBtn = react_1.screen.getAllByRole('button', {
217
+ name: /Common.Delete/i,
218
+ });
219
+ removeBtn.forEach(function (btn) {
220
+ react_1.fireEvent.click(btn);
221
+ });
222
+ return [4 /*yield*/, (0, react_1.waitFor)(function () {
223
+ expect(Utils.enhancedUpdate).toBeCalledTimes(2);
224
+ })];
225
+ case 1:
226
+ _a.sent();
227
+ return [2 /*return*/];
228
+ }
218
229
  });
219
230
  }); });
220
231
  });
@@ -1,15 +1,36 @@
1
+ /// <reference types="lodash" />
1
2
  import { ITemplateParameter } from '../../Types';
2
3
  import { DataObject } from '../../../../AWING';
3
- export declare const CUSTOM_FIELD_NAME: {
4
+ export interface IFlatParameter {
5
+ parentFieldType: string | undefined;
6
+ parentId: string[];
7
+ parentFieldName: string[];
8
+ errField: boolean;
9
+ shouldRemove: boolean;
10
+ id: string;
11
+ templateId: string;
12
+ fieldName: string;
13
+ fieldType: string;
14
+ defaultValue: string | number | boolean | null;
15
+ labelName: string;
16
+ isRequired: boolean;
17
+ childrens: IFlatParameter[];
18
+ isAdvanced: boolean;
19
+ }
20
+ export declare const FIELDS: {
4
21
  CHILDRENS: string;
5
22
  REMOVE: string;
6
23
  FIELD_TYPE: string;
24
+ FIELD_NAME: string;
7
25
  IS_REQUIRED: string;
8
26
  IS_ADVANCED: string;
27
+ LABEL_NAME: string;
28
+ DEFAULT_VALUE: string;
29
+ PARENT_ID: string;
9
30
  };
10
31
  export declare const removeFiledName: (templateParameters: ITemplateParameter[]) => ITemplateParameter[];
11
- export declare const flattenParameter4Parent: (rows: DataObject[], parentFieldName?: string[]) => DataObject[];
12
- export declare const flattenParameter: (parameters: DataObject[], parentId?: string[], parentFieldType?: string, parentFieldName?: string[]) => DataObject[];
32
+ export declare const flattenParameter4Parent: ((rows: DataObject[], parentFieldName?: string[]) => DataObject[]) & import("lodash").MemoizedFunction;
33
+ export declare const flattenParameter: ((parameters: DataObject[], parentId?: string[], parentFieldType?: string, parentFieldName?: string[]) => IFlatParameter[]) & import("lodash").MemoizedFunction;
13
34
  export declare const enhancedFindIndex: (rows: DataObject[], ids: string[]) => number[];
14
35
  /**
15
36
  * function enhancedUpdate
@@ -22,4 +43,7 @@ export declare const enhancedFindIndex: (rows: DataObject[], ids: string[]) => n
22
43
  * @param defaultParam
23
44
  */
24
45
  export declare const enhancedUpdate: (rows: DataObject[], ids: string[], field: string, value: any, defaultParam: ITemplateParameter) => void;
25
- export declare const enhancedRemove: (ids: string[]) => void;
46
+ /**
47
+ * viết type là DataObject thôi nhưng type của nó là:
48
+ */
49
+ export declare const getFieldName: ((row: IFlatParameter) => string) & import("lodash").MemoizedFunction;
@@ -20,22 +20,26 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
20
20
  return to.concat(ar || Array.prototype.slice.call(from));
21
21
  };
22
22
  Object.defineProperty(exports, "__esModule", { value: true });
23
- exports.enhancedRemove = exports.enhancedUpdate = exports.enhancedFindIndex = exports.flattenParameter = exports.flattenParameter4Parent = exports.removeFiledName = exports.CUSTOM_FIELD_NAME = void 0;
23
+ exports.getFieldName = exports.enhancedUpdate = exports.enhancedFindIndex = exports.flattenParameter = exports.flattenParameter4Parent = exports.removeFiledName = exports.FIELDS = void 0;
24
24
  var Enum_1 = require("../../../../ACM-AXN/ViewTemplate/Enum");
25
25
  var lodash_1 = require("lodash");
26
- exports.CUSTOM_FIELD_NAME = {
26
+ exports.FIELDS = {
27
27
  CHILDRENS: 'childrens',
28
28
  REMOVE: 'remove',
29
29
  FIELD_TYPE: 'fieldType',
30
+ FIELD_NAME: 'fieldName',
30
31
  IS_REQUIRED: 'isRequired',
31
32
  IS_ADVANCED: 'isAdvanced',
33
+ LABEL_NAME: 'labelName',
34
+ DEFAULT_VALUE: 'defaultValue',
35
+ PARENT_ID: 'parentId',
32
36
  };
33
37
  var removeFiledName = function (templateParameters) { return templateParameters.map(function (item) {
34
38
  var _a;
35
39
  return (__assign(__assign({}, item), { childrens: (0, exports.removeFiledName)(item.childrens), fieldName: (_a = item === null || item === void 0 ? void 0 : item.fieldName) === null || _a === void 0 ? void 0 : _a.split('.').at(-1) }));
36
40
  }); };
37
41
  exports.removeFiledName = removeFiledName;
38
- var flattenParameter4Parent = function (rows, parentFieldName) {
42
+ exports.flattenParameter4Parent = (0, lodash_1.memoize)(function (rows, parentFieldName) {
39
43
  if (parentFieldName === void 0) { parentFieldName = []; }
40
44
  parentFieldName = parentFieldName.filter(Boolean);
41
45
  return rows
@@ -50,15 +54,14 @@ var flattenParameter4Parent = function (rows, parentFieldName) {
50
54
  ], false).flat()), true);
51
55
  })
52
56
  .flat();
53
- };
54
- exports.flattenParameter4Parent = flattenParameter4Parent;
55
- var flattenParameter = function (parameters, parentId, parentFieldType, parentFieldName) {
57
+ });
58
+ exports.flattenParameter = (0, lodash_1.memoize)(function (parameters, parentId, parentFieldType, parentFieldName) {
56
59
  if (parentId === void 0) { parentId = []; }
57
60
  if (parentFieldName === void 0) { parentFieldName = []; }
58
61
  var shouldRemove = parameters.length > 1;
59
62
  return parameters
60
63
  .map(function (item) {
61
- var errField = !!parameters.find(function (el) { return el.id !== item.id && el.fieldName === item.fieldName; });
64
+ var errField = !!parameters.find(function (el) { return el.id !== item.id && el.fieldName === item.fieldName; }) || item.fieldName === '';
62
65
  var childrens = __spreadArray([], item.childrens, true);
63
66
  parentFieldName = parentFieldName.filter(function (field) { return field !== undefined; });
64
67
  // delete item.childrens
@@ -69,9 +72,17 @@ var flattenParameter = function (parameters, parentId, parentFieldType, parentFi
69
72
  item.fieldName,
70
73
  ], false).flat()), true);
71
74
  })
72
- .flat();
73
- };
74
- exports.flattenParameter = flattenParameter;
75
+ .flat().map(function (item) {
76
+ Object.keys(item).forEach(function (key) {
77
+ var value = item[key];
78
+ if (Array.isArray(value)) {
79
+ ;
80
+ item[key] = value.filter(Boolean);
81
+ }
82
+ });
83
+ return item;
84
+ });
85
+ });
75
86
  var enhancedFindIndex = function (rows, ids) {
76
87
  var indexs = [];
77
88
  var index = (0, lodash_1.findIndex)(rows, { id: ids[0] });
@@ -102,14 +113,14 @@ var enhancedUpdate = function (rows, ids, field, value, defaultParam) {
102
113
  }
103
114
  else {
104
115
  switch (field) {
105
- case exports.CUSTOM_FIELD_NAME.CHILDRENS:
116
+ case exports.FIELDS.CHILDRENS:
106
117
  rowsUpdate[indexs[turn]].childrens.push(value);
107
118
  break;
108
- case exports.CUSTOM_FIELD_NAME.REMOVE: {
119
+ case exports.FIELDS.REMOVE: {
109
120
  rowsUpdate.splice(indexs[turn], 1);
110
121
  break;
111
122
  }
112
- case exports.CUSTOM_FIELD_NAME.FIELD_TYPE: {
123
+ case exports.FIELDS.FIELD_TYPE: {
113
124
  ;
114
125
  rowsUpdate[indexs[turn]][field] = value;
115
126
  rowsUpdate[indexs[turn]].childrens = [];
@@ -134,5 +145,22 @@ var enhancedUpdate = function (rows, ids, field, value, defaultParam) {
134
145
  }
135
146
  };
136
147
  exports.enhancedUpdate = enhancedUpdate;
137
- var enhancedRemove = function (ids) { };
138
- exports.enhancedRemove = enhancedRemove;
148
+ /**
149
+ * viết type là DataObject thôi nhưng type của nó là:
150
+ */
151
+ exports.getFieldName = (0, lodash_1.memoize)(function (row) {
152
+ var value = '';
153
+ var parentName = row.parentFieldName.length
154
+ ? __spreadArray(__spreadArray([], row.parentFieldName, true), [''], false).join('.')
155
+ : '';
156
+ if (parentName.split('.').length === row.parentId.length) {
157
+ parentName += '.';
158
+ }
159
+ if (row.fieldName) {
160
+ value += parentName + row.fieldName;
161
+ }
162
+ if (row.parentId.length && !value.split('.').at(row.parentId.length)) {
163
+ value = parentName;
164
+ }
165
+ return value;
166
+ });
@@ -58,7 +58,7 @@ var TabFile_1 = __importDefault(require("../../../ACM-AXN/Page/CreateOrEdit/TabF
58
58
  var enums_1 = require("../../../ACM-AXN/Page/enums");
59
59
  var AWING_1 = require("../../../AWING");
60
60
  var Wrapper_1 = __importDefault(require("../../../AWING/HOC/Wrapper"));
61
- var immer_1 = __importDefault(require("immer"));
61
+ var immer_1 = require("immer");
62
62
  var Router_1 = require("../../../AWING/Router");
63
63
  var validation_1 = require("../../../AWING/ultis/validation");
64
64
  var ClassicDrawer_1 = __importDefault(require("../../../Commons/Components/ClassicDrawer"));
@@ -90,6 +90,7 @@ var CreateOrEdit = function () {
90
90
  var _e = (0, react_1.useState)([]), templateTypes = _e[0], setTemplateTypes = _e[1];
91
91
  var _f = (0, recoil_1.useRecoilState)(Recoils_1.templateState), templateData = _f[0], setTemplateData = _f[1];
92
92
  var confirmExit = (0, recoil_1.useRecoilValue)(Recoils_1.isEditState);
93
+ var isError = (0, recoil_1.useRecoilValue)(Recoils_1.isErrorParameterState);
93
94
  var _g = (0, react_1.useState)('0'), value = _g[0], setValue = _g[1];
94
95
  (0, react_1.useEffect)(function () {
95
96
  setLoading(true);
@@ -104,7 +105,7 @@ var CreateOrEdit = function () {
104
105
  // eslint-disable-next-line react-hooks/exhaustive-deps
105
106
  }, []);
106
107
  (0, react_1.useEffect)(function () {
107
- setTemplateData((0, immer_1.default)(function (prev) {
108
+ setTemplateData((0, immer_1.produce)(function (prev) {
108
109
  var _a;
109
110
  prev.template.directoryId =
110
111
  prev.template.directoryId ||
@@ -152,7 +153,7 @@ var CreateOrEdit = function () {
152
153
  var fetchTemplateData = function () {
153
154
  if (templateId) {
154
155
  return service.templatesGet(templateId).then(function (res) {
155
- setTemplateData(__assign(__assign({}, res), { templateParameters: (0, Utils_1.removeFiledName)(res.templateParameters) }));
156
+ setTemplateData(__assign(__assign({}, res), { template: __assign(__assign({}, res.template), { pageCode: isNaN(Number(res.template.pageCode)) ? res.template.pageCode : Number(res.template.pageCode) ? 'lgn' : 'wlc' }), templateParameters: (0, Utils_1.removeFiledName)(res.templateParameters) }));
156
157
  });
157
158
  }
158
159
  };
@@ -205,7 +206,10 @@ var CreateOrEdit = function () {
205
206
  }
206
207
  return service.templatesPost(data4Update);
207
208
  };
208
- return ((0, jsx_runtime_1.jsx)(ClassicDrawer_1.default, { title: "".concat(t(['TemplateManagement', templateId ? 'Edit' : 'Create'].join('.'))).concat(templateId ? ": ".concat((_a = templateData === null || templateData === void 0 ? void 0 : templateData.template) === null || _a === void 0 ? void 0 : _a.description) : '', "\n "), onSubmit: handleSubmit, disableButtonSubmit: !((_b = templateData.template) === null || _b === void 0 ? void 0 : _b.templateTypeId) || !descriptionValid.valid || !confirmExit, confirmExit: confirmExit, childrenWrapperStyle: { padding: 0 }, children: (0, jsx_runtime_1.jsx)(material_1.Grid, { container: true, sx: {
209
+ return ((0, jsx_runtime_1.jsx)(ClassicDrawer_1.default, { title: "".concat(t(['TemplateManagement', templateId ? 'Edit' : 'Create'].join('.'))).concat(templateId ? ": ".concat((_a = templateData === null || templateData === void 0 ? void 0 : templateData.template) === null || _a === void 0 ? void 0 : _a.description) : '', "\n "), onSubmit: handleSubmit, disableButtonSubmit: !((_b = templateData.template) === null || _b === void 0 ? void 0 : _b.templateTypeId) ||
210
+ !descriptionValid.valid ||
211
+ !confirmExit ||
212
+ isError, confirmExit: confirmExit, childrenWrapperStyle: { padding: 0 }, children: (0, jsx_runtime_1.jsx)(material_1.Grid, { container: true, sx: {
209
213
  display: 'flex',
210
214
  flexDirection: 'column',
211
215
  flexGrow: 1,
@@ -51,7 +51,7 @@ var ImportTemplate = function () {
51
51
  };
52
52
  var handleSubmit = function () {
53
53
  var directoryId = bussinessData.directoryId, id = bussinessData.id, name = bussinessData.name;
54
- return service.templatesImport(directoryId, id, name, {
54
+ return service.templatesImport(directoryId, id || '0', name, {
55
55
  data: tempFile,
56
56
  fileName: tempFile === null || tempFile === void 0 ? void 0 : tempFile.name,
57
57
  });
@@ -59,7 +59,7 @@ var ImportTemplate = function () {
59
59
  var handleChangeFormData = (0, react_1.useCallback)(function (obj, valid, key) {
60
60
  setBussinessData(function (prev) {
61
61
  var _a;
62
- return (__assign(__assign({}, prev), (_a = {}, _a[key] = obj[key], _a.id = prev.id || (obj === null || obj === void 0 ? void 0 : obj.id) || '0', _a.directoryId = (obj === null || obj === void 0 ? void 0 : obj.directoryId) || rootDirectoryId, _a)));
62
+ return (__assign(__assign({}, prev), (_a = {}, _a[key] = obj[key], _a.directoryId = (obj === null || obj === void 0 ? void 0 : obj.directoryId) || rootDirectoryId, _a)));
63
63
  });
64
64
  }, [rootDirectoryId]);
65
65
  return ((0, jsx_runtime_1.jsxs)(ClassicDrawer_1.default, { title: t('TemplateManagement.ImportTemplate'), onSubmit: handleSubmit, disableButtonSubmit: !(tempFile === null || tempFile === void 0 ? void 0 : tempFile.name), confirmExit: true, childrenWrapperStyle: { padding: 0 }, children: [(0, jsx_runtime_1.jsx)(AWING_1.DataForm, { fields: [
@@ -10,15 +10,15 @@ export interface ITemplateType {
10
10
  templateTypeCode?: string;
11
11
  }
12
12
  export interface ITemplateParameter {
13
- id?: string;
14
- templateId?: string;
15
- fieldName?: string;
16
- fieldType?: string;
17
- defaultValue?: string;
18
- labelName?: string;
19
- isRequired?: boolean;
20
- childrens?: ITemplateParameter[];
21
- isAdvanced?: boolean;
13
+ id: string;
14
+ templateId: string;
15
+ fieldName: string;
16
+ fieldType: string;
17
+ defaultValue: string | number | boolean | undefined;
18
+ labelName: string | undefined;
19
+ isRequired: boolean;
20
+ childrens: ITemplateParameter[];
21
+ isAdvanced: boolean;
22
22
  }
23
23
  export interface ITemplateEvent {
24
24
  id?: number;
@@ -92,7 +92,7 @@ var newStyles = {
92
92
  removedGutterBackground: '#ececec',
93
93
  },
94
94
  titleBlock: {
95
- fontFamily: "'AW-Roboto', sans-serif",
95
+ fontFamily: "'Roboto', sans-serif",
96
96
  fontSize: '12px',
97
97
  fontWeight: 'bold',
98
98
  },
@@ -43,17 +43,16 @@ var Preview = function (props) {
43
43
  var _a;
44
44
  var classes = useStyles();
45
45
  var t = (0, react_i18next_1.useTranslation)().t;
46
- var validStatus = props.validStatus, pagePath = props.pagePath, templateDatas = props.templateDatas,
47
- // domainId,
48
- configs = props.configs;
46
+ var validStatus = props.validStatus, pagePath = props.pagePath, templateDatas = props.templateDatas, domainId = props.domainId, configs = props.configs;
49
47
  var viewIndex = ((_a = templateDatas[0]) === null || _a === void 0 ? void 0 : _a.viewNumber) || -1;
50
48
  var formRef = react_1.default.useRef(null);
51
49
  var iframeSrc = (0, react_1.useMemo)(function () {
52
- var result = "".concat(configs.CAPTIVE_DOMAIN, "/").concat(configs.TEMPLATE_PREVIEW);
50
+ var result = "".concat(configs.CAPTIVE_DOMAIN, "/").concat(configs.TEMPLATE_PREVIEW, "?domainId=").concat(domainId);
53
51
  if (result.startsWith("http://"))
54
52
  result = result.replace("http://", "https://");
55
53
  return result;
56
- }, [configs.CAPTIVE_DOMAIN, configs.TEMPLATE_PREVIEW]);
54
+ }, [configs.CAPTIVE_DOMAIN, configs.TEMPLATE_PREVIEW, domainId]);
55
+ var iframeName = react_1.default.useMemo(function () { return "iframe-demo".concat(viewIndex); }, [viewIndex]);
57
56
  (0, react_1.useEffect)(function () {
58
57
  var handleFormdata = function (_a) {
59
58
  var formData = _a.formData;
@@ -87,6 +86,6 @@ var Preview = function (props) {
87
86
  }, children: [(0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body1", style: {
88
87
  fontWeight: "bold",
89
88
  textTransform: "uppercase",
90
- }, children: t("ViewTemplate.PreviewTitle") }), (0, jsx_runtime_1.jsx)(material_1.Tooltip, { title: t("Common.Refresh") || "", placement: "top", children: (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)(material_1.IconButton, { onClick: function () { return formRef.current.submit(); }, "aria-label": "refresh", style: { float: "right" }, disabled: !validStatus, children: (0, jsx_runtime_1.jsx)(Refresh_1.default, {}) }) }) })] }), (0, jsx_runtime_1.jsx)("form", { action: iframeSrc, method: "post", target: "iframe-demo", ref: formRef }), (0, jsx_runtime_1.jsx)("iframe", { title: "iframe-demo-".concat(viewIndex), id: "iframe-demo", name: "iframe-demo", className: classes.root, width: "100%" })] }));
89
+ }, children: t("ViewTemplate.PreviewTitle") }), (0, jsx_runtime_1.jsx)(material_1.Tooltip, { title: t("Common.Refresh") || "", placement: "top", children: (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)(material_1.IconButton, { onClick: function () { return formRef.current.submit(); }, "aria-label": "refresh", style: { float: "right" }, disabled: !validStatus, children: (0, jsx_runtime_1.jsx)(Refresh_1.default, {}) }) }) })] }), (0, jsx_runtime_1.jsx)("form", { action: iframeSrc, method: "post", target: iframeName, ref: formRef }), (0, jsx_runtime_1.jsx)("iframe", { title: iframeName, id: iframeName, name: iframeName, className: classes.root, width: "100%" })] }));
91
90
  };
92
91
  exports.default = Preview;
@@ -27,22 +27,32 @@ var Events = function (_a) {
27
27
  var t = (0, react_i18next_1.useTranslation)(undefined, { i18n: i18n_1.default }).t;
28
28
  var _b = react_1.default.useState(''), tempValue = _b[0], setTempValue = _b[1];
29
29
  var _c = react_1.default.useState(''), error = _c[0], setError = _c[1];
30
+ var handleValue = function () {
31
+ if (tempValue.trim() === '') {
32
+ return;
33
+ }
34
+ var _a = (0, validation_1.textValidation)(tempValue, 50, false, /^[a-zA-Z0-9đĐ_.()\u0080-\uFFFF]+$/g), valid = _a.valid, message = _a.message;
35
+ var isStartWithNumber = tempValue.match(/^\d/);
36
+ if (viewEvents.map(function (item) { return item.event; }).includes((0, Helpers_1.changeToAlias)(tempValue)) || !valid || isStartWithNumber) {
37
+ setError(!valid ? message : isStartWithNumber ? t('Common.InvalidData') : t('Common.Existed').replace('{0}', tempValue));
38
+ return;
39
+ }
40
+ onChangeEvent((0, lodash_1.uniqBy)(viewEvents.concat({ event: tempValue, id: 0 }), function (item) { return (0, Helpers_1.changeToAlias)(item.event); }));
41
+ setTempValue('');
42
+ };
30
43
  return ((0, jsx_runtime_1.jsx)(material_1.Box, { sx: {
31
44
  marginBottom: 2,
32
45
  width: '100%',
33
46
  }, children: (0, jsx_runtime_1.jsx)(material_1.TextField, __assign({ error: !!error, helperText: error, fullWidth: true, variant: "standard", placeholder: "".concat(t('Common.Events'), "...") }, (!disabledLabel && { label: t('Common.Events') }), { inputProps: {
34
47
  autoComplete: 'off',
35
48
  }, value: tempValue, onKeyDown: function (e) {
36
- if (e.key === 'Enter') {
37
- var _a = (0, validation_1.textValidation)(tempValue, 50, false, /^[a-zA-Z0-9đĐ_.()\u0080-\uFFFF]+$/g), valid = _a.valid, message = _a.message;
38
- var isStartWithNumber = tempValue.match(/^\d/);
39
- if (viewEvents.map(function (item) { return item.event; }).includes((0, Helpers_1.changeToAlias)(tempValue)) || !valid || isStartWithNumber) {
40
- setError(!valid ? message : isStartWithNumber ? t('Common.InvalidData') : t('Common.Existed').replace('{0}', tempValue));
41
- return;
42
- }
43
- onChangeEvent((0, lodash_1.uniqBy)(viewEvents.concat({ event: tempValue, id: 0 }), function (item) { return (0, Helpers_1.changeToAlias)(item.event); }));
44
- setTempValue('');
49
+ if (e.key === 'Enter' || e.key === 'Tab' || e.key === ',') {
50
+ e.preventDefault();
51
+ handleValue();
45
52
  }
53
+ }, onBlur: function (e) {
54
+ e.preventDefault();
55
+ handleValue();
46
56
  }, onChange: function (event) {
47
57
  setTempValue(event.target.value);
48
58
  setError('');
@@ -62,8 +72,10 @@ var Events = function (_a) {
62
72
  marginRight: 1,
63
73
  marginBottom: 0.5,
64
74
  }, label: option.event, title: option.event, disabled: option === null || option === void 0 ? void 0 : option.protected, onDelete: function () {
65
- onChangeEvent(viewEvents.filter(function (item) { return item.event !== option.event; }));
66
- } }, option.event)); }),
75
+ var res = viewEvents.filter(function (item) { return item.event !== option.event; });
76
+ console.log("res", res);
77
+ onChangeEvent(res);
78
+ } }, JSON.stringify(option))); }),
67
79
  } })) }));
68
80
  };
69
81
  exports.default = Events;
@@ -0,0 +1,18 @@
1
+ /// <reference types="lodash" />
2
+ import { Configs, FieldInfo } from "../../../../../ACM-AXN/ViewTemplate/interface";
3
+ export declare const getValidationParams: (templateDatas: FieldInfo[], pagePath: string, configs: Configs) => {
4
+ fieldValue: any;
5
+ id?: string | undefined;
6
+ defaultValue?: string | undefined;
7
+ fieldName: string;
8
+ fieldType: "object" | "color" | "html" | "textarea" | "video" | "image" | "list" | "checkbox" | "url" | "textfield" | "textfield_number" | "dropdownlist" | "checkboxlist";
9
+ isRequired: boolean;
10
+ labelName?: string | undefined;
11
+ pageId?: string | undefined;
12
+ templateId?: string | undefined;
13
+ viewNumber?: number | undefined;
14
+ childrens?: FieldInfo[] | undefined;
15
+ }[][];
16
+ export declare const runValidate: import("lodash").DebouncedFunc<(scriptValidate: string, fields: FieldInfo[], pagePath: string, notifyError: (errorMessage: string) => void, changeViewValidStatus: (status: boolean) => void, changeViewValidProcess: (processValue: number) => void, configs: Configs) => void>;
17
+ export declare const getAutoFieldParams: (templateDatas: FieldInfo[], fieldPath: string, pagePath: string, configs: Configs) => any[];
18
+ export declare const runAutoField: import("lodash").DebouncedFunc<(scriptAutoField: string, fields: FieldInfo[], fieldPath: string, pagePath: string, updateNewValue: (needUpdateFieldPath: string, newValue: any) => void, configs: Configs) => void>;