awing-library 2.1.21 → 2.1.22-stage
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.d.ts +2 -0
- package/lib/ACM-AXN/AuthenticationProfile/Container.js +82 -0
- package/lib/ACM-AXN/AuthenticationProfile/Container.test.d.ts +1 -0
- package/lib/ACM-AXN/AuthenticationProfile/Container.test.js +184 -0
- package/lib/ACM-AXN/AuthenticationProfile/Context.d.ts +3 -0
- package/lib/ACM-AXN/AuthenticationProfile/Context.js +5 -0
- package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/CreateOrEdit.test.d.ts +1 -0
- package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/CreateOrEdit.test.js +203 -0
- package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.d.ts +2 -0
- package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.js +129 -0
- package/lib/ACM-AXN/AuthenticationProfile/Hooks.d.ts +2 -0
- package/lib/ACM-AXN/AuthenticationProfile/Hooks.js +12 -0
- package/lib/ACM-AXN/AuthenticationProfile/Types.d.ts +75 -0
- package/lib/ACM-AXN/AuthenticationProfile/Types.js +2 -0
- package/lib/ACM-AXN/AuthenticationProfile/Utils.d.ts +11 -0
- package/lib/ACM-AXN/AuthenticationProfile/Utils.js +14 -0
- package/lib/ACM-AXN/AuthenticationProfile/index.d.ts +3 -0
- package/lib/ACM-AXN/AuthenticationProfile/index.js +40 -0
- package/lib/ACM-AXN/Campaign/Container.js +6 -7
- package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.d.ts +2 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.js +9 -4
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabInfomation.js +2 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPermission/index.js +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticComponent.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticComponent.test.js +80 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticContainer.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/AnalyticContainer.test.js +49 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.d.ts +17 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +113 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.test.js +67 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.d.ts +2 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.js +114 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.test.js +27 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/DetailGroupBy.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/DetailGroupBy.test.js +55 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.d.ts +7 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.js +28 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/RowDetail.test.js +49 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.d.ts +2 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.js +182 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +30 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +464 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/component.d.ts +14 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/component.js +77 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +15 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +137 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/index.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/index.js +8 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +12 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +274 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.test.js +84 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Context.d.ts +5 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Context.js +13 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerComponent.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerComponent.test.js +53 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerContainer.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/CustomerContainer.test.js +124 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.d.ts +14 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +130 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.d.ts +7 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +76 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/index.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/index.js +8 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventComponent.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventComponent.test.js +91 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventContainer.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/EventContainer.test.js +48 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.d.ts +5 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +33 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.test.js +30 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.d.ts +7 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +81 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.d.ts +15 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.js +166 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.d.ts +10 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +111 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/index.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/index.js +8 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +6 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +65 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.test.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.test.js +26 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +99 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.js +2 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.d.ts +6 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +36 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +6 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +9 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.d.ts +9 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +36 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.d.ts +8 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +91 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/index.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/index.js +8 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdDetail.js +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdDetail.test.js +3 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +18 -14
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +3 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/AddOrEditRule.js +6 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/AddOrEditRule.test.js +12 -12
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/Create.js +2 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/Create.test.js +3 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/Edit.test.js +2 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/EditExpression.test.js +9 -9
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.d.ts +8 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/Authentication.js +47 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitClick.test.js +1 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitEvent.js +52 -6
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitEvent.test.js +1 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/LimitView.test.js +1 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetAge.test.js +3 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetGender.test.js +2 -2
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.d.ts +1 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/index.js +3 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.d.ts +4 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +13 -7
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +9 -9
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.d.ts +1 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +88 -54
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +7 -6
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +9 -9
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.d.ts +2 -0
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +7 -3
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +10 -9
- package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
- package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +3 -1
- package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +35 -22
- package/lib/ACM-AXN/Campaign/Enum.d.ts +73 -0
- package/lib/ACM-AXN/Campaign/Enum.js +82 -1
- package/lib/ACM-AXN/Campaign/Types.d.ts +10 -127
- package/lib/ACM-AXN/Campaign/Types.js +0 -79
- package/lib/ACM-AXN/Campaign/Utils.d.ts +9 -2
- package/lib/ACM-AXN/Campaign/Utils.js +26 -11
- package/lib/ACM-AXN/Campaign/index.d.ts +2 -0
- package/lib/ACM-AXN/Campaign/index.js +17 -2
- package/lib/ACM-AXN/CampaignPlan/Container.js +25 -13
- package/lib/ACM-AXN/CampaignPlan/Container.test.d.ts +1 -1
- package/lib/ACM-AXN/CampaignPlan/Container.test.js +1 -2
- package/lib/ACM-AXN/CampaignPlan/Detail.js +9 -8
- package/lib/ACM-AXN/CampaignPlan/Detail.test.d.ts +1 -1
- package/lib/ACM-AXN/CampaignPlan/Detail.test.js +2 -3
- package/lib/ACM-AXN/CampaignPlan/Filter.js +11 -4
- package/lib/ACM-AXN/CampaignPlan/Filter.test.d.ts +1 -1
- package/lib/ACM-AXN/CampaignPlan/Filter.test.js +0 -1
- package/lib/ACM-AXN/CampaignPlan/Types.d.ts +6 -74
- package/lib/ACM-AXN/CampaignPlan/Types.js +1 -253
- package/lib/ACM-AXN/CampaignPlan/index.js +1 -1
- package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.d.ts +1 -1
- package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +28 -10
- package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +32 -13
- package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/container.js +3 -3
- package/lib/ACM-AXN/CampaignSchedule/Components/TableHeaderDragable.js +5 -1
- package/lib/ACM-AXN/CampaignSchedule/DataConfig.d.ts +1 -1
- package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +10 -5
- package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.d.ts +1 -1
- package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +9 -4
- package/lib/ACM-AXN/CampaignSchedule/Enum.d.ts +4 -0
- package/lib/ACM-AXN/CampaignSchedule/Enum.js +4 -0
- package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +2 -1
- package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +7 -2
- package/lib/ACM-AXN/CampaignSchedule/container.d.ts +1 -1
- package/lib/ACM-AXN/CampaignSchedule/container.js +6 -1
- package/lib/ACM-AXN/CampaignSchedule/helper.d.ts +0 -2
- package/lib/ACM-AXN/CampaignSchedule/helper.js +1 -24
- package/lib/ACM-AXN/CampaignSchedule/interface.d.ts +3 -0
- package/lib/ACM-AXN/{Notifications → Common}/Constant.d.ts +33 -20
- package/lib/ACM-AXN/{Notifications → Common}/Constant.js +35 -22
- package/lib/ACM-AXN/Common/Enum.d.ts +59 -0
- package/lib/ACM-AXN/Common/Enum.js +74 -0
- package/lib/ACM-AXN/Common/Types.d.ts +16 -0
- package/lib/ACM-AXN/Common/Types.js +2 -0
- package/lib/ACM-AXN/Directory/DomainDirectory/FolderDetail.js +2 -2
- package/lib/ACM-AXN/Directory/DomainDirectory/index.js +5 -5
- package/lib/ACM-AXN/Directory/MenuDirectory/index.js +2 -2
- package/lib/ACM-AXN/Directory/SystemDirectory/index.js +2 -2
- package/lib/ACM-AXN/Directory/components/Permission/Management.js +3 -3
- package/lib/ACM-AXN/Directory/components/Permission/MenuPermissions/MenuPermissionManagement.js +3 -3
- package/lib/ACM-AXN/Directory/components/Permission/UserOrGroup.js +2 -2
- package/lib/ACM-AXN/Directory/components/Permission/index.js +2 -2
- package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
- package/lib/ACM-AXN/GroupUser/Container.js +3 -3
- package/lib/ACM-AXN/GroupUser/Container.test.js +3 -3
- package/lib/ACM-AXN/GroupUser/CreateOrEdit.js +3 -3
- package/lib/ACM-AXN/GroupUser/User/UserComponent.js +3 -3
- package/lib/ACM-AXN/GroupUser/index.js +3 -3
- package/lib/ACM-AXN/Holiday/Container.d.ts +2 -0
- package/lib/ACM-AXN/Holiday/Container.js +55 -0
- package/lib/ACM-AXN/Holiday/Container.test.d.ts +1 -0
- package/lib/ACM-AXN/Holiday/Container.test.js +227 -0
- package/lib/ACM-AXN/Holiday/Context.d.ts +3 -0
- package/lib/ACM-AXN/Holiday/Context.js +5 -0
- package/lib/ACM-AXN/Holiday/CreateOrEdit.d.ts +2 -0
- package/lib/ACM-AXN/Holiday/CreateOrEdit.js +62 -0
- package/lib/ACM-AXN/Holiday/CreateOrEdit.test.d.ts +1 -0
- package/lib/ACM-AXN/Holiday/CreateOrEdit.test.js +255 -0
- package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.d.ts +2 -0
- package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.js +107 -0
- package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.test.d.ts +1 -0
- package/lib/ACM-AXN/Holiday/Detail/AddOrEditDate.test.js +181 -0
- package/lib/ACM-AXN/Holiday/Detail/Dates.d.ts +6 -0
- package/lib/ACM-AXN/Holiday/Detail/Dates.js +153 -0
- package/lib/ACM-AXN/Holiday/Detail/Dates.test.d.ts +1 -0
- package/lib/ACM-AXN/Holiday/Detail/Dates.test.js +220 -0
- package/lib/ACM-AXN/Holiday/Detail/Form.d.ts +6 -0
- package/lib/ACM-AXN/Holiday/Detail/Form.js +32 -0
- package/lib/ACM-AXN/Holiday/Detail/Form.test.d.ts +1 -0
- package/lib/ACM-AXN/Holiday/Detail/Form.test.js +120 -0
- package/lib/ACM-AXN/Holiday/Detail.d.ts +2 -0
- package/lib/ACM-AXN/Holiday/Detail.js +29 -0
- package/lib/ACM-AXN/Holiday/FormHoliday.d.ts +9 -0
- package/lib/ACM-AXN/Holiday/FormHoliday.js +110 -0
- package/lib/ACM-AXN/Holiday/Hooks.d.ts +2 -0
- package/lib/ACM-AXN/Holiday/Hooks.js +12 -0
- package/lib/ACM-AXN/Holiday/Types.d.ts +91 -0
- package/lib/ACM-AXN/Holiday/Types.js +15 -0
- package/lib/ACM-AXN/Holiday/Utils.d.ts +13 -0
- package/lib/ACM-AXN/Holiday/Utils.js +34 -0
- package/lib/ACM-AXN/Holiday/index.d.ts +3 -0
- package/lib/ACM-AXN/Holiday/index.js +45 -0
- package/lib/ACM-AXN/Notifications/NotificationDetail/HeaderInfo/ButtonTabs.js +1 -1
- package/lib/ACM-AXN/Notifications/NotificationDetail/HeaderInfo/MenuNotification.js +1 -1
- package/lib/ACM-AXN/Notifications/NotificationDetail/HeaderInfo/index.js +1 -1
- package/lib/ACM-AXN/Notifications/NotificationDetail/NotificationList/NotificationItem/Message.js +7 -6
- package/lib/ACM-AXN/Notifications/NotificationDetail/NotificationList/index.js +1 -1
- package/lib/ACM-AXN/Notifications/NotificationDetail/index.js +29 -26
- package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +1 -1
- package/lib/ACM-AXN/Notifications/Types.d.ts +2 -2
- package/lib/ACM-AXN/Page/Constant.d.ts +0 -10
- package/lib/ACM-AXN/Page/Constant.js +1 -11
- package/lib/ACM-AXN/Page/Container.js +12 -13
- package/lib/ACM-AXN/Page/CreateOrEdit/Components/useListPageView.js +2 -2
- 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 +12 -1
- package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +20 -1
- 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 +48 -29
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +53 -64
- package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +26 -31
- package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +7 -9
- package/lib/ACM-AXN/Page/CreateOrEdit/index.d.ts +2 -3
- package/lib/ACM-AXN/Page/CreateOrEdit/index.js +99 -45
- package/lib/ACM-AXN/Page/Import/index.js +1 -0
- package/lib/ACM-AXN/Page/Types.d.ts +2 -1
- package/lib/ACM-AXN/Page/index.js +9 -7
- package/lib/ACM-AXN/Permission/Components/Management.js +1 -1
- package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
- package/lib/ACM-AXN/Permission/index.js +1 -1
- package/lib/ACM-AXN/PlaceGroup/Container.js +1 -1
- package/lib/ACM-AXN/PlaceGroup/Container.test.js +1 -1
- package/lib/ACM-AXN/PlaceGroup/Context.d.ts +0 -5
- package/lib/ACM-AXN/PlaceGroup/Context.js +0 -5
- package/lib/ACM-AXN/PlaceGroup/index.js +1 -1
- package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +43 -28
- package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +11 -13
- package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +27 -22
- package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +28 -19
- package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.test.js +3 -3
- package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +29 -19
- package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.test.js +3 -3
- package/lib/ACM-AXN/ScheduleCompletionRate/Detail/index.js +1 -1
- package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
- package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +46 -59
- package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
- package/lib/ACM-AXN/ScheduleCompletionRate/Recoils.d.ts +7 -6
- package/lib/ACM-AXN/ScheduleCompletionRate/Recoils.js +6 -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 +74 -110
- package/lib/ACM-AXN/ScheduleCompletionRate/Types.js +21 -279
- package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +22 -3
- package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +64 -11
- package/lib/ACM-AXN/ScheduleCompletionRate/index.js +3 -3
- package/lib/ACM-AXN/Statistics/ControlPanel.d.ts +1 -1
- package/lib/ACM-AXN/Statistics/ControlPanel.js +28 -12
- package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
- package/lib/ACM-AXN/Statistics/Enums.js +1 -0
- package/lib/ACM-AXN/Statistics/container.d.ts +1 -1
- package/lib/ACM-AXN/Statistics/container.js +2 -2
- package/lib/ACM-AXN/Statistics/interface.d.ts +1 -0
- package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +6 -5
- package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/TableAndPieChart.js +5 -5
- package/lib/ACM-AXN/StatisticsAudienceDemographic/container.d.ts +1 -1
- package/lib/ACM-AXN/StatisticsAudienceDemographic/container.js +2 -2
- package/lib/ACM-AXN/StatisticsAudienceDemographic/interfaces.d.ts +1 -0
- package/lib/ACM-AXN/StatisticsByProvince/container.d.ts +1 -1
- package/lib/ACM-AXN/StatisticsByProvince/container.js +2 -2
- package/lib/ACM-AXN/StatisticsByProvince/interfaces.d.ts +1 -0
- package/lib/ACM-AXN/TaskScheduler/Components/CornJobInput.js +1 -2
- package/lib/ACM-AXN/TaskScheduler/Container.js +3 -3
- package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +9 -10
- package/lib/ACM-AXN/TaskScheduler/Types.d.ts +1 -1
- package/lib/ACM-AXN/TaskScheduler/Utils.d.ts +5 -0
- package/lib/ACM-AXN/TaskScheduler/Utils.js +8 -3
- package/lib/ACM-AXN/TaskScheduler/index.js +3 -3
- package/lib/ACM-AXN/Template/Container.js +5 -5
- package/lib/ACM-AXN/Template/Container.test.js +6 -5
- package/lib/ACM-AXN/Template/CreateOrEdit/CreateOrEdit.test.js +1 -1
- package/lib/ACM-AXN/Template/CreateOrEdit/Infomation.js +13 -2
- package/lib/ACM-AXN/Template/CreateOrEdit/Infomation.test.js +1 -1
- 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/Script.js +3 -3
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +3 -2
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +57 -32
- 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/Template/index.js +7 -3
- package/lib/ACM-AXN/Template/CreateOrEdit/index.js +11 -7
- package/lib/ACM-AXN/Template/Import.js +6 -3
- package/lib/ACM-AXN/Template/Import.test.js +2 -2
- package/lib/ACM-AXN/Template/Types.d.ts +9 -9
- package/lib/ACM-AXN/Template/index.js +4 -4
- package/lib/ACM-AXN/TransactionLog/Container.js +1 -1
- package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
- package/lib/ACM-AXN/TransactionLog/index.js +1 -1
- package/lib/ACM-AXN/User/Add.js +2 -2
- package/lib/ACM-AXN/User/Container.js +2 -2
- package/lib/ACM-AXN/User/index.js +2 -2
- package/lib/ACM-AXN/ViewTemplate/Enum.d.ts +1 -0
- package/lib/ACM-AXN/ViewTemplate/Enum.js +1 -0
- package/lib/ACM-AXN/ViewTemplate/Preview.js +52 -42
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.d.ts +12 -0
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +69 -0
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.test.d.ts +1 -0
- package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.test.js +84 -0
- 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 +54 -159
- package/lib/ACM-AXN/ViewTemplate/common.js +1 -1
- package/lib/ACM-AXN/ViewTemplate/constant.d.ts +1 -0
- package/lib/ACM-AXN/ViewTemplate/constant.js +2 -1
- package/lib/ACM-AXN/ViewTemplate/container.d.ts +1 -1
- package/lib/ACM-AXN/ViewTemplate/container.js +36 -25
- package/lib/ACM-AXN/ViewTemplate/interface.d.ts +3 -7
- package/lib/ACM-AXN/Wizard/Container.d.ts +2 -0
- package/lib/ACM-AXN/Wizard/Container.js +46 -0
- package/lib/ACM-AXN/Wizard/Container.test.d.ts +1 -0
- package/lib/ACM-AXN/Wizard/Container.test.js +162 -0
- package/lib/ACM-AXN/Wizard/Context.d.ts +3 -0
- package/lib/ACM-AXN/Wizard/Context.js +5 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.d.ts +11 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.js +90 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.test.d.ts +1 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/FormInformationBasic.test.js +113 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +14 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +88 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.d.ts +1 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +99 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.d.ts +14 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +161 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.test.d.ts +1 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.test.js +255 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/index.d.ts +2 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +150 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/index.test.d.ts +1 -0
- package/lib/ACM-AXN/Wizard/CreateOrEdit/index.test.js +223 -0
- package/lib/ACM-AXN/Wizard/Hooks.d.ts +2 -0
- package/lib/ACM-AXN/Wizard/Hooks.js +12 -0
- package/lib/ACM-AXN/Wizard/Types.d.ts +217 -0
- package/lib/ACM-AXN/Wizard/Types.js +22 -0
- package/lib/ACM-AXN/Wizard/Utils.d.ts +27 -0
- package/lib/ACM-AXN/Wizard/Utils.js +31 -0
- package/lib/ACM-AXN/Wizard/index.d.ts +3 -0
- package/lib/ACM-AXN/Wizard/index.js +40 -0
- package/lib/AWING/AsyncAutocomplete/index.js +2 -2
- package/lib/AWING/Chart/BarLineComponent.js +105 -9
- package/lib/AWING/Chart/PieComponent.js +2 -2
- package/lib/AWING/Chart/Styles.js +49 -16
- package/lib/AWING/DataForm/DataInput.js +22 -18
- package/lib/AWING/DataGrid/index.js +9 -1
- package/lib/AWING/DataGrid/interface.d.ts +39 -1
- package/lib/AWING/DateRangePicker/component.js +32 -14
- package/lib/AWING/Form/Utils/Types.d.ts +4 -0
- package/lib/AWING/Form/useForm.d.ts +2 -3
- package/lib/AWING/Form/useForm.js +6 -4
- package/lib/AWING/GroupTable/GroupTable.js +7 -7
- package/lib/AWING/Hooks/index.d.ts +1 -0
- package/lib/AWING/Hooks/index.js +17 -0
- package/lib/AWING/Hooks/useGetData.d.ts +9 -0
- package/lib/AWING/Hooks/useGetData.js +26 -0
- package/lib/AWING/NumberFormat/index.d.ts +3 -1
- package/lib/AWING/NumberFormat/index.js +2 -2
- package/lib/AWING/ultis/validation.d.ts +1 -0
- package/lib/AWING/ultis/validation.js +22 -15
- package/lib/Commons/Components/ClassicDrawer.js +2 -2
- package/lib/Commons/Components/DeprecatedEnhancedDialog.js +1 -1
- package/lib/Commons/Hooks/usePath.js +3 -3
- package/lib/Utils/Helpers.d.ts +11 -3
- package/lib/Utils/Helpers.js +65 -4
- package/lib/translate/en/translation.json +84 -7
- package/lib/translate/vi/translation.json +86 -7
- package/package.json +128 -126
- package/lib/ACM-AXN/Campaign/Constant.d.ts +0 -38
- package/lib/ACM-AXN/Campaign/Constant.js +0 -41
- package/lib/ACM-AXN/CampaignPlan/Constant.d.ts +0 -8
- package/lib/ACM-AXN/CampaignPlan/Constant.js +0 -11
- package/lib/ACM-AXN/Directory/Constant.d.ts +0 -13
- package/lib/ACM-AXN/Directory/Constant.js +0 -15
- package/lib/ACM-AXN/GroupUser/Constants.d.ts +0 -7
- package/lib/ACM-AXN/GroupUser/Constants.js +0 -10
- package/lib/ACM-AXN/PlaceGroup/Constant.d.ts +0 -9
- package/lib/ACM-AXN/PlaceGroup/Constant.js +0 -12
- package/lib/ACM-AXN/ScheduleCompletionRate/Constant.d.ts +0 -8
- package/lib/ACM-AXN/ScheduleCompletionRate/Constant.js +0 -11
- package/lib/ACM-AXN/TaskScheduler/Constant.d.ts +0 -9
- package/lib/ACM-AXN/TaskScheduler/Constant.js +0 -13
- package/lib/ACM-AXN/TaskScheduler/Enums.d.ts +0 -4
- package/lib/ACM-AXN/TaskScheduler/Enums.js +0 -8
- package/lib/ACM-AXN/Template/Constants.d.ts +0 -0
- package/lib/ACM-AXN/Template/Constants.js +0 -1
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Events.d.ts +0 -5
- package/lib/ACM-AXN/Template/CreateOrEdit/Template/Events.js +0 -41
- package/lib/ACM-AXN/TransactionLog/Constant.d.ts +0 -10
- package/lib/ACM-AXN/TransactionLog/Constant.js +0 -13
- package/lib/ACM-AXN/User/Constants.d.ts +0 -2
- package/lib/ACM-AXN/User/Constants.js +0 -5
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { IDirectory, TemplateType, IWizardTemplate } from '../Types';
|
|
3
|
+
interface PropsRowTemplate {
|
|
4
|
+
pageCode: string;
|
|
5
|
+
directories: IDirectory[];
|
|
6
|
+
templateTypes: TemplateType[];
|
|
7
|
+
template: IWizardTemplate;
|
|
8
|
+
disabledIconDelete: boolean;
|
|
9
|
+
onChangeRow: (fieldValue: any, sortOrder: number) => void;
|
|
10
|
+
onUpdateWizardLogin?: (type: string, sortOrder?: number) => void;
|
|
11
|
+
}
|
|
12
|
+
declare function RowTemplate(props: PropsRowTemplate): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
declare const _default: import("react").MemoExoticComponent<typeof RowTemplate>;
|
|
14
|
+
export default _default;
|
|
@@ -0,0 +1,161 @@
|
|
|
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
|
+
};
|
|
13
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
18
|
+
var react_1 = require("react");
|
|
19
|
+
var react_i18next_1 = require("react-i18next");
|
|
20
|
+
var Delete_1 = __importDefault(require("@mui/icons-material/Delete"));
|
|
21
|
+
var material_1 = require("@mui/material");
|
|
22
|
+
var Hooks_1 = __importDefault(require("../Hooks"));
|
|
23
|
+
var Utils_1 = require("../Utils");
|
|
24
|
+
var validation_1 = require("../../../AWING/ultis/validation");
|
|
25
|
+
function RowTemplate(props) {
|
|
26
|
+
var _a;
|
|
27
|
+
var pageCode = props.pageCode, template = props.template, onChangeRow = props.onChangeRow, directories = props.directories, templateTypes = props.templateTypes, onUpdateWizardLogin = props.onUpdateWizardLogin, _b = props.disabledIconDelete, disabledIconDelete = _b === void 0 ? false : _b;
|
|
28
|
+
var t = (0, react_i18next_1.useTranslation)().t;
|
|
29
|
+
var service = (0, Hooks_1.default)().service;
|
|
30
|
+
// DATA => Chọn Template
|
|
31
|
+
var _c = (0, react_1.useState)([]), templates = _c[0], setTemplates = _c[1];
|
|
32
|
+
// DATA => Các trường dữ liệu
|
|
33
|
+
var _d = (0, react_1.useState)(), templateModel = _d[0], setTemplateModel = _d[1];
|
|
34
|
+
// DATA ROW TEMPLATE
|
|
35
|
+
var _e = (0, react_1.useState)(function () {
|
|
36
|
+
var _a;
|
|
37
|
+
return (__assign(__assign({}, template), { templateTypeId: 0, directoryId: ((_a = directories[0]) === null || _a === void 0 ? void 0 : _a.directoryId) || '' }));
|
|
38
|
+
}), wizardTemplate = _e[0], setWizardTemplate = _e[1];
|
|
39
|
+
// disabled => Các trường dữ liệu => call API
|
|
40
|
+
var _f = (0, react_1.useState)(true), isLoadingParameter = _f[0], setIsLoadingParameter = _f[1];
|
|
41
|
+
var _g = (0, react_1.useState)({
|
|
42
|
+
status: true,
|
|
43
|
+
message: '',
|
|
44
|
+
}), validFieldName = _g[0], setValidFieldName = _g[1];
|
|
45
|
+
(0, react_1.useLayoutEffect)(function () {
|
|
46
|
+
setWizardTemplate(function (oldWizardData) { return (__assign(__assign({}, oldWizardData), template)); });
|
|
47
|
+
}, [template]);
|
|
48
|
+
(0, react_1.useEffect)(function () {
|
|
49
|
+
if (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.directoryId) {
|
|
50
|
+
!isLoadingParameter && setIsLoadingParameter(true);
|
|
51
|
+
service
|
|
52
|
+
.templatesGetByDirectoryId(wizardTemplate.directoryId)
|
|
53
|
+
.then(function (template_) {
|
|
54
|
+
var newTemplates = template_ === null || template_ === void 0 ? void 0 : template_.filter(function (item) {
|
|
55
|
+
return item.pageCode === pageCode &&
|
|
56
|
+
(wizardTemplate.templateTypeId === 0 ||
|
|
57
|
+
item.templateTypeId ===
|
|
58
|
+
wizardTemplate.templateTypeId);
|
|
59
|
+
});
|
|
60
|
+
// Sắp xếp chuỗi theo thứ tự tăng dần (a => z).
|
|
61
|
+
newTemplates.sort(function (a, b) {
|
|
62
|
+
return ((a === null || a === void 0 ? void 0 : a.description) || '').localeCompare((b === null || b === void 0 ? void 0 : b.description) || '');
|
|
63
|
+
});
|
|
64
|
+
setTemplates(newTemplates);
|
|
65
|
+
})
|
|
66
|
+
.finally(function () {
|
|
67
|
+
setIsLoadingParameter(false);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
71
|
+
}, [pageCode, wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.directoryId]);
|
|
72
|
+
(0, react_1.useEffect)(function () {
|
|
73
|
+
if (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId) {
|
|
74
|
+
service
|
|
75
|
+
.templatesGet(wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId)
|
|
76
|
+
.then(setTemplateModel);
|
|
77
|
+
}
|
|
78
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
79
|
+
}, [wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId]);
|
|
80
|
+
var handleChange = function (fieldName, value) {
|
|
81
|
+
var _a, _b, _c;
|
|
82
|
+
// Update dữ liệu nội bộ
|
|
83
|
+
var newWizardTemplate = __assign(__assign({}, wizardTemplate), (_a = {}, _a[fieldName] = value, _a));
|
|
84
|
+
if (fieldName === 'directoryId' || fieldName === 'templateTypeId') {
|
|
85
|
+
newWizardTemplate.templateId = '';
|
|
86
|
+
newWizardTemplate.templateParameterDisplayFieldNames = [];
|
|
87
|
+
}
|
|
88
|
+
else if (fieldName === 'templateId') {
|
|
89
|
+
newWizardTemplate.templateParameterDisplayFieldNames = [];
|
|
90
|
+
}
|
|
91
|
+
setWizardTemplate(newWizardTemplate);
|
|
92
|
+
// Update dữ liệu API
|
|
93
|
+
if (fieldName !== 'directoryId' && fieldName !== 'templateTypeId') {
|
|
94
|
+
if (fieldName === 'name') {
|
|
95
|
+
var _d = (0, validation_1.textValidation)(value, 50, true), valid = _d.valid, message = _d.message;
|
|
96
|
+
setValidFieldName({ status: valid, message: message });
|
|
97
|
+
onChangeRow((_b = {},
|
|
98
|
+
_b[fieldName] = typeof value === 'string'
|
|
99
|
+
? valid
|
|
100
|
+
? value.trim()
|
|
101
|
+
: ''
|
|
102
|
+
: value,
|
|
103
|
+
_b), (template === null || template === void 0 ? void 0 : template.sortOrder) || 0);
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
onChangeRow((_c = {},
|
|
107
|
+
_c[fieldName] = typeof value === 'string' ? value.trim() : value,
|
|
108
|
+
_c), (template === null || template === void 0 ? void 0 : template.sortOrder) || 0);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
var handleDeleteRowTemplate = function () {
|
|
113
|
+
onUpdateWizardLogin &&
|
|
114
|
+
onUpdateWizardLogin(Utils_1.TYPE_LOGIN_TEMPLATE.REMOVE, template.sortOrder);
|
|
115
|
+
};
|
|
116
|
+
return ((0, jsx_runtime_1.jsxs)(material_1.Box, { component: "div", sx: {
|
|
117
|
+
flex: 1,
|
|
118
|
+
display: 'flex',
|
|
119
|
+
flexDirection: 'row',
|
|
120
|
+
alignItems: 'center',
|
|
121
|
+
}, children: [(0, jsx_runtime_1.jsx)(material_1.TextField, { id: "name", required: true, fullWidth: true, variant: "standard", label: t('Common.Name'), "data-testid": "Common.Name", value: wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.name, error: !validFieldName.status, sx: { mr: 2, minWidth: '100px', maxWidth: '140px' }, helperText: !validFieldName.status && validFieldName.message, onChange: function (event) { return handleChange('name', event.target.value); } }), (0, jsx_runtime_1.jsx)(material_1.TextField, { select: true, fullWidth: true, id: "directoryId", variant: "standard", label: t('Wizard.Directory'), "data-testid": "Wizard.Directory", disabled: !(directories === null || directories === void 0 ? void 0 : directories.length), value: (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.directoryId) || '', sx: { mr: 2, minWidth: '140px', maxWidth: '180px' }, onChange: function (event) {
|
|
122
|
+
return handleChange('directoryId', event.target.value);
|
|
123
|
+
}, children: directories.map(function (directory) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { style: {
|
|
124
|
+
paddingLeft: directory.level &&
|
|
125
|
+
directory.level >= 2 &&
|
|
126
|
+
directory.isSystem !== true
|
|
127
|
+
? (directory.level - 2) * 24 + 'px'
|
|
128
|
+
: '8px',
|
|
129
|
+
}, value: directory.directoryId, children: directory.name }, directory.directoryId)); }) }), (0, jsx_runtime_1.jsxs)(material_1.TextField, { select: true, fullWidth: true, variant: "standard", id: "templateTypeId", label: t('Common.TypeTemplate'), "data-testid": "Common.TypeTemplate", value: wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateTypeId, sx: { mr: 2, minWidth: '120px', maxWidth: '140px' }, onChange: function (event) {
|
|
130
|
+
return handleChange('templateTypeId', event.target.value);
|
|
131
|
+
}, children: [(0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: 0, children: t('Common.SelectAll') }), templateTypes.map(function (templateType) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: templateType.id, children: templateType.name }, templateType.id)); })] }), (0, jsx_runtime_1.jsx)(material_1.TextField, { select: true, fullWidth: true, required: true, id: "template", variant: "standard", disabled: !(templates === null || templates === void 0 ? void 0 : templates.length), sx: { mr: 2, minWidth: '140px' }, label: t('Wizard.SelectTemplate'), "data-testid": "Wizard.SelectTemplate", value: (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateId) || '', onChange: function (event) {
|
|
132
|
+
return handleChange('templateId', event.target.value);
|
|
133
|
+
}, children: templates
|
|
134
|
+
.filter(function (template) {
|
|
135
|
+
return (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateTypeId) === 0 ||
|
|
136
|
+
template.templateTypeId ===
|
|
137
|
+
(wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateTypeId);
|
|
138
|
+
})
|
|
139
|
+
.map(function (temp) { return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: temp.id, children: temp.description }, temp.id)); }) }), (0, jsx_runtime_1.jsxs)(material_1.FormControl, { fullWidth: true, variant: "standard", sx: { mr: 2, minWidth: '180px' }, children: [(0, jsx_runtime_1.jsx)(material_1.InputLabel, { htmlFor: "component-simple", "data-testid": "Wizard.FieldNames", children: t('Wizard.FieldNames') }), (0, jsx_runtime_1.jsx)(material_1.Select, { multiple: true, id: "component-simple", value: (wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateParameterDisplayFieldNames) || [], disabled: isLoadingParameter ||
|
|
140
|
+
!(templates === null || templates === void 0 ? void 0 : templates.length) ||
|
|
141
|
+
!(templateModel === null || templateModel === void 0 ? void 0 : templateModel.templateParameters), onChange: function (event) {
|
|
142
|
+
return handleChange('templateParameterDisplayFieldNames', event.target.value);
|
|
143
|
+
}, renderValue: function (selected) {
|
|
144
|
+
var _a;
|
|
145
|
+
var fieldNames = selected;
|
|
146
|
+
return (_a = templateModel === null || templateModel === void 0 ? void 0 : templateModel.templateParameters) === null || _a === void 0 ? void 0 : _a.filter(function (parameter) {
|
|
147
|
+
return fieldNames.includes(parameter.fieldName || '');
|
|
148
|
+
}).map(function (parameter) {
|
|
149
|
+
return parameter.labelName;
|
|
150
|
+
}).join(', ');
|
|
151
|
+
}, MenuProps: {
|
|
152
|
+
PaperProps: {
|
|
153
|
+
style: {
|
|
154
|
+
maxHeight: 224,
|
|
155
|
+
},
|
|
156
|
+
},
|
|
157
|
+
}, children: (_a = templateModel === null || templateModel === void 0 ? void 0 : templateModel.templateParameters) === null || _a === void 0 ? void 0 : _a.map(function (parameter, idx) { return ((0, jsx_runtime_1.jsxs)(material_1.MenuItem, { value: parameter.fieldName, children: [(0, jsx_runtime_1.jsx)(material_1.Checkbox, { color: "primary", checked: ((wizardTemplate === null || wizardTemplate === void 0 ? void 0 : wizardTemplate.templateParameterDisplayFieldNames) ||
|
|
158
|
+
[]).indexOf((parameter === null || parameter === void 0 ? void 0 : parameter.fieldName) || '') >
|
|
159
|
+
-1 }), (0, jsx_runtime_1.jsx)(material_1.ListItemText, { primary: parameter.labelName })] }, idx)); }) })] }), (0, jsx_runtime_1.jsx)(material_1.IconButton, { edge: "end", "aria-label": "delete", "data-testid": "deleteIcon", disabled: disabledIconDelete, onClick: handleDeleteRowTemplate, children: (0, jsx_runtime_1.jsx)(Delete_1.default, {}) })] }));
|
|
160
|
+
}
|
|
161
|
+
exports.default = (0, react_1.memo)(RowTemplate);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,255 @@
|
|
|
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
|
+
};
|
|
13
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
14
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
15
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
16
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
17
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
18
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
19
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
23
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
24
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
25
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
26
|
+
function step(op) {
|
|
27
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
28
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
29
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
30
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
31
|
+
switch (op[0]) {
|
|
32
|
+
case 0: case 1: t = op; break;
|
|
33
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
34
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
35
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
36
|
+
default:
|
|
37
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
38
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
39
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
40
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
41
|
+
if (t[2]) _.ops.pop();
|
|
42
|
+
_.trys.pop(); continue;
|
|
43
|
+
}
|
|
44
|
+
op = body.call(thisArg, _);
|
|
45
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
46
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
50
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
51
|
+
};
|
|
52
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
53
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
54
|
+
/* eslint-disable testing-library/no-wait-for-side-effects */
|
|
55
|
+
var react_1 = require("@testing-library/react");
|
|
56
|
+
var RowTemplate_1 = __importDefault(require("./RowTemplate"));
|
|
57
|
+
var Utils_1 = require("../Utils");
|
|
58
|
+
var directories = [
|
|
59
|
+
{
|
|
60
|
+
description: null,
|
|
61
|
+
directoryId: '4711650767517730267',
|
|
62
|
+
directoryPath: '.0.99.4711650767517730267.',
|
|
63
|
+
isFile: false,
|
|
64
|
+
isSystem: true,
|
|
65
|
+
level: 2,
|
|
66
|
+
name: 'SYSTEM TEMPLATE',
|
|
67
|
+
objectTypeCode: 'template',
|
|
68
|
+
order: 0,
|
|
69
|
+
parentDirectoryId: '99',
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
description: null,
|
|
73
|
+
directoryId: '5084661221099431199',
|
|
74
|
+
directoryPath: '.0.99.4711650767517730267.5084661221099431199.',
|
|
75
|
+
isFile: false,
|
|
76
|
+
isSystem: false,
|
|
77
|
+
level: 3,
|
|
78
|
+
name: 'Beta template',
|
|
79
|
+
objectTypeCode: 'template',
|
|
80
|
+
order: 0,
|
|
81
|
+
parentDirectoryId: '4711650767517730267',
|
|
82
|
+
},
|
|
83
|
+
];
|
|
84
|
+
var templateTypes = [
|
|
85
|
+
{ id: 1, name: 'Banner', templateTypeCode: 'lgn' },
|
|
86
|
+
{ id: 5, name: 'Customize', templateTypeCode: 'lgn' },
|
|
87
|
+
];
|
|
88
|
+
var templates = [
|
|
89
|
+
{
|
|
90
|
+
autoField: '',
|
|
91
|
+
description: '07.[DEFAULT] Data Collection 1 Page_v1.0',
|
|
92
|
+
directoryId: '5183679953246990989',
|
|
93
|
+
directoryPath: '.0.99.4711650767517730267.5183679953246990989.4619609303918768290.',
|
|
94
|
+
id: '4619609303918768290',
|
|
95
|
+
layoutId: '0',
|
|
96
|
+
name: '',
|
|
97
|
+
pageCode: 'lgn',
|
|
98
|
+
templateHtml: '<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1,user-scalable=0"/>\r\n<link href="/static/Files/template/5246961620307474338/template_cpa_v1_0.css?432" rel="stylesheet" />\r\n<div id="cpa-container" style="width:100%">\r\n <img id="background_img_1" src="{cpa_1_banner_1}">\r\n <div class="box-wrapper-2">\r\n <table class="form_table formtable-fix form_table_text" id="cpa_field_list">\r\n </table>\r\n <table class="form_table btn-form-label form_table_text form-paddingtop">\r\n <tr>\r\n <td>\r\n <button class="btn_action btn_left btn_form_2" onclick="nextView();">\r\n <strong id="btn_left_text2">KẾT NỐI<br/>INTERNET NGAY</strong>\r\n <br/>\r\n <small class="smallen">(ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n <td>\r\n <button class="btn_action btn_right btn_form_2" onclick="doSubmit()">\r\n <strong id="btn_right_text2">ĐĂNG KÝ<br/>& KẾT NỐI INTERNET</strong>\r\n <br/>\r\n <small class="smallen">(REGISTER & ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n</div>\r\n<textarea id="textLeftButtonBanner2" style="display: none;">{cpa_1_banner_2}</textarea>\r\n<textarea id="textRightButtonBanner2" style="display: none;">{cpa_1_banner_3}</textarea>\r\n<div id="continue_scroll" style="display: none;">\r\n <a id="continue_text"><span></span>Còn tiếp</a>\r\n</div>\r\n<script>\r\nvar textLeftButtonBanner2 = $("#textLeftButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar textRightButtonBanner2 = $("#textRightButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar colorCodeLeftButton = "#"+"{cpa_1_banner_4}";\r\nvar colorCodeRightButton = "#"+"{cpa_1_banner_5}";\r\nvar colorTextLeftButton = "#"+"{cpa_1_banner_6}";\r\nvar colorTextRightButton = "#"+"{cpa_1_banner_7}";\r\nvar fieldList = [];\r\nvar nameFieldCheckbox = "{cpa_1_banner_8}" == "true" ? fieldList.push("name") : "";\r\nvar phoneFieldCheckbox = "{cpa_1_banner_9}" == "true" ? fieldList.push("phone") : "";\r\nvar emailFieldCheckbox = "{cpa_1_banner_10}" == "true" ? fieldList.push("email") : "";\r\nvar textFieldBackGroundColor = "{cpa_1_banner_11}";\r\nvar textFieldBorderColor = "#"+"{cpa_1_banner_12}";\r\n\r\nfieldList.forEach(function(item){\r\n if(item == "name"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'name\' name=\'name\' placeholder=\'Họ và tên\' class=\'input-text input-box-2 input-text-name\'></input><span class=\'tooltiptext\' id=\'tooltipname\'>Họ và tên không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "phone"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'number\' id = \'phone\' placeholder=\'Số điện thoại\' class=\'input-text input-box-2 input-text-phone\'></input><span class=\'tooltiptext\' id=\'tooltipphone\'>Số điện thoại không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "email"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'email\' placeholder=\'Email\' class=\'input-text input-box-2 input-text-email\' /><span class=\'tooltiptext\' id=\'tooltipemail\'>Email không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n});\r\nif(fieldList.length == 3) {\r\n $(".box-wrapper-2").addClass("three-field-form");\r\n}\r\nvar mInfo = detectDeviceInfo();\r\nvar windowheight = window.innerHeight;\r\nvar browserLang = navigator.language || navigator.userLanguage;\r\nif(browserLang !="vi-VN"){\r\n $("#continue_text").html("<span></span>More</a>");\r\n // $(".wa-button-maxview").addClass("wa-button-en");\r\n $("#continue_scroll").addClass("continue-en");\r\n}\r\nif(textLeftButtonBanner2.length > 0) { $("#btn_left_text2").html(textLeftButtonBanner2); }\r\nif(textRightButtonBanner2.length > 0) { $("#btn_right_text2").html(textRightButtonBanner2); }\r\n$(".btn_left").css({\r\n "background-color": colorCodeLeftButton,\r\n "color": colorTextLeftButton\r\n});\r\n$(".btn_right").css({\r\n "background-color": colorCodeRightButton,\r\n "color": colorTextRightButton\r\n});\r\nif(textFieldBackGroundColor.toLowerCase() == "màu xám") {\r\n $("td > .input-box-2").css("background-color", "#d9d9d9");\r\n}\r\n$("td > .input-box-2").css("border",\'1px solid \' + textFieldBorderColor);\r\n\r\nif(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(\'#continue_text\').css(\'color\', colorCodeLeftButton);\r\n $(\'#continue_text span\').css({\r\n "border-left":"5px solid " + colorCodeLeftButton,\r\n "border-bottom": "5px solid " + colorCodeLeftButton\r\n });\r\n}\r\n\r\n$("#continue_scroll").hide();\r\nfunction startAnimation(){\r\n $(\'#layoutHeader\').hide();\r\n if(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(window).off(\'scroll\');\r\n // var footerHeight = ($(\'#wa_hotline\').outerHeight() > 0 ) ? $(\'#wa_hotline\').outerHeight() : 32.4;\r\n // $(\'#cpa-container\').css(\'min-height\', windowheight - footerHeight);\r\n // $(\'#cpa-container\').css(\'background\', colorCodeBody);\r\n setTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));}, 750);\r\n $(document).on(\'touchend\', function() {\r\n setTimeout(function()\r\n {\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n });\r\n }\r\n else {\r\n window.onresize = function(event) {\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 3;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+5);\r\n };\r\n setTimeout(function(){\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 5;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+10);\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n }\r\n}\r\n$(".input-text").focus(function(){\r\n $("#tooltipphone").hide();\r\n $("#tooltipname").hide();\r\n $("#tooltipemail").hide();\r\n remove_error($(\'.input-text\'));\r\n});\r\nfunction goToForm(){\r\n $(\'.box-wrapper\').hide();\r\n $(\'.box-wrapper-2\').show();\r\n $(\'#background_img\').hide();\r\n $(\'#background_img_1\').show();\r\n}\r\nfunction doSubmit(){\r\n var phone = $(\'#phone\').val();\r\n var name = $(\'#name\').val();\r\n var email = $(\'#email\').val();\r\n var valObject = {name: name, phone: phone, email: email};\r\n if (validateDataCustomer(name,phone,email)){\r\n var eventObject = {};\r\n fieldList.forEach(function(item) {\r\n eventObject[item] = valObject[item];\r\n });\r\n postAnalyticEvent("eventcpa",JSON.stringify(eventObject));\r\n nextView();\r\n }\r\n}\r\nfunction validateDataCustomer(name,phone,email){\r\n var validate = true;\r\n if(fieldList.indexOf("name") !== -1){\r\n if ((!name)||(ContainNum(name))){\r\n set_error($(\'#name\'));\r\n set_errortooltip($(\'#tooltipname\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("phone") !== -1){\r\n phone = phone.replace(\'(+84)\', \'0\');\r\n phone = phone.replace(\'+84\', \'0\');\r\n phone = phone.replace(\'0084\', \'0\');\r\n phone = phone.replace(/ /g, \'\');\r\n if (phone != \'\') {\r\n var firstNumber = phone.substring(0, 2);\r\n if ((firstNumber == \'03\' || firstNumber == \'05\' || firstNumber == \'07\' || firstNumber == \'08\' || firstNumber == \'09\') && phone.length == 10) {\r\n if (phone.match(/^\\d{10}/)) {}\r\n } else if (firstNumber == \'01\' && phone.length == 11) {\r\n if (phone.match(/^\\d{11}/)) {}\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("email") !== -1){\r\n if (email != \'\') {\r\n if (!isEmail(email)){\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n else {\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n return validate;\r\n}\r\nfunction isEmail(email) {\r\n var regex = /^([a-zA-Z0-9_.+-])+\\@(([a-zA-Z0-9-])+\\.)+([a-zA-Z0-9]{2,4})+$/;\r\n return regex.test(email);\r\n}\r\nfunction ContainNum(t)\r\n{\r\n var regex = /\\d/g;\r\n return regex.test(t);\r\n}\r\nfunction set_error(element){\r\n element.addClass(\'_error\');\r\n}\r\nfunction set_errortooltip(element){\r\n element.show();\r\n}\r\nfunction remove_error(element){\r\n element.removeClass(\'_error\');\r\n}\r\nfunction continueScrollHandle(elm, scroll){\r\n if(checkVisible(elm)) {$(\'#continue_scroll\').hide();}\r\n else {$(\'#continue_scroll\').show();}\r\n}\r\nfunction checkVisible(elm){\r\n var viewHeight = Math.max(document.documentElement.clientHeight, window.innerHeight);\r\n if(elm != "" && elm != undefined){\r\n var rect = elm.getBoundingClientRect();\r\n return !(rect.bottom == 0 || rect.top - viewHeight >= -(rect.height - 12));\r\n }else{\r\n return true;\r\n }\r\n}\r\n</script>',
|
|
99
|
+
templateTypeId: 17,
|
|
100
|
+
validation: '',
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
autoField: '',
|
|
104
|
+
description: '08.[DEFAULT] Horizontal Video_v1.1',
|
|
105
|
+
directoryId: '5183679953246990989',
|
|
106
|
+
directoryPath: '.0.99.4711650767517730267.5183679953246990989.4631090508536728844.',
|
|
107
|
+
id: '4631090508536728844',
|
|
108
|
+
layoutId: '0',
|
|
109
|
+
name: '',
|
|
110
|
+
pageCode: 'lgn',
|
|
111
|
+
templateHtml: '<link href="/static/Files/template/4631090508536728844/video_horizontal_v1.1.css?01" rel="stylesheet" />\r\n<div id="horizontal-video-container" class="frame1">\r\n\t<div class="video">\r\n\t\t<div class="wpvideo">\r\n\t\t\t<video style="width: 100%" src="{video_1}" playsinline id="mVideo" poster="" preload="auto"></video> \r\n\t\t\t<img src="{video_3}" id="mImg" style="display:none;margin: 0px auto;">\r\n\t\t\t<div class="connection-container">\r\n\t\t\t\t<button id="connectToInternet" class="wa-button wa-button-view blur btn-bif wa-button-video" style="margin-top:0.5em;">BỎ QUA VIDEO TRONG <small class="smallen">(SKIP AD)</small><i id="countdowntimer" style="padding-left: 3px" class="countdown">6S</i></button>\r\n\t\t\t\t<a id="user-not-interest" class="class-user-interest" title="Cảm ơn, tôi muốn kết nối Internet ngay/ No thanks, just take me online" onclick="nextView()" style="display: none;">Cảm ơn, tôi muốn kết nối Internet ngay/ No thanks, just take me online </a>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n</div>\r\n<div id="continue_scroll_video" style="display: none;">\r\n\t<a id="continue_text_video"><span></span>Còn tiếp</a>\r\n</div>\r\n<script>\r\nvar browserLang = navigator.language || navigator.userLanguage;\r\nif(browserLang !="vi-VN"){\r\n\t$("#continue_text_video").html("<span></span>More</a>");\r\n\t$("#continue_scroll_video").addClass("continue-en");\r\n}\r\nvar mInfo = detectDeviceInfo();\r\nvar isShowBanner="{video_2}" == "true";banner="{video_3}";timeSkipAd = "{video_4}" == "" ? 6 : "{video_4}";colorButton = "#"+"{video_5}";colorTextButton = "#"+"{video_6}";textButton = "{video_7}";colorCodeBackgroundBanner = "#"+"{video_8}";isShowUserInterest = "{video_9}" == "true";\r\nif(Number(timeSkipAd) <= 0){\r\n\t$(\'#connectToInternet\').removeClass(\'blur\').html(\'BỎ QUA VIDEO <small class="smallen">(SKIP AD)</small>\').click(function () {\r\n\t\t\tdocument.body.style.backgroundColor = "#f5f5f5";\r\n\t\t\t\tif(isShowBanner){ showBanner();} else{connectToWifi();}\r\n\t});\r\n}\r\nif(Number(timeSkipAd) > 0){$(\'#countdowntimer\').html(timeSkipAd+"S");}\r\nif(mInfo.os == "iOS" || mInfo.os == "Android"){ \r\n\t$(\'.wa-button-video\').css({"background-color": colorButton,"color": colorTextButton});\r\n\t$(\'#continue_text_video\').css(\'color\', colorButton);\r\n\t$(\'#continue_text_video span\').css({\r\n\t\t"border-left":"5px solid " + colorButton,\r\n\t\t"border-bottom": "5px solid " + colorButton\r\n\t});\r\n}\r\nif(textButton =="") textButton ="KẾT NỐI INTERNET";\r\nif(banner == "") {\r\n\t$("#mImg").attr("src", "/static/Files/template/4631090508536728844/default_banner.png");\r\n}\r\nfunction startAnimation() {\r\n\t$(\'#layoutFooter\').hide();\r\n\t$(\'#layoutHeader\').hide();var videoId = document.getElementById(\'mVideo\');\r\n\tplayVideo();\r\n\t$(\'#mVideo\').on(\'pause\', function () {showBanner();});\r\n\t$(\'#mVideo\').on(\'play\', function () {\r\n\t\tdocument.body.style.backgroundColor = "rgb(33, 31, 31)";\r\n\t\tpostAnalyticEvent("View(Video)",JSON.stringify({}));\r\n\t\tif (mInfo.os == "iOS" && mInfo.os_value < 113) {\r\n\t\t\t\tdocument.body.style.backgroundColor = "#F5F5F5";\r\n\t\t} else {\r\n\t\t\t\t$("#connectToInternet").show();\r\n\t\t}\r\n\t\tsetTimeout(function () {if(Number(timeSkipAd) > 0) countDown(); }, 100);\r\n\t});\r\n\t$(\'#mVideo\').on(\'ended\', function () {\r\n\t\tpostAnalyticEvent("Completed_View(Video)",JSON.stringify({}));\r\n\t\tnextView();\r\n\t});\r\n\tfunction playVideo() { mVideo.play(); }\r\n\tif(mInfo.os !== "iOS" || mInfo.os !== "Android"){\r\n\t\t$(window).off(\'scroll\');\r\n\t\tsetTimeout(function(){\r\n\t\t\tvar rightContinue = ($(window).width() - $("#mVideo").width())/2 - $("#continue_scroll_video").width() + 5;\r\n\t\t\t$("#continue_scroll_video").css(\'right\', rightContinue);\r\n\t\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue+10);\r\n\t\t\tcontinueScrollHandle($("#connectToInternet")[0], $(\'#continue_scroll_video\'));\r\n\t\t}, 750);\r\n\t\t$(document).on(\'scroll\', function() {\r\n\t\t\tif($("#wa_hotline").height() > 0) {\r\n\t\t\t\tsetTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t\t}\r\n\t\t\telse \r\n\t\t\t\tsetTimeout(function(){continueScrollHandle($("#connectToInternet")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t});\r\n\t}\r\n}\r\nfunction countDown() {\r\n\t\tvar timeleft = 6;\r\n\t\tif(Number(timeSkipAd) > 0) timeleft = Number(timeSkipAd);\r\n\t\tvar downloadTimer = setInterval(function () {\r\n\t\t\t\ttimeleft--;\r\n\t\t\t\tvar x = document.getElementById("countdowntimer");\r\n\t\t\t\tx.textContent = timeleft + "S";\r\n\t\t\t\tif (timeleft <= 0) {\r\n\t\t\t\t\t\tclearInterval(downloadTimer);\r\n\t\t\t\t\t\t$(\'#connectToInternet\').removeClass(\'blur\').html(\'BỎ QUA VIDEO <small class="smallen">(SKIP AD)</small>\').click(function () {\r\n\t\t\t\t\t\t\t\tdocument.body.style.backgroundColor = "#F5F5F5";\r\n\t\t\t\t\t\t\t\t\tif(isShowBanner){ showBanner();} else{connectToWifi();}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t}, 1000);\r\n} \r\nfunction showBanner() {\r\n\t$(\'#layoutFooter\').show();\r\n\tmVideo.pause();\r\n\tdocument.body.style.backgroundColor = "#F5F5F5";\r\n\tcloseFullscreen();\r\n\tdocument.getElementById("mImg").style.display = "block";\r\n\t$("#mVideo").hide();\r\n\t$(\'#mImg\').click(function () { connectToWifi() });\r\n\t$(\'#connectToInternet\').removeClass(\'blur\');\r\n $(\'#connectToInternet\').unbind(\'click\');\r\n\t$(\'#connectToInternet\').addClass(\'connectInternet\').html(textButton+\'<BR/><small class="smallen">(ACCESS INTERNET)</small>\').click(function () {\r\n connectToWifi();\r\n\t});\r\n\tif(isShowUserInterest) $(\'#user-not-interest\').show();\r\n\tif(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n\t\t$(window).off(\'scroll\');\r\n\t\tvar windowheight = window.innerHeight;\r\n\t\tif(windowheight < 700) {\r\n\t\t\t$("#connectToInternet").addClass("wa-button-video-continue");\r\n\t\t}\r\n \thandleFullscreenVideoBanner();\r\n\t\tif(isShowUserInterest){$("#connectToInternet").addClass("wa-button-video-continue-userInterest");}\r\n\t\tvar rightContinue = ($(window).width() - $(".wa-button-video").width())/2 - $("#continue_scroll_video").width();\r\n\t\t$("#continue_scroll_video").css(\'right\', rightContinue-1);\r\n\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue-1);\r\n\t\tsetTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t$(document).on(\'touchend\', function() {\r\n\t\t\tsetTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));}, 750);\r\n\t\t});\r\n\t}\r\n\telse {\r\n\t\twindow.onresize = function(event) {\r\n\t\t\tvar rightContinue = ($(window).width() - $("#mImg").width())/2 - $("#continue_scroll_video").width() + 3;\r\n\t\t\t$("#continue_scroll_video").css(\'right\', rightContinue);\r\n\t\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue+5);\r\n\t\t};\r\n\t\tsetTimeout(function(){\r\n\t\t\tvar rightContinue = ($(window).width() - $("#mImg").width())/2 - $("#continue_scroll_video").width() + 5;\r\n\t\t\t$("#continue_scroll_video").css(\'right\', rightContinue);\r\n\t\t\t$("#continue_scroll_video.continue-en").css(\'right\', rightContinue+10);\r\n\t\t\tcontinueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll_video\'));\r\n\t\t}, 750);\r\n\t}\r\n}\r\nfunction handleFullscreenVideoBanner() {\r\n var footerHeight = ($(\'#wa_hotline\').outerHeight() > 0 ) ? $(\'#wa_hotline\').outerHeight() : 32.4;\r\n $(\'#horizontal-video-container\').css(\'min-height\', window.innerHeight - footerHeight);\r\n $(\'#horizontal-video-container\').css(\'background\', colorCodeBackgroundBanner);\r\n}\r\nfunction connectToWifi(){\r\n\tif(isShowUserInterest) {postAnalyticEvent("user_interest",JSON.stringify({}));}\r\n\tnextView();\r\n}\r\nfunction continueScrollHandle(elm, scroll){\r\n\tif(checkVisible(elm)) { scroll.hide(); }\r\n\telse { scroll.show(); }\r\n}\r\nfunction checkVisible(elm) {\r\n\tvar viewHeight = Math.max(document.documentElement.clientHeight, window.innerHeight);\r\n\tif(elm != "" && elm != undefined){\r\n\t\tvar rect = elm.getBoundingClientRect();\r\n\t\treturn !(rect.bottom == 0 || rect.top - viewHeight >= -(rect.height - 12));\r\n\t}else{\r\n\t\treturn true;\r\n\t}\r\n}\r\nfunction closeFullscreen() {\r\n\tif (document.getElementById(\'mVideo\').exitFullscreen) {\r\n\t\tdocument.getElementById(\'mVideo\').exitFullscreen();\r\n\t} else if (document.getElementById(\'mVideo\').mozCancelFullScreen) { /* Firefox */\r\n\t\tdocument.getElementById(\'mVideo\').mozCancelFullScreen();\r\n\t} else if (document.getElementById(\'mVideo\').webkitExitFullscreen) { /* Chrome, Safari and Opera */\r\n\t\tdocument.getElementById(\'mVideo\').webkitExitFullscreen();\r\n\t} else if (document.getElementById(\'mVideo\').msExitFullscreen) { /* IE/Edge */\r\n\t\tdocument.getElementById(\'mVideo\').msExitFullscreen();\r\n\t}\r\n}\r\n</script>',
|
|
112
|
+
templateTypeId: 18,
|
|
113
|
+
validation: '',
|
|
114
|
+
},
|
|
115
|
+
];
|
|
116
|
+
var templateModel = {
|
|
117
|
+
template: {
|
|
118
|
+
autoField: '',
|
|
119
|
+
description: '07.[DEFAULT] Data Collection 1 Page_v1.0',
|
|
120
|
+
directoryId: '5183679953246990989',
|
|
121
|
+
directoryPath: '.0.99.4711650767517730267.5183679953246990989.4619609303918768290.',
|
|
122
|
+
id: '4619609303918768290',
|
|
123
|
+
layoutId: '0',
|
|
124
|
+
name: '',
|
|
125
|
+
pageCode: 'lgn',
|
|
126
|
+
templateHtml: '<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1,user-scalable=0"/>\r\n<link href="/static/Files/template/5246961620307474338/template_cpa_v1_0.css?432" rel="stylesheet" />\r\n<div id="cpa-container" style="width:100%">\r\n <img id="background_img_1" src="{cpa_1_banner_1}">\r\n <div class="box-wrapper-2">\r\n <table class="form_table formtable-fix form_table_text" id="cpa_field_list">\r\n </table>\r\n <table class="form_table btn-form-label form_table_text form-paddingtop">\r\n <tr>\r\n <td>\r\n <button class="btn_action btn_left btn_form_2" onclick="nextView();">\r\n <strong id="btn_left_text2">KẾT NỐI<br/>INTERNET NGAY</strong>\r\n <br/>\r\n <small class="smallen">(ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n <td>\r\n <button class="btn_action btn_right btn_form_2" onclick="doSubmit()">\r\n <strong id="btn_right_text2">ĐĂNG KÝ<br/>& KẾT NỐI INTERNET</strong>\r\n <br/>\r\n <small class="smallen">(REGISTER & ACCESS INTERNET)</small>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n</div>\r\n<textarea id="textLeftButtonBanner2" style="display: none;">{cpa_1_banner_2}</textarea>\r\n<textarea id="textRightButtonBanner2" style="display: none;">{cpa_1_banner_3}</textarea>\r\n<div id="continue_scroll" style="display: none;">\r\n <a id="continue_text"><span></span>Còn tiếp</a>\r\n</div>\r\n<script>\r\nvar textLeftButtonBanner2 = $("#textLeftButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar textRightButtonBanner2 = $("#textRightButtonBanner2").text().replace(/(?:\\r\\n|\\r|\\n)/g, \'<br/>\');\r\nvar colorCodeLeftButton = "#"+"{cpa_1_banner_4}";\r\nvar colorCodeRightButton = "#"+"{cpa_1_banner_5}";\r\nvar colorTextLeftButton = "#"+"{cpa_1_banner_6}";\r\nvar colorTextRightButton = "#"+"{cpa_1_banner_7}";\r\nvar fieldList = [];\r\nvar nameFieldCheckbox = "{cpa_1_banner_8}" == "true" ? fieldList.push("name") : "";\r\nvar phoneFieldCheckbox = "{cpa_1_banner_9}" == "true" ? fieldList.push("phone") : "";\r\nvar emailFieldCheckbox = "{cpa_1_banner_10}" == "true" ? fieldList.push("email") : "";\r\nvar textFieldBackGroundColor = "{cpa_1_banner_11}";\r\nvar textFieldBorderColor = "#"+"{cpa_1_banner_12}";\r\n\r\nfieldList.forEach(function(item){\r\n if(item == "name"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'name\' name=\'name\' placeholder=\'Họ và tên\' class=\'input-text input-box-2 input-text-name\'></input><span class=\'tooltiptext\' id=\'tooltipname\'>Họ và tên không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "phone"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'number\' id = \'phone\' placeholder=\'Số điện thoại\' class=\'input-text input-box-2 input-text-phone\'></input><span class=\'tooltiptext\' id=\'tooltipphone\'>Số điện thoại không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n if(item == "email"){\r\n $("#cpa_field_list").append("<tr><td colspan=\'2\' class=\'tooltip\'><input type=\'text\' id=\'email\' placeholder=\'Email\' class=\'input-text input-box-2 input-text-email\' /><span class=\'tooltiptext\' id=\'tooltipemail\'>Email không đúng, xin vui lòng nhập lại!</span></td></tr>");\r\n }\r\n});\r\nif(fieldList.length == 3) {\r\n $(".box-wrapper-2").addClass("three-field-form");\r\n}\r\nvar mInfo = detectDeviceInfo();\r\nvar windowheight = window.innerHeight;\r\nvar browserLang = navigator.language || navigator.userLanguage;\r\nif(browserLang !="vi-VN"){\r\n $("#continue_text").html("<span></span>More</a>");\r\n // $(".wa-button-maxview").addClass("wa-button-en");\r\n $("#continue_scroll").addClass("continue-en");\r\n}\r\nif(textLeftButtonBanner2.length > 0) { $("#btn_left_text2").html(textLeftButtonBanner2); }\r\nif(textRightButtonBanner2.length > 0) { $("#btn_right_text2").html(textRightButtonBanner2); }\r\n$(".btn_left").css({\r\n "background-color": colorCodeLeftButton,\r\n "color": colorTextLeftButton\r\n});\r\n$(".btn_right").css({\r\n "background-color": colorCodeRightButton,\r\n "color": colorTextRightButton\r\n});\r\nif(textFieldBackGroundColor.toLowerCase() == "màu xám") {\r\n $("td > .input-box-2").css("background-color", "#d9d9d9");\r\n}\r\n$("td > .input-box-2").css("border",\'1px solid \' + textFieldBorderColor);\r\n\r\nif(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(\'#continue_text\').css(\'color\', colorCodeLeftButton);\r\n $(\'#continue_text span\').css({\r\n "border-left":"5px solid " + colorCodeLeftButton,\r\n "border-bottom": "5px solid " + colorCodeLeftButton\r\n });\r\n}\r\n\r\n$("#continue_scroll").hide();\r\nfunction startAnimation(){\r\n $(\'#layoutHeader\').hide();\r\n if(mInfo.os == "iOS" || mInfo.os == "Android"){\r\n $(window).off(\'scroll\');\r\n // var footerHeight = ($(\'#wa_hotline\').outerHeight() > 0 ) ? $(\'#wa_hotline\').outerHeight() : 32.4;\r\n // $(\'#cpa-container\').css(\'min-height\', windowheight - footerHeight);\r\n // $(\'#cpa-container\').css(\'background\', colorCodeBody);\r\n setTimeout(function(){continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));}, 750);\r\n $(document).on(\'touchend\', function() {\r\n setTimeout(function()\r\n {\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n });\r\n }\r\n else {\r\n window.onresize = function(event) {\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 3;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+5);\r\n };\r\n setTimeout(function(){\r\n var rightContinue = ($(window).width() - $("#background_img_1").width())/2 - $("#continue_scroll").width() + 5;\r\n $("#continue_scroll").css(\'right\', rightContinue);\r\n $("#continue_scroll.continue-en").css(\'right\', rightContinue+10);\r\n continueScrollHandle($("#wa_hotline")[0], $(\'#continue_scroll\'));\r\n }, 750);\r\n }\r\n}\r\n$(".input-text").focus(function(){\r\n $("#tooltipphone").hide();\r\n $("#tooltipname").hide();\r\n $("#tooltipemail").hide();\r\n remove_error($(\'.input-text\'));\r\n});\r\nfunction goToForm(){\r\n $(\'.box-wrapper\').hide();\r\n $(\'.box-wrapper-2\').show();\r\n $(\'#background_img\').hide();\r\n $(\'#background_img_1\').show();\r\n}\r\nfunction doSubmit(){\r\n var phone = $(\'#phone\').val();\r\n var name = $(\'#name\').val();\r\n var email = $(\'#email\').val();\r\n var valObject = {name: name, phone: phone, email: email};\r\n if (validateDataCustomer(name,phone,email)){\r\n var eventObject = {};\r\n fieldList.forEach(function(item) {\r\n eventObject[item] = valObject[item];\r\n });\r\n postAnalyticEvent("eventcpa",JSON.stringify(eventObject));\r\n nextView();\r\n }\r\n}\r\nfunction validateDataCustomer(name,phone,email){\r\n var validate = true;\r\n if(fieldList.indexOf("name") !== -1){\r\n if ((!name)||(ContainNum(name))){\r\n set_error($(\'#name\'));\r\n set_errortooltip($(\'#tooltipname\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("phone") !== -1){\r\n phone = phone.replace(\'(+84)\', \'0\');\r\n phone = phone.replace(\'+84\', \'0\');\r\n phone = phone.replace(\'0084\', \'0\');\r\n phone = phone.replace(/ /g, \'\');\r\n if (phone != \'\') {\r\n var firstNumber = phone.substring(0, 2);\r\n if ((firstNumber == \'03\' || firstNumber == \'05\' || firstNumber == \'07\' || firstNumber == \'08\' || firstNumber == \'09\') && phone.length == 10) {\r\n if (phone.match(/^\\d{10}/)) {}\r\n } else if (firstNumber == \'01\' && phone.length == 11) {\r\n if (phone.match(/^\\d{11}/)) {}\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n else{\r\n set_error($(\'#phone\'));\r\n set_errortooltip($(\'#tooltipphone\'));\r\n validate = false;\r\n }\r\n }\r\n if(fieldList.indexOf("email") !== -1){\r\n if (email != \'\') {\r\n if (!isEmail(email)){\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n else {\r\n set_error($(\'#email\'));\r\n set_errortooltip($(\'#tooltipemail\'));\r\n validate = false;\r\n }\r\n }\r\n return validate;\r\n}\r\nfunction isEmail(email) {\r\n var regex = /^([a-zA-Z0-9_.+-])+\\@(([a-zA-Z0-9-])+\\.)+([a-zA-Z0-9]{2,4})+$/;\r\n return regex.test(email);\r\n}\r\nfunction ContainNum(t)\r\n{\r\n var regex = /\\d/g;\r\n return regex.test(t);\r\n}\r\nfunction set_error(element){\r\n element.addClass(\'_error\');\r\n}\r\nfunction set_errortooltip(element){\r\n element.show();\r\n}\r\nfunction remove_error(element){\r\n element.removeClass(\'_error\');\r\n}\r\nfunction continueScrollHandle(elm, scroll){\r\n if(checkVisible(elm)) {$(\'#continue_scroll\').hide();}\r\n else {$(\'#continue_scroll\').show();}\r\n}\r\nfunction checkVisible(elm){\r\n var viewHeight = Math.max(document.documentElement.clientHeight, window.innerHeight);\r\n if(elm != "" && elm != undefined){\r\n var rect = elm.getBoundingClientRect();\r\n return !(rect.bottom == 0 || rect.top - viewHeight >= -(rect.height - 12));\r\n }else{\r\n return true;\r\n }\r\n}\r\n</script>',
|
|
127
|
+
templateTypeId: 17,
|
|
128
|
+
validation: '',
|
|
129
|
+
},
|
|
130
|
+
templateParameters: [
|
|
131
|
+
{
|
|
132
|
+
childrens: [],
|
|
133
|
+
defaultValue: '',
|
|
134
|
+
fieldName: 'cpa_1_banner_1',
|
|
135
|
+
fieldType: 'image',
|
|
136
|
+
id: '22302',
|
|
137
|
+
isRequired: true,
|
|
138
|
+
labelName: 'File Banner',
|
|
139
|
+
templateId: '4619609303918768290',
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
childrens: [],
|
|
143
|
+
defaultValue: 'Màu trắng\\nMàu xám',
|
|
144
|
+
fieldName: 'cpa_1_banner_11',
|
|
145
|
+
fieldType: 'dropdownlist',
|
|
146
|
+
id: '22303',
|
|
147
|
+
isRequired: false,
|
|
148
|
+
labelName: 'Mã màu nền trường điền',
|
|
149
|
+
templateId: '4619609303918768290',
|
|
150
|
+
},
|
|
151
|
+
],
|
|
152
|
+
};
|
|
153
|
+
var clientMethod = {
|
|
154
|
+
templatesGetByDirectoryId: function (_id) {
|
|
155
|
+
return Promise.resolve(templates);
|
|
156
|
+
},
|
|
157
|
+
templatesGet: function () { return function (_id) {
|
|
158
|
+
Promise.resolve(templateModel);
|
|
159
|
+
}; },
|
|
160
|
+
};
|
|
161
|
+
// Mock Hooks
|
|
162
|
+
jest.mock('../Hooks', function () { return ({
|
|
163
|
+
__esModule: true,
|
|
164
|
+
default: function () { return ({
|
|
165
|
+
service: {
|
|
166
|
+
templatesGetByDirectoryId: jest.fn(function (_id) {
|
|
167
|
+
return Promise.resolve(clientMethod.templatesGetByDirectoryId(_id));
|
|
168
|
+
}),
|
|
169
|
+
templatesGet: jest.fn(function (_id) {
|
|
170
|
+
return Promise.resolve(clientMethod.templatesGet());
|
|
171
|
+
}),
|
|
172
|
+
},
|
|
173
|
+
}); },
|
|
174
|
+
}); });
|
|
175
|
+
// Mock đa ngữ
|
|
176
|
+
jest.mock('react-i18next', function () { return (__assign(__assign({}, jest.requireActual('react-i18next')), { useTranslation: function () { return ({ t: jest.fn(function (key) { return key; }) }); } })); });
|
|
177
|
+
describe('RowTemplate component', function () {
|
|
178
|
+
var mockProps = {
|
|
179
|
+
pageCode: 'lgn',
|
|
180
|
+
template: { sortOrder: 1 },
|
|
181
|
+
disabledIconDelete: false,
|
|
182
|
+
onChangeRow: jest.fn(),
|
|
183
|
+
onUpdateWizardLogin: jest.fn(),
|
|
184
|
+
directories: directories,
|
|
185
|
+
templateTypes: templateTypes,
|
|
186
|
+
};
|
|
187
|
+
var renderUi = function () { return (0, react_1.render)((0, jsx_runtime_1.jsx)(RowTemplate_1.default, __assign({}, mockProps))); };
|
|
188
|
+
it('renders component', function () {
|
|
189
|
+
renderUi();
|
|
190
|
+
expect(react_1.screen.getByTestId('Common.Name')).toBeInTheDocument();
|
|
191
|
+
expect(react_1.screen.getByTestId('Wizard.Directory')).toBeInTheDocument();
|
|
192
|
+
expect(react_1.screen.getByTestId('Common.TypeTemplate')).toBeInTheDocument();
|
|
193
|
+
expect(react_1.screen.getByTestId('Wizard.SelectTemplate')).toBeInTheDocument();
|
|
194
|
+
expect(react_1.screen.getByTestId('Wizard.FieldNames')).toBeInTheDocument();
|
|
195
|
+
expect(react_1.screen.getByTestId('deleteIcon')).toBeInTheDocument();
|
|
196
|
+
});
|
|
197
|
+
it('check handleDeleteRowTemplate', function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
198
|
+
var deleteIcon;
|
|
199
|
+
return __generator(this, function (_a) {
|
|
200
|
+
switch (_a.label) {
|
|
201
|
+
case 0:
|
|
202
|
+
renderUi();
|
|
203
|
+
deleteIcon = react_1.screen.getByTestId('deleteIcon');
|
|
204
|
+
react_1.fireEvent.click(deleteIcon);
|
|
205
|
+
return [4 /*yield*/, (0, react_1.waitFor)(function () {
|
|
206
|
+
expect(mockProps.onUpdateWizardLogin).toHaveBeenCalledWith(Utils_1.TYPE_LOGIN_TEMPLATE.REMOVE, 1);
|
|
207
|
+
})];
|
|
208
|
+
case 1:
|
|
209
|
+
_a.sent();
|
|
210
|
+
return [2 /*return*/];
|
|
211
|
+
}
|
|
212
|
+
});
|
|
213
|
+
}); });
|
|
214
|
+
it('check handleChange', function () {
|
|
215
|
+
renderUi();
|
|
216
|
+
react_1.fireEvent.change(react_1.screen.getByRole('textbox', { name: /Common.Name/i }), {
|
|
217
|
+
target: { value: 'test1' },
|
|
218
|
+
});
|
|
219
|
+
});
|
|
220
|
+
it('check handleChange combobox directories', function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
221
|
+
var templatesGetByDirectoryIdSpy;
|
|
222
|
+
return __generator(this, function (_a) {
|
|
223
|
+
switch (_a.label) {
|
|
224
|
+
case 0:
|
|
225
|
+
templatesGetByDirectoryIdSpy = jest.spyOn(clientMethod, 'templatesGetByDirectoryId');
|
|
226
|
+
renderUi();
|
|
227
|
+
// Tên Thư Mục
|
|
228
|
+
return [4 /*yield*/, (0, react_1.waitFor)(function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
229
|
+
var selectContainer, comboBox;
|
|
230
|
+
return __generator(this, function (_a) {
|
|
231
|
+
switch (_a.label) {
|
|
232
|
+
case 0:
|
|
233
|
+
selectContainer = react_1.screen.getByTestId('Wizard.Directory');
|
|
234
|
+
return [4 /*yield*/, (0, react_1.within)(selectContainer).findByRole('combobox')];
|
|
235
|
+
case 1:
|
|
236
|
+
comboBox = _a.sent();
|
|
237
|
+
if (comboBox) {
|
|
238
|
+
react_1.fireEvent.mouseDown(comboBox);
|
|
239
|
+
react_1.screen.getAllByText('SYSTEM TEMPLATE').forEach(function (el) {
|
|
240
|
+
react_1.fireEvent.click(el);
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
return [2 /*return*/];
|
|
244
|
+
}
|
|
245
|
+
});
|
|
246
|
+
}); })];
|
|
247
|
+
case 1:
|
|
248
|
+
// Tên Thư Mục
|
|
249
|
+
_a.sent();
|
|
250
|
+
expect(templatesGetByDirectoryIdSpy).toHaveBeenCalledWith(directories[0].directoryId);
|
|
251
|
+
return [2 /*return*/];
|
|
252
|
+
}
|
|
253
|
+
});
|
|
254
|
+
}); });
|
|
255
|
+
});
|