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.
- package/lib/ACM-AXN/AuthenticationProfile/Container.js +4 -4
- package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.js +2 -2
- package/lib/ACM-AXN/Campaign/Container.js +52 -54
- package/lib/ACM-AXN/Campaign/Container.test.js +1 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.d.ts +8 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.js +27 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.d.ts +17 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.js +121 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.js +219 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.d.ts +2 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.js +306 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.js +230 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.js +123 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.js +253 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabInfomation.js +21 -5
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.d.ts +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.js +47 -78
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.d.ts +2 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +2 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.js +2 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.js +2 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +19 -42
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +298 -96
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +3 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +119 -54
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +46 -8
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +6 -4
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.d.ts +9 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.js +56 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +5 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.d.ts +12 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +22 -7
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +63 -12
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +17 -4
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +10 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +4 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +3 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +6 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +31 -29
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetOS/container.js +2 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +5 -5
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +44 -33
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +3 -13
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +45 -20
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +3 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +3 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
- package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +5 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +172 -59
- package/lib/ACM-AXN/Campaign/Enum.d.ts +24 -6
- package/lib/ACM-AXN/Campaign/Enum.js +30 -11
- package/lib/ACM-AXN/Campaign/Types.d.ts +53 -5
- package/lib/ACM-AXN/Campaign/Utils.d.ts +6 -1
- package/lib/ACM-AXN/Campaign/Utils.js +50 -3
- package/lib/ACM-AXN/Campaign/index.js +2 -2
- package/lib/ACM-AXN/CampaignPlan/Container.js +4 -6
- package/lib/ACM-AXN/CampaignPlan/Detail.js +3 -3
- package/lib/ACM-AXN/CampaignPlan/Filter.js +3 -3
- package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +14 -10
- package/lib/ACM-AXN/CampaignSchedule/Components/EnhancedPagination/index.js +3 -2
- package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +5 -7
- package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +4 -4
- package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +5 -4
- package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +1 -2
- package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +1 -5
- package/lib/ACM-AXN/Common/Constant.d.ts +3 -0
- package/lib/ACM-AXN/Common/Constant.js +2 -0
- package/lib/ACM-AXN/Common/Enum.d.ts +8 -3
- package/lib/ACM-AXN/Common/Enum.js +19 -4
- package/lib/ACM-AXN/Common/Types.d.ts +5 -0
- package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
- package/lib/ACM-AXN/GeoFencing/component.js +7 -7
- package/lib/ACM-AXN/GeoFencing/interface.d.ts +1 -2
- package/lib/ACM-AXN/Holiday/FormHoliday.js +1 -0
- package/lib/ACM-AXN/Notifications/NotificationPopover/Container.d.ts +0 -5
- package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +7 -90
- package/lib/ACM-AXN/Notifications/NotificationPopover/index.d.ts +0 -5
- package/lib/ACM-AXN/Notifications/Types.d.ts +2 -0
- package/lib/ACM-AXN/Page/Constant.js +2 -0
- package/lib/ACM-AXN/Page/Container.js +3 -3
- package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.d.ts +6 -0
- package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.js +63 -0
- package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.d.ts +11 -2
- package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +16 -12
- package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/TrackingCode.js +1 -1
- package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/Utils.js +1 -1
- package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/index.js +1 -0
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.d.ts +1 -9
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.js +0 -9
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewContent.js +11 -44
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +39 -61
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +29 -32
- package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +6 -6
- package/lib/ACM-AXN/Page/CreateOrEdit/index.js +19 -4
- package/lib/ACM-AXN/Page/Import/index.js +2 -2
- package/lib/ACM-AXN/Page/Types.d.ts +3 -0
- package/lib/ACM-AXN/Page/enums.d.ts +5 -0
- package/lib/ACM-AXN/Page/enums.js +7 -1
- package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
- package/lib/ACM-AXN/PlaceFilter/DataTable/component/index.js +2 -5
- package/lib/ACM-AXN/PlaceFilter/Input/component/index.js +1 -2
- package/lib/ACM-AXN/PlaceFilter/Tag/component/TagChip.js +1 -1
- package/lib/ACM-AXN/PlaceFilter/interface.d.ts +1 -0
- package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +16 -16
- package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +14 -9
- package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +19 -18
- package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +16 -6
- package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +17 -10
- package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
- package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +30 -51
- package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
- package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
- package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
- package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +16 -36
- package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +5 -5
- package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +13 -10
- package/lib/ACM-AXN/Statistics/ControlPanel.js +17 -5
- package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
- package/lib/ACM-AXN/Statistics/Enums.js +1 -0
- package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +1 -0
- package/lib/ACM-AXN/StatisticsByProvince/DataTable.js +1 -1
- package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +4 -4
- package/lib/ACM-AXN/Template/Container.js +2 -2
- package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
- package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +2 -2
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +56 -37
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
- package/lib/ACM-AXN/Template/CreateOrEdit/index.js +8 -4
- package/lib/ACM-AXN/Template/Import.js +2 -2
- package/lib/ACM-AXN/Template/Types.d.ts +9 -9
- package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
- package/lib/ACM-AXN/ViewTemplate/Preview.js +5 -6
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +23 -11
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +42 -129
- package/lib/ACM-AXN/ViewTemplate/common.d.ts +2 -1
- package/lib/ACM-AXN/ViewTemplate/common.js +47 -7
- package/lib/ACM-AXN/ViewTemplate/container.js +8 -2
- package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +3 -1
- package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +18 -28
- package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +2 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +1 -1
- package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +17 -1
- package/lib/ACM-AXN/index.d.ts +1 -0
- package/lib/ACM-AXN/index.js +1 -0
- package/lib/AWING/AsyncAutocomplete/index.js +2 -2
- package/lib/AWING/BasicDataForm/BasicDataForm.js +9 -6
- package/lib/AWING/BasicDataForm/interface.d.ts +3 -0
- package/lib/AWING/Chart/BarLineComponent.js +20 -24
- package/lib/AWING/Chart/PieComponent.d.ts +3 -4
- package/lib/AWING/Chart/PieComponent.js +16 -16
- package/lib/AWING/Chart/Styles.js +51 -16
- package/lib/AWING/DataForm/DataInput.js +105 -23
- package/lib/AWING/DataForm/interface.d.ts +2 -0
- package/lib/AWING/DataGrid/index.js +8 -13
- package/lib/AWING/DateRangePicker/component.js +81 -33
- package/lib/AWING/DateRangePicker/configDate.d.ts +1 -2
- package/lib/AWING/DateRangePicker/configDate.js +12 -12
- package/lib/AWING/DateRangePicker/interface.d.ts +1 -0
- package/lib/AWING/Form/useForm.js +3 -2
- package/lib/AWING/GoogleMap/GGMap.d.ts +3 -0
- package/lib/AWING/GoogleMap/GGMap.js +256 -0
- package/lib/AWING/GoogleMap/index.d.ts +4 -0
- package/lib/AWING/GoogleMap/index.js +41 -0
- package/lib/AWING/GoogleMap/interface.d.ts +21 -0
- package/lib/AWING/GoogleMap/interface.js +2 -0
- package/lib/AWING/GoogleMap/utils.d.ts +25 -0
- package/lib/AWING/GoogleMap/utils.js +135 -0
- package/lib/AWING/GroupTable/GroupTable.js +2 -2
- package/lib/AWING/GroupTable/component.d.ts +1 -0
- package/lib/AWING/GroupTable/component.js +2 -2
- package/lib/AWING/NumberFormat/index.d.ts +3 -1
- package/lib/AWING/NumberFormat/index.js +2 -2
- package/lib/AWING/PageManagement/PageManagement.js +4 -3
- package/lib/AWING/Pagination/index.js +11 -3
- package/lib/AWING/index.d.ts +1 -0
- package/lib/AWING/index.js +1 -0
- package/lib/AWING/ultis/validation.d.ts +1 -0
- package/lib/AWING/ultis/validation.js +25 -6
- package/lib/Commons/Components/ClassicDrawer.js +5 -4
- package/lib/Commons/Components/HighlightedCode/MarkdownElement.js +6 -1
- package/lib/Commons/Hooks/usePath.js +3 -3
- package/lib/Utils/Helpers.d.ts +4 -3
- package/lib/Utils/Helpers.js +54 -23
- package/lib/i18n.js +31 -2
- package/lib/translate/en/translation.json +131 -71
- package/lib/translate/id/translation.json +893 -0
- package/lib/translate/ind/translation.json +893 -0
- package/lib/translate/ja/translation.json +893 -0
- package/lib/translate/lao/translation.json +893 -0
- package/lib/translate/mys/translation.json +893 -0
- package/lib/translate/phl/translation.json +893 -0
- package/lib/translate/th/translation.json +893 -0
- package/lib/translate/vi/translation.json +91 -31
- package/package.json +9 -4
|
@@ -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
|
|
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
|
|
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)(
|
|
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
|
-
|
|
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;
|
|
@@ -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); } },
|
|
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:
|
|
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
|
-
|
|
82
|
-
|
|
83
|
-
|
|
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
|
-
|
|
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.
|
|
93
|
-
onSubCampaignChange(function (pre) { return (__assign(__assign({}, pre), {
|
|
94
|
-
}, disabled: isCreate, children:
|
|
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.
|
|
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.
|
|
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.
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
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
|
|
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
|
-
.
|
|
137
|
-
|
|
138
|
-
|
|
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
|
-
|
|
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,
|
|
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.
|
|
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
|
|
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.
|
|
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
|
-
|
|
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,
|
|
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:
|
|
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
|
},
|