awing-library 2.1.131-beta → 2.1.131

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 (219) hide show
  1. package/lib/ACM-AXN/Campaign/Container.js +52 -54
  2. package/lib/ACM-AXN/Campaign/Container.test.js +1 -3
  3. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.d.ts +8 -1
  4. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.js +27 -3
  5. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.d.ts +17 -0
  6. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.js +121 -0
  7. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.d.ts +1 -0
  8. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.js +219 -0
  9. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.d.ts +2 -0
  10. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.js +306 -0
  11. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.d.ts +1 -0
  12. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.js +230 -0
  13. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.d.ts +1 -0
  14. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.js +123 -0
  15. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.d.ts +1 -0
  16. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.js +253 -0
  17. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabInfomation.js +2 -2
  18. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.d.ts +1 -1
  19. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.js +47 -78
  20. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.d.ts +6 -1
  21. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +3 -22
  22. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.js +2 -1
  23. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.js +2 -3
  24. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +22 -42
  25. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +316 -96
  26. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/component.js +1 -1
  27. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +3 -0
  28. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +119 -55
  29. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +1 -1
  30. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +46 -8
  31. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +11 -8
  32. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +1 -1
  33. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +5 -1
  34. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +4 -7
  35. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.js +3 -3
  36. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +3 -3
  37. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +1 -0
  38. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +17 -4
  39. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +10 -0
  40. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +4 -1
  41. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +1 -0
  42. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +3 -2
  43. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +6 -2
  44. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +31 -29
  45. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +5 -2
  46. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +2 -2
  47. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/AddOrEditRule.js +6 -0
  48. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.d.ts +8 -0
  49. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.js +47 -0
  50. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitEvent.js +52 -6
  51. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetOS/container.js +2 -2
  52. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.d.ts +1 -0
  53. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.js +3 -1
  54. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.d.ts +4 -3
  55. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +13 -7
  56. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +5 -5
  57. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.d.ts +1 -1
  58. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +75 -123
  59. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +3 -13
  60. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +45 -20
  61. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.d.ts +2 -0
  62. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +8 -3
  63. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +3 -2
  64. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
  65. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +5 -1
  66. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +176 -59
  67. package/lib/ACM-AXN/Campaign/Enum.d.ts +23 -4
  68. package/lib/ACM-AXN/Campaign/Enum.js +30 -10
  69. package/lib/ACM-AXN/Campaign/Types.d.ts +52 -6
  70. package/lib/ACM-AXN/Campaign/Utils.d.ts +5 -0
  71. package/lib/ACM-AXN/Campaign/Utils.js +29 -2
  72. package/lib/ACM-AXN/Campaign/index.js +2 -2
  73. package/lib/ACM-AXN/CampaignPlan/Container.js +21 -10
  74. package/lib/ACM-AXN/CampaignPlan/Container.test.d.ts +1 -1
  75. package/lib/ACM-AXN/CampaignPlan/Container.test.js +1 -2
  76. package/lib/ACM-AXN/CampaignPlan/Detail.js +5 -7
  77. package/lib/ACM-AXN/CampaignPlan/Detail.test.d.ts +1 -1
  78. package/lib/ACM-AXN/CampaignPlan/Detail.test.js +2 -3
  79. package/lib/ACM-AXN/CampaignPlan/Filter.js +11 -4
  80. package/lib/ACM-AXN/CampaignPlan/Filter.test.d.ts +1 -1
  81. package/lib/ACM-AXN/CampaignPlan/Filter.test.js +0 -1
  82. package/lib/ACM-AXN/CampaignPlan/Types.d.ts +6 -74
  83. package/lib/ACM-AXN/CampaignPlan/Types.js +1 -253
  84. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +14 -10
  85. package/lib/ACM-AXN/CampaignSchedule/Components/EnhancedPagination/index.js +3 -2
  86. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +7 -5
  87. package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +4 -4
  88. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +5 -4
  89. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +1 -2
  90. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +1 -5
  91. package/lib/ACM-AXN/Common/Constant.d.ts +3 -0
  92. package/lib/ACM-AXN/Common/Constant.js +2 -0
  93. package/lib/ACM-AXN/Common/Enum.d.ts +8 -3
  94. package/lib/ACM-AXN/Common/Enum.js +19 -4
  95. package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
  96. package/lib/ACM-AXN/GeoFencing/component.js +7 -7
  97. package/lib/ACM-AXN/GeoFencing/interface.d.ts +1 -2
  98. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.d.ts +0 -5
  99. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +7 -90
  100. package/lib/ACM-AXN/Notifications/NotificationPopover/index.d.ts +0 -5
  101. package/lib/ACM-AXN/Notifications/Types.d.ts +2 -0
  102. package/lib/ACM-AXN/Page/Constant.js +2 -0
  103. package/lib/ACM-AXN/Page/Container.js +3 -3
  104. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.d.ts +6 -0
  105. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.js +63 -0
  106. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.d.ts +11 -2
  107. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +16 -12
  108. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/Utils.js +1 -1
  109. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/index.js +1 -0
  110. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.d.ts +1 -9
  111. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.js +0 -9
  112. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewContent.js +11 -45
  113. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
  114. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +39 -61
  115. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +29 -32
  116. package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +10 -9
  117. package/lib/ACM-AXN/Page/CreateOrEdit/index.js +17 -4
  118. package/lib/ACM-AXN/Page/Types.d.ts +3 -0
  119. package/lib/ACM-AXN/Page/enums.d.ts +5 -0
  120. package/lib/ACM-AXN/Page/enums.js +7 -1
  121. package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
  122. package/lib/ACM-AXN/PlaceFilter/DataTable/component/index.js +2 -5
  123. package/lib/ACM-AXN/PlaceFilter/Input/component/index.js +1 -2
  124. package/lib/ACM-AXN/PlaceFilter/interface.d.ts +1 -0
  125. package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +16 -16
  126. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +14 -9
  127. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +19 -18
  128. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +16 -6
  129. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +17 -10
  130. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
  131. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +30 -51
  132. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
  133. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
  134. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
  135. package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +16 -36
  136. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +5 -5
  137. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +14 -11
  138. package/lib/ACM-AXN/Statistics/ControlPanel.js +16 -4
  139. package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
  140. package/lib/ACM-AXN/Statistics/Enums.js +1 -0
  141. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +1 -0
  142. package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +3 -3
  143. package/lib/ACM-AXN/Template/Container.js +1 -1
  144. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
  145. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
  146. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +2 -2
  147. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +56 -39
  148. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
  149. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
  150. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
  151. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
  152. package/lib/ACM-AXN/Template/CreateOrEdit/index.js +8 -4
  153. package/lib/ACM-AXN/Template/Import.js +6 -3
  154. package/lib/ACM-AXN/Template/Types.d.ts +9 -9
  155. package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
  156. package/lib/ACM-AXN/ViewTemplate/Preview.js +5 -6
  157. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +23 -11
  158. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
  159. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
  160. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +46 -160
  161. package/lib/ACM-AXN/ViewTemplate/common.js +2 -3
  162. package/lib/ACM-AXN/ViewTemplate/container.js +23 -24
  163. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +3 -1
  164. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +18 -28
  165. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +2 -0
  166. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +1 -1
  167. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +17 -1
  168. package/lib/ACM-AXN/index.d.ts +1 -0
  169. package/lib/ACM-AXN/index.js +1 -0
  170. package/lib/AWING/AsyncAutocomplete/index.js +2 -2
  171. package/lib/AWING/BasicDataForm/BasicDataForm.js +9 -6
  172. package/lib/AWING/BasicDataForm/interface.d.ts +3 -0
  173. package/lib/AWING/Chart/BarLineComponent.js +29 -11
  174. package/lib/AWING/Chart/PieComponent.d.ts +3 -4
  175. package/lib/AWING/Chart/PieComponent.js +16 -16
  176. package/lib/AWING/Chart/Styles.js +51 -16
  177. package/lib/AWING/DataForm/DataInput.js +63 -20
  178. package/lib/AWING/DataForm/interface.d.ts +1 -0
  179. package/lib/AWING/DataGrid/index.js +8 -13
  180. package/lib/AWING/DateRangePicker/component.js +55 -30
  181. package/lib/AWING/DateRangePicker/configDate.d.ts +1 -2
  182. package/lib/AWING/DateRangePicker/configDate.js +12 -12
  183. package/lib/AWING/DateRangePicker/interface.d.ts +1 -0
  184. package/lib/AWING/Form/useForm.js +3 -2
  185. package/lib/AWING/GoogleMap/GGMap.d.ts +3 -0
  186. package/lib/AWING/GoogleMap/GGMap.js +256 -0
  187. package/lib/AWING/GoogleMap/index.d.ts +4 -0
  188. package/lib/AWING/GoogleMap/index.js +41 -0
  189. package/lib/AWING/GoogleMap/interface.d.ts +21 -0
  190. package/lib/AWING/GoogleMap/interface.js +2 -0
  191. package/lib/AWING/GoogleMap/utils.d.ts +25 -0
  192. package/lib/AWING/GoogleMap/utils.js +135 -0
  193. package/lib/AWING/GroupTable/GroupTable.js +4 -5
  194. package/lib/AWING/GroupTable/component.d.ts +1 -0
  195. package/lib/AWING/GroupTable/component.js +2 -2
  196. package/lib/AWING/NumberFormat/index.d.ts +3 -1
  197. package/lib/AWING/NumberFormat/index.js +2 -2
  198. package/lib/AWING/PageManagement/PageManagement.js +4 -3
  199. package/lib/AWING/Pagination/index.js +11 -3
  200. package/lib/AWING/index.d.ts +1 -0
  201. package/lib/AWING/index.js +1 -0
  202. package/lib/AWING/ultis/validation.d.ts +1 -0
  203. package/lib/AWING/ultis/validation.js +21 -5
  204. package/lib/Commons/Components/ClassicDrawer.js +5 -4
  205. package/lib/Commons/Components/DeprecatedEnhancedDialog.js +1 -1
  206. package/lib/Commons/Hooks/usePath.js +3 -3
  207. package/lib/Utils/Helpers.d.ts +3 -2
  208. package/lib/Utils/Helpers.js +48 -8
  209. package/lib/i18n.js +14 -2
  210. package/lib/translate/en/translation.json +112 -71
  211. package/lib/translate/id/translation.json +870 -0
  212. package/lib/translate/ja/translation.json +870 -0
  213. package/lib/translate/th/translation.json +870 -0
  214. package/lib/translate/vi/translation.json +76 -35
  215. package/package.json +131 -126
  216. package/lib/ACM-AXN/ScheduleCompletionRate/json.d.ts +0 -61
  217. package/lib/ACM-AXN/ScheduleCompletionRate/json.js +0 -268
  218. package/lib/ACM-AXN/ViewTemplate/TemplateField/Utils.d.ts +0 -5
  219. package/lib/ACM-AXN/ViewTemplate/TemplateField/Utils.js +0 -14
@@ -33,39 +33,37 @@ var __importStar = (this && this.__importStar) || function (mod) {
33
33
  __setModuleDefault(result, mod);
34
34
  return result;
35
35
  };
36
+ var __importDefault = (this && this.__importDefault) || function (mod) {
37
+ return (mod && mod.__esModule) ? mod : { "default": mod };
38
+ };
36
39
  Object.defineProperty(exports, "__esModule", { value: true });
37
40
  var jsx_runtime_1 = require("react/jsx-runtime");
38
41
  var react_1 = __importStar(require("react"));
39
- var recoil_1 = require("recoil");
40
42
  var react_i18next_1 = require("react-i18next");
41
- // import { CampaignGroup, CampaignTicket } from '../../types'
43
+ var recoil_1 = require("recoil");
44
+ var Enum_1 = require("../../../../ACM-AXN/Campaign/Enum");
45
+ var Enum_2 = require("../../../../ACM-AXN/Common/Enum");
42
46
  var lodash_1 = require("lodash");
43
47
  var Utils_1 = require("../../Utils");
44
48
  var Recoils_1 = require("../Recoils");
45
- var AWING_1 = require("../../../../AWING");
46
- var Enum_1 = require("../../../../ACM-AXN/Campaign/Enum");
47
- var Enum_2 = require("../../../../ACM-AXN/Common/Enum");
49
+ var material_1 = require("@mui/material");
50
+ var Hooks_1 = __importDefault(require("../../../../ACM-AXN/Campaign/Hooks"));
48
51
  function SubCampaignDetail(props) {
49
52
  var t = (0, react_i18next_1.useTranslation)().t;
50
53
  var subCampaign = props.subCampaign, onSubCampaignChange = props.onSubCampaignChange, onChangeSubCampaignStatus = props.onChangeSubCampaignStatus;
54
+ var service = (0, Hooks_1.default)().service;
51
55
  var getFormValid = function () { return ({
52
56
  name: (0, Utils_1.nameValid)(subCampaign.name),
53
57
  bookingAmount: !(0, Utils_1.checkPriority)(subCampaign.priority, Enum_1.CampaignPriority.ClassB) || (0, Utils_1.bookingValid)(subCampaign.bookingAmount),
54
58
  bonusAmount: (0, Utils_1.bonusValid)(subCampaign.bonusAmount),
55
59
  billingUnit: subCampaign.billingUnit !== null,
56
60
  }); };
57
- var cacheSubId = react_1.default.useRef();
58
- (0, react_1.useEffect)(function () {
59
- cacheSubId.current = subCampaign.id;
60
- return function () {
61
- cacheSubId.current = undefined;
62
- };
63
- }, [subCampaign.id]);
61
+ var _a = react_1.default.useState(getFormValid), subValid = _a[0], setSubValid = _a[1];
64
62
  var isCreate = (0, recoil_1.useRecoilValue)(Recoils_1.isCreateState);
65
63
  (0, react_1.useEffect)(function () {
66
64
  onSubCampaignChange(function (prev) { return (0, lodash_1.cloneDeep)(prev); });
67
65
  // eslint-disable-next-line react-hooks/exhaustive-deps
68
- }, [subCampaign.id, onSubCampaignChange]);
66
+ }, [onSubCampaignChange]);
69
67
  (0, react_1.useEffect)(function () {
70
68
  onChangeSubCampaignStatus(Object.values(getFormValid()).every(Boolean));
71
69
  // eslint-disable-next-line react-hooks/exhaustive-deps
@@ -77,7 +75,8 @@ function SubCampaignDetail(props) {
77
75
  */
78
76
  var translationText = {
79
77
  name: t('Campaign.Name'),
80
- ticket: t('Campaign.Ticket'),
78
+ status: t('Campaign.Ticket'),
79
+ subCampaignLable: t('Campaign.BillingUnit.subCampaignLable'),
81
80
  BillingUnit: t('Campaign.BillingUnit.Title'),
82
81
  priority: t('Campaign.Detail.Priority'),
83
82
  booking: t('Campaign.BookingText'),
@@ -87,114 +86,67 @@ function SubCampaignDetail(props) {
87
86
  helperText: t('Common.Required'),
88
87
  notNegative: t('Common.NotNegative'),
89
88
  };
90
- var fields = react_1.default.useMemo(function () {
91
- var tempField = [
92
- {
93
- fieldName: 'name',
94
- type: 'text',
95
- label: translationText.name,
96
- required: true,
97
- gridSize: 4,
98
- pattern: false,
99
- length: 500,
100
- },
101
- {
102
- fieldName: 'ticket',
103
- type: 'select',
104
- label: translationText.ticket,
105
- required: true,
106
- gridSize: 4,
107
- disabled: isCreate,
108
- options: [
109
- {
110
- text: t('Campaign.Active'),
111
- value: Enum_1.CampaignTicket.ACTIVE,
112
- },
113
- {
114
- text: t('Campaign.InActive'),
115
- value: Enum_1.CampaignTicket.INACTIVE,
116
- },
117
- ],
118
- },
119
- {
120
- fieldName: 'priority',
121
- type: 'select',
122
- gridSize: 4,
123
- label: translationText.priority,
124
- required: true,
125
- options: Object.values(Enum_1.CampaignPriority).map(function (priority) { return ({
126
- text: t("Campaign.".concat(priority)),
127
- value: priority,
128
- }); }),
129
- },
130
- ];
131
- if ((0, Utils_1.checkPriority)(subCampaign.priority, Enum_1.CampaignPriority.ClassB)) {
132
- tempField.push({
133
- fieldName: 'bookingAmount',
134
- type: 'number',
135
- gridSize: 4,
136
- required: true,
137
- label: translationText.booking,
138
- InputProps: {
139
- type: 'number',
140
- },
141
- onValidate: function (value) { return (0, Utils_1.bookingValid)(Number(value)); },
142
- }, {
143
- fieldName: 'bonusAmount',
144
- type: 'number',
145
- gridSize: 4,
146
- required: true,
147
- label: translationText.booking,
148
- InputProps: {
149
- type: 'number',
150
- },
151
- onValidate: function (value) { return (0, Utils_1.bonusValid)(Number(value)); },
152
- }, {
153
- fieldName: 'billingUnit',
154
- type: 'select',
155
- gridSize: 4,
156
- label: translationText.BillingUnit,
157
- required: true,
158
- value: String(subCampaign.billingUnit),
159
- onValidate: function (value) { return value !== null; },
160
- options: Object.values(Enum_2.AnalyticType)
161
- .filter(function (item) { return !isNaN(Number(item)); })
162
- .map(function (item) { return ({
163
- text: t("Campaign.BillingUnit.".concat((0, lodash_1.capitalize)((0, lodash_1.camelCase)(Enum_2.AnalyticType[item])))),
164
- value: item,
165
- }); }),
166
- });
167
- }
168
- tempField.push({
169
- fieldName: 'isReserved',
170
- type: 'checkbox',
171
- gridSize: 4,
172
- label: translationText.reserved,
173
- });
174
- return tempField;
175
- },
176
- // eslint-disable-next-line react-hooks/exhaustive-deps
177
- [subCampaign]);
178
- var handleUpdate = react_1.default.useCallback(function (data, valid, fieldName) {
179
- if (!fieldName || cacheSubId.current !== subCampaign.id)
180
- return;
181
- onSubCampaignChange(function (pre) {
182
- var _a;
183
- return fieldName === 'priority'
184
- ? __assign(__assign(__assign(__assign({}, pre), { priority: data[fieldName] }), ((0, Utils_1.checkPriority)(data[fieldName], Enum_1.CampaignPriority.ClassB)
185
- ? {
186
- bookingAmount: 10,
187
- billingUnit: null,
188
- }
189
- : {
190
- bookingAmount: 0,
191
- billingUnit: 0,
192
- })), { bonusAmount: 0 }) : __assign(__assign({}, pre), (_a = {}, _a[fieldName] = data[fieldName], _a));
193
- });
194
- // eslint-disable-next-line react-hooks/exhaustive-deps
195
- }, [subCampaign.id, onSubCampaignChange]);
196
- return ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: (0, jsx_runtime_1.jsx)(AWING_1.DataForm, { padding: "none", fields: fields, oldValue: __assign(__assign({}, subCampaign), { priority: isNaN(Number(subCampaign.priority))
197
- ? subCampaign.priority
198
- : Object.values(Enum_1.CampaignPriority)[subCampaign.priority] }), onUpdate: handleUpdate }) }));
89
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)(material_1.Grid, { container: true, style: { padding: 8, paddingBottom: 0 }, children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: true, style: { padding: 8 }, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "name", name: "name", variant: "standard", required: true, fullWidth: true, label: translationText.name, value: subCampaign.name, onChange: function (e) {
90
+ onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { name: e.target.value })); });
91
+ }, error: subValid.name !== undefined && !subValid.name, helperText: subValid.name !== undefined && !subValid.name
92
+ ? translationText.helperText
93
+ : '' }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: true, style: { padding: 8 }, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "status", name: "status", variant: "standard", select: true, required: true, fullWidth: true, label: translationText.status, value: subCampaign.status, onChange: function (e) {
94
+ onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { status: Number(e.target.value) })); });
95
+ }, disabled: isCreate, children: (0, Utils_1.getCampaignStatus)(!Boolean(service.attributesGetByObjectTypeCode)).map(function (item) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: item.value, children: t("Campaign.Status.".concat(item.key)) }, item.key)); }) }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: true, style: { padding: 8 }, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "priority", select: true, required: true, variant: "standard", fullWidth: true, label: translationText.priority, value: isNaN(Number(subCampaign.priority))
96
+ ? subCampaign.priority
97
+ : Object.values(Enum_1.CampaignPriority)[subCampaign.priority], onChange: function (e) {
98
+ var newPriority = Object.values(Enum_1.CampaignPriority).indexOf(e.target.value);
99
+ onSubCampaignChange(function (pre) {
100
+ var newSubCamp = __assign(__assign(__assign(__assign({}, pre), { priority: newPriority }), ((0, Utils_1.checkPriority)(newPriority, Enum_1.CampaignPriority.ClassB)
101
+ ? {
102
+ bookingAmount: 10,
103
+ billingUnit: Enum_2.AnalyticType.Authentication,
104
+ billingUnitLabel: Enum_2.AnalyticType[Enum_2.AnalyticType.Authentication],
105
+ }
106
+ : {
107
+ bookingAmount: 0,
108
+ billingUnit: Enum_2.AnalyticType.Authentication,
109
+ billingUnitLabel: Enum_2.AnalyticType[Enum_2.AnalyticType.Authentication],
110
+ })), { bonusAmount: 0 });
111
+ setSubValid(function (pre) { return (__assign(__assign({}, pre), { bookingAmount: true, bonusAmount: true })); });
112
+ return newSubCamp;
113
+ });
114
+ }, children: Object.values(Enum_1.CampaignPriority).map(function (priority) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: priority, children: t("Campaign.".concat(priority)) }, priority)); }) }) })] }), (0, jsx_runtime_1.jsx)(material_1.Grid, { container: true, style: { padding: 8, paddingTop: 0 }, children: (0, Utils_1.checkPriority)(subCampaign.priority, Enum_1.CampaignPriority.ClassB) && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 4, style: { padding: 8 }, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "bookingAmount", required: true, fullWidth: true, variant: "standard", type: "number", label: translationText.booking, value: subCampaign.bookingAmount, onChange: function (e) {
115
+ onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { bookingAmount: Number(e.target.value), bonusAmount: Math.round(Number(e.target.value) * 0.05) })); });
116
+ }, onFocus: function (event) { return event.target.select(); }, error: subValid.bookingAmount !== undefined &&
117
+ !subValid.bookingAmount, helperText: subValid.bookingAmount !== undefined &&
118
+ !subValid.bookingAmount
119
+ ? subCampaign.bookingAmount < 0
120
+ ? translationText.notNegative
121
+ : translationText.helperText
122
+ : '' }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 4, style: { padding: 8 }, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "bonusAmount", variant: "standard", fullWidth: true, type: "number", label: translationText.bonus, value: subCampaign.bonusAmount, onChange: function (e) {
123
+ var value = Number(e.target.value);
124
+ onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { bonusAmount: value })); });
125
+ }, onFocus: function (event) { return event.target.select(); }, error: subValid.bonusAmount !== undefined &&
126
+ !subValid.bonusAmount, helperText: subValid.bonusAmount !== undefined &&
127
+ !subValid.bonusAmount
128
+ ? subCampaign.bonusAmount < 0
129
+ ? translationText.notNegative
130
+ : translationText.helperText
131
+ : '' }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 4, style: { padding: 8 }, children: Boolean(service.attributesGetByObjectTypeCode) ?
132
+ ((0, jsx_runtime_1.jsx)(material_1.TextField, { id: "billingUnit", required: true, select: true, variant: "standard", fullWidth: true, label: translationText.subCampaignLable, value: [Enum_2.AnalyticType[subCampaign.billingUnit], subCampaign.billingUnitLabel || Enum_2.AnalyticType[Enum_2.AnalyticType.Authentication]].join(">"), onChange: function (e) {
133
+ var _a = e.target.value.split(">"), billingUnit = _a[0], billingUnitLabel = _a[1];
134
+ onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { billingUnit: Enum_2.AnalyticType[billingUnit], billingUnitLabel: billingUnitLabel })); });
135
+ }, error: !!subValid.billingUnit && !subValid.billingUnit, helperText: !!subValid.billingUnit && !subValid.billingUnit
136
+ ? translationText.helperText
137
+ : '', children: Enum_2.MarkAnalyticTypes
138
+ .map(function (type) {
139
+ var value = [Enum_2.AnalyticType[type.billingUnit], type.billingUnitLabel].join(">");
140
+ return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: value, children: t("Campaign.BillingUnit.".concat(value)) }, value));
141
+ }) })) :
142
+ ((0, jsx_runtime_1.jsx)(material_1.TextField, { id: "billingUnit", required: true, select: true, variant: "standard", fullWidth: true, label: translationText.BillingUnit, value: String(subCampaign.billingUnit), onChange: function (e) {
143
+ onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { billingUnit: Number(e.target.value) })); });
144
+ }, error: !!subValid.billingUnit && !subValid.billingUnit, helperText: !!subValid.billingUnit && !subValid.billingUnit
145
+ ? translationText.helperText
146
+ : '', children: Object.values(Enum_2.AnalyticType)
147
+ .filter(function (item) { return !isNaN(Number(item)); })
148
+ .filter(function (item) { return item !== Enum_2.AnalyticType.AuthenticationSuccess; })
149
+ .filter(Boolean)
150
+ .map(function (type) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: type, children: t("Campaign.BillingUnit.".concat((0, lodash_1.capitalize)((0, lodash_1.camelCase)(Enum_2.AnalyticType[type])))) }, type)); }) })) })] })) })] }));
199
151
  }
200
152
  exports.default = SubCampaignDetail;
@@ -23,9 +23,8 @@ var subCampaignMock = {
23
23
  name: 'Test Campaign',
24
24
  bookingAmount: 100000,
25
25
  bonusAmount: 500000,
26
- ticket: Enum_1.CampaignTicket.INACTIVE,
26
+ status: Enum_1.CampaignStatus.Draft,
27
27
  priority: Enum_1.CampaignPriority.ClassB,
28
- isReserved: false,
29
28
  billingUnit: 1,
30
29
  };
31
30
  describe('<SubCampaignDetail />', function () {
@@ -36,19 +35,15 @@ describe('<SubCampaignDetail />', function () {
36
35
  expect(react_1.screen.getByLabelText(/^Campaign.Detail.Priority.*$/).textContent).toBe('Campaign.PriorityB');
37
36
  expect(react_1.screen.getByLabelText(/^Campaign.BookingText.*$/).value).toBe(subCampaignMock.bookingAmount.toString());
38
37
  expect(react_1.screen.getByLabelText(/^Campaign.BonusText.*$/).value).toBe(subCampaignMock.bonusAmount.toString());
39
- expect(
40
- // eslint-disable-next-line testing-library/no-container
41
- container.querySelector('input[name="isReserved"]').checked).toBe(subCampaignMock.isReserved);
42
38
  });
43
39
  it('should render with correct information classA', function () {
44
- var subCampaign = __assign(__assign({}, subCampaignMock), { priority: Enum_1.CampaignPriority.ClassA, ticket: Enum_1.CampaignTicket.ACTIVE, isReserved: true });
40
+ var subCampaign = __assign(__assign({}, subCampaignMock), { priority: Enum_1.CampaignPriority.ClassA, status: Enum_1.CampaignStatus.Active });
45
41
  var _a = (0, react_1.render)((0, jsx_runtime_1.jsx)(SubCampaignDetail_1.default, { subCampaign: subCampaign, onSubCampaignChange: function () { }, onChangeSubCampaignStatus: function () { } })), container = _a.container, getByLabelText = _a.getByLabelText, queryByLabelText = _a.queryByLabelText;
46
42
  expect(react_1.screen.getByLabelText(/^Campaign.Name.*$/).value).toBe(subCampaign.name);
47
43
  expect(react_1.screen.getByLabelText(/^Campaign.Ticket.*$/).textContent).toBe('Campaign.Active');
48
44
  expect(react_1.screen.getByLabelText(/^Campaign.Detail.Priority.*$/).textContent).toBe('Campaign.PriorityA');
49
45
  expect(react_1.screen.queryByLabelText(/^Campaign.BookingText.*$/)).toBeNull();
50
46
  expect(react_1.screen.queryByLabelText(/^Campaign.BonusText.*$/)).toBeNull();
51
- expect(container.querySelector('input[name="isReserved"]').checked).toBe(subCampaign.isReserved);
52
47
  });
53
48
  it('should update sub campaign', function () {
54
49
  var state = __assign({}, subCampaignMock);
@@ -71,16 +66,11 @@ describe('<SubCampaignDetail />', function () {
71
66
  react_1.fireEvent.change(bonusInput, { target: { valueAsNumber: 837483 } });
72
67
  expect(onSubCampaignChange).toHaveBeenCalledTimes(3);
73
68
  expect(state.bonusAmount).toBe(837483);
74
- var isReservedCheckbox = container.querySelector('input[name="isReserved"]');
75
- expect(isReservedCheckbox).not.toBeNull();
76
- react_1.fireEvent.click(isReservedCheckbox);
77
- expect(onSubCampaignChange).toHaveBeenCalledTimes(4);
78
- expect(state.isReserved).toBe(true);
79
69
  var selectParam = react_1.screen.getAllByRole('button');
80
70
  react_1.fireEvent.mouseDown(selectParam[0]);
81
71
  react_1.screen.getAllByRole('option')[0].click();
82
72
  expect(onSubCampaignChange).toHaveBeenCalledTimes(5);
83
- expect(state.ticket).toBe(Enum_1.CampaignTicket.ACTIVE);
73
+ expect(state.status).toBe(Enum_1.CampaignStatus.Active);
84
74
  react_1.fireEvent.mouseDown(selectParam[1]);
85
75
  react_1.screen.getAllByRole('option')[2].click();
86
76
  expect(onSubCampaignChange).toHaveBeenCalledTimes(6);
@@ -15,22 +15,20 @@ Object.defineProperty(exports, "__esModule", { value: true });
15
15
  exports.SubCampaignPreview = void 0;
16
16
  var jsx_runtime_1 = require("react/jsx-runtime");
17
17
  var Add_1 = __importDefault(require("@mui/icons-material/Add"));
18
- var CheckCircle_1 = __importDefault(require("@mui/icons-material/CheckCircle"));
19
18
  var Delete_1 = __importDefault(require("@mui/icons-material/Delete"));
20
19
  var FileCopy_1 = __importDefault(require("@mui/icons-material/FileCopy"));
21
- var RemoveCircle_1 = __importDefault(require("@mui/icons-material/RemoveCircle"));
22
20
  var material_1 = require("@mui/material");
21
+ var Enum_1 = require("../../../../ACM-AXN/Campaign/Enum");
22
+ var react_1 = require("react");
23
23
  var react_i18next_1 = require("react-i18next");
24
24
  var recoil_1 = require("recoil");
25
- var atoms_1 = require("./atoms");
26
- var react_1 = require("react");
27
25
  var AWING_1 = require("../../../../AWING");
28
- var Recoils_1 = require("../Recoils");
29
- var Helpers_1 = require("../../../../Utils/Helpers");
30
- var Utils_1 = require("../../Utils");
31
26
  var Context_1 = require("../../../../Context");
32
27
  var i18n_1 = __importDefault(require("../../../../i18n"));
33
- var Enum_1 = require("../../../../ACM-AXN/Campaign/Enum");
28
+ var Helpers_1 = require("../../../../Utils/Helpers");
29
+ var Utils_1 = require("../../Utils");
30
+ var Recoils_1 = require("../Recoils");
31
+ var atoms_1 = require("./atoms");
34
32
  function SubCampaignList(props) {
35
33
  var onAdd = props.onAdd, onDelete = props.onDelete;
36
34
  var t = (0, react_i18next_1.useTranslation)(undefined, { i18n: i18n_1.default }).t;
@@ -70,7 +68,7 @@ function SubCampaignPreview(_a) {
70
68
  var subCampaign = _a.subCampaign, isSelected = _a.isSelected, onSelect = _a.onSelect, onMultiSelect = _a.onMultiSelect, onDuplicate = _a.onDuplicate, onDelete = _a.onDelete, error = _a.error;
71
69
  var t = (0, react_i18next_1.useTranslation)().t;
72
70
  var today = (0, Helpers_1.getToday)();
73
- var isActive = ((_b = subCampaign.campaignGroup) === null || _b === void 0 ? void 0 : _b.ticket) === Enum_1.CampaignTicket.ACTIVE &&
71
+ var isActive = ((_b = subCampaign.campaignGroup) === null || _b === void 0 ? void 0 : _b.status) === Enum_1.CampaignStatus.Active &&
74
72
  ((_c = subCampaign.ads) === null || _c === void 0 ? void 0 : _c.some(function (ad) {
75
73
  return ad.status &&
76
74
  (0, Helpers_1.convertTimestampToDateTime)(ad.startDate) <= today &&
@@ -84,9 +82,44 @@ function SubCampaignPreview(_a) {
84
82
  numberHasRunText: t('Campaign.NumberHasRunText'),
85
83
  reserved: t('Campaign.Reserved'),
86
84
  };
85
+ var renderStatus = function () {
86
+ switch (subCampaign.campaignGroup.status) {
87
+ case Enum_1.CampaignStatus.Draft:
88
+ return ((0, jsx_runtime_1.jsx)(material_1.Chip, { label: t('Campaign.Status.Draft'), style: {
89
+ height: 18,
90
+ backgroundColor: Enum_1.ColorCampaignStatus.Draft,
91
+ color: 'white',
92
+ } }));
93
+ case Enum_1.CampaignStatus.Reserved:
94
+ return ((0, jsx_runtime_1.jsx)(material_1.Chip, { label: t('Campaign.Status.Reserved'), style: {
95
+ height: 18,
96
+ backgroundColor: Enum_1.ColorCampaignStatus.Reserved,
97
+ color: 'white',
98
+ } }));
99
+ case Enum_1.CampaignStatus.Pending:
100
+ return ((0, jsx_runtime_1.jsx)(material_1.Chip, { label: t('Campaign.Status.Pending'), style: {
101
+ height: 18,
102
+ backgroundColor: Enum_1.ColorCampaignStatus.UnderApproval,
103
+ color: 'white',
104
+ } }));
105
+ case Enum_1.CampaignStatus.Active:
106
+ return ((0, jsx_runtime_1.jsx)(material_1.Chip, { label: t('Campaign.Status.Active'), style: {
107
+ height: 18,
108
+ backgroundColor: isActive ? Enum_1.ColorCampaignStatus.Active : Enum_1.ColorCampaignStatus.UnActive,
109
+ color: 'white',
110
+ } }));
111
+ case Enum_1.CampaignStatus.Done:
112
+ return ((0, jsx_runtime_1.jsx)(material_1.Chip, { label: t('Campaign.Status.Done'), style: {
113
+ height: 18,
114
+ backgroundColor: Enum_1.ColorCampaignStatus.Done,
115
+ color: 'white',
116
+ } }));
117
+ }
118
+ };
87
119
  return ((0, jsx_runtime_1.jsxs)(material_1.Card, { sx: {
88
120
  width: 214,
89
- height: 124,
121
+ minHeight: 124,
122
+ height: 'auto',
90
123
  marginLeft: function (theme) { return theme.spacing(2); },
91
124
  cursor: 'pointer',
92
125
  border: "2px solid ".concat(isSelected ? '#2196F3' : '#fafafa'),
@@ -104,11 +137,7 @@ function SubCampaignPreview(_a) {
104
137
  fontWeight: '500',
105
138
  }, children: [subCampaign.campaignGroup.name.length > 30
106
139
  ? "".concat(subCampaign.campaignGroup.name.substring(0, 30), "...")
107
- : subCampaign.campaignGroup.name, subCampaign.campaignGroup.ticket ===
108
- Enum_1.CampaignTicket.ACTIVE ? ((0, jsx_runtime_1.jsx)(CheckCircle_1.default, { fontSize: "small", style: {
109
- fontSize: '14px',
110
- color: isActive ? '#008000' : '#8D8D8D',
111
- } })) : ((0, jsx_runtime_1.jsx)(RemoveCircle_1.default, { fontSize: "small", style: { fontSize: '14px' }, color: "primary" })), (0, jsx_runtime_1.jsx)(material_1.Typography, { component: 'span', sx: {
140
+ : subCampaign.campaignGroup.name, (0, jsx_runtime_1.jsx)(material_1.Typography, { component: 'span', sx: {
112
141
  fontFamily: '"Segoe UI Symbol", "Apple Symbols", "Noto Sans Symbols 2" !important',
113
142
  fontSize: 18,
114
143
  }, children: (0, Utils_1.getCampaignPriority)(subCampaign.campaignGroup.priority) })] }) }), action: (0, jsx_runtime_1.jsx)(AWING_1.Actions, { menus: __spreadArray([
@@ -131,10 +160,6 @@ function SubCampaignPreview(_a) {
131
160
  ? " (+".concat((0, Helpers_1.formatNumber)(subCampaign.campaignGroup.bonusAmount), ")")
132
161
  : '' })] }) }), (0, jsx_runtime_1.jsx)(material_1.Tooltip, { title: translationText.bonus, placement: "right", arrow: true, children: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "caption", children: subCampaign.campaignGroup.numberHasRun
133
162
  ? "".concat(translationText.numberHasRunText, ": ").concat((0, Helpers_1.formatNumber)(subCampaign.campaignGroup.numberHasRun))
134
- : '' }) })] }), (0, jsx_runtime_1.jsx)(material_1.CardActions, { style: { padding: '0 8px' }, children: subCampaign.campaignGroup.isReserved && ((0, jsx_runtime_1.jsx)(material_1.Chip, { label: translationText.reserved, style: {
135
- height: 18,
136
- backgroundColor: '#c49f47',
137
- color: 'white',
138
- } })) })] }));
163
+ : '' }) })] }), (0, jsx_runtime_1.jsx)(material_1.CardActions, { style: { padding: '0 8px 8px 8px' }, children: renderStatus() })] }));
139
164
  }
140
165
  exports.SubCampaignPreview = SubCampaignPreview;
@@ -5,6 +5,7 @@ import { CampaignAd } from '../../Types';
5
5
  export type AdDefine = {
6
6
  subCampaignId: number;
7
7
  adId: number;
8
+ loginId: string;
8
9
  };
9
10
  /**
10
11
  * State lưu trạng thái thông tin cơ bản của từng chiến dịch con
@@ -52,3 +53,4 @@ export declare const campaignPageIdState: import("recoil").RecoilState<{
52
53
  lgn: string;
53
54
  wlc: string;
54
55
  }>;
56
+ export declare const campaignLoginIdState: import("recoil").RecoilState<string[]>;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.campaignPageIdState = exports.adOpenState = exports.adSelectedState = exports.adListState = exports.checkGroupsClassCState = exports.selectedSubCampaignIdState = exports.copiedAdState = exports.subCampaignValidState = exports.subCampaignAdsValidState = exports.subCampaignDetailValidState = void 0;
3
+ exports.campaignLoginIdState = exports.campaignPageIdState = exports.adOpenState = exports.adSelectedState = exports.adListState = exports.checkGroupsClassCState = exports.selectedSubCampaignIdState = exports.copiedAdState = exports.subCampaignValidState = exports.subCampaignAdsValidState = exports.subCampaignDetailValidState = void 0;
4
4
  var recoil_1 = require("recoil");
5
5
  var Utils_1 = require("../../Utils");
6
6
  // import directoryPermissionService from 'Services/DirectoryPermission'
@@ -22,7 +22,7 @@ exports.subCampaignDetailValidState = (0, recoil_1.atom)({
22
22
  return (result[sub.campaignGroup.id] =
23
23
  (0, Utils_1.nameValid)(sub.campaignGroup.name) &&
24
24
  (0, Utils_1.groupClassBValid)(sub.campaignGroup) &&
25
- (0, Utils_1.groupClassCValid)(sub));
25
+ (0, Utils_1.groupClassCValid)(sub) && !!sub.campaignGroup.billingUnit);
26
26
  });
27
27
  return result;
28
28
  },
@@ -58,9 +58,10 @@ exports.subCampaignValidState = (0, recoil_1.selector)({
58
58
  var subCampaignAdsValid = get(exports.subCampaignAdsValidState);
59
59
  var result = {};
60
60
  subCampaigns.forEach(function (sub) {
61
+ var _a;
61
62
  return (result[sub.campaignGroup.id] =
62
63
  subCampaignDetailValid[sub.campaignGroup.id] &&
63
- subCampaignAdsValid[sub.campaignGroup.id]);
64
+ subCampaignAdsValid[sub.campaignGroup.id] && Boolean((_a = sub.campaignGroup) === null || _a === void 0 ? void 0 : _a.billingUnit));
64
65
  });
65
66
  return result;
66
67
  },
@@ -132,3 +133,7 @@ exports.campaignPageIdState = (0, recoil_1.atom)({
132
133
  wlc: '',
133
134
  },
134
135
  });
136
+ exports.campaignLoginIdState = (0, recoil_1.atom)({
137
+ key: 'campaignLoginIdState',
138
+ default: [],
139
+ });
@@ -38,6 +38,7 @@ var react_router_dom_1 = require("react-router-dom");
38
38
  var Constant_1 = require("../../../../ACM-AXN/Common/Constant");
39
39
  var EditPage_1 = __importDefault(require("./EditPage"));
40
40
  var Enum_1 = require("../../../../ACM-AXN/Campaign/Enum");
41
+ var Enum_2 = require("../../../../ACM-AXN/Common/Enum");
41
42
  function TabSubCampaign() {
42
43
  var _a = (0, recoil_1.useRecoilState)(Recoils_1.campaignGroupsState), subCampaigns = _a[0], setSubCampaigns = _a[1];
43
44
  var _b = (0, recoil_1.useRecoilState)(atoms_1.selectedSubCampaignIdState), selectedSubCampaignId = _b[0], setSelectedSubCampaignId = _b[1];
@@ -60,11 +61,11 @@ function TabSubCampaign() {
60
61
  campaignGroup: {
61
62
  id: newId,
62
63
  name: 'Sub-Campaign ' + newId,
63
- ticket: Enum_1.CampaignTicket.INACTIVE,
64
+ status: Enum_1.CampaignStatus.Draft,
64
65
  priority: Enum_1.CampaignPriority.ClassB,
65
66
  bookingAmount: 10,
66
67
  bonusAmount: 0,
67
- isReserved: false,
68
+ billingUnit: Enum_2.AnalyticType.Authentication,
68
69
  },
69
70
  ads: [],
70
71
  });
@@ -1,4 +1,15 @@
1
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
+ };
2
13
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
14
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
15
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -43,24 +54,38 @@ var react_1 = require("react");
43
54
  var recoil_1 = require("recoil");
44
55
  var atoms_1 = require("./atoms");
45
56
  var Hooks_1 = __importDefault(require("../../Hooks"));
57
+ var Recoils_1 = require("../Recoils");
46
58
  function useSearchPage(type) {
47
59
  var _this = this;
48
60
  var directoryId = (0, recoil_1.useRecoilValue)(atoms_1.campaignPageIdState);
61
+ var _a = (0, recoil_1.useRecoilState)(Recoils_1.cacheSearchPageState), cache = _a[0], setCache = _a[1];
49
62
  var service = (0, Hooks_1.default)().service;
50
63
  return (0, react_1.useCallback)(function (searchString) { return __awaiter(_this, void 0, void 0, function () {
51
- var temp;
64
+ var options;
52
65
  var _a;
53
66
  return __generator(this, function (_b) {
54
67
  switch (_b.label) {
55
- case 0: return [4 /*yield*/, service.pagesPaging(searchString, 10, 0, directoryId[type])];
68
+ case 0:
69
+ if (Object.keys(cache).includes(searchString || type)) {
70
+ return [2 /*return*/, cache[searchString || type]];
71
+ }
72
+ return [4 /*yield*/, service
73
+ .pagesPaging(searchString, 10, 0, directoryId[type])
74
+ .then(function (_a) {
75
+ var items = _a.items;
76
+ return items === null || items === void 0 ? void 0 : items.map(function (page) { return ({
77
+ text: page.title,
78
+ value: page.pageId,
79
+ }); });
80
+ })];
56
81
  case 1:
57
- temp = _b.sent();
58
- return [2 /*return*/, (_a = temp.items) === null || _a === void 0 ? void 0 : _a.map(function (page) { return ({
59
- text: page.title,
60
- value: page.pageId,
61
- }); })];
82
+ options = _b.sent();
83
+ setCache(__assign(__assign({}, cache), (_a = {}, _a[searchString || type] = options, _a)));
84
+ return [2 /*return*/, options];
62
85
  }
63
86
  });
64
- }); }, [service, directoryId, type]);
87
+ }); },
88
+ // eslint-disable-next-line react-hooks/exhaustive-deps
89
+ [directoryId, type]);
65
90
  }
66
91
  exports.default = useSearchPage;
@@ -1,3 +1,7 @@
1
1
  import React from 'react';
2
- declare const _default: React.FC<unknown>;
2
+ interface CreateOrEditProps {
3
+ quickWizard?: (p?: any) => JSX.Element;
4
+ type?: string;
5
+ }
6
+ declare const _default: React.FC<CreateOrEditProps>;
3
7
  export default _default;