awing-library 2.1.21 → 2.1.22-stage

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 (426) hide show
  1. package/lib/ACM-AXN/AuthenticationProfile/Container.d.ts +2 -0
  2. package/lib/ACM-AXN/AuthenticationProfile/Container.js +82 -0
  3. package/lib/ACM-AXN/AuthenticationProfile/Container.test.d.ts +1 -0
  4. package/lib/ACM-AXN/AuthenticationProfile/Container.test.js +184 -0
  5. package/lib/ACM-AXN/AuthenticationProfile/Context.d.ts +3 -0
  6. package/lib/ACM-AXN/AuthenticationProfile/Context.js +5 -0
  7. package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/CreateOrEdit.test.d.ts +1 -0
  8. package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/CreateOrEdit.test.js +203 -0
  9. package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.d.ts +2 -0
  10. package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.js +129 -0
  11. package/lib/ACM-AXN/AuthenticationProfile/Hooks.d.ts +2 -0
  12. package/lib/ACM-AXN/AuthenticationProfile/Hooks.js +12 -0
  13. package/lib/ACM-AXN/AuthenticationProfile/Types.d.ts +75 -0
  14. package/lib/ACM-AXN/AuthenticationProfile/Types.js +2 -0
  15. package/lib/ACM-AXN/AuthenticationProfile/Utils.d.ts +11 -0
  16. package/lib/ACM-AXN/AuthenticationProfile/Utils.js +14 -0
  17. package/lib/ACM-AXN/AuthenticationProfile/index.d.ts +3 -0
  18. package/lib/ACM-AXN/AuthenticationProfile/index.js +40 -0
  19. package/lib/ACM-AXN/Campaign/Container.js +6 -7
  20. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.d.ts +2 -0
  21. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.js +9 -4
  22. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabInfomation.js +2 -2
  23. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPermission/index.js +1 -1
  24. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticComponent.test.d.ts +1 -0
  25. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticComponent.test.js +80 -0
  26. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticContainer.test.d.ts +1 -0
  27. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticContainer.test.js +49 -0
  28. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.d.ts +17 -0
  29. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +113 -0
  30. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.test.d.ts +1 -0
  31. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.test.js +67 -0
  32. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.d.ts +2 -0
  33. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.js +114 -0
  34. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.test.d.ts +1 -0
  35. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.test.js +27 -0
  36. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/DetailGroupBy.test.d.ts +1 -0
  37. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/DetailGroupBy.test.js +55 -0
  38. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.d.ts +7 -0
  39. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.js +28 -0
  40. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.test.d.ts +1 -0
  41. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.test.js +49 -0
  42. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.d.ts +2 -0
  43. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.js +182 -0
  44. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +30 -0
  45. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +464 -0
  46. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/component.d.ts +14 -0
  47. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/component.js +77 -0
  48. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +15 -0
  49. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +137 -0
  50. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/index.d.ts +1 -0
  51. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/index.js +8 -0
  52. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +12 -0
  53. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +274 -0
  54. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.test.d.ts +1 -0
  55. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.test.js +84 -0
  56. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Context.d.ts +5 -0
  57. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Context.js +13 -0
  58. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerComponent.test.d.ts +1 -0
  59. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerComponent.test.js +53 -0
  60. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerContainer.test.d.ts +1 -0
  61. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerContainer.test.js +124 -0
  62. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.d.ts +14 -0
  63. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +130 -0
  64. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.d.ts +7 -0
  65. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +76 -0
  66. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/index.d.ts +1 -0
  67. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/index.js +8 -0
  68. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventComponent.test.d.ts +1 -0
  69. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventComponent.test.js +91 -0
  70. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventContainer.test.d.ts +1 -0
  71. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventContainer.test.js +48 -0
  72. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.d.ts +5 -0
  73. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +33 -0
  74. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.test.d.ts +1 -0
  75. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.test.js +30 -0
  76. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.d.ts +7 -0
  77. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +81 -0
  78. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.d.ts +15 -0
  79. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.js +166 -0
  80. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.d.ts +10 -0
  81. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +111 -0
  82. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/index.d.ts +1 -0
  83. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/index.js +8 -0
  84. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +6 -0
  85. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +65 -0
  86. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.test.d.ts +1 -0
  87. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.test.js +26 -0
  88. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +99 -0
  89. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.js +2 -0
  90. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.d.ts +6 -0
  91. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +36 -0
  92. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +6 -0
  93. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +9 -0
  94. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.d.ts +9 -0
  95. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +36 -0
  96. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.d.ts +8 -0
  97. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +91 -0
  98. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/index.d.ts +1 -0
  99. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/index.js +8 -0
  100. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdDetail.js +1 -1
  101. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdDetail.test.js +3 -3
  102. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +18 -14
  103. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +3 -3
  104. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/AddOrEditRule.js +6 -0
  105. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/AddOrEditRule.test.js +12 -12
  106. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/Create.js +2 -3
  107. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/Create.test.js +3 -3
  108. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/Edit.test.js +2 -2
  109. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/EditExpression.test.js +9 -9
  110. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.d.ts +8 -0
  111. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.js +47 -0
  112. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitClick.test.js +1 -2
  113. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitEvent.js +52 -6
  114. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitEvent.test.js +1 -2
  115. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitView.test.js +1 -2
  116. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetAge.test.js +3 -3
  117. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetGender.test.js +2 -2
  118. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.d.ts +1 -0
  119. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.js +3 -1
  120. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.d.ts +4 -3
  121. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +13 -7
  122. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +9 -9
  123. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.d.ts +1 -1
  124. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +88 -54
  125. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +7 -6
  126. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +9 -9
  127. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.d.ts +2 -0
  128. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +7 -3
  129. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +10 -9
  130. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
  131. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +3 -1
  132. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +35 -22
  133. package/lib/ACM-AXN/Campaign/Enum.d.ts +73 -0
  134. package/lib/ACM-AXN/Campaign/Enum.js +82 -1
  135. package/lib/ACM-AXN/Campaign/Types.d.ts +10 -127
  136. package/lib/ACM-AXN/Campaign/Types.js +0 -79
  137. package/lib/ACM-AXN/Campaign/Utils.d.ts +9 -2
  138. package/lib/ACM-AXN/Campaign/Utils.js +26 -11
  139. package/lib/ACM-AXN/Campaign/index.d.ts +2 -0
  140. package/lib/ACM-AXN/Campaign/index.js +17 -2
  141. package/lib/ACM-AXN/CampaignPlan/Container.js +25 -13
  142. package/lib/ACM-AXN/CampaignPlan/Container.test.d.ts +1 -1
  143. package/lib/ACM-AXN/CampaignPlan/Container.test.js +1 -2
  144. package/lib/ACM-AXN/CampaignPlan/Detail.js +9 -8
  145. package/lib/ACM-AXN/CampaignPlan/Detail.test.d.ts +1 -1
  146. package/lib/ACM-AXN/CampaignPlan/Detail.test.js +2 -3
  147. package/lib/ACM-AXN/CampaignPlan/Filter.js +11 -4
  148. package/lib/ACM-AXN/CampaignPlan/Filter.test.d.ts +1 -1
  149. package/lib/ACM-AXN/CampaignPlan/Filter.test.js +0 -1
  150. package/lib/ACM-AXN/CampaignPlan/Types.d.ts +6 -74
  151. package/lib/ACM-AXN/CampaignPlan/Types.js +1 -253
  152. package/lib/ACM-AXN/CampaignPlan/index.js +1 -1
  153. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.d.ts +1 -1
  154. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +28 -10
  155. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +32 -13
  156. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/container.js +3 -3
  157. package/lib/ACM-AXN/CampaignSchedule/Components/TableHeaderDragable.js +5 -1
  158. package/lib/ACM-AXN/CampaignSchedule/DataConfig.d.ts +1 -1
  159. package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +10 -5
  160. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.d.ts +1 -1
  161. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +9 -4
  162. package/lib/ACM-AXN/CampaignSchedule/Enum.d.ts +4 -0
  163. package/lib/ACM-AXN/CampaignSchedule/Enum.js +4 -0
  164. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +2 -1
  165. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +7 -2
  166. package/lib/ACM-AXN/CampaignSchedule/container.d.ts +1 -1
  167. package/lib/ACM-AXN/CampaignSchedule/container.js +6 -1
  168. package/lib/ACM-AXN/CampaignSchedule/helper.d.ts +0 -2
  169. package/lib/ACM-AXN/CampaignSchedule/helper.js +1 -24
  170. package/lib/ACM-AXN/CampaignSchedule/interface.d.ts +3 -0
  171. package/lib/ACM-AXN/{Notifications → Common}/Constant.d.ts +33 -20
  172. package/lib/ACM-AXN/{Notifications → Common}/Constant.js +35 -22
  173. package/lib/ACM-AXN/Common/Enum.d.ts +59 -0
  174. package/lib/ACM-AXN/Common/Enum.js +74 -0
  175. package/lib/ACM-AXN/Common/Types.d.ts +16 -0
  176. package/lib/ACM-AXN/Common/Types.js +2 -0
  177. package/lib/ACM-AXN/Directory/DomainDirectory/FolderDetail.js +2 -2
  178. package/lib/ACM-AXN/Directory/DomainDirectory/index.js +5 -5
  179. package/lib/ACM-AXN/Directory/MenuDirectory/index.js +2 -2
  180. package/lib/ACM-AXN/Directory/SystemDirectory/index.js +2 -2
  181. package/lib/ACM-AXN/Directory/components/Permission/Management.js +3 -3
  182. package/lib/ACM-AXN/Directory/components/Permission/MenuPermissions/MenuPermissionManagement.js +3 -3
  183. package/lib/ACM-AXN/Directory/components/Permission/UserOrGroup.js +2 -2
  184. package/lib/ACM-AXN/Directory/components/Permission/index.js +2 -2
  185. package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
  186. package/lib/ACM-AXN/GroupUser/Container.js +3 -3
  187. package/lib/ACM-AXN/GroupUser/Container.test.js +3 -3
  188. package/lib/ACM-AXN/GroupUser/CreateOrEdit.js +3 -3
  189. package/lib/ACM-AXN/GroupUser/User/UserComponent.js +3 -3
  190. package/lib/ACM-AXN/GroupUser/index.js +3 -3
  191. package/lib/ACM-AXN/Holiday/Container.d.ts +2 -0
  192. package/lib/ACM-AXN/Holiday/Container.js +55 -0
  193. package/lib/ACM-AXN/Holiday/Container.test.d.ts +1 -0
  194. package/lib/ACM-AXN/Holiday/Container.test.js +227 -0
  195. package/lib/ACM-AXN/Holiday/Context.d.ts +3 -0
  196. package/lib/ACM-AXN/Holiday/Context.js +5 -0
  197. package/lib/ACM-AXN/Holiday/CreateOrEdit.d.ts +2 -0
  198. package/lib/ACM-AXN/Holiday/CreateOrEdit.js +62 -0
  199. package/lib/ACM-AXN/Holiday/CreateOrEdit.test.d.ts +1 -0
  200. package/lib/ACM-AXN/Holiday/CreateOrEdit.test.js +255 -0
  201. package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.d.ts +2 -0
  202. package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.js +107 -0
  203. package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.test.d.ts +1 -0
  204. package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.test.js +181 -0
  205. package/lib/ACM-AXN/Holiday/Detail/Dates.d.ts +6 -0
  206. package/lib/ACM-AXN/Holiday/Detail/Dates.js +153 -0
  207. package/lib/ACM-AXN/Holiday/Detail/Dates.test.d.ts +1 -0
  208. package/lib/ACM-AXN/Holiday/Detail/Dates.test.js +220 -0
  209. package/lib/ACM-AXN/Holiday/Detail/Form.d.ts +6 -0
  210. package/lib/ACM-AXN/Holiday/Detail/Form.js +32 -0
  211. package/lib/ACM-AXN/Holiday/Detail/Form.test.d.ts +1 -0
  212. package/lib/ACM-AXN/Holiday/Detail/Form.test.js +120 -0
  213. package/lib/ACM-AXN/Holiday/Detail.d.ts +2 -0
  214. package/lib/ACM-AXN/Holiday/Detail.js +29 -0
  215. package/lib/ACM-AXN/Holiday/FormHoliday.d.ts +9 -0
  216. package/lib/ACM-AXN/Holiday/FormHoliday.js +110 -0
  217. package/lib/ACM-AXN/Holiday/Hooks.d.ts +2 -0
  218. package/lib/ACM-AXN/Holiday/Hooks.js +12 -0
  219. package/lib/ACM-AXN/Holiday/Types.d.ts +91 -0
  220. package/lib/ACM-AXN/Holiday/Types.js +15 -0
  221. package/lib/ACM-AXN/Holiday/Utils.d.ts +13 -0
  222. package/lib/ACM-AXN/Holiday/Utils.js +34 -0
  223. package/lib/ACM-AXN/Holiday/index.d.ts +3 -0
  224. package/lib/ACM-AXN/Holiday/index.js +45 -0
  225. package/lib/ACM-AXN/Notifications/NotificationDetail/HeaderInfo/ButtonTabs.js +1 -1
  226. package/lib/ACM-AXN/Notifications/NotificationDetail/HeaderInfo/MenuNotification.js +1 -1
  227. package/lib/ACM-AXN/Notifications/NotificationDetail/HeaderInfo/index.js +1 -1
  228. package/lib/ACM-AXN/Notifications/NotificationDetail/NotificationList/NotificationItem/Message.js +7 -6
  229. package/lib/ACM-AXN/Notifications/NotificationDetail/NotificationList/index.js +1 -1
  230. package/lib/ACM-AXN/Notifications/NotificationDetail/index.js +29 -26
  231. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +1 -1
  232. package/lib/ACM-AXN/Notifications/Types.d.ts +2 -2
  233. package/lib/ACM-AXN/Page/Constant.d.ts +0 -10
  234. package/lib/ACM-AXN/Page/Constant.js +1 -11
  235. package/lib/ACM-AXN/Page/Container.js +12 -13
  236. package/lib/ACM-AXN/Page/CreateOrEdit/Components/useListPageView.js +2 -2
  237. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.d.ts +6 -0
  238. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.js +63 -0
  239. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.d.ts +12 -1
  240. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +20 -1
  241. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.d.ts +1 -9
  242. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.js +0 -9
  243. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewContent.js +48 -29
  244. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
  245. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +53 -64
  246. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +26 -31
  247. package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +7 -9
  248. package/lib/ACM-AXN/Page/CreateOrEdit/index.d.ts +2 -3
  249. package/lib/ACM-AXN/Page/CreateOrEdit/index.js +99 -45
  250. package/lib/ACM-AXN/Page/Import/index.js +1 -0
  251. package/lib/ACM-AXN/Page/Types.d.ts +2 -1
  252. package/lib/ACM-AXN/Page/index.js +9 -7
  253. package/lib/ACM-AXN/Permission/Components/Management.js +1 -1
  254. package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
  255. package/lib/ACM-AXN/Permission/index.js +1 -1
  256. package/lib/ACM-AXN/PlaceGroup/Container.js +1 -1
  257. package/lib/ACM-AXN/PlaceGroup/Container.test.js +1 -1
  258. package/lib/ACM-AXN/PlaceGroup/Context.d.ts +0 -5
  259. package/lib/ACM-AXN/PlaceGroup/Context.js +0 -5
  260. package/lib/ACM-AXN/PlaceGroup/index.js +1 -1
  261. package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +43 -28
  262. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +11 -13
  263. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +27 -22
  264. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +28 -19
  265. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.test.js +3 -3
  266. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +29 -19
  267. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.test.js +3 -3
  268. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/index.js +1 -1
  269. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
  270. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +46 -59
  271. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
  272. package/lib/ACM-AXN/ScheduleCompletionRate/Recoils.d.ts +7 -6
  273. package/lib/ACM-AXN/ScheduleCompletionRate/Recoils.js +6 -1
  274. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
  275. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
  276. package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +74 -110
  277. package/lib/ACM-AXN/ScheduleCompletionRate/Types.js +21 -279
  278. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +22 -3
  279. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +64 -11
  280. package/lib/ACM-AXN/ScheduleCompletionRate/index.js +3 -3
  281. package/lib/ACM-AXN/Statistics/ControlPanel.d.ts +1 -1
  282. package/lib/ACM-AXN/Statistics/ControlPanel.js +28 -12
  283. package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
  284. package/lib/ACM-AXN/Statistics/Enums.js +1 -0
  285. package/lib/ACM-AXN/Statistics/container.d.ts +1 -1
  286. package/lib/ACM-AXN/Statistics/container.js +2 -2
  287. package/lib/ACM-AXN/Statistics/interface.d.ts +1 -0
  288. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +6 -5
  289. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/TableAndPieChart.js +5 -5
  290. package/lib/ACM-AXN/StatisticsAudienceDemographic/container.d.ts +1 -1
  291. package/lib/ACM-AXN/StatisticsAudienceDemographic/container.js +2 -2
  292. package/lib/ACM-AXN/StatisticsAudienceDemographic/interfaces.d.ts +1 -0
  293. package/lib/ACM-AXN/StatisticsByProvince/container.d.ts +1 -1
  294. package/lib/ACM-AXN/StatisticsByProvince/container.js +2 -2
  295. package/lib/ACM-AXN/StatisticsByProvince/interfaces.d.ts +1 -0
  296. package/lib/ACM-AXN/TaskScheduler/Components/CornJobInput.js +1 -2
  297. package/lib/ACM-AXN/TaskScheduler/Container.js +3 -3
  298. package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +9 -10
  299. package/lib/ACM-AXN/TaskScheduler/Types.d.ts +1 -1
  300. package/lib/ACM-AXN/TaskScheduler/Utils.d.ts +5 -0
  301. package/lib/ACM-AXN/TaskScheduler/Utils.js +8 -3
  302. package/lib/ACM-AXN/TaskScheduler/index.js +3 -3
  303. package/lib/ACM-AXN/Template/Container.js +5 -5
  304. package/lib/ACM-AXN/Template/Container.test.js +6 -5
  305. package/lib/ACM-AXN/Template/CreateOrEdit/CreateOrEdit.test.js +1 -1
  306. package/lib/ACM-AXN/Template/CreateOrEdit/Infomation.js +13 -2
  307. package/lib/ACM-AXN/Template/CreateOrEdit/Infomation.test.js +1 -1
  308. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
  309. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
  310. package/lib/ACM-AXN/Template/CreateOrEdit/Script.js +3 -3
  311. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +3 -2
  312. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +57 -32
  313. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
  314. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
  315. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
  316. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
  317. package/lib/ACM-AXN/Template/CreateOrEdit/Template/index.js +7 -3
  318. package/lib/ACM-AXN/Template/CreateOrEdit/index.js +11 -7
  319. package/lib/ACM-AXN/Template/Import.js +6 -3
  320. package/lib/ACM-AXN/Template/Import.test.js +2 -2
  321. package/lib/ACM-AXN/Template/Types.d.ts +9 -9
  322. package/lib/ACM-AXN/Template/index.js +4 -4
  323. package/lib/ACM-AXN/TransactionLog/Container.js +1 -1
  324. package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
  325. package/lib/ACM-AXN/TransactionLog/index.js +1 -1
  326. package/lib/ACM-AXN/User/Add.js +2 -2
  327. package/lib/ACM-AXN/User/Container.js +2 -2
  328. package/lib/ACM-AXN/User/index.js +2 -2
  329. package/lib/ACM-AXN/ViewTemplate/Enum.d.ts +1 -0
  330. package/lib/ACM-AXN/ViewTemplate/Enum.js +1 -0
  331. package/lib/ACM-AXN/ViewTemplate/Preview.js +52 -42
  332. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.d.ts +12 -0
  333. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +69 -0
  334. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.test.d.ts +1 -0
  335. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.test.js +84 -0
  336. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
  337. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
  338. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +54 -159
  339. package/lib/ACM-AXN/ViewTemplate/common.js +1 -1
  340. package/lib/ACM-AXN/ViewTemplate/constant.d.ts +1 -0
  341. package/lib/ACM-AXN/ViewTemplate/constant.js +2 -1
  342. package/lib/ACM-AXN/ViewTemplate/container.d.ts +1 -1
  343. package/lib/ACM-AXN/ViewTemplate/container.js +36 -25
  344. package/lib/ACM-AXN/ViewTemplate/interface.d.ts +3 -7
  345. package/lib/ACM-AXN/Wizard/Container.d.ts +2 -0
  346. package/lib/ACM-AXN/Wizard/Container.js +46 -0
  347. package/lib/ACM-AXN/Wizard/Container.test.d.ts +1 -0
  348. package/lib/ACM-AXN/Wizard/Container.test.js +162 -0
  349. package/lib/ACM-AXN/Wizard/Context.d.ts +3 -0
  350. package/lib/ACM-AXN/Wizard/Context.js +5 -0
  351. package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.d.ts +11 -0
  352. package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.js +90 -0
  353. package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.test.d.ts +1 -0
  354. package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.test.js +113 -0
  355. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +14 -0
  356. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +88 -0
  357. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.d.ts +1 -0
  358. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +99 -0
  359. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.d.ts +14 -0
  360. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +161 -0
  361. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.test.d.ts +1 -0
  362. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.test.js +255 -0
  363. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.d.ts +2 -0
  364. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +150 -0
  365. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.test.d.ts +1 -0
  366. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.test.js +223 -0
  367. package/lib/ACM-AXN/Wizard/Hooks.d.ts +2 -0
  368. package/lib/ACM-AXN/Wizard/Hooks.js +12 -0
  369. package/lib/ACM-AXN/Wizard/Types.d.ts +217 -0
  370. package/lib/ACM-AXN/Wizard/Types.js +22 -0
  371. package/lib/ACM-AXN/Wizard/Utils.d.ts +27 -0
  372. package/lib/ACM-AXN/Wizard/Utils.js +31 -0
  373. package/lib/ACM-AXN/Wizard/index.d.ts +3 -0
  374. package/lib/ACM-AXN/Wizard/index.js +40 -0
  375. package/lib/AWING/AsyncAutocomplete/index.js +2 -2
  376. package/lib/AWING/Chart/BarLineComponent.js +105 -9
  377. package/lib/AWING/Chart/PieComponent.js +2 -2
  378. package/lib/AWING/Chart/Styles.js +49 -16
  379. package/lib/AWING/DataForm/DataInput.js +22 -18
  380. package/lib/AWING/DataGrid/index.js +9 -1
  381. package/lib/AWING/DataGrid/interface.d.ts +39 -1
  382. package/lib/AWING/DateRangePicker/component.js +32 -14
  383. package/lib/AWING/Form/Utils/Types.d.ts +4 -0
  384. package/lib/AWING/Form/useForm.d.ts +2 -3
  385. package/lib/AWING/Form/useForm.js +6 -4
  386. package/lib/AWING/GroupTable/GroupTable.js +7 -7
  387. package/lib/AWING/Hooks/index.d.ts +1 -0
  388. package/lib/AWING/Hooks/index.js +17 -0
  389. package/lib/AWING/Hooks/useGetData.d.ts +9 -0
  390. package/lib/AWING/Hooks/useGetData.js +26 -0
  391. package/lib/AWING/NumberFormat/index.d.ts +3 -1
  392. package/lib/AWING/NumberFormat/index.js +2 -2
  393. package/lib/AWING/ultis/validation.d.ts +1 -0
  394. package/lib/AWING/ultis/validation.js +22 -15
  395. package/lib/Commons/Components/ClassicDrawer.js +2 -2
  396. package/lib/Commons/Components/DeprecatedEnhancedDialog.js +1 -1
  397. package/lib/Commons/Hooks/usePath.js +3 -3
  398. package/lib/Utils/Helpers.d.ts +11 -3
  399. package/lib/Utils/Helpers.js +65 -4
  400. package/lib/translate/en/translation.json +84 -7
  401. package/lib/translate/vi/translation.json +86 -7
  402. package/package.json +128 -126
  403. package/lib/ACM-AXN/Campaign/Constant.d.ts +0 -38
  404. package/lib/ACM-AXN/Campaign/Constant.js +0 -41
  405. package/lib/ACM-AXN/CampaignPlan/Constant.d.ts +0 -8
  406. package/lib/ACM-AXN/CampaignPlan/Constant.js +0 -11
  407. package/lib/ACM-AXN/Directory/Constant.d.ts +0 -13
  408. package/lib/ACM-AXN/Directory/Constant.js +0 -15
  409. package/lib/ACM-AXN/GroupUser/Constants.d.ts +0 -7
  410. package/lib/ACM-AXN/GroupUser/Constants.js +0 -10
  411. package/lib/ACM-AXN/PlaceGroup/Constant.d.ts +0 -9
  412. package/lib/ACM-AXN/PlaceGroup/Constant.js +0 -12
  413. package/lib/ACM-AXN/ScheduleCompletionRate/Constant.d.ts +0 -8
  414. package/lib/ACM-AXN/ScheduleCompletionRate/Constant.js +0 -11
  415. package/lib/ACM-AXN/TaskScheduler/Constant.d.ts +0 -9
  416. package/lib/ACM-AXN/TaskScheduler/Constant.js +0 -13
  417. package/lib/ACM-AXN/TaskScheduler/Enums.d.ts +0 -4
  418. package/lib/ACM-AXN/TaskScheduler/Enums.js +0 -8
  419. package/lib/ACM-AXN/Template/Constants.d.ts +0 -0
  420. package/lib/ACM-AXN/Template/Constants.js +0 -1
  421. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Events.d.ts +0 -5
  422. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Events.js +0 -41
  423. package/lib/ACM-AXN/TransactionLog/Constant.d.ts +0 -10
  424. package/lib/ACM-AXN/TransactionLog/Constant.js +0 -13
  425. package/lib/ACM-AXN/User/Constants.d.ts +0 -2
  426. package/lib/ACM-AXN/User/Constants.js +0 -5
@@ -0,0 +1,14 @@
1
+ /// <reference types="react" />
2
+ import { IDirectory, TemplateType, IWizardTemplate } from '../Types';
3
+ interface PropsRowTemplate {
4
+ pageCode: string;
5
+ directories: IDirectory[];
6
+ templateTypes: TemplateType[];
7
+ template: IWizardTemplate;
8
+ disabledIconDelete: boolean;
9
+ onChangeRow: (fieldValue: any, sortOrder: number) => void;
10
+ onUpdateWizardLogin?: (type: string, sortOrder?: number) => void;
11
+ }
12
+ declare function RowTemplate(props: PropsRowTemplate): import("react/jsx-runtime").JSX.Element;
13
+ declare const _default: import("react").MemoExoticComponent<typeof RowTemplate>;
14
+ export default _default;
@@ -0,0 +1,161 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ var jsx_runtime_1 = require("react/jsx-runtime");
18
+ var react_1 = require("react");
19
+ var react_i18next_1 = require("react-i18next");
20
+ var Delete_1 = __importDefault(require("@mui/icons-material/Delete"));
21
+ var material_1 = require("@mui/material");
22
+ var Hooks_1 = __importDefault(require("../Hooks"));
23
+ var Utils_1 = require("../Utils");
24
+ var validation_1 = require("../../../AWING/ultis/validation");
25
+ function RowTemplate(props) {
26
+ var _a;
27
+ var pageCode = props.pageCode, template = props.template, onChangeRow = props.onChangeRow, directories = props.directories, templateTypes = props.templateTypes, onUpdateWizardLogin = props.onUpdateWizardLogin, _b = props.disabledIconDelete, disabledIconDelete = _b === void 0 ? false : _b;
28
+ var t = (0, react_i18next_1.useTranslation)().t;
29
+ var service = (0, Hooks_1.default)().service;
30
+ // DATA => Chọn Template
31
+ var _c = (0, react_1.useState)([]), templates = _c[0], setTemplates = _c[1];
32
+ // DATA => Các trường dữ liệu
33
+ var _d = (0, react_1.useState)(), templateModel = _d[0], setTemplateModel = _d[1];
34
+ // DATA ROW TEMPLATE
35
+ var _e = (0, react_1.useState)(function () {
36
+ var _a;
37
+ return (__assign(__assign({}, template), { templateTypeId: 0, directoryId: ((_a = directories[0]) === null || _a === void 0 ? void 0 : _a.directoryId) || '' }));
38
+ }), wizardTemplate = _e[0], setWizardTemplate = _e[1];
39
+ // disabled => Các trường dữ liệu => call API
40
+ var _f = (0, react_1.useState)(true), isLoadingParameter = _f[0], setIsLoadingParameter = _f[1];
41
+ var _g = (0, react_1.useState)({
42
+ status: true,
43
+ message: '',
44
+ }), validFieldName = _g[0], setValidFieldName = _g[1];
45
+ (0, react_1.useLayoutEffect)(function () {
46
+ setWizardTemplate(function (oldWizardData) { return (__assign(__assign({}, oldWizardData), template)); });
47
+ }, [template]);
48
+ (0, react_1.useEffect)(function () {
49
+ if (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.directoryId) {
50
+ !isLoadingParameter && setIsLoadingParameter(true);
51
+ service
52
+ .templatesGetByDirectoryId(wizardTemplate.directoryId)
53
+ .then(function (template_) {
54
+ var newTemplates = template_ === null || template_ === void 0 ? void 0 : template_.filter(function (item) {
55
+ return item.pageCode === pageCode &&
56
+ (wizardTemplate.templateTypeId === 0 ||
57
+ item.templateTypeId ===
58
+ wizardTemplate.templateTypeId);
59
+ });
60
+ // Sắp xếp chuỗi theo thứ tự tăng dần (a => z).
61
+ newTemplates.sort(function (a, b) {
62
+ return ((a === null || a === void 0 ? void 0 : a.description) || '').localeCompare((b === null || b === void 0 ? void 0 : b.description) || '');
63
+ });
64
+ setTemplates(newTemplates);
65
+ })
66
+ .finally(function () {
67
+ setIsLoadingParameter(false);
68
+ });
69
+ }
70
+ // eslint-disable-next-line react-hooks/exhaustive-deps
71
+ }, [pageCode, wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.directoryId]);
72
+ (0, react_1.useEffect)(function () {
73
+ if (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId) {
74
+ service
75
+ .templatesGet(wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId)
76
+ .then(setTemplateModel);
77
+ }
78
+ // eslint-disable-next-line react-hooks/exhaustive-deps
79
+ }, [wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId]);
80
+ var handleChange = function (fieldName, value) {
81
+ var _a, _b, _c;
82
+ // Update dữ liệu nội bộ
83
+ var newWizardTemplate = __assign(__assign({}, wizardTemplate), (_a = {}, _a[fieldName] = value, _a));
84
+ if (fieldName === 'directoryId' || fieldName === 'templateTypeId') {
85
+ newWizardTemplate.templateId = '';
86
+ newWizardTemplate.templateParameterDisplayFieldNames = [];
87
+ }
88
+ else if (fieldName === 'templateId') {
89
+ newWizardTemplate.templateParameterDisplayFieldNames = [];
90
+ }
91
+ setWizardTemplate(newWizardTemplate);
92
+ // Update dữ liệu API
93
+ if (fieldName !== 'directoryId' && fieldName !== 'templateTypeId') {
94
+ if (fieldName === 'name') {
95
+ var _d = (0, validation_1.textValidation)(value, 50, true), valid = _d.valid, message = _d.message;
96
+ setValidFieldName({ status: valid, message: message });
97
+ onChangeRow((_b = {},
98
+ _b[fieldName] = typeof value === 'string'
99
+ ? valid
100
+ ? value.trim()
101
+ : ''
102
+ : value,
103
+ _b), (template === null || template === void 0 ? void 0 : template.sortOrder) || 0);
104
+ }
105
+ else {
106
+ onChangeRow((_c = {},
107
+ _c[fieldName] = typeof value === 'string' ? value.trim() : value,
108
+ _c), (template === null || template === void 0 ? void 0 : template.sortOrder) || 0);
109
+ }
110
+ }
111
+ };
112
+ var handleDeleteRowTemplate = function () {
113
+ onUpdateWizardLogin &&
114
+ onUpdateWizardLogin(Utils_1.TYPE_LOGIN_TEMPLATE.REMOVE, template.sortOrder);
115
+ };
116
+ return ((0, jsx_runtime_1.jsxs)(material_1.Box, { component: "div", sx: {
117
+ flex: 1,
118
+ display: 'flex',
119
+ flexDirection: 'row',
120
+ alignItems: 'center',
121
+ }, children: [(0, jsx_runtime_1.jsx)(material_1.TextField, { id: "name", required: true, fullWidth: true, variant: "standard", label: t('Common.Name'), "data-testid": "Common.Name", value: wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.name, error: !validFieldName.status, sx: { mr: 2, minWidth: '100px', maxWidth: '140px' }, helperText: !validFieldName.status && validFieldName.message, onChange: function (event) { return handleChange('name', event.target.value); } }), (0, jsx_runtime_1.jsx)(material_1.TextField, { select: true, fullWidth: true, id: "directoryId", variant: "standard", label: t('Wizard.Directory'), "data-testid": "Wizard.Directory", disabled: !(directories === null || directories === void 0 ? void 0 : directories.length), value: (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.directoryId) || '', sx: { mr: 2, minWidth: '140px', maxWidth: '180px' }, onChange: function (event) {
122
+ return handleChange('directoryId', event.target.value);
123
+ }, children: directories.map(function (directory) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { style: {
124
+ paddingLeft: directory.level &&
125
+ directory.level >= 2 &&
126
+ directory.isSystem !== true
127
+ ? (directory.level - 2) * 24 + 'px'
128
+ : '8px',
129
+ }, value: directory.directoryId, children: directory.name }, directory.directoryId)); }) }), (0, jsx_runtime_1.jsxs)(material_1.TextField, { select: true, fullWidth: true, variant: "standard", id: "templateTypeId", label: t('Common.TypeTemplate'), "data-testid": "Common.TypeTemplate", value: wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateTypeId, sx: { mr: 2, minWidth: '120px', maxWidth: '140px' }, onChange: function (event) {
130
+ return handleChange('templateTypeId', event.target.value);
131
+ }, children: [(0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: 0, children: t('Common.SelectAll') }), templateTypes.map(function (templateType) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: templateType.id, children: templateType.name }, templateType.id)); })] }), (0, jsx_runtime_1.jsx)(material_1.TextField, { select: true, fullWidth: true, required: true, id: "template", variant: "standard", disabled: !(templates === null || templates === void 0 ? void 0 : templates.length), sx: { mr: 2, minWidth: '140px' }, label: t('Wizard.SelectTemplate'), "data-testid": "Wizard.SelectTemplate", value: (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId) || '', onChange: function (event) {
132
+ return handleChange('templateId', event.target.value);
133
+ }, children: templates
134
+ .filter(function (template) {
135
+ return (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateTypeId) === 0 ||
136
+ template.templateTypeId ===
137
+ (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateTypeId);
138
+ })
139
+ .map(function (temp) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: temp.id, children: temp.description }, temp.id)); }) }), (0, jsx_runtime_1.jsxs)(material_1.FormControl, { fullWidth: true, variant: "standard", sx: { mr: 2, minWidth: '180px' }, children: [(0, jsx_runtime_1.jsx)(material_1.InputLabel, { htmlFor: "component-simple", "data-testid": "Wizard.FieldNames", children: t('Wizard.FieldNames') }), (0, jsx_runtime_1.jsx)(material_1.Select, { multiple: true, id: "component-simple", value: (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateParameterDisplayFieldNames) || [], disabled: isLoadingParameter ||
140
+ !(templates === null || templates === void 0 ? void 0 : templates.length) ||
141
+ !(templateModel === null || templateModel === void 0 ? void 0 : templateModel.templateParameters), onChange: function (event) {
142
+ return handleChange('templateParameterDisplayFieldNames', event.target.value);
143
+ }, renderValue: function (selected) {
144
+ var _a;
145
+ var fieldNames = selected;
146
+ return (_a = templateModel === null || templateModel === void 0 ? void 0 : templateModel.templateParameters) === null || _a === void 0 ? void 0 : _a.filter(function (parameter) {
147
+ return fieldNames.includes(parameter.fieldName || '');
148
+ }).map(function (parameter) {
149
+ return parameter.labelName;
150
+ }).join(', ');
151
+ }, MenuProps: {
152
+ PaperProps: {
153
+ style: {
154
+ maxHeight: 224,
155
+ },
156
+ },
157
+ }, children: (_a = templateModel === null || templateModel === void 0 ? void 0 : templateModel.templateParameters) === null || _a === void 0 ? void 0 : _a.map(function (parameter, idx) { return ((0, jsx_runtime_1.jsxs)(material_1.MenuItem, { value: parameter.fieldName, children: [(0, jsx_runtime_1.jsx)(material_1.Checkbox, { color: "primary", checked: ((wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateParameterDisplayFieldNames) ||
158
+ []).indexOf((parameter === null || parameter === void 0 ? void 0 : parameter.fieldName) || '') >
159
+ -1 }), (0, jsx_runtime_1.jsx)(material_1.ListItemText, { primary: parameter.labelName })] }, idx)); }) })] }), (0, jsx_runtime_1.jsx)(material_1.IconButton, { edge: "end", "aria-label": "delete", "data-testid": "deleteIcon", disabled: disabledIconDelete, onClick: handleDeleteRowTemplate, children: (0, jsx_runtime_1.jsx)(Delete_1.default, {}) })] }));
160
+ }
161
+ exports.default = (0, react_1.memo)(RowTemplate);
@@ -0,0 +1,255 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
49
+ var __importDefault = (this && this.__importDefault) || function (mod) {
50
+ return (mod && mod.__esModule) ? mod : { "default": mod };
51
+ };
52
+ Object.defineProperty(exports, "__esModule", { value: true });
53
+ var jsx_runtime_1 = require("react/jsx-runtime");
54
+ /* eslint-disable testing-library/no-wait-for-side-effects */
55
+ var react_1 = require("@testing-library/react");
56
+ var RowTemplate_1 = __importDefault(require("./RowTemplate"));
57
+ var Utils_1 = require("../Utils");
58
+ var directories = [
59
+ {
60
+ description: null,
61
+ directoryId: '4711650767517730267',
62
+ directoryPath: '.0.99.4711650767517730267.',
63
+ isFile: false,
64
+ isSystem: true,
65
+ level: 2,
66
+ name: 'SYSTEM TEMPLATE',
67
+ objectTypeCode: 'template',
68
+ order: 0,
69
+ parentDirectoryId: '99',
70
+ },
71
+ {
72
+ description: null,
73
+ directoryId: '5084661221099431199',
74
+ directoryPath: '.0.99.4711650767517730267.5084661221099431199.',
75
+ isFile: false,
76
+ isSystem: false,
77
+ level: 3,
78
+ name: 'Beta template',
79
+ objectTypeCode: 'template',
80
+ order: 0,
81
+ parentDirectoryId: '4711650767517730267',
82
+ },
83
+ ];
84
+ var templateTypes = [
85
+ { id: 1, name: 'Banner', templateTypeCode: 'lgn' },
86
+ { id: 5, name: 'Customize', templateTypeCode: 'lgn' },
87
+ ];
88
+ var templates = [
89
+ {
90
+ autoField: '',
91
+ description: '07.[DEFAULT] Data Collection 1 Page_v1.0',
92
+ directoryId: '5183679953246990989',
93
+ directoryPath: '.0.99.4711650767517730267.5183679953246990989.4619609303918768290.',
94
+ id: '4619609303918768290',
95
+ layoutId: '0',
96
+ name: '',
97
+ pageCode: 'lgn',
98
+ templateHtml: '<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1,user-scalable=0"/>\r\n<link href="/static/Files/template/5246961620307474338/template_cpa_v1_0.css?432" rel="stylesheet" />\r\n<div id="cpa-container" style="width:100%">\r\n <img id="background_img_1" src="{cpa_1_banner_1}">\r\n <div class="box-wrapper-2">\r\n <table class="form_table formtable-fix form_table_text" id="cpa_field_list">\r\n </table>\r\n <table class="form_table btn-form-label form_table_text form-paddingtop">\r\n <tr>\r\n <td>\r\n <button class="btn_action btn_left btn_form_2" onclick="nextView();">\r\n <strong id="btn_left_text2">KẾT NỐI<br/>INTERNET NGAY</strong>\r\n <br/>\r\n <small class="smallen">(ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n <td>\r\n <button class="btn_action btn_right btn_form_2" onclick="doSubmit()">\r\n <strong id="btn_right_text2">ĐĂNG KÝ<br/>& KẾT NỐI INTERNET</strong>\r\n <br/>\r\n <small class="smallen">(REGISTER & ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n</div>\r\n<textarea id="textLeftButtonBanner2" style="display: none;">{cpa_1_banner_2}</textarea>\r\n<textarea id="textRightButtonBanner2" style="display: none;">{cpa_1_banner_3}</textarea>\r\n<div id="continue_scroll" style="display: none;">\r\n <a id="continue_text"><span></span>Còn tiếp</a>\r\n</div>\r\n<script>\r\nvar textLeftButtonBanner2 = $("#textLeftButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar textRightButtonBanner2 = $("#textRightButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar colorCodeLeftButton = "#"+"{cpa_1_banner_4}";\r\nvar colorCodeRightButton = "#"+"{cpa_1_banner_5}";\r\nvar colorTextLeftButton = "#"+"{cpa_1_banner_6}";\r\nvar colorTextRightButton = "#"+"{cpa_1_banner_7}";\r\nvar fieldList = [];\r\nvar nameFieldCheckbox = "{cpa_1_banner_8}" == "true" ? fieldList.push("name") : "";\r\nvar phoneFieldCheckbox = "{cpa_1_banner_9}" == "true" ? fieldList.push("phone") : "";\r\nvar emailFieldCheckbox = "{cpa_1_banner_10}" == "true" ? fieldList.push("email") : "";\r\nvar textFieldBackGroundColor = "{cpa_1_banner_11}";\r\nvar textFieldBorderColor = "#"+"{cpa_1_banner_12}";\r\n\r\nfieldList.forEach(function(item){\r\n if(item == "name"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'name\' name=\'name\' placeholder=\'Họ và tên\' class=\'input-text input-box-2 input-text-name\'></input><span class=\'tooltiptext\' id=\'tooltipname\'>Họ và tên không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "phone"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'number\' id = \'phone\' placeholder=\'Số điện thoại\' class=\'input-text input-box-2 input-text-phone\'></input><span class=\'tooltiptext\' id=\'tooltipphone\'>Số điện thoại không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "email"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'email\' placeholder=\'Email\' class=\'input-text input-box-2 input-text-email\' /><span class=\'tooltiptext\' id=\'tooltipemail\'>Email không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n});\r\nif(fieldList.length == 3) {\r\n $(".box-wrapper-2").addClass("three-field-form");\r\n}\r\nvar mInfo = detectDeviceInfo();\r\nvar windowheight = window.innerHeight;\r\nvar browserLang = navigator.language || navigator.userLanguage;\r\nif(browserLang !="vi-VN"){\r\n $("#continue_text").html("<span></span>More</a>");\r\n // $(".wa-button-maxview").addClass("wa-button-en");\r\n $("#continue_scroll").addClass("continue-en");\r\n}\r\nif(textLeftButtonBanner2.length > 0) { $("#btn_left_text2").html(textLeftButtonBanner2); }\r\nif(textRightButtonBanner2.length > 0) { $("#btn_right_text2").html(textRightButtonBanner2); }\r\n$(".btn_left").css({\r\n "background-color": colorCodeLeftButton,\r\n "color": colorTextLeftButton\r\n});\r\n$(".btn_right").css({\r\n "background-color": colorCodeRightButton,\r\n "color": colorTextRightButton\r\n});\r\nif(textFieldBackGroundColor.toLowerCase() == "màu xám") {\r\n $("td > .input-box-2").css("background-color", "#d9d9d9");\r\n}\r\n$("td > .input-box-2").css("border",\'1px solid \' + textFieldBorderColor);\r\n\r\nif(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(\'#continue_text\').css(\'color\', colorCodeLeftButton);\r\n $(\'#continue_text span\').css({\r\n "border-left":"5px solid " + colorCodeLeftButton,\r\n "border-bottom": "5px solid " + colorCodeLeftButton\r\n });\r\n}\r\n\r\n$("#continue_scroll").hide();\r\nfunction startAnimation(){\r\n $(\'#layoutHeader\').hide();\r\n if(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(window).off(\'scroll\');\r\n // var footerHeight = ($(\'#wa_hotline\').outerHeight() > 0 ) ? $(\'#wa_hotline\').outerHeight() : 32.4;\r\n // $(\'#cpa-container\').css(\'min-height\', windowheight - footerHeight);\r\n // $(\'#cpa-container\').css(\'background\', colorCodeBody);\r\n setTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));}, 750);\r\n $(document).on(\'touchend\', function() {\r\n setTimeout(function()\r\n {\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n });\r\n }\r\n else {\r\n window.onresize = function(event) {\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 3;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+5);\r\n };\r\n setTimeout(function(){\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 5;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+10);\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n }\r\n}\r\n$(".input-text").focus(function(){\r\n $("#tooltipphone").hide();\r\n $("#tooltipname").hide();\r\n $("#tooltipemail").hide();\r\n remove_error($(\'.input-text\'));\r\n});\r\nfunction goToForm(){\r\n $(\'.box-wrapper\').hide();\r\n $(\'.box-wrapper-2\').show();\r\n $(\'#background_img\').hide();\r\n $(\'#background_img_1\').show();\r\n}\r\nfunction doSubmit(){\r\n var phone = $(\'#phone\').val();\r\n var name = $(\'#name\').val();\r\n var email = $(\'#email\').val();\r\n var valObject = {name: name, phone: phone, email: email};\r\n if (validateDataCustomer(name,phone,email)){\r\n var eventObject = {};\r\n fieldList.forEach(function(item) {\r\n eventObject[item] = valObject[item];\r\n });\r\n postAnalyticEvent("eventcpa",JSON.stringify(eventObject));\r\n nextView();\r\n }\r\n}\r\nfunction validateDataCustomer(name,phone,email){\r\n var validate = true;\r\n if(fieldList.indexOf("name") !== -1){\r\n if ((!name)||(ContainNum(name))){\r\n set_error($(\'#name\'));\r\n set_errortooltip($(\'#tooltipname\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("phone") !== -1){\r\n phone = phone.replace(\'(+84)\', \'0\');\r\n phone = phone.replace(\'+84\', \'0\');\r\n phone = phone.replace(\'0084\', \'0\');\r\n phone = phone.replace(/ /g, \'\');\r\n if (phone != \'\') {\r\n var firstNumber = phone.substring(0, 2);\r\n if ((firstNumber == \'03\' || firstNumber == \'05\' || firstNumber == \'07\' || firstNumber == \'08\' || firstNumber == \'09\') && phone.length == 10) {\r\n if (phone.match(/^\\d{10}/)) {}\r\n } else if (firstNumber == \'01\' && phone.length == 11) {\r\n if (phone.match(/^\\d{11}/)) {}\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("email") !== -1){\r\n if (email != \'\') {\r\n if (!isEmail(email)){\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n else {\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n return validate;\r\n}\r\nfunction isEmail(email) {\r\n var regex = /^([a-zA-Z0-9_.+-])+\\@(([a-zA-Z0-9-])+\\.)+([a-zA-Z0-9]{2,4})+$/;\r\n return regex.test(email);\r\n}\r\nfunction ContainNum(t)\r\n{\r\n var regex = /\\d/g;\r\n return regex.test(t);\r\n}\r\nfunction set_error(element){\r\n element.addClass(\'_error\');\r\n}\r\nfunction set_errortooltip(element){\r\n element.show();\r\n}\r\nfunction remove_error(element){\r\n element.removeClass(\'_error\');\r\n}\r\nfunction continueScrollHandle(elm, scroll){\r\n if(checkVisible(elm)) {$(\'#continue_scroll\').hide();}\r\n else {$(\'#continue_scroll\').show();}\r\n}\r\nfunction checkVisible(elm){\r\n var viewHeight = Math.max(document.documentElement.clientHeight, window.innerHeight);\r\n if(elm != "" && elm != undefined){\r\n var rect = elm.getBoundingClientRect();\r\n return !(rect.bottom == 0 || rect.top - viewHeight >= -(rect.height - 12));\r\n }else{\r\n return true;\r\n }\r\n}\r\n</script>',
99
+ templateTypeId: 17,
100
+ validation: '',
101
+ },
102
+ {
103
+ autoField: '',
104
+ description: '08.[DEFAULT] Horizontal Video_v1.1',
105
+ directoryId: '5183679953246990989',
106
+ directoryPath: '.0.99.4711650767517730267.5183679953246990989.4631090508536728844.',
107
+ id: '4631090508536728844',
108
+ layoutId: '0',
109
+ name: '',
110
+ pageCode: 'lgn',
111
+ templateHtml: '<link href="/static/Files/template/4631090508536728844/video_horizontal_v1.1.css?01" rel="stylesheet" />\r\n<div id="horizontal-video-container" class="frame1">\r\n\t<div class="video">\r\n\t\t<div class="wpvideo">\r\n\t\t\t<video style="width: 100%" src="{video_1}" playsinline id="mVideo" poster="" preload="auto"></video> \r\n\t\t\t<img src="{video_3}" id="mImg" style="display:none;margin: 0px auto;">\r\n\t\t\t<div class="connection-container">\r\n\t\t\t\t<button id="connectToInternet" class="wa-button wa-button-view blur btn-bif wa-button-video" style="margin-top:0.5em;">BỎ QUA VIDEO TRONG <small class="smallen">(SKIP AD)</small><i id="countdowntimer" style="padding-left: 3px" class="countdown">6S</i></button>\r\n\t\t\t\t<a id="user-not-interest" class="class-user-interest" title="Cảm ơn, tôi muốn kết nối Internet ngay/ No thanks, just take me online" onclick="nextView()" style="display: none;">Cảm ơn, tôi muốn kết nối Internet ngay/ No thanks, just take me online </a>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n</div>\r\n<div id="continue_scroll_video" style="display: none;">\r\n\t<a id="continue_text_video"><span></span>Còn tiếp</a>\r\n</div>\r\n<script>\r\nvar browserLang = navigator.language || navigator.userLanguage;\r\nif(browserLang !="vi-VN"){\r\n\t$("#continue_text_video").html("<span></span>More</a>");\r\n\t$("#continue_scroll_video").addClass("continue-en");\r\n}\r\nvar mInfo = detectDeviceInfo();\r\nvar isShowBanner="{video_2}" == "true";banner="{video_3}";timeSkipAd = "{video_4}" == "" ? 6 : "{video_4}";colorButton = "#"+"{video_5}";colorTextButton = "#"+"{video_6}";textButton = "{video_7}";colorCodeBackgroundBanner = "#"+"{video_8}";isShowUserInterest = "{video_9}" == "true";\r\nif(Number(timeSkipAd) <= 0){\r\n\t$(\'#connectToInternet\').removeClass(\'blur\').html(\'BỎ QUA VIDEO <small class="smallen">(SKIP AD)</small>\').click(function () {\r\n\t\t\tdocument.body.style.backgroundColor = "#f5f5f5";\r\n\t\t\t\tif(isShowBanner){ showBanner();} else{connectToWifi();}\r\n\t});\r\n}\r\nif(Number(timeSkipAd) > 0){$(\'#countdowntimer\').html(timeSkipAd+"S");}\r\nif(mInfo.os == "iOS" || mInfo.os == "Android"){ \r\n\t$(\'.wa-button-video\').css({"background-color": colorButton,"color": colorTextButton});\r\n\t$(\'#continue_text_video\').css(\'color\', colorButton);\r\n\t$(\'#continue_text_video span\').css({\r\n\t\t"border-left":"5px solid " + colorButton,\r\n\t\t"border-bottom": "5px solid " + colorButton\r\n\t});\r\n}\r\nif(textButton =="") textButton ="KẾT NỐI INTERNET";\r\nif(banner == "") {\r\n\t$("#mImg").attr("src", "/static/Files/template/4631090508536728844/default_banner.png");\r\n}\r\nfunction startAnimation() {\r\n\t$(\'#layoutFooter\').hide();\r\n\t$(\'#layoutHeader\').hide();var videoId = document.getElementById(\'mVideo\');\r\n\tplayVideo();\r\n\t$(\'#mVideo\').on(\'pause\', function () {showBanner();});\r\n\t$(\'#mVideo\').on(\'play\', function () {\r\n\t\tdocument.body.style.backgroundColor = "rgb(33, 31, 31)";\r\n\t\tpostAnalyticEvent("View(Video)",JSON.stringify({}));\r\n\t\tif (mInfo.os == "iOS" && mInfo.os_value < 113) {\r\n\t\t\t\tdocument.body.style.backgroundColor = "#F5F5F5";\r\n\t\t} else {\r\n\t\t\t\t$("#connectToInternet").show();\r\n\t\t}\r\n\t\tsetTimeout(function () {if(Number(timeSkipAd) > 0) countDown(); }, 100);\r\n\t});\r\n\t$(\'#mVideo\').on(\'ended\', function () {\r\n\t\tpostAnalyticEvent("Completed_View(Video)",JSON.stringify({}));\r\n\t\tnextView();\r\n\t});\r\n\tfunction playVideo() { mVideo.play(); }\r\n\tif(mInfo.os !== "iOS" || mInfo.os !== "Android"){\r\n\t\t$(window).off(\'scroll\');\r\n\t\tsetTimeout(function(){\r\n\t\t\tvar rightContinue = ($(window).width() - $("#mVideo").width())/2 - $("#continue_scroll_video").width() + 5;\r\n\t\t\t$("#continue_scroll_video").css(\'right\', rightContinue);\r\n\t\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue+10);\r\n\t\t\tcontinueScrollHandle($("#connectToInternet")[0], $(\'#continue_scroll_video\'));\r\n\t\t}, 750);\r\n\t\t$(document).on(\'scroll\', function() {\r\n\t\t\tif($("#wa_hotline").height() > 0) {\r\n\t\t\t\tsetTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t\t}\r\n\t\t\telse \r\n\t\t\t\tsetTimeout(function(){continueScrollHandle($("#connectToInternet")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t});\r\n\t}\r\n}\r\nfunction countDown() {\r\n\t\tvar timeleft = 6;\r\n\t\tif(Number(timeSkipAd) > 0) timeleft = Number(timeSkipAd);\r\n\t\tvar downloadTimer = setInterval(function () {\r\n\t\t\t\ttimeleft--;\r\n\t\t\t\tvar x = document.getElementById("countdowntimer");\r\n\t\t\t\tx.textContent = timeleft + "S";\r\n\t\t\t\tif (timeleft <= 0) {\r\n\t\t\t\t\t\tclearInterval(downloadTimer);\r\n\t\t\t\t\t\t$(\'#connectToInternet\').removeClass(\'blur\').html(\'BỎ QUA VIDEO <small class="smallen">(SKIP AD)</small>\').click(function () {\r\n\t\t\t\t\t\t\t\tdocument.body.style.backgroundColor = "#F5F5F5";\r\n\t\t\t\t\t\t\t\t\tif(isShowBanner){ showBanner();} else{connectToWifi();}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t}, 1000);\r\n} \r\nfunction showBanner() {\r\n\t$(\'#layoutFooter\').show();\r\n\tmVideo.pause();\r\n\tdocument.body.style.backgroundColor = "#F5F5F5";\r\n\tcloseFullscreen();\r\n\tdocument.getElementById("mImg").style.display = "block";\r\n\t$("#mVideo").hide();\r\n\t$(\'#mImg\').click(function () { connectToWifi() });\r\n\t$(\'#connectToInternet\').removeClass(\'blur\');\r\n $(\'#connectToInternet\').unbind(\'click\');\r\n\t$(\'#connectToInternet\').addClass(\'connectInternet\').html(textButton+\'<BR/><small class="smallen">(ACCESS INTERNET)</small>\').click(function () {\r\n connectToWifi();\r\n\t});\r\n\tif(isShowUserInterest) $(\'#user-not-interest\').show();\r\n\tif(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n\t\t$(window).off(\'scroll\');\r\n\t\tvar windowheight = window.innerHeight;\r\n\t\tif(windowheight < 700) {\r\n\t\t\t$("#connectToInternet").addClass("wa-button-video-continue");\r\n\t\t}\r\n \thandleFullscreenVideoBanner();\r\n\t\tif(isShowUserInterest){$("#connectToInternet").addClass("wa-button-video-continue-userInterest");}\r\n\t\tvar rightContinue = ($(window).width() - $(".wa-button-video").width())/2 - $("#continue_scroll_video").width();\r\n\t\t$("#continue_scroll_video").css(\'right\', rightContinue-1);\r\n\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue-1);\r\n\t\tsetTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t$(document).on(\'touchend\', function() {\r\n\t\t\tsetTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t});\r\n\t}\r\n\telse {\r\n\t\twindow.onresize = function(event) {\r\n\t\t\tvar rightContinue = ($(window).width() - $("#mImg").width())/2 - $("#continue_scroll_video").width() + 3;\r\n\t\t\t$("#continue_scroll_video").css(\'right\', rightContinue);\r\n\t\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue+5);\r\n\t\t};\r\n\t\tsetTimeout(function(){\r\n\t\t\tvar rightContinue = ($(window).width() - $("#mImg").width())/2 - $("#continue_scroll_video").width() + 5;\r\n\t\t\t$("#continue_scroll_video").css(\'right\', rightContinue);\r\n\t\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue+10);\r\n\t\t\tcontinueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));\r\n\t\t}, 750);\r\n\t}\r\n}\r\nfunction handleFullscreenVideoBanner() {\r\n var footerHeight = ($(\'#wa_hotline\').outerHeight() > 0 ) ? $(\'#wa_hotline\').outerHeight() : 32.4;\r\n $(\'#horizontal-video-container\').css(\'min-height\', window.innerHeight - footerHeight);\r\n $(\'#horizontal-video-container\').css(\'background\', colorCodeBackgroundBanner);\r\n}\r\nfunction connectToWifi(){\r\n\tif(isShowUserInterest) {postAnalyticEvent("user_interest",JSON.stringify({}));}\r\n\tnextView();\r\n}\r\nfunction continueScrollHandle(elm, scroll){\r\n\tif(checkVisible(elm)) { scroll.hide(); }\r\n\telse { scroll.show(); }\r\n}\r\nfunction checkVisible(elm) {\r\n\tvar viewHeight = Math.max(document.documentElement.clientHeight, window.innerHeight);\r\n\tif(elm != "" && elm != undefined){\r\n\t\tvar rect = elm.getBoundingClientRect();\r\n\t\treturn !(rect.bottom == 0 || rect.top - viewHeight >= -(rect.height - 12));\r\n\t}else{\r\n\t\treturn true;\r\n\t}\r\n}\r\nfunction closeFullscreen() {\r\n\tif (document.getElementById(\'mVideo\').exitFullscreen) {\r\n\t\tdocument.getElementById(\'mVideo\').exitFullscreen();\r\n\t} else if (document.getElementById(\'mVideo\').mozCancelFullScreen) { /* Firefox */\r\n\t\tdocument.getElementById(\'mVideo\').mozCancelFullScreen();\r\n\t} else if (document.getElementById(\'mVideo\').webkitExitFullscreen) { /* Chrome, Safari and Opera */\r\n\t\tdocument.getElementById(\'mVideo\').webkitExitFullscreen();\r\n\t} else if (document.getElementById(\'mVideo\').msExitFullscreen) { /* IE/Edge */\r\n\t\tdocument.getElementById(\'mVideo\').msExitFullscreen();\r\n\t}\r\n}\r\n</script>',
112
+ templateTypeId: 18,
113
+ validation: '',
114
+ },
115
+ ];
116
+ var templateModel = {
117
+ template: {
118
+ autoField: '',
119
+ description: '07.[DEFAULT] Data Collection 1 Page_v1.0',
120
+ directoryId: '5183679953246990989',
121
+ directoryPath: '.0.99.4711650767517730267.5183679953246990989.4619609303918768290.',
122
+ id: '4619609303918768290',
123
+ layoutId: '0',
124
+ name: '',
125
+ pageCode: 'lgn',
126
+ templateHtml: '<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1,user-scalable=0"/>\r\n<link href="/static/Files/template/5246961620307474338/template_cpa_v1_0.css?432" rel="stylesheet" />\r\n<div id="cpa-container" style="width:100%">\r\n <img id="background_img_1" src="{cpa_1_banner_1}">\r\n <div class="box-wrapper-2">\r\n <table class="form_table formtable-fix form_table_text" id="cpa_field_list">\r\n </table>\r\n <table class="form_table btn-form-label form_table_text form-paddingtop">\r\n <tr>\r\n <td>\r\n <button class="btn_action btn_left btn_form_2" onclick="nextView();">\r\n <strong id="btn_left_text2">KẾT NỐI<br/>INTERNET NGAY</strong>\r\n <br/>\r\n <small class="smallen">(ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n <td>\r\n <button class="btn_action btn_right btn_form_2" onclick="doSubmit()">\r\n <strong id="btn_right_text2">ĐĂNG KÝ<br/>& KẾT NỐI INTERNET</strong>\r\n <br/>\r\n <small class="smallen">(REGISTER & ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n</div>\r\n<textarea id="textLeftButtonBanner2" style="display: none;">{cpa_1_banner_2}</textarea>\r\n<textarea id="textRightButtonBanner2" style="display: none;">{cpa_1_banner_3}</textarea>\r\n<div id="continue_scroll" style="display: none;">\r\n <a id="continue_text"><span></span>Còn tiếp</a>\r\n</div>\r\n<script>\r\nvar textLeftButtonBanner2 = $("#textLeftButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar textRightButtonBanner2 = $("#textRightButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar colorCodeLeftButton = "#"+"{cpa_1_banner_4}";\r\nvar colorCodeRightButton = "#"+"{cpa_1_banner_5}";\r\nvar colorTextLeftButton = "#"+"{cpa_1_banner_6}";\r\nvar colorTextRightButton = "#"+"{cpa_1_banner_7}";\r\nvar fieldList = [];\r\nvar nameFieldCheckbox = "{cpa_1_banner_8}" == "true" ? fieldList.push("name") : "";\r\nvar phoneFieldCheckbox = "{cpa_1_banner_9}" == "true" ? fieldList.push("phone") : "";\r\nvar emailFieldCheckbox = "{cpa_1_banner_10}" == "true" ? fieldList.push("email") : "";\r\nvar textFieldBackGroundColor = "{cpa_1_banner_11}";\r\nvar textFieldBorderColor = "#"+"{cpa_1_banner_12}";\r\n\r\nfieldList.forEach(function(item){\r\n if(item == "name"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'name\' name=\'name\' placeholder=\'Họ và tên\' class=\'input-text input-box-2 input-text-name\'></input><span class=\'tooltiptext\' id=\'tooltipname\'>Họ và tên không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "phone"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'number\' id = \'phone\' placeholder=\'Số điện thoại\' class=\'input-text input-box-2 input-text-phone\'></input><span class=\'tooltiptext\' id=\'tooltipphone\'>Số điện thoại không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "email"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'email\' placeholder=\'Email\' class=\'input-text input-box-2 input-text-email\' /><span class=\'tooltiptext\' id=\'tooltipemail\'>Email không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n});\r\nif(fieldList.length == 3) {\r\n $(".box-wrapper-2").addClass("three-field-form");\r\n}\r\nvar mInfo = detectDeviceInfo();\r\nvar windowheight = window.innerHeight;\r\nvar browserLang = navigator.language || navigator.userLanguage;\r\nif(browserLang !="vi-VN"){\r\n $("#continue_text").html("<span></span>More</a>");\r\n // $(".wa-button-maxview").addClass("wa-button-en");\r\n $("#continue_scroll").addClass("continue-en");\r\n}\r\nif(textLeftButtonBanner2.length > 0) { $("#btn_left_text2").html(textLeftButtonBanner2); }\r\nif(textRightButtonBanner2.length > 0) { $("#btn_right_text2").html(textRightButtonBanner2); }\r\n$(".btn_left").css({\r\n "background-color": colorCodeLeftButton,\r\n "color": colorTextLeftButton\r\n});\r\n$(".btn_right").css({\r\n "background-color": colorCodeRightButton,\r\n "color": colorTextRightButton\r\n});\r\nif(textFieldBackGroundColor.toLowerCase() == "màu xám") {\r\n $("td > .input-box-2").css("background-color", "#d9d9d9");\r\n}\r\n$("td > .input-box-2").css("border",\'1px solid \' + textFieldBorderColor);\r\n\r\nif(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(\'#continue_text\').css(\'color\', colorCodeLeftButton);\r\n $(\'#continue_text span\').css({\r\n "border-left":"5px solid " + colorCodeLeftButton,\r\n "border-bottom": "5px solid " + colorCodeLeftButton\r\n });\r\n}\r\n\r\n$("#continue_scroll").hide();\r\nfunction startAnimation(){\r\n $(\'#layoutHeader\').hide();\r\n if(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(window).off(\'scroll\');\r\n // var footerHeight = ($(\'#wa_hotline\').outerHeight() > 0 ) ? $(\'#wa_hotline\').outerHeight() : 32.4;\r\n // $(\'#cpa-container\').css(\'min-height\', windowheight - footerHeight);\r\n // $(\'#cpa-container\').css(\'background\', colorCodeBody);\r\n setTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));}, 750);\r\n $(document).on(\'touchend\', function() {\r\n setTimeout(function()\r\n {\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n });\r\n }\r\n else {\r\n window.onresize = function(event) {\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 3;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+5);\r\n };\r\n setTimeout(function(){\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 5;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+10);\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n }\r\n}\r\n$(".input-text").focus(function(){\r\n $("#tooltipphone").hide();\r\n $("#tooltipname").hide();\r\n $("#tooltipemail").hide();\r\n remove_error($(\'.input-text\'));\r\n});\r\nfunction goToForm(){\r\n $(\'.box-wrapper\').hide();\r\n $(\'.box-wrapper-2\').show();\r\n $(\'#background_img\').hide();\r\n $(\'#background_img_1\').show();\r\n}\r\nfunction doSubmit(){\r\n var phone = $(\'#phone\').val();\r\n var name = $(\'#name\').val();\r\n var email = $(\'#email\').val();\r\n var valObject = {name: name, phone: phone, email: email};\r\n if (validateDataCustomer(name,phone,email)){\r\n var eventObject = {};\r\n fieldList.forEach(function(item) {\r\n eventObject[item] = valObject[item];\r\n });\r\n postAnalyticEvent("eventcpa",JSON.stringify(eventObject));\r\n nextView();\r\n }\r\n}\r\nfunction validateDataCustomer(name,phone,email){\r\n var validate = true;\r\n if(fieldList.indexOf("name") !== -1){\r\n if ((!name)||(ContainNum(name))){\r\n set_error($(\'#name\'));\r\n set_errortooltip($(\'#tooltipname\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("phone") !== -1){\r\n phone = phone.replace(\'(+84)\', \'0\');\r\n phone = phone.replace(\'+84\', \'0\');\r\n phone = phone.replace(\'0084\', \'0\');\r\n phone = phone.replace(/ /g, \'\');\r\n if (phone != \'\') {\r\n var firstNumber = phone.substring(0, 2);\r\n if ((firstNumber == \'03\' || firstNumber == \'05\' || firstNumber == \'07\' || firstNumber == \'08\' || firstNumber == \'09\') && phone.length == 10) {\r\n if (phone.match(/^\\d{10}/)) {}\r\n } else if (firstNumber == \'01\' && phone.length == 11) {\r\n if (phone.match(/^\\d{11}/)) {}\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("email") !== -1){\r\n if (email != \'\') {\r\n if (!isEmail(email)){\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n else {\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n return validate;\r\n}\r\nfunction isEmail(email) {\r\n var regex = /^([a-zA-Z0-9_.+-])+\\@(([a-zA-Z0-9-])+\\.)+([a-zA-Z0-9]{2,4})+$/;\r\n return regex.test(email);\r\n}\r\nfunction ContainNum(t)\r\n{\r\n var regex = /\\d/g;\r\n return regex.test(t);\r\n}\r\nfunction set_error(element){\r\n element.addClass(\'_error\');\r\n}\r\nfunction set_errortooltip(element){\r\n element.show();\r\n}\r\nfunction remove_error(element){\r\n element.removeClass(\'_error\');\r\n}\r\nfunction continueScrollHandle(elm, scroll){\r\n if(checkVisible(elm)) {$(\'#continue_scroll\').hide();}\r\n else {$(\'#continue_scroll\').show();}\r\n}\r\nfunction checkVisible(elm){\r\n var viewHeight = Math.max(document.documentElement.clientHeight, window.innerHeight);\r\n if(elm != "" && elm != undefined){\r\n var rect = elm.getBoundingClientRect();\r\n return !(rect.bottom == 0 || rect.top - viewHeight >= -(rect.height - 12));\r\n }else{\r\n return true;\r\n }\r\n}\r\n</script>',
127
+ templateTypeId: 17,
128
+ validation: '',
129
+ },
130
+ templateParameters: [
131
+ {
132
+ childrens: [],
133
+ defaultValue: '',
134
+ fieldName: 'cpa_1_banner_1',
135
+ fieldType: 'image',
136
+ id: '22302',
137
+ isRequired: true,
138
+ labelName: 'File Banner',
139
+ templateId: '4619609303918768290',
140
+ },
141
+ {
142
+ childrens: [],
143
+ defaultValue: 'Màu trắng\\nMàu xám',
144
+ fieldName: 'cpa_1_banner_11',
145
+ fieldType: 'dropdownlist',
146
+ id: '22303',
147
+ isRequired: false,
148
+ labelName: 'Mã màu nền trường điền',
149
+ templateId: '4619609303918768290',
150
+ },
151
+ ],
152
+ };
153
+ var clientMethod = {
154
+ templatesGetByDirectoryId: function (_id) {
155
+ return Promise.resolve(templates);
156
+ },
157
+ templatesGet: function () { return function (_id) {
158
+ Promise.resolve(templateModel);
159
+ }; },
160
+ };
161
+ // Mock Hooks
162
+ jest.mock('../Hooks', function () { return ({
163
+ __esModule: true,
164
+ default: function () { return ({
165
+ service: {
166
+ templatesGetByDirectoryId: jest.fn(function (_id) {
167
+ return Promise.resolve(clientMethod.templatesGetByDirectoryId(_id));
168
+ }),
169
+ templatesGet: jest.fn(function (_id) {
170
+ return Promise.resolve(clientMethod.templatesGet());
171
+ }),
172
+ },
173
+ }); },
174
+ }); });
175
+ // Mock đa ngữ
176
+ jest.mock('react-i18next', function () { return (__assign(__assign({}, jest.requireActual('react-i18next')), { useTranslation: function () { return ({ t: jest.fn(function (key) { return key; }) }); } })); });
177
+ describe('RowTemplate component', function () {
178
+ var mockProps = {
179
+ pageCode: 'lgn',
180
+ template: { sortOrder: 1 },
181
+ disabledIconDelete: false,
182
+ onChangeRow: jest.fn(),
183
+ onUpdateWizardLogin: jest.fn(),
184
+ directories: directories,
185
+ templateTypes: templateTypes,
186
+ };
187
+ var renderUi = function () { return (0, react_1.render)((0, jsx_runtime_1.jsx)(RowTemplate_1.default, __assign({}, mockProps))); };
188
+ it('renders component', function () {
189
+ renderUi();
190
+ expect(react_1.screen.getByTestId('Common.Name')).toBeInTheDocument();
191
+ expect(react_1.screen.getByTestId('Wizard.Directory')).toBeInTheDocument();
192
+ expect(react_1.screen.getByTestId('Common.TypeTemplate')).toBeInTheDocument();
193
+ expect(react_1.screen.getByTestId('Wizard.SelectTemplate')).toBeInTheDocument();
194
+ expect(react_1.screen.getByTestId('Wizard.FieldNames')).toBeInTheDocument();
195
+ expect(react_1.screen.getByTestId('deleteIcon')).toBeInTheDocument();
196
+ });
197
+ it('check handleDeleteRowTemplate', function () { return __awaiter(void 0, void 0, void 0, function () {
198
+ var deleteIcon;
199
+ return __generator(this, function (_a) {
200
+ switch (_a.label) {
201
+ case 0:
202
+ renderUi();
203
+ deleteIcon = react_1.screen.getByTestId('deleteIcon');
204
+ react_1.fireEvent.click(deleteIcon);
205
+ return [4 /*yield*/, (0, react_1.waitFor)(function () {
206
+ expect(mockProps.onUpdateWizardLogin).toHaveBeenCalledWith(Utils_1.TYPE_LOGIN_TEMPLATE.REMOVE, 1);
207
+ })];
208
+ case 1:
209
+ _a.sent();
210
+ return [2 /*return*/];
211
+ }
212
+ });
213
+ }); });
214
+ it('check handleChange', function () {
215
+ renderUi();
216
+ react_1.fireEvent.change(react_1.screen.getByRole('textbox', { name: /Common.Name/i }), {
217
+ target: { value: 'test1' },
218
+ });
219
+ });
220
+ it('check handleChange combobox directories', function () { return __awaiter(void 0, void 0, void 0, function () {
221
+ var templatesGetByDirectoryIdSpy;
222
+ return __generator(this, function (_a) {
223
+ switch (_a.label) {
224
+ case 0:
225
+ templatesGetByDirectoryIdSpy = jest.spyOn(clientMethod, 'templatesGetByDirectoryId');
226
+ renderUi();
227
+ // Tên Thư Mục
228
+ return [4 /*yield*/, (0, react_1.waitFor)(function () { return __awaiter(void 0, void 0, void 0, function () {
229
+ var selectContainer, comboBox;
230
+ return __generator(this, function (_a) {
231
+ switch (_a.label) {
232
+ case 0:
233
+ selectContainer = react_1.screen.getByTestId('Wizard.Directory');
234
+ return [4 /*yield*/, (0, react_1.within)(selectContainer).findByRole('combobox')];
235
+ case 1:
236
+ comboBox = _a.sent();
237
+ if (comboBox) {
238
+ react_1.fireEvent.mouseDown(comboBox);
239
+ react_1.screen.getAllByText('SYSTEM TEMPLATE').forEach(function (el) {
240
+ react_1.fireEvent.click(el);
241
+ });
242
+ }
243
+ return [2 /*return*/];
244
+ }
245
+ });
246
+ }); })];
247
+ case 1:
248
+ // Tên Thư Mục
249
+ _a.sent();
250
+ expect(templatesGetByDirectoryIdSpy).toHaveBeenCalledWith(directories[0].directoryId);
251
+ return [2 /*return*/];
252
+ }
253
+ });
254
+ }); });
255
+ });
@@ -0,0 +1,2 @@
1
+ declare function CreateOrEdit(): import("react/jsx-runtime").JSX.Element;
2
+ export default CreateOrEdit;