awing-library 2.1.142-beta → 2.1.142

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 (216) 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 +6 -1
  23. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +3 -22
  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 -3
  26. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +22 -42
  27. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +317 -104
  28. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/component.js +1 -1
  29. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +3 -0
  30. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +119 -54
  31. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +1 -1
  32. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +46 -8
  33. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +8 -6
  34. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +1 -1
  35. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.d.ts +9 -0
  36. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.js +56 -0
  37. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +5 -1
  38. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.d.ts +12 -0
  39. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +23 -8
  40. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.js +3 -3
  41. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +63 -12
  42. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +1 -0
  43. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +17 -4
  44. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +10 -0
  45. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +4 -1
  46. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +1 -0
  47. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +3 -2
  48. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +6 -2
  49. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +31 -29
  50. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +1 -1
  51. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +1 -1
  52. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitEvent.js +1 -2
  53. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetOS/container.js +2 -2
  54. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +1 -1
  55. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +5 -5
  56. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +69 -124
  57. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +3 -13
  58. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +45 -20
  59. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +3 -2
  60. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +3 -2
  61. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
  62. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +5 -1
  63. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +176 -59
  64. package/lib/ACM-AXN/Campaign/Enum.d.ts +24 -6
  65. package/lib/ACM-AXN/Campaign/Enum.js +30 -11
  66. package/lib/ACM-AXN/Campaign/Types.d.ts +53 -5
  67. package/lib/ACM-AXN/Campaign/Utils.d.ts +6 -1
  68. package/lib/ACM-AXN/Campaign/Utils.js +50 -3
  69. package/lib/ACM-AXN/Campaign/index.js +2 -2
  70. package/lib/ACM-AXN/CampaignPlan/Container.js +4 -6
  71. package/lib/ACM-AXN/CampaignPlan/Detail.js +3 -3
  72. package/lib/ACM-AXN/CampaignPlan/Filter.js +1 -1
  73. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +14 -10
  74. package/lib/ACM-AXN/CampaignSchedule/Components/EnhancedPagination/index.js +3 -2
  75. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +6 -4
  76. package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +4 -4
  77. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +5 -4
  78. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +1 -2
  79. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +1 -5
  80. package/lib/ACM-AXN/Common/Constant.d.ts +3 -0
  81. package/lib/ACM-AXN/Common/Constant.js +2 -0
  82. package/lib/ACM-AXN/Common/Enum.d.ts +8 -3
  83. package/lib/ACM-AXN/Common/Enum.js +19 -4
  84. package/lib/ACM-AXN/Common/Types.d.ts +5 -0
  85. package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
  86. package/lib/ACM-AXN/GeoFencing/component.js +7 -7
  87. package/lib/ACM-AXN/GeoFencing/interface.d.ts +1 -2
  88. package/lib/ACM-AXN/Holiday/FormHoliday.js +1 -0
  89. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.d.ts +0 -5
  90. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +7 -90
  91. package/lib/ACM-AXN/Notifications/NotificationPopover/index.d.ts +0 -5
  92. package/lib/ACM-AXN/Notifications/Types.d.ts +2 -0
  93. package/lib/ACM-AXN/Page/Constant.js +2 -0
  94. package/lib/ACM-AXN/Page/Container.js +3 -3
  95. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.d.ts +6 -0
  96. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.js +63 -0
  97. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.d.ts +11 -2
  98. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +16 -12
  99. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/TrackingCode.js +1 -1
  100. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/Utils.js +1 -1
  101. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/index.js +1 -0
  102. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.d.ts +1 -9
  103. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.js +0 -9
  104. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewContent.js +11 -44
  105. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
  106. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +39 -61
  107. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +29 -32
  108. package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +6 -6
  109. package/lib/ACM-AXN/Page/CreateOrEdit/index.js +19 -4
  110. package/lib/ACM-AXN/Page/Import/index.js +2 -2
  111. package/lib/ACM-AXN/Page/Types.d.ts +3 -0
  112. package/lib/ACM-AXN/Page/enums.d.ts +5 -0
  113. package/lib/ACM-AXN/Page/enums.js +7 -1
  114. package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
  115. package/lib/ACM-AXN/PlaceFilter/DataTable/component/index.js +2 -5
  116. package/lib/ACM-AXN/PlaceFilter/Input/component/index.js +1 -2
  117. package/lib/ACM-AXN/PlaceFilter/Tag/component/TagChip.js +1 -1
  118. package/lib/ACM-AXN/PlaceFilter/interface.d.ts +1 -0
  119. package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +16 -16
  120. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +14 -9
  121. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +19 -18
  122. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +16 -6
  123. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +17 -10
  124. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
  125. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +30 -51
  126. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
  127. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
  128. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
  129. package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +16 -36
  130. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +5 -5
  131. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +13 -10
  132. package/lib/ACM-AXN/Statistics/ControlPanel.js +17 -5
  133. package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
  134. package/lib/ACM-AXN/Statistics/Enums.js +1 -0
  135. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +1 -0
  136. package/lib/ACM-AXN/StatisticsByProvince/DataTable.js +1 -1
  137. package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +4 -4
  138. package/lib/ACM-AXN/Template/Container.js +2 -2
  139. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
  140. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
  141. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +2 -2
  142. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +56 -39
  143. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
  144. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
  145. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
  146. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
  147. package/lib/ACM-AXN/Template/CreateOrEdit/index.js +8 -4
  148. package/lib/ACM-AXN/Template/Import.js +2 -2
  149. package/lib/ACM-AXN/Template/Types.d.ts +9 -9
  150. package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
  151. package/lib/ACM-AXN/ViewTemplate/Preview.js +5 -6
  152. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +23 -11
  153. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
  154. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
  155. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +42 -129
  156. package/lib/ACM-AXN/ViewTemplate/common.d.ts +2 -1
  157. package/lib/ACM-AXN/ViewTemplate/common.js +47 -7
  158. package/lib/ACM-AXN/ViewTemplate/container.js +8 -2
  159. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +3 -1
  160. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +18 -28
  161. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +2 -0
  162. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +1 -1
  163. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +17 -1
  164. package/lib/ACM-AXN/index.d.ts +1 -0
  165. package/lib/ACM-AXN/index.js +1 -0
  166. package/lib/AWING/AsyncAutocomplete/index.js +2 -2
  167. package/lib/AWING/BasicDataForm/BasicDataForm.js +9 -6
  168. package/lib/AWING/BasicDataForm/interface.d.ts +3 -0
  169. package/lib/AWING/Chart/BarLineComponent.js +20 -24
  170. package/lib/AWING/Chart/PieComponent.d.ts +3 -4
  171. package/lib/AWING/Chart/PieComponent.js +16 -16
  172. package/lib/AWING/Chart/Styles.js +51 -16
  173. package/lib/AWING/DataForm/DataInput.js +104 -22
  174. package/lib/AWING/DataForm/interface.d.ts +2 -0
  175. package/lib/AWING/DataGrid/index.js +8 -13
  176. package/lib/AWING/DateRangePicker/component.js +61 -30
  177. package/lib/AWING/DateRangePicker/configDate.d.ts +1 -2
  178. package/lib/AWING/DateRangePicker/configDate.js +12 -12
  179. package/lib/AWING/DateRangePicker/interface.d.ts +1 -0
  180. package/lib/AWING/Form/useForm.js +3 -2
  181. package/lib/AWING/GoogleMap/GGMap.d.ts +3 -0
  182. package/lib/AWING/GoogleMap/GGMap.js +256 -0
  183. package/lib/AWING/GoogleMap/index.d.ts +4 -0
  184. package/lib/AWING/GoogleMap/index.js +41 -0
  185. package/lib/AWING/GoogleMap/interface.d.ts +21 -0
  186. package/lib/AWING/GoogleMap/interface.js +2 -0
  187. package/lib/AWING/GoogleMap/utils.d.ts +25 -0
  188. package/lib/AWING/GoogleMap/utils.js +135 -0
  189. package/lib/AWING/GroupTable/GroupTable.js +2 -2
  190. package/lib/AWING/GroupTable/component.d.ts +1 -0
  191. package/lib/AWING/GroupTable/component.js +2 -2
  192. package/lib/AWING/NumberFormat/index.d.ts +3 -1
  193. package/lib/AWING/NumberFormat/index.js +2 -2
  194. package/lib/AWING/PageManagement/PageManagement.js +4 -3
  195. package/lib/AWING/Pagination/index.js +11 -3
  196. package/lib/AWING/index.d.ts +1 -0
  197. package/lib/AWING/index.js +1 -0
  198. package/lib/AWING/ultis/validation.d.ts +1 -0
  199. package/lib/AWING/ultis/validation.js +25 -6
  200. package/lib/Commons/Components/ClassicDrawer.js +5 -4
  201. package/lib/Commons/Components/HighlightedCode/MarkdownElement.js +6 -1
  202. package/lib/Commons/Hooks/usePath.js +3 -3
  203. package/lib/Utils/Helpers.d.ts +3 -2
  204. package/lib/Utils/Helpers.js +49 -13
  205. package/lib/i18n.js +27 -2
  206. package/lib/translate/en/translation.json +132 -71
  207. package/lib/translate/id/translation.json +893 -0
  208. package/lib/translate/ind/translation.json +893 -0
  209. package/lib/translate/ja/translation.json +893 -0
  210. package/lib/translate/mys/translation.json +893 -0
  211. package/lib/translate/phl/translation.json +893 -0
  212. package/lib/translate/th/translation.json +893 -0
  213. package/lib/translate/vi/translation.json +92 -31
  214. package/package.json +9 -4
  215. package/lib/ACM-AXN/ViewTemplate/TemplateField/Utils.d.ts +0 -5
  216. package/lib/ACM-AXN/ViewTemplate/TemplateField/Utils.js +0 -14
@@ -42,34 +42,28 @@ 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
- var AWING_1 = require("../../../../AWING");
48
46
  var lodash_1 = require("lodash");
49
47
  var Utils_1 = require("../../Utils");
50
48
  var Recoils_1 = require("../Recoils");
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),
58
58
  bonusAmount: (0, Utils_1.bonusValid)(subCampaign.bonusAmount),
59
59
  billingUnit: subCampaign.billingUnit !== null,
60
60
  }); };
61
- var cacheSubId = react_1.default.useRef();
62
- (0, react_1.useEffect)(function () {
63
- cacheSubId.current = subCampaign.id;
64
- return function () {
65
- cacheSubId.current = undefined;
66
- };
67
- }, [subCampaign.id]);
61
+ var _a = react_1.default.useState(getFormValid), subValid = _a[0], setSubValid = _a[1];
68
62
  var isCreate = (0, recoil_1.useRecoilValue)(Recoils_1.isCreateState);
69
63
  (0, react_1.useEffect)(function () {
70
64
  onSubCampaignChange(function (prev) { return (0, lodash_1.cloneDeep)(prev); });
71
65
  // eslint-disable-next-line react-hooks/exhaustive-deps
72
- }, [subCampaign.id, onSubCampaignChange]);
66
+ }, [onSubCampaignChange]);
73
67
  (0, react_1.useEffect)(function () {
74
68
  onChangeSubCampaignStatus(Object.values(getFormValid()).every(Boolean));
75
69
  // eslint-disable-next-line react-hooks/exhaustive-deps
@@ -81,7 +75,8 @@ function SubCampaignDetail(props) {
81
75
  */
82
76
  var translationText = {
83
77
  name: t('Campaign.Name'),
84
- ticket: t('Campaign.Ticket'),
78
+ status: t('Campaign.Ticket'),
79
+ subCampaignLable: t('Campaign.BillingUnit.subCampaignLable'),
85
80
  BillingUnit: t('Campaign.BillingUnit.Title'),
86
81
  priority: t('Campaign.Detail.Priority'),
87
82
  booking: t('Campaign.BookingText'),
@@ -91,117 +86,67 @@ function SubCampaignDetail(props) {
91
86
  helperText: t('Common.Required'),
92
87
  notNegative: t('Common.NotNegative'),
93
88
  };
94
- var fields = react_1.default.useMemo(function () {
95
- var tempField = [
96
- {
97
- fieldName: 'name',
98
- type: 'text',
99
- label: translationText.name,
100
- required: true,
101
- gridSize: 4,
102
- pattern: false,
103
- length: 500,
104
- },
105
- {
106
- fieldName: 'ticket',
107
- type: 'select',
108
- label: translationText.ticket,
109
- required: true,
110
- gridSize: 4,
111
- disabled: isCreate,
112
- options: [
113
- {
114
- text: t('Campaign.Active'),
115
- value: Enum_1.CampaignTicket.ACTIVE,
116
- },
117
- {
118
- text: t('Campaign.InActive'),
119
- value: Enum_1.CampaignTicket.INACTIVE,
120
- },
121
- ],
122
- },
123
- {
124
- fieldName: 'priority',
125
- type: 'select',
126
- gridSize: 4,
127
- label: translationText.priority,
128
- required: true,
129
- options: Object.values(Enum_1.CampaignPriority).map(function (priority) { return ({
130
- text: t("Campaign.".concat(priority)),
131
- value: priority,
132
- }); }),
133
- },
134
- ];
135
- if ((0, Utils_1.checkPriority)(subCampaign.priority, Enum_1.CampaignPriority.ClassB)) {
136
- tempField.push({
137
- fieldName: 'bookingAmount',
138
- type: 'number',
139
- gridSize: 4,
140
- required: true,
141
- label: translationText.booking,
142
- InputProps: {
143
- type: 'number',
144
- },
145
- onValidate: function (value) { return (0, Utils_1.bookingValid)(Number(value)); },
146
- }, {
147
- fieldName: 'bonusAmount',
148
- type: 'number',
149
- gridSize: 4,
150
- required: true,
151
- label: translationText.booking,
152
- InputProps: {
153
- type: 'number',
154
- },
155
- onValidate: function (value) { return (0, Utils_1.bonusValid)(Number(value)); },
156
- });
157
- if (service.attributesGetByObjectTypeCode) {
158
- tempField.push({
159
- fieldName: 'billingUnit',
160
- type: 'select',
161
- gridSize: 4,
162
- label: translationText.BillingUnit,
163
- required: true,
164
- value: String(subCampaign.billingUnit),
165
- onValidate: function (value) { return value !== null; },
166
- options: Object.values(Enum_2.AnalyticType)
167
- .filter(function (item) { return !isNaN(Number(item)); })
168
- .map(function (item) { return ({
169
- text: t("Campaign.BillingUnit.".concat((0, lodash_1.capitalize)((0, lodash_1.camelCase)(Enum_2.AnalyticType[item])))),
170
- value: item,
171
- }); }),
172
- });
173
- }
174
- }
175
- tempField.push({
176
- fieldName: 'isReserved',
177
- type: 'checkbox',
178
- gridSize: 4,
179
- label: translationText.reserved,
180
- });
181
- return tempField;
182
- },
183
- // eslint-disable-next-line react-hooks/exhaustive-deps
184
- [subCampaign]);
185
- var handleUpdate = react_1.default.useCallback(function (data, valid, fieldName) {
186
- if (!fieldName || cacheSubId.current !== subCampaign.id)
187
- return;
188
- onSubCampaignChange(function (pre) {
189
- var _a;
190
- return fieldName === 'priority'
191
- ? __assign(__assign(__assign(__assign({}, pre), { priority: data[fieldName] }), ((0, Utils_1.checkPriority)(data[fieldName], Enum_1.CampaignPriority.ClassB)
192
- ? {
193
- bookingAmount: 10,
194
- billingUnit: null,
195
- }
196
- : {
197
- bookingAmount: 0,
198
- billingUnit: 0,
199
- })), { bonusAmount: 0 }) : __assign(__assign({}, pre), (_a = {}, _a[fieldName] = data[fieldName], _a));
200
- });
201
- // eslint-disable-next-line react-hooks/exhaustive-deps
202
- }, [subCampaign.id, onSubCampaignChange]);
203
- 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))
204
- ? subCampaign.priority
205
- : 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)); }) })) })] })) })] }));
206
151
  }
207
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
  },
@@ -38,6 +38,7 @@ var react_router_dom_1 = require("react-router-dom");
38
38
  var Constant_1 = require("../../../../ACM-AXN/Common/Constant");
39
39
  var EditPage_1 = __importDefault(require("./EditPage"));
40
40
  var Enum_1 = require("../../../../ACM-AXN/Campaign/Enum");
41
+ var Enum_2 = require("../../../../ACM-AXN/Common/Enum");
41
42
  function TabSubCampaign() {
42
43
  var _a = (0, recoil_1.useRecoilState)(Recoils_1.campaignGroupsState), subCampaigns = _a[0], setSubCampaigns = _a[1];
43
44
  var _b = (0, recoil_1.useRecoilState)(atoms_1.selectedSubCampaignIdState), selectedSubCampaignId = _b[0], setSelectedSubCampaignId = _b[1];
@@ -60,11 +61,11 @@ function TabSubCampaign() {
60
61
  campaignGroup: {
61
62
  id: newId,
62
63
  name: 'Sub-Campaign ' + newId,
63
- ticket: Enum_1.CampaignTicket.INACTIVE,
64
+ status: Enum_1.CampaignStatus.Draft,
64
65
  priority: Enum_1.CampaignPriority.ClassB,
65
66
  bookingAmount: 10,
66
67
  bonusAmount: 0,
67
- isReserved: false,
68
+ billingUnit: Enum_2.AnalyticType.Authentication,
68
69
  },
69
70
  ads: [],
70
71
  });
@@ -1,4 +1,15 @@
1
1
  "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
2
13
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
14
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
15
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -43,24 +54,38 @@ var react_1 = require("react");
43
54
  var recoil_1 = require("recoil");
44
55
  var atoms_1 = require("./atoms");
45
56
  var Hooks_1 = __importDefault(require("../../Hooks"));
57
+ var Recoils_1 = require("../Recoils");
46
58
  function useSearchPage(type) {
47
59
  var _this = this;
48
60
  var directoryId = (0, recoil_1.useRecoilValue)(atoms_1.campaignPageIdState);
61
+ var _a = (0, recoil_1.useRecoilState)(Recoils_1.cacheSearchPageState), cache = _a[0], setCache = _a[1];
49
62
  var service = (0, Hooks_1.default)().service;
50
63
  return (0, react_1.useCallback)(function (searchString) { return __awaiter(_this, void 0, void 0, function () {
51
- var temp;
64
+ var options;
52
65
  var _a;
53
66
  return __generator(this, function (_b) {
54
67
  switch (_b.label) {
55
- case 0: return [4 /*yield*/, service.pagesPaging(searchString, 10, 0, directoryId[type])];
68
+ case 0:
69
+ if (Object.keys(cache).includes(searchString || type)) {
70
+ return [2 /*return*/, cache[searchString || type]];
71
+ }
72
+ return [4 /*yield*/, service
73
+ .pagesPaging(searchString, 10, 0, directoryId[type])
74
+ .then(function (_a) {
75
+ var items = _a.items;
76
+ return items === null || items === void 0 ? void 0 : items.map(function (page) { return ({
77
+ text: page.title,
78
+ value: page.pageId,
79
+ }); });
80
+ })];
56
81
  case 1:
57
- temp = _b.sent();
58
- return [2 /*return*/, (_a = temp.items) === null || _a === void 0 ? void 0 : _a.map(function (page) { return ({
59
- text: page.title,
60
- value: page.pageId,
61
- }); })];
82
+ options = _b.sent();
83
+ setCache(__assign(__assign({}, cache), (_a = {}, _a[searchString || type] = options, _a)));
84
+ return [2 /*return*/, options];
62
85
  }
63
86
  });
64
- }); }, [service, directoryId, type]);
87
+ }); },
88
+ // eslint-disable-next-line react-hooks/exhaustive-deps
89
+ [directoryId, type]);
65
90
  }
66
91
  exports.default = useSearchPage;
@@ -1,3 +1,7 @@
1
1
  import React from 'react';
2
- declare const _default: React.FC<unknown>;
2
+ interface CreateOrEditProps {
3
+ quickWizard?: (p?: any) => JSX.Element;
4
+ type?: string;
5
+ }
6
+ declare const _default: React.FC<CreateOrEditProps>;
3
7
  export default _default;