awing-library 2.1.147-beta → 2.1.147

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 (212) hide show
  1. package/lib/ACM-AXN/AuthenticationProfile/Container.js +4 -4
  2. package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.js +2 -2
  3. package/lib/ACM-AXN/Campaign/Container.js +52 -54
  4. package/lib/ACM-AXN/Campaign/Container.test.js +1 -3
  5. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.d.ts +8 -1
  6. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.js +27 -3
  7. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.d.ts +17 -0
  8. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.js +121 -0
  9. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.d.ts +1 -0
  10. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.js +219 -0
  11. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.d.ts +2 -0
  12. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.js +306 -0
  13. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.d.ts +1 -0
  14. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.js +230 -0
  15. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.d.ts +1 -0
  16. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.js +123 -0
  17. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.d.ts +1 -0
  18. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.js +253 -0
  19. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabInfomation.js +21 -5
  20. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.d.ts +1 -1
  21. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.js +47 -78
  22. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.d.ts +2 -1
  23. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +2 -2
  24. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.js +2 -1
  25. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.js +2 -1
  26. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +19 -42
  27. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +298 -96
  28. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +3 -0
  29. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +119 -54
  30. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +1 -1
  31. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +46 -8
  32. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +6 -4
  33. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +1 -1
  34. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.d.ts +9 -0
  35. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.js +56 -0
  36. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +5 -1
  37. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.d.ts +12 -0
  38. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +22 -7
  39. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +63 -12
  40. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +1 -0
  41. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +17 -4
  42. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +10 -0
  43. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +4 -1
  44. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +1 -0
  45. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +3 -2
  46. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +6 -2
  47. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +31 -29
  48. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +1 -1
  49. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +1 -1
  50. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetOS/container.js +2 -2
  51. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +1 -1
  52. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +5 -5
  53. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +44 -33
  54. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +3 -13
  55. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +45 -20
  56. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +3 -2
  57. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +3 -2
  58. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
  59. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +5 -1
  60. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +172 -59
  61. package/lib/ACM-AXN/Campaign/Enum.d.ts +24 -6
  62. package/lib/ACM-AXN/Campaign/Enum.js +30 -11
  63. package/lib/ACM-AXN/Campaign/Types.d.ts +53 -5
  64. package/lib/ACM-AXN/Campaign/Utils.d.ts +6 -1
  65. package/lib/ACM-AXN/Campaign/Utils.js +50 -3
  66. package/lib/ACM-AXN/Campaign/index.js +2 -2
  67. package/lib/ACM-AXN/CampaignPlan/Container.js +4 -6
  68. package/lib/ACM-AXN/CampaignPlan/Detail.js +3 -3
  69. package/lib/ACM-AXN/CampaignPlan/Filter.js +3 -3
  70. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +14 -10
  71. package/lib/ACM-AXN/CampaignSchedule/Components/EnhancedPagination/index.js +3 -2
  72. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +5 -7
  73. package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +4 -4
  74. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +5 -4
  75. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +1 -2
  76. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +1 -5
  77. package/lib/ACM-AXN/Common/Constant.d.ts +3 -0
  78. package/lib/ACM-AXN/Common/Constant.js +2 -0
  79. package/lib/ACM-AXN/Common/Enum.d.ts +8 -3
  80. package/lib/ACM-AXN/Common/Enum.js +19 -4
  81. package/lib/ACM-AXN/Common/Types.d.ts +5 -0
  82. package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
  83. package/lib/ACM-AXN/GeoFencing/component.js +7 -7
  84. package/lib/ACM-AXN/GeoFencing/interface.d.ts +1 -2
  85. package/lib/ACM-AXN/Holiday/FormHoliday.js +1 -0
  86. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.d.ts +0 -5
  87. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +7 -90
  88. package/lib/ACM-AXN/Notifications/NotificationPopover/index.d.ts +0 -5
  89. package/lib/ACM-AXN/Notifications/Types.d.ts +2 -0
  90. package/lib/ACM-AXN/Page/Constant.js +2 -0
  91. package/lib/ACM-AXN/Page/Container.js +3 -3
  92. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.d.ts +6 -0
  93. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.js +63 -0
  94. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.d.ts +11 -2
  95. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +16 -12
  96. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/TrackingCode.js +1 -1
  97. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/Utils.js +1 -1
  98. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/index.js +1 -0
  99. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.d.ts +1 -9
  100. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.js +0 -9
  101. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewContent.js +11 -44
  102. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
  103. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +39 -61
  104. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +29 -32
  105. package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +6 -6
  106. package/lib/ACM-AXN/Page/CreateOrEdit/index.js +19 -4
  107. package/lib/ACM-AXN/Page/Import/index.js +2 -2
  108. package/lib/ACM-AXN/Page/Types.d.ts +3 -0
  109. package/lib/ACM-AXN/Page/enums.d.ts +5 -0
  110. package/lib/ACM-AXN/Page/enums.js +7 -1
  111. package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
  112. package/lib/ACM-AXN/PlaceFilter/DataTable/component/index.js +2 -5
  113. package/lib/ACM-AXN/PlaceFilter/Input/component/index.js +1 -2
  114. package/lib/ACM-AXN/PlaceFilter/Tag/component/TagChip.js +1 -1
  115. package/lib/ACM-AXN/PlaceFilter/interface.d.ts +1 -0
  116. package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +16 -16
  117. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +14 -9
  118. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +19 -18
  119. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +16 -6
  120. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +17 -10
  121. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
  122. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +30 -51
  123. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
  124. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
  125. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
  126. package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +16 -36
  127. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +5 -5
  128. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +13 -10
  129. package/lib/ACM-AXN/Statistics/ControlPanel.js +17 -5
  130. package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
  131. package/lib/ACM-AXN/Statistics/Enums.js +1 -0
  132. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +1 -0
  133. package/lib/ACM-AXN/StatisticsByProvince/DataTable.js +1 -1
  134. package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +4 -4
  135. package/lib/ACM-AXN/Template/Container.js +2 -2
  136. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
  137. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
  138. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +2 -2
  139. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +56 -37
  140. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
  141. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
  142. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
  143. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
  144. package/lib/ACM-AXN/Template/CreateOrEdit/index.js +8 -4
  145. package/lib/ACM-AXN/Template/Import.js +2 -2
  146. package/lib/ACM-AXN/Template/Types.d.ts +9 -9
  147. package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
  148. package/lib/ACM-AXN/ViewTemplate/Preview.js +5 -6
  149. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +23 -11
  150. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
  151. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
  152. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +42 -129
  153. package/lib/ACM-AXN/ViewTemplate/common.d.ts +2 -1
  154. package/lib/ACM-AXN/ViewTemplate/common.js +47 -7
  155. package/lib/ACM-AXN/ViewTemplate/container.js +8 -2
  156. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +3 -1
  157. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +18 -28
  158. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +2 -0
  159. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +1 -1
  160. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +17 -1
  161. package/lib/ACM-AXN/index.d.ts +1 -0
  162. package/lib/ACM-AXN/index.js +1 -0
  163. package/lib/AWING/AsyncAutocomplete/index.js +2 -2
  164. package/lib/AWING/BasicDataForm/BasicDataForm.js +9 -6
  165. package/lib/AWING/BasicDataForm/interface.d.ts +3 -0
  166. package/lib/AWING/Chart/BarLineComponent.js +20 -24
  167. package/lib/AWING/Chart/PieComponent.d.ts +3 -4
  168. package/lib/AWING/Chart/PieComponent.js +16 -16
  169. package/lib/AWING/Chart/Styles.js +51 -16
  170. package/lib/AWING/DataForm/DataInput.js +105 -23
  171. package/lib/AWING/DataForm/interface.d.ts +2 -0
  172. package/lib/AWING/DataGrid/index.js +8 -13
  173. package/lib/AWING/DateRangePicker/component.js +81 -33
  174. package/lib/AWING/DateRangePicker/configDate.d.ts +1 -2
  175. package/lib/AWING/DateRangePicker/configDate.js +12 -12
  176. package/lib/AWING/DateRangePicker/interface.d.ts +1 -0
  177. package/lib/AWING/Form/useForm.js +3 -2
  178. package/lib/AWING/GoogleMap/GGMap.d.ts +3 -0
  179. package/lib/AWING/GoogleMap/GGMap.js +256 -0
  180. package/lib/AWING/GoogleMap/index.d.ts +4 -0
  181. package/lib/AWING/GoogleMap/index.js +41 -0
  182. package/lib/AWING/GoogleMap/interface.d.ts +21 -0
  183. package/lib/AWING/GoogleMap/interface.js +2 -0
  184. package/lib/AWING/GoogleMap/utils.d.ts +25 -0
  185. package/lib/AWING/GoogleMap/utils.js +135 -0
  186. package/lib/AWING/GroupTable/GroupTable.js +2 -2
  187. package/lib/AWING/GroupTable/component.d.ts +1 -0
  188. package/lib/AWING/GroupTable/component.js +2 -2
  189. package/lib/AWING/NumberFormat/index.d.ts +3 -1
  190. package/lib/AWING/NumberFormat/index.js +2 -2
  191. package/lib/AWING/PageManagement/PageManagement.js +4 -3
  192. package/lib/AWING/Pagination/index.js +11 -3
  193. package/lib/AWING/index.d.ts +1 -0
  194. package/lib/AWING/index.js +1 -0
  195. package/lib/AWING/ultis/validation.d.ts +1 -0
  196. package/lib/AWING/ultis/validation.js +25 -6
  197. package/lib/Commons/Components/ClassicDrawer.js +5 -4
  198. package/lib/Commons/Components/HighlightedCode/MarkdownElement.js +6 -1
  199. package/lib/Commons/Hooks/usePath.js +3 -3
  200. package/lib/Utils/Helpers.d.ts +4 -3
  201. package/lib/Utils/Helpers.js +54 -23
  202. package/lib/i18n.js +31 -2
  203. package/lib/translate/en/translation.json +131 -71
  204. package/lib/translate/id/translation.json +893 -0
  205. package/lib/translate/ind/translation.json +893 -0
  206. package/lib/translate/ja/translation.json +893 -0
  207. package/lib/translate/lao/translation.json +893 -0
  208. package/lib/translate/mys/translation.json +893 -0
  209. package/lib/translate/phl/translation.json +893 -0
  210. package/lib/translate/th/translation.json +893 -0
  211. package/lib/translate/vi/translation.json +91 -31
  212. package/package.json +9 -4
@@ -1,6 +1,7 @@
1
1
  import React from 'react';
2
2
  interface Props {
3
3
  onSubmit: (value: string) => void;
4
+ loading?: boolean;
4
5
  }
5
6
  declare const SplitButtonExportType: React.FC<Props>;
6
7
  export default SplitButtonExportType;
@@ -20,13 +20,25 @@ var material_1 = require("@mui/material");
20
20
  var ArrowDropDown_1 = __importDefault(require("@mui/icons-material/ArrowDropDown"));
21
21
  var common_1 = require("./common");
22
22
  var react_i18next_1 = require("react-i18next");
23
- var options = Object.values(common_1.EXPORT_TYPES).map(function (type, idx) { return type; });
23
+ var i18n_1 = __importDefault(require("../../../../i18n"));
24
+ var lab_1 = require("@mui/lab");
25
+ var Context_1 = __importDefault(require("./Context"));
24
26
  var SplitButtonExportType = function (props) {
25
- var onSubmit = props.onSubmit;
27
+ var onSubmit = props.onSubmit, loading = props.loading;
28
+ var services = (0, Context_1.default)().services;
26
29
  var _a = react_1.default.useState(false), open = _a[0], setOpen = _a[1];
27
30
  var anchorRef = react_1.default.useRef(null);
28
31
  var _b = react_1.default.useState(0), selectedIndex = _b[0], setSelectedIndex = _b[1];
29
- var t = (0, react_i18next_1.useTranslation)().t;
32
+ var options = react_1.default.useMemo(function () {
33
+ return Object.values(common_1.EXPORT_TYPES)
34
+ .map(function (type, idx) { return type; })
35
+ .filter(function (type) {
36
+ return services.domainsGetAll ? true : type !== 'Domain';
37
+ });
38
+ },
39
+ // eslint-disable-next-line react-hooks/exhaustive-deps
40
+ []);
41
+ var t = (0, react_i18next_1.useTranslation)(undefined, { i18n: i18n_1.default }).t;
30
42
  var handleClick = function () {
31
43
  onSubmit(options[selectedIndex]);
32
44
  };
@@ -49,8 +61,9 @@ var SplitButtonExportType = function (props) {
49
61
  Domain: t("Campaign.ExportType.Domain"),
50
62
  Location: t('Campaign.ExportType.Location'),
51
63
  LocationGroup: t('Campaign.ExportType.LocationGroup'),
64
+ Ad: t('Campaign.ExportType.Ad'),
52
65
  };
53
- return ((0, jsx_runtime_1.jsx)(material_1.Grid, { container: true, direction: "column", alignItems: "center", children: (0, jsx_runtime_1.jsxs)(material_1.Grid, { item: true, xs: 12, children: [(0, jsx_runtime_1.jsxs)(material_1.ButtonGroup, { variant: "outlined", color: "inherit", ref: anchorRef, "aria-label": "split button", children: [(0, jsx_runtime_1.jsx)(material_1.Button, { onClick: handleClick, children: translationText[options[selectedIndex]] }), (0, jsx_runtime_1.jsx)(material_1.Button, { size: "small", "aria-controls": open ? 'split-button-menu' : undefined, "aria-expanded": open ? 'true' : undefined, "aria-label": "select merge strategy", "aria-haspopup": "menu", onClick: handleToggle, children: (0, jsx_runtime_1.jsx)(ArrowDropDown_1.default, {}) })] }), (0, jsx_runtime_1.jsx)(material_1.Popper, { style: { zIndex: 99999 }, open: open, anchorEl: anchorRef.current, transition: true, children: function (_a) {
66
+ return ((0, jsx_runtime_1.jsx)(material_1.Grid, { container: true, direction: "column", alignItems: "center", children: (0, jsx_runtime_1.jsxs)(material_1.Grid, { item: true, xs: 12, children: [(0, jsx_runtime_1.jsxs)(material_1.ButtonGroup, { disabled: loading, variant: "outlined", color: "inherit", ref: anchorRef, "aria-label": "split button", children: [(0, jsx_runtime_1.jsx)(lab_1.LoadingButton, { variant: 'outlined', onClick: handleClick, loading: loading, children: translationText[options[selectedIndex]] }), (0, jsx_runtime_1.jsx)(material_1.Button, { size: "small", "aria-controls": open ? 'split-button-menu' : undefined, "aria-expanded": open ? 'true' : undefined, "aria-label": "select merge strategy", "aria-haspopup": "menu", onClick: handleToggle, children: (0, jsx_runtime_1.jsx)(ArrowDropDown_1.default, {}) })] }), (0, jsx_runtime_1.jsx)(material_1.Popper, { style: { zIndex: 99999 }, open: open, anchorEl: anchorRef.current, transition: true, children: function (_a) {
54
67
  var TransitionProps = _a.TransitionProps, placement = _a.placement;
55
68
  return ((0, jsx_runtime_1.jsx)(material_1.Grow, __assign({}, TransitionProps, { style: {
56
69
  transformOrigin: placement === 'bottom'
@@ -2,6 +2,7 @@
2
2
  import { CampaignGroupModel, PlaceFilter } from '../../../../ACM-AXN/Campaign/Types';
3
3
  import { ShareType } from '../../../../ACM-AXN/Common/Enum';
4
4
  import { IStatisticDTO, Timestamp } from '../../../../ACM-AXN/Common/Types';
5
+ import { AdministrativeUnitType } from '../../../../ACM-AXN/Page/enums';
5
6
  import { BaseChartComponent } from 'react-chartjs-2/dist/types';
6
7
  export interface IAudienceObjectOverview {
7
8
  timeline?: number;
@@ -81,6 +82,12 @@ export type DateRange = {
81
82
  startDate: Date;
82
83
  endDate: Date;
83
84
  };
85
+ export type AdministrativeUnit = {
86
+ code?: string | undefined;
87
+ parentUnitCode?: string | undefined;
88
+ name?: string | undefined;
89
+ type?: AdministrativeUnitType;
90
+ };
84
91
  export interface CampaignAnalyticService {
85
92
  campaignStatisticGetEvents(body: IStatisticDTO | undefined): Promise<AnalyticEvent[]>;
86
93
  campaignStatisticGetCustomer(startDate: string | undefined, endDate: string | undefined, campaignId: string | undefined): Promise<AudienceObjectReply>;
@@ -88,12 +95,15 @@ export interface CampaignAnalyticService {
88
95
  domainsGetAll?: () => Promise<IDomain[]>;
89
96
  placesGetPagingByPlaceFilter: (pageIndex?: number, pageSize?: number, body?: PlaceFilter) => Promise<any>;
90
97
  placesGetByPlaceFilter: (body?: PlaceFilter) => Promise<any[]>;
98
+ administrativeUnitsGet: () => Promise<AdministrativeUnit[]>;
91
99
  }
92
100
  export interface CampaignAnalyticProps {
93
101
  placeMultiSelectComponent: (p?: any) => JSX.Element;
102
+ fullPlaces?: AdministrativeUnit[];
94
103
  chart: BaseChartComponent;
95
104
  services: CampaignAnalyticService;
96
105
  campaignId: string;
106
+ campaignName?: string;
97
107
  isNetwork?: boolean;
98
108
  subCampaigns: CampaignGroupModel[];
99
109
  }
@@ -27,7 +27,10 @@ var getTime = function (subCampaigns) {
27
27
  exports.getTime = getTime;
28
28
  var extractEvent = function (eventLabel) {
29
29
  if (eventLabel === void 0) { eventLabel = ''; }
30
- var _a = eventLabel.match(/^(\d+)_([\s\S]*)$/) || [], view = _a[1], eventName = _a[2];
30
+ if (!eventLabel) {
31
+ throw new Error('Event label is required');
32
+ }
33
+ var _a = eventLabel.match(/^(\d+)_([\s\S]*)$/) || ['', '1', eventLabel], view = _a[1], eventName = _a[2];
31
34
  return { view: view, eventName: eventName };
32
35
  };
33
36
  exports.extractEvent = extractEvent;
@@ -3,4 +3,5 @@ export declare const EXPORT_TYPES: {
3
3
  Domain: string;
4
4
  LocationGroup: string;
5
5
  Location: string;
6
+ Ad: string;
6
7
  };
@@ -4,6 +4,7 @@ exports.EXPORT_TYPES = void 0;
4
4
  exports.EXPORT_TYPES = {
5
5
  Export: "Export",
6
6
  Domain: "Domain",
7
- LocationGroup: "LocationGroup",
8
- Location: "Location",
7
+ LocationGroup: "LocationGroup", // Chiến dịch con
8
+ Location: "Location", // Địa điểm
9
+ Ad: "Ad" // Quảng cáo
9
10
  };
@@ -1,14 +1,18 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  var jsx_runtime_1 = require("react/jsx-runtime");
4
7
  var react_i18next_1 = require("react-i18next");
5
8
  var material_1 = require("@mui/material");
6
9
  var react_1 = require("react");
7
10
  var container_1 = require("./container");
11
+ var i18n_1 = __importDefault(require("../../../../i18n"));
8
12
  var color = ['inherit', 'primary'];
9
13
  var variant = ['outlined', 'contained'];
10
14
  var TabStatistic = function (props) {
11
- var t = (0, react_i18next_1.useTranslation)().t;
15
+ var t = (0, react_i18next_1.useTranslation)(undefined, { i18n: i18n_1.default }).t;
12
16
  var tabIndex = props.tabIndex, onChangeTab = props.onChangeTab, tabPanel = props.tabPanel, isNetwork = props.isNetwork;
13
17
  var translationText = (0, react_1.useMemo)(function () { return ({
14
18
  analytic: t('Campaign.Analytic'),
@@ -19,7 +23,7 @@ var TabStatistic = function (props) {
19
23
  var handleChangeTab = function (event) {
20
24
  onChangeTab(Number(event.target.tabIndex));
21
25
  };
22
- return ((0, jsx_runtime_1.jsxs)(material_1.Grid, { container: true, sx: { padding: function (theme) { return theme.spacing(2); } }, className: "ahihu", children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 12, children: (0, jsx_runtime_1.jsxs)(material_1.Grid, { container: true, children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 3, children: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "h6", sx: {
26
+ return ((0, jsx_runtime_1.jsxs)(material_1.Grid, { container: true, sx: { padding: function (theme) { return theme.spacing(2); } }, children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 12, children: (0, jsx_runtime_1.jsxs)(material_1.Grid, { container: true, children: [(0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 3, children: (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "h6", sx: {
23
27
  marginTop: function (theme) { return theme.spacing(1); },
24
28
  marginLeft: function (theme) { return theme.spacing(2); },
25
29
  }, children: translationText.title }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 6, children: (0, jsx_runtime_1.jsx)(material_1.ButtonGroup, { sx: {
@@ -39,13 +39,42 @@ var Context_1 = __importStar(require("./Context"));
39
39
  var Hooks_1 = require("../../../../AWING/Hooks");
40
40
  exports.tabs = { ANALYTIC: 0, EVENT: 1, CUSTOMER: 2 };
41
41
  function TabStatisticsContainer() {
42
- var _a = (0, Context_1.default)(), client = _a.services, campaignId = _a.campaignId, subCampaigns = _a.subCampaigns, isNetwork = _a.isNetwork;
42
+ var _a = (0, Context_1.default)(), client = _a.services, campaignId = _a.campaignId, subCampaigns = _a.subCampaigns, isNetwork = _a.isNetwork, campaignName = _a.campaignName, fullPlaces = _a.fullPlaces;
43
43
  var _b = (0, react_1.useState)(exports.tabs.ANALYTIC), tabIndex = _b[0], setTabIndex = _b[1];
44
44
  var time = (0, react_1.useMemo)(function () { return (0, Utils_1.getTime)(subCampaigns); }, [subCampaigns]);
45
+ var _c = (0, Hooks_1.useGetData)([], function () {
46
+ return client.domainsGetAll
47
+ ? client === null || client === void 0 ? void 0 : client.domainsGetAll().then(function (res) {
48
+ var campaignDomains = [];
49
+ subCampaigns.forEach(function (s) {
50
+ var _a;
51
+ (_a = s === null || s === void 0 ? void 0 : s.ads) === null || _a === void 0 ? void 0 : _a.forEach(function (ad) {
52
+ var _a;
53
+ (_a = ad === null || ad === void 0 ? void 0 : ad.places) === null || _a === void 0 ? void 0 : _a.forEach(function (p) {
54
+ var _a;
55
+ var idx = campaignDomains.findIndex(function (c) { return c.domainId === p.domainId; });
56
+ if (idx > -1) {
57
+ campaignDomains[idx].places.push(p);
58
+ }
59
+ else {
60
+ var domainName = (_a = res.find(function (d) { return d.domainId === p.domainId; })) === null || _a === void 0 ? void 0 : _a.name;
61
+ campaignDomains.push({
62
+ domainId: p.domainId,
63
+ domainName: domainName,
64
+ places: [p],
65
+ });
66
+ }
67
+ });
68
+ });
69
+ });
70
+ return campaignDomains;
71
+ })
72
+ : Promise.resolve([]);
73
+ }), isLoading = _c.isLoading, data = _c.data;
45
74
  var tabPanel = function () {
46
75
  switch (tabIndex) {
47
76
  case exports.tabs.ANALYTIC:
48
- return ((0, jsx_runtime_1.jsx)(Analytic_1.default, { campaignId: campaignId, subCampaigns: subCampaigns, startDate: time.startDate, endDate: time.endDate, domains: data }));
77
+ return ((0, jsx_runtime_1.jsx)(Analytic_1.default, { campaignId: campaignId, subCampaigns: subCampaigns, startDate: time.startDate, endDate: time.endDate, domains: data, campaignName: campaignName, fullPlaces: fullPlaces }));
49
78
  case exports.tabs.EVENT:
50
79
  return ((0, jsx_runtime_1.jsx)(Event_1.default, { campaignId: campaignId, startDate: time.startDate, endDate: time.endDate, subCampaigns: subCampaigns, domains: data }));
51
80
  case exports.tabs.CUSTOMER:
@@ -54,33 +83,6 @@ function TabStatisticsContainer() {
54
83
  return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {});
55
84
  }
56
85
  };
57
- var _c = (0, Hooks_1.useGetData)([], function () {
58
- return client.domainsGetAll ? client === null || client === void 0 ? void 0 : client.domainsGetAll().then(function (res) {
59
- var campaignDomains = [];
60
- subCampaigns.forEach(function (s) {
61
- var _a;
62
- (_a = s === null || s === void 0 ? void 0 : s.ads) === null || _a === void 0 ? void 0 : _a.forEach(function (ad) {
63
- var _a;
64
- (_a = ad === null || ad === void 0 ? void 0 : ad.places) === null || _a === void 0 ? void 0 : _a.forEach(function (p) {
65
- var _a;
66
- var idx = campaignDomains.findIndex(function (c) { return c.domainId === p.domainId; });
67
- if (idx > -1) {
68
- campaignDomains[idx].places.push(p);
69
- }
70
- else {
71
- var domainName = (_a = res.find(function (d) { return d.domainId === p.domainId; })) === null || _a === void 0 ? void 0 : _a.name;
72
- campaignDomains.push({
73
- domainId: p.domainId,
74
- domainName: domainName,
75
- places: [p],
76
- });
77
- }
78
- });
79
- });
80
- });
81
- return campaignDomains;
82
- }) : Promise.resolve([]);
83
- }), isLoading = _c.isLoading, data = _c.data;
84
86
  var handleChangeTab = function (newValue) {
85
87
  setTabIndex(newValue);
86
88
  };
@@ -348,7 +348,7 @@ function AdList(props) {
348
348
  } }, idx));
349
349
  }) })] })] }), open &&
350
350
  (0, jsx_runtime_1.jsx)(PreviewButton_1.default, { anchorEl: anchorEl, open: open, domainIds: previewId.domainIds, handlePreviewClose: handlePreviewClose, handlePreviewDomain: function (event, domainId) {
351
- handlePreview(event, ads.find(function (x) { return x.loginId === previewId.loginId; }), domainId);
351
+ handlePreview(event, ads.find(function (x) { return x.loginId === previewId.loginId && x.welcomeId === previewId.welcomeId; }), domainId);
352
352
  // handlePreview(previewId, domainId)
353
353
  }, service: service })] }));
354
354
  }
@@ -200,6 +200,6 @@ function AdRow(props) {
200
200
  paddingBottom: 0,
201
201
  paddingTop: 0,
202
202
  borderBottomWidth: open ? 1 : 0,
203
- }, colSpan: 3, children: (0, jsx_runtime_1.jsx)(material_1.Collapse, { in: open, timeout: "auto", unmountOnExit: true, children: (0, jsx_runtime_1.jsx)(material_1.Box, { margin: 1, children: (0, jsx_runtime_1.jsx)(AdDetail_1.default, __assign({ ad: ad, onChange: onChange }, other)) }) }) })] })] }));
203
+ }, colSpan: 3, children: (0, jsx_runtime_1.jsx)(material_1.Collapse, { in: open, timeout: "auto", unmountOnExit: true, children: (0, jsx_runtime_1.jsx)(material_1.Box, { margin: 1, sx: { height: '416px' }, children: (0, jsx_runtime_1.jsx)(AdDetail_1.default, __assign({ ad: ad, onChange: onChange }, other)) }) }) })] })] }));
204
204
  }
205
205
  exports.default = AdRow;
@@ -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
@@ -180,6 +180,7 @@ var Advanced = function (props) {
180
180
  type: {
181
181
  LimitView: t('Campaign.RuleType.LimitView'),
182
182
  LimitClick: t('Campaign.RuleType.LimitClick'),
183
+ Authentication: t('Campaign.RuleType.Engagement'),
183
184
  LimitEvent: t('Campaign.RuleType.LimitEvent'),
184
185
  TargetGender: t('Campaign.RuleType.TargetGender'),
185
186
  TargetAge: t('Campaign.RuleType.TargetAge'),
@@ -189,7 +190,6 @@ var Advanced = function (props) {
189
190
  RetargetPlace: t('Campaign.RuleType.RetargetPlace'),
190
191
  RetargetDomain: t('Campaign.RuleType.RetargetDomain'),
191
192
  RetargetMacAddress: t('Campaign.RuleType.RetargetMacAddress'),
192
- Authentication: t('Campaign.RuleType.Engagement'),
193
193
  },
194
194
  };
195
195
  var handleSubmit = function () {
@@ -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',
@@ -42,16 +42,16 @@ var react_1 = __importStar(require("react"));
42
42
  var react_i18next_1 = require("react-i18next");
43
43
  var recoil_1 = require("recoil");
44
44
  var Enum_1 = require("../../../../ACM-AXN/Campaign/Enum");
45
- var Hooks_1 = __importDefault(require("../../../../ACM-AXN/Campaign/Hooks"));
46
45
  var Enum_2 = require("../../../../ACM-AXN/Common/Enum");
47
46
  var lodash_1 = require("lodash");
48
47
  var Utils_1 = require("../../Utils");
49
48
  var Recoils_1 = require("../Recoils");
50
49
  var material_1 = require("@mui/material");
50
+ var Hooks_1 = __importDefault(require("../../../../ACM-AXN/Campaign/Hooks"));
51
51
  function SubCampaignDetail(props) {
52
52
  var t = (0, react_i18next_1.useTranslation)().t;
53
- var service = (0, Hooks_1.default)().service;
54
53
  var subCampaign = props.subCampaign, onSubCampaignChange = props.onSubCampaignChange, onChangeSubCampaignStatus = props.onChangeSubCampaignStatus;
54
+ var service = (0, Hooks_1.default)().service;
55
55
  var getFormValid = function () { return ({
56
56
  name: (0, Utils_1.nameValid)(subCampaign.name),
57
57
  bookingAmount: !(0, Utils_1.checkPriority)(subCampaign.priority, Enum_1.CampaignPriority.ClassB) || (0, Utils_1.bookingValid)(subCampaign.bookingAmount),
@@ -75,7 +75,8 @@ function SubCampaignDetail(props) {
75
75
  */
76
76
  var translationText = {
77
77
  name: t('Campaign.Name'),
78
- ticket: t('Campaign.Ticket'),
78
+ status: t('Campaign.Ticket'),
79
+ subCampaignLable: t('Campaign.BillingUnit.subCampaignLable'),
79
80
  BillingUnit: t('Campaign.BillingUnit.Title'),
80
81
  priority: t('Campaign.Detail.Priority'),
81
82
  booking: t('Campaign.BookingText'),
@@ -89,9 +90,9 @@ function SubCampaignDetail(props) {
89
90
  onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { name: e.target.value })); });
90
91
  }, error: subValid.name !== undefined && !subValid.name, helperText: subValid.name !== undefined && !subValid.name
91
92
  ? translationText.helperText
92
- : '' }) }), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: true, style: { padding: 8 }, children: (0, jsx_runtime_1.jsxs)(material_1.TextField, { id: "ticket", name: "ticket", variant: "standard", select: true, required: true, fullWidth: true, label: translationText.ticket, value: subCampaign.ticket, onChange: function (e) {
93
- onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { ticket: Number(e.target.value) })); });
94
- }, disabled: isCreate, children: [(0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: Enum_1.CampaignTicket.ACTIVE, children: t('Campaign.Active') }), (0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: Enum_1.CampaignTicket.INACTIVE, children: t('Campaign.InActive') })] }) }), (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))
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))
95
96
  ? subCampaign.priority
96
97
  : Object.values(Enum_1.CampaignPriority)[subCampaign.priority], onChange: function (e) {
97
98
  var newPriority = Object.values(Enum_1.CampaignPriority).indexOf(e.target.value);
@@ -99,43 +100,53 @@ function SubCampaignDetail(props) {
99
100
  var newSubCamp = __assign(__assign(__assign(__assign({}, pre), { priority: newPriority }), ((0, Utils_1.checkPriority)(newPriority, Enum_1.CampaignPriority.ClassB)
100
101
  ? {
101
102
  bookingAmount: 10,
102
- billingUnit: Enum_2.AnalyticType.AUTHENTICATION,
103
+ billingUnit: Enum_2.AnalyticType.Authentication,
104
+ billingUnitLabel: Enum_2.AnalyticType[Enum_2.AnalyticType.Authentication],
103
105
  }
104
106
  : {
105
107
  bookingAmount: 0,
106
- billingUnit: Enum_2.AnalyticType.AUTHENTICATION,
108
+ billingUnit: Enum_2.AnalyticType.Authentication,
109
+ billingUnitLabel: Enum_2.AnalyticType[Enum_2.AnalyticType.Authentication],
107
110
  })), { bonusAmount: 0 });
108
111
  setSubValid(function (pre) { return (__assign(__assign({}, pre), { bookingAmount: true, bonusAmount: true })); });
109
112
  return newSubCamp;
110
113
  });
111
- }, 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.jsxs)(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) {
112
- onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { bookingAmount: Number(e.target.value) })); });
113
- }, onFocus: function (event) { return event.target.select(); }, error: subValid.bookingAmount !== undefined &&
114
- !subValid.bookingAmount, helperText: subValid.bookingAmount !== undefined &&
115
- !subValid.bookingAmount
116
- ? subCampaign.bookingAmount < 0
117
- ? translationText.notNegative
118
- : translationText.helperText
119
- : '' }) }), (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) {
120
- var value = Number(e.target.value);
121
- onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { bonusAmount: value })); });
122
- }, onFocus: function (event) { return event.target.select(); }, error: subValid.bonusAmount !== undefined &&
123
- !subValid.bonusAmount, helperText: subValid.bonusAmount !== undefined &&
124
- !subValid.bonusAmount
125
- ? subCampaign.bonusAmount < 0
126
- ? translationText.notNegative
127
- : translationText.helperText
128
- : '' }) }), !service.attributesGetByObjectTypeCode ? ((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: "billingUnit", required: true, select: true, variant: "standard", fullWidth: true, label: translationText.BillingUnit, value: String(subCampaign.billingUnit), onChange: function (e) {
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) {
129
143
  onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { billingUnit: Number(e.target.value) })); });
130
- }, error: subValid.billingUnit !== undefined &&
131
- !subValid.billingUnit, helperText: subValid.billingUnit !== undefined &&
132
- !subValid.billingUnit
144
+ }, error: !!subValid.billingUnit && !subValid.billingUnit, helperText: !!subValid.billingUnit && !subValid.billingUnit
133
145
  ? translationText.helperText
134
146
  : '', children: Object.values(Enum_2.AnalyticType)
135
147
  .filter(function (item) { return !isNaN(Number(item)); })
136
- .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)); }) }) })) : null] })), (0, jsx_runtime_1.jsx)(material_1.Grid, { item: true, xs: 4, style: { padding: 8 }, children: (0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: subCampaign.isReserved, onChange: function (e) {
137
- e.persist();
138
- onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), { isReserved: e.target.checked })); });
139
- }, name: "isReserved", color: "primary" }), label: translationText.reserved, style: { marginTop: 6 } }) })] })] }));
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)); }) })) })] })) })] }));
140
151
  }
141
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;
@@ -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
  },