awing-library 2.1.130-beta → 2.1.130

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 (218) 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 -43
  25. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +321 -103
  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 +122 -58
  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.d.ts +6 -1
  35. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +88 -8
  36. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.js +3 -3
  37. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +23 -71
  38. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +1 -0
  39. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +17 -4
  40. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +22 -4
  41. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +4 -1
  42. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +1 -0
  43. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +3 -2
  44. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +6 -2
  45. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +31 -32
  46. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +5 -2
  47. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +2 -2
  48. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/AddOrEditRule.js +6 -0
  49. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.d.ts +8 -0
  50. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.js +47 -0
  51. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitEvent.js +52 -6
  52. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetOS/container.js +2 -2
  53. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.d.ts +1 -0
  54. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.js +3 -1
  55. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.d.ts +4 -3
  56. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +13 -7
  57. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +5 -5
  58. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.d.ts +1 -1
  59. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +75 -123
  60. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +3 -13
  61. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +45 -20
  62. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.d.ts +2 -0
  63. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +8 -3
  64. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +3 -2
  65. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
  66. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +5 -1
  67. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +176 -59
  68. package/lib/ACM-AXN/Campaign/Enum.d.ts +23 -4
  69. package/lib/ACM-AXN/Campaign/Enum.js +30 -10
  70. package/lib/ACM-AXN/Campaign/Types.d.ts +52 -6
  71. package/lib/ACM-AXN/Campaign/Utils.d.ts +5 -0
  72. package/lib/ACM-AXN/Campaign/Utils.js +29 -2
  73. package/lib/ACM-AXN/Campaign/index.js +2 -2
  74. package/lib/ACM-AXN/CampaignPlan/Container.js +21 -10
  75. package/lib/ACM-AXN/CampaignPlan/Container.test.d.ts +1 -1
  76. package/lib/ACM-AXN/CampaignPlan/Container.test.js +1 -2
  77. package/lib/ACM-AXN/CampaignPlan/Detail.js +5 -7
  78. package/lib/ACM-AXN/CampaignPlan/Detail.test.d.ts +1 -1
  79. package/lib/ACM-AXN/CampaignPlan/Detail.test.js +2 -3
  80. package/lib/ACM-AXN/CampaignPlan/Filter.js +11 -4
  81. package/lib/ACM-AXN/CampaignPlan/Filter.test.d.ts +1 -1
  82. package/lib/ACM-AXN/CampaignPlan/Filter.test.js +0 -1
  83. package/lib/ACM-AXN/CampaignPlan/Types.d.ts +6 -74
  84. package/lib/ACM-AXN/CampaignPlan/Types.js +1 -253
  85. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +14 -10
  86. package/lib/ACM-AXN/CampaignSchedule/Components/EnhancedPagination/index.js +3 -2
  87. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +7 -5
  88. package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +4 -4
  89. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +5 -4
  90. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +1 -2
  91. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +1 -5
  92. package/lib/ACM-AXN/Common/Constant.d.ts +3 -0
  93. package/lib/ACM-AXN/Common/Constant.js +2 -0
  94. package/lib/ACM-AXN/Common/Enum.d.ts +8 -3
  95. package/lib/ACM-AXN/Common/Enum.js +19 -4
  96. package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
  97. package/lib/ACM-AXN/GeoFencing/component.js +7 -7
  98. package/lib/ACM-AXN/GeoFencing/interface.d.ts +1 -2
  99. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.d.ts +0 -5
  100. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +7 -90
  101. package/lib/ACM-AXN/Notifications/NotificationPopover/index.d.ts +0 -5
  102. package/lib/ACM-AXN/Notifications/Types.d.ts +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 -1
  107. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +16 -1
  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 +6 -9
  113. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
  114. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +40 -61
  115. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +26 -30
  116. package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +6 -8
  117. package/lib/ACM-AXN/Page/CreateOrEdit/index.js +5 -3
  118. package/lib/ACM-AXN/Page/enums.d.ts +5 -0
  119. package/lib/ACM-AXN/Page/enums.js +7 -1
  120. package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
  121. package/lib/ACM-AXN/PlaceFilter/DataTable/component/index.js +2 -5
  122. package/lib/ACM-AXN/PlaceFilter/Input/component/index.js +1 -2
  123. package/lib/ACM-AXN/PlaceFilter/interface.d.ts +1 -0
  124. package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +16 -16
  125. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +14 -9
  126. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +19 -18
  127. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +16 -6
  128. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +17 -10
  129. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
  130. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +30 -51
  131. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
  132. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
  133. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
  134. package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +16 -36
  135. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +5 -5
  136. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +14 -11
  137. package/lib/ACM-AXN/Statistics/ControlPanel.js +16 -4
  138. package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
  139. package/lib/ACM-AXN/Statistics/Enums.js +1 -0
  140. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +1 -0
  141. package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +3 -3
  142. package/lib/ACM-AXN/Template/Container.js +1 -1
  143. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
  144. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
  145. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +2 -2
  146. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +56 -39
  147. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
  148. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
  149. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
  150. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
  151. package/lib/ACM-AXN/Template/CreateOrEdit/index.js +8 -4
  152. package/lib/ACM-AXN/Template/Import.js +6 -3
  153. package/lib/ACM-AXN/Template/Types.d.ts +9 -9
  154. package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
  155. package/lib/ACM-AXN/ViewTemplate/Preview.js +5 -6
  156. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
  157. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
  158. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +46 -160
  159. package/lib/ACM-AXN/ViewTemplate/common.js +2 -3
  160. package/lib/ACM-AXN/ViewTemplate/container.js +23 -24
  161. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +3 -1
  162. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +18 -28
  163. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +2 -0
  164. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +1 -1
  165. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +17 -1
  166. package/lib/ACM-AXN/index.d.ts +1 -0
  167. package/lib/ACM-AXN/index.js +1 -0
  168. package/lib/AWING/AsyncAutocomplete/index.js +2 -2
  169. package/lib/AWING/BasicDataForm/BasicDataForm.js +9 -6
  170. package/lib/AWING/BasicDataForm/interface.d.ts +3 -0
  171. package/lib/AWING/Chart/BarLineComponent.js +29 -11
  172. package/lib/AWING/Chart/PieComponent.d.ts +3 -4
  173. package/lib/AWING/Chart/PieComponent.js +16 -16
  174. package/lib/AWING/Chart/Styles.js +51 -16
  175. package/lib/AWING/DataForm/DataInput.js +63 -20
  176. package/lib/AWING/DataForm/interface.d.ts +1 -0
  177. package/lib/AWING/DataGrid/index.js +8 -13
  178. package/lib/AWING/DateRangePicker/component.js +55 -30
  179. package/lib/AWING/DateRangePicker/configDate.d.ts +1 -2
  180. package/lib/AWING/DateRangePicker/configDate.js +12 -12
  181. package/lib/AWING/DateRangePicker/interface.d.ts +1 -0
  182. package/lib/AWING/Form/useForm.js +3 -2
  183. package/lib/AWING/GoogleMap/GGMap.d.ts +3 -0
  184. package/lib/AWING/GoogleMap/GGMap.js +256 -0
  185. package/lib/AWING/GoogleMap/index.d.ts +4 -0
  186. package/lib/AWING/GoogleMap/index.js +41 -0
  187. package/lib/AWING/GoogleMap/interface.d.ts +21 -0
  188. package/lib/AWING/GoogleMap/interface.js +2 -0
  189. package/lib/AWING/GoogleMap/utils.d.ts +25 -0
  190. package/lib/AWING/GoogleMap/utils.js +135 -0
  191. package/lib/AWING/GroupTable/GroupTable.js +4 -5
  192. package/lib/AWING/GroupTable/component.d.ts +1 -0
  193. package/lib/AWING/GroupTable/component.js +2 -2
  194. package/lib/AWING/NumberFormat/index.d.ts +3 -1
  195. package/lib/AWING/NumberFormat/index.js +2 -2
  196. package/lib/AWING/PageManagement/PageManagement.js +4 -3
  197. package/lib/AWING/Pagination/index.js +11 -3
  198. package/lib/AWING/index.d.ts +1 -0
  199. package/lib/AWING/index.js +1 -0
  200. package/lib/AWING/ultis/validation.d.ts +1 -0
  201. package/lib/AWING/ultis/validation.js +21 -5
  202. package/lib/Commons/Components/ClassicDrawer.js +5 -4
  203. package/lib/Commons/Components/DeprecatedEnhancedDialog.js +1 -1
  204. package/lib/Commons/Hooks/usePath.js +3 -3
  205. package/lib/Utils/Helpers.d.ts +4 -2
  206. package/lib/Utils/Helpers.js +56 -7
  207. package/lib/i18n.js +14 -2
  208. package/lib/translate/en/translation.json +112 -71
  209. package/lib/translate/id/translation.json +870 -0
  210. package/lib/translate/ja/translation.json +870 -0
  211. package/lib/translate/th/translation.json +870 -0
  212. package/lib/translate/vi/translation.json +76 -35
  213. package/package.json +131 -126
  214. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/fakeCampaignData.json +0 -397
  215. package/lib/ACM-AXN/ScheduleCompletionRate/json.d.ts +0 -61
  216. package/lib/ACM-AXN/ScheduleCompletionRate/json.js +0 -268
  217. package/lib/ACM-AXN/ViewTemplate/TemplateField/Utils.d.ts +0 -5
  218. package/lib/ACM-AXN/ViewTemplate/TemplateField/Utils.js +0 -14
@@ -10,41 +10,87 @@ var __assign = (this && this.__assign) || function () {
10
10
  };
11
11
  return __assign.apply(this, arguments);
12
12
  };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
13
16
  Object.defineProperty(exports, "__esModule", { value: true });
14
17
  var jsx_runtime_1 = require("react/jsx-runtime");
15
18
  var material_1 = require("@mui/material");
19
+ var Hooks_1 = __importDefault(require("../../../../../../ACM-AXN/Campaign/Hooks"));
20
+ var AWING_1 = require("../../../../../../AWING");
21
+ var Hooks_2 = require("../../../../../../AWING/Hooks");
22
+ var lodash_1 = __importDefault(require("lodash"));
23
+ var react_1 = __importDefault(require("react"));
16
24
  var react_i18next_1 = require("react-i18next");
25
+ var recoil_1 = require("recoil");
17
26
  var Enum_1 = require("../../../../Enum");
27
+ var atoms_1 = require("../../atoms");
18
28
  var LimitEvent = function (props) {
19
- var _a, _b;
29
+ var _a, _b, _c, _d, _e, _f;
20
30
  var rule = props.rule, valids = props.valids, onChange = props.onChange;
21
31
  var t = (0, react_i18next_1.useTranslation)().t;
32
+ var loginPageIds = (0, recoil_1.useRecoilValue)(atoms_1.campaignLoginIdState);
33
+ var service = (0, Hooks_1.default)().service;
22
34
  var handleChange = function (fieldName, fieldValue) {
23
35
  var _a;
24
36
  onChange(__assign(__assign({}, rule), (_a = {}, _a[fieldName] = fieldValue, _a)));
25
37
  };
38
+ var _g = (0, Hooks_2.useGetData)([loginPageIds], service.pagesGetPageViewEventByPageIds), data = _g.data, isLoading = _g.isLoading;
39
+ var eventSelected = react_1.default.useMemo(function () {
40
+ return (0, lodash_1.default)(data)
41
+ .groupBy(function (d) { return "".concat(d.viewNumber, "_").concat(d.event); })
42
+ .filter(function (value) {
43
+ return !lodash_1.default.difference(loginPageIds, value.map(function (v) { return v.pageId; })).length;
44
+ }).flatten()
45
+ .uniqBy(function (d) { return "".concat(d.viewNumber, "_").concat(d.event); })
46
+ .groupBy('event')
47
+ .value();
48
+ }, [data, loginPageIds]);
49
+ var viewNumberSelected = react_1.default.useMemo(function () {
50
+ var _a, _b, _c;
51
+ return ((_a = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _a === void 0 ? void 0 : _a.eventLabel)
52
+ ? (_c = eventSelected[(_b = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _b === void 0 ? void 0 : _b.eventLabel]) === null || _c === void 0 ? void 0 : _c.sort(function (a, b) { return a.viewNumber - b.viewNumber; })
53
+ : [];
54
+ }, [eventSelected, (_a = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _a === void 0 ? void 0 : _a.eventLabel]);
26
55
  var handleChangeParameter = function (fieldName, fieldValue) {
27
- var _a;
28
- handleChange('parameter', __assign(__assign({}, rule.parameter), (_a = {}, _a[fieldName] = fieldValue, _a)));
56
+ var _a, _b;
57
+ var _c, _d;
58
+ if (fieldName === 'eventLabel') {
59
+ var viewNumber = undefined;
60
+ if (((_c = eventSelected[fieldValue]) === null || _c === void 0 ? void 0 : _c.length) === 1) {
61
+ viewNumber = (_d = eventSelected[fieldValue]) === null || _d === void 0 ? void 0 : _d.at(-1).viewNumber;
62
+ }
63
+ handleChange('parameter', __assign(__assign({}, rule.parameter), (_a = { viewNumber: viewNumber }, _a[fieldName] = fieldValue, _a)));
64
+ return;
65
+ }
66
+ handleChange('parameter', __assign(__assign({}, rule.parameter), (_b = {}, _b[fieldName] = fieldValue, _b)));
29
67
  };
30
68
  var translationText = {
31
69
  eventLabel: t('Campaign.Detail.EventLabel'),
70
+ viewNumber: t('Campaign.Detail.ViewNumber'),
32
71
  operator: t('Campaign.Operator'),
33
72
  period: t('Campaign.Period'),
34
73
  value: t('Campaign.Detail.Value'),
35
74
  periodHelperText: t('Campaign.PeriodHelperText'),
36
75
  helperText: t('Common.Required'),
37
76
  };
38
- return ((0, jsx_runtime_1.jsxs)(material_1.Grid, { container: true, spacing: 2, children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 12, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "eventLabel", name: "eventLabel", variant: "standard", fullWidth: true, label: translationText.eventLabel, value: (_a = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _a === void 0 ? void 0 : _a.eventLabel, onChange: function (e) {
77
+ return isLoading ? ((0, jsx_runtime_1.jsx)(AWING_1.CircularProgress, {})) : ((0, jsx_runtime_1.jsxs)(material_1.Grid, { container: true, spacing: 2, children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 6, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "eventLabel", name: "eventLabel", variant: "standard", fullWidth: true, select: true, label: translationText.eventLabel, value: (_b = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _b === void 0 ? void 0 : _b.eventLabel, onChange: function (e) {
39
78
  return handleChangeParameter('eventLabel', e.target.value);
40
79
  }, error: valids && !valids.eventLabel, helperText: valids && !valids.eventLabel
41
80
  ? translationText.helperText
42
- : '' }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 6, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: 'operator', variant: "standard", name: 'operator', select: true, fullWidth: true, label: translationText.operator, value: rule === null || rule === void 0 ? void 0 : rule.operator, onChange: function (e) { return handleChange('operator', e.target.value); }, children: Object.entries(Enum_1.EnumOperator).map(function (_a) {
81
+ : '', children: Object.keys(eventSelected).map(function (event, index) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: event, children: event }, index)); }) }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 6, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "viewNumber", name: "viewNumber", variant: "standard", disabled: !((_c = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _c === void 0 ? void 0 : _c.eventLabel), required: true, select: true, fullWidth: true, label: translationText.viewNumber, value: (_e = (_d = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _d === void 0 ? void 0 : _d.viewNumber) !== null && _e !== void 0 ? _e : "", onChange: function (e) {
82
+ return handleChangeParameter('viewNumber', e.target.value);
83
+ }, error: valids && !valids.viewNumber, helperText: valids && !valids.viewNumber
84
+ ? translationText.helperText
85
+ : '', children: viewNumberSelected.map(function (_a) {
86
+ var viewNumber = _a.viewNumber;
87
+ return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: viewNumber, children: viewNumber }, viewNumber));
88
+ }) }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 6, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: 'operator', variant: "standard", name: 'operator', select: true, fullWidth: true, label: translationText.operator, value: rule === null || rule === void 0 ? void 0 : rule.operator, onChange: function (e) { return handleChange('operator', e.target.value); }, children: Object.entries(Enum_1.EnumOperator).map(function (_a) {
43
89
  var key = _a[0], val = _a[1];
44
90
  return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: val.id, children: val.text }, val.id));
45
91
  }) }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 6, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { id: "value", name: "value", variant: "standard", type: "number", fullWidth: true, label: translationText.value, value: rule === null || rule === void 0 ? void 0 : rule.value, onChange: function (e) { return handleChange('value', e.target.value); }, error: valids && !valids.value, helperText: valids && !valids.value
46
92
  ? translationText.helperText
47
- : '' }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 12, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { variant: "standard", id: "period", name: "period", type: "number", fullWidth: true, label: translationText.period, value: (_b = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _b === void 0 ? void 0 : _b.period, onChange: function (e) {
93
+ : '' }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 12, children: (0, jsx_runtime_1.jsx)(material_1.TextField, { variant: "standard", id: "period", name: "period", type: "number", fullWidth: true, label: translationText.period, value: (_f = rule === null || rule === void 0 ? void 0 : rule.parameter) === null || _f === void 0 ? void 0 : _f.period, onChange: function (e) {
48
94
  return handleChangeParameter('period', e.target.value);
49
95
  }, error: valids && !valids.period, helperText: translationText.periodHelperText }) })] }));
50
96
  };
@@ -39,9 +39,9 @@ var TargetOSContainer = function (props) {
39
39
  if (!rule ||
40
40
  !osVerList.some(function (x) { return x.value === rule.value; }) ||
41
41
  !osVerList.some(function (x) { return x.osName === rule.parameter.os; })) {
42
- onChange(__assign(__assign({}, rule), { value: osVerList[0].value, parameter: JSON.stringify({
42
+ onChange(__assign(__assign({}, rule), { value: osVerList[0].value, parameter: {
43
43
  os: osVerList[0].osName,
44
- }) }));
44
+ } }));
45
45
  }
46
46
  });
47
47
  // eslint-disable-next-line react-hooks/exhaustive-deps
@@ -6,3 +6,4 @@ export { default as TargetAge } from './TargetAge';
6
6
  export { default as TargetOS } from './TargetOS';
7
7
  export { default as TargetDevice } from './TargetDevice';
8
8
  export { default as RetargetMacAddress } from './RetargetMacAddress';
9
+ export { default as AuthenCation } from './Authentication';
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.RetargetMacAddress = exports.TargetDevice = exports.TargetOS = exports.TargetAge = exports.TargetGender = exports.LimitEvent = exports.LimitClick = exports.LimitView = void 0;
6
+ exports.AuthenCation = exports.RetargetMacAddress = exports.TargetDevice = exports.TargetOS = exports.TargetAge = exports.TargetGender = exports.LimitEvent = exports.LimitClick = exports.LimitView = void 0;
7
7
  var LimitClick_1 = require("./LimitClick");
8
8
  Object.defineProperty(exports, "LimitView", { enumerable: true, get: function () { return __importDefault(LimitClick_1).default; } });
9
9
  var LimitClick_2 = require("./LimitClick");
@@ -20,3 +20,5 @@ var TargetDevice_1 = require("./TargetDevice");
20
20
  Object.defineProperty(exports, "TargetDevice", { enumerable: true, get: function () { return __importDefault(TargetDevice_1).default; } });
21
21
  var RetargetMacAddress_1 = require("./RetargetMacAddress");
22
22
  Object.defineProperty(exports, "RetargetMacAddress", { enumerable: true, get: function () { return __importDefault(RetargetMacAddress_1).default; } });
23
+ var Authentication_1 = require("./Authentication");
24
+ Object.defineProperty(exports, "AuthenCation", { enumerable: true, get: function () { return __importDefault(Authentication_1).default; } });
@@ -1,4 +1,4 @@
1
- import { Dispatch, SetStateAction } from 'react';
1
+ import React, { Dispatch, SetStateAction } from 'react';
2
2
  import { CampaignAdAdvanced } from '../../Types';
3
3
  type Props = {
4
4
  /**
@@ -18,6 +18,7 @@ type Props = {
18
18
  */
19
19
  initialCampaignAdAdvanced?: CampaignAdAdvanced;
20
20
  service: any;
21
+ loginIds: string[];
21
22
  };
22
- declare const Advanced: (props: Props) => import("react/jsx-runtime").JSX.Element;
23
- export default Advanced;
23
+ declare const _default: React.FC<Props>;
24
+ export default _default;
@@ -49,15 +49,18 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
49
49
  };
50
50
  Object.defineProperty(exports, "__esModule", { value: true });
51
51
  var jsx_runtime_1 = require("react/jsx-runtime");
52
- var react_1 = __importStar(require("react"));
53
- var material_1 = require("@mui/material");
54
52
  var icons_material_1 = require("@mui/icons-material");
55
- var Utils_1 = require("../../Utils");
53
+ var material_1 = require("@mui/material");
54
+ var react_1 = __importStar(require("react"));
56
55
  var react_i18next_1 = require("react-i18next");
57
- var AddOrEditRule_1 = require("./AddOrEditRule");
58
56
  var ClassicBaseDrawer_1 = __importDefault(require("../../../../Commons/Components/ClassicBaseDrawer"));
59
57
  var Context_1 = require("../../../../Context");
60
58
  var i18n_1 = __importDefault(require("../../../../i18n"));
59
+ var Utils_1 = require("../../Utils");
60
+ var AddOrEditRule_1 = require("./AddOrEditRule");
61
+ var Wrapper_1 = __importDefault(require("../../../../AWING/HOC/Wrapper"));
62
+ var recoil_1 = require("recoil");
63
+ var atoms_1 = require("./atoms");
61
64
  var classes = {
62
65
  paper: {
63
66
  padding: function (theme) { return theme.spacing(2); },
@@ -107,6 +110,7 @@ var Advanced = function (props) {
107
110
  editRule: false,
108
111
  editExpression: false,
109
112
  }), drawerRule = _b[0], setDrawerRule = _b[1];
113
+ var setLoginIds = (0, recoil_1.useSetRecoilState)(atoms_1.campaignLoginIdState);
110
114
  var _c = react_1.default.useState(null), anchorElRule = _c[0], setAnchorElRule = _c[1];
111
115
  var _d = react_1.default.useState({
112
116
  type: '',
@@ -115,6 +119,7 @@ var Advanced = function (props) {
115
119
  var _e = react_1.default.useState(defaultCampaignAdAdvanced), campaignAdAdvanced = _e[0], setCampaignAdAdvanced = _e[1];
116
120
  var _f = react_1.default.useState(false), isConfirm = _f[0], setIsConfirm = _f[1];
117
121
  (0, react_1.useEffect)(function () {
122
+ setLoginIds(props.loginIds);
118
123
  if (initialCampaignAdAdvanced)
119
124
  setCampaignAdAdvanced(initialCampaignAdAdvanced);
120
125
  }, [initialCampaignAdAdvanced]);
@@ -134,7 +139,7 @@ var Advanced = function (props) {
134
139
  alert(t('Campaign.MaximumNumberOfRule'));
135
140
  return;
136
141
  }
137
- setRule(__assign(__assign({}, rule), { type: type }));
142
+ setRule(function (prev) { return (__assign(__assign({}, prev), { type: type })); });
138
143
  handleButtonMenuClose();
139
144
  setDrawerRule(function (prev) { return (__assign(__assign({}, prev), { addRule: true })); });
140
145
  // navigate(Constants.CAMPAIGN_ADD_RULE)
@@ -144,7 +149,7 @@ var Advanced = function (props) {
144
149
  // navigate(Constants.CAMPAIGN_UPDATE_EXPRESSION)
145
150
  };
146
151
  var handleEditRule = function (ruleName) {
147
- setRule(__assign(__assign({}, rule), { name: ruleName }));
152
+ setRule(function (prev) { return (__assign(__assign({}, prev), { name: ruleName })); });
148
153
  setDrawerRule(function (prev) { return (__assign(__assign({}, prev), { editRule: true })); });
149
154
  // navigate(Constants.CAMPAIGN_EDIT_RULE)
150
155
  };
@@ -175,6 +180,7 @@ var Advanced = function (props) {
175
180
  type: {
176
181
  LimitView: t('Campaign.RuleType.LimitView'),
177
182
  LimitClick: t('Campaign.RuleType.LimitClick'),
183
+ Authentication: t('Campaign.RuleType.Engagement'),
178
184
  LimitEvent: t('Campaign.RuleType.LimitEvent'),
179
185
  TargetGender: t('Campaign.RuleType.TargetGender'),
180
186
  TargetAge: t('Campaign.RuleType.TargetAge'),
@@ -230,4 +236,4 @@ var Advanced = function (props) {
230
236
  setCampaignAdAdvanced(__assign(__assign({}, campaignAdAdvanced), { ruleLogicalExpression: ruleLogicalExpression }));
231
237
  } }))] }));
232
238
  };
233
- exports.default = Advanced;
239
+ exports.default = (0, Wrapper_1.default)(Advanced, { component: recoil_1.RecoilRoot });
@@ -77,11 +77,11 @@ function EditAds(props) {
77
77
  label: t('Campaign.Ad.Time'),
78
78
  required: true,
79
79
  },
80
- {
81
- fieldName: 'isReserved',
82
- type: 'checkbox',
83
- label: t('Campaign.Ad.Reserved'),
84
- },
80
+ // {
81
+ // fieldName: 'isReserved',
82
+ // type: 'checkbox',
83
+ // label: t('Campaign.Ad.Reserved'),
84
+ // },
85
85
  {
86
86
  fieldName: 'placeFilter',
87
87
  type: 'text',
@@ -1,4 +1,4 @@
1
- import { SetStateAction, Dispatch } from 'react';
1
+ import { Dispatch, SetStateAction } from 'react';
2
2
  import { CampaignGroup } from '../../Types';
3
3
  type SubCampaignDetailProps = {
4
4
  /**
@@ -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);