awing-library 2.1.145-beta → 2.1.145

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (213) hide show
  1. package/lib/ACM-AXN/AuthenticationProfile/Container.js +4 -4
  2. package/lib/ACM-AXN/AuthenticationProfile/CreateOrEdit/index.js +2 -2
  3. package/lib/ACM-AXN/Campaign/Container.js +52 -54
  4. package/lib/ACM-AXN/Campaign/Container.test.js +1 -3
  5. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.d.ts +8 -1
  6. package/lib/ACM-AXN/Campaign/CreateOrEdit/Recoils.js +27 -3
  7. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.d.ts +17 -0
  8. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.js +121 -0
  9. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.d.ts +1 -0
  10. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RowTable.test.js +219 -0
  11. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.d.ts +2 -0
  12. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.js +306 -0
  13. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.d.ts +1 -0
  14. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/RunInBackground.test.js +230 -0
  15. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.d.ts +1 -0
  16. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.js +123 -0
  17. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.d.ts +1 -0
  18. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabApprove/index.test.js +253 -0
  19. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabInfomation.js +21 -5
  20. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.d.ts +1 -1
  21. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabPartner.js +47 -78
  22. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.d.ts +2 -1
  23. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/ChartWithType.js +2 -2
  24. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/ControlPanel.js +2 -1
  25. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Detail/index.js +2 -1
  26. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.d.ts +19 -42
  27. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/Utils.js +298 -96
  28. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.d.ts +3 -0
  29. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Analytic/container.js +119 -54
  30. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.d.ts +1 -1
  31. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/ChartFilter.js +46 -8
  32. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/component.js +8 -6
  33. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Customer/container.js +1 -1
  34. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.d.ts +9 -0
  35. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/PasswordDialog.js +56 -0
  36. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Table.js +5 -1
  37. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.d.ts +12 -0
  38. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/Util.js +23 -8
  39. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/component.js +3 -3
  40. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Event/container.js +63 -12
  41. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.d.ts +1 -0
  42. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/SplitButtonExportType.js +17 -4
  43. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Types.d.ts +10 -0
  44. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/Utils.js +4 -1
  45. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.d.ts +1 -0
  46. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/common.js +3 -2
  47. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/component.js +6 -2
  48. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabStatistic/container.js +31 -29
  49. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdList.js +1 -1
  50. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AdRow.js +1 -1
  51. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/AddOrEditRule/RuleForm/TargetOS/container.js +2 -2
  52. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/Advanced.js +1 -1
  53. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/EditAds.js +5 -5
  54. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.js +44 -33
  55. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignDetail.test.js +3 -13
  56. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/SubCampaignList.js +45 -20
  57. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/atoms.js +3 -2
  58. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/index.js +3 -2
  59. package/lib/ACM-AXN/Campaign/CreateOrEdit/TabSubCampaign/useSearchPage.js +33 -8
  60. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.d.ts +5 -1
  61. package/lib/ACM-AXN/Campaign/CreateOrEdit/index.js +172 -59
  62. package/lib/ACM-AXN/Campaign/Enum.d.ts +24 -6
  63. package/lib/ACM-AXN/Campaign/Enum.js +30 -11
  64. package/lib/ACM-AXN/Campaign/Types.d.ts +53 -5
  65. package/lib/ACM-AXN/Campaign/Utils.d.ts +6 -1
  66. package/lib/ACM-AXN/Campaign/Utils.js +50 -3
  67. package/lib/ACM-AXN/Campaign/index.js +2 -2
  68. package/lib/ACM-AXN/CampaignPlan/Container.js +4 -6
  69. package/lib/ACM-AXN/CampaignPlan/Detail.js +3 -3
  70. package/lib/ACM-AXN/CampaignPlan/Filter.js +3 -3
  71. package/lib/ACM-AXN/CampaignSchedule/Components/ControlPanel/Filter.js +14 -10
  72. package/lib/ACM-AXN/CampaignSchedule/Components/EnhancedPagination/index.js +3 -2
  73. package/lib/ACM-AXN/CampaignSchedule/Components/RowAdvance/component.js +6 -4
  74. package/lib/ACM-AXN/CampaignSchedule/DataConfig.js +4 -4
  75. package/lib/ACM-AXN/CampaignSchedule/DataConfigAXN.js +5 -4
  76. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.d.ts +1 -2
  77. package/lib/ACM-AXN/CampaignSchedule/Recoil/Atom.js +1 -5
  78. package/lib/ACM-AXN/Common/Constant.d.ts +3 -0
  79. package/lib/ACM-AXN/Common/Constant.js +2 -0
  80. package/lib/ACM-AXN/Common/Enum.d.ts +8 -3
  81. package/lib/ACM-AXN/Common/Enum.js +19 -4
  82. package/lib/ACM-AXN/Common/Types.d.ts +5 -0
  83. package/lib/ACM-AXN/GeoFencing/GoongMap/index.d.ts +8 -9
  84. package/lib/ACM-AXN/GeoFencing/component.js +7 -7
  85. package/lib/ACM-AXN/GeoFencing/interface.d.ts +1 -2
  86. package/lib/ACM-AXN/Holiday/FormHoliday.js +1 -0
  87. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.d.ts +0 -5
  88. package/lib/ACM-AXN/Notifications/NotificationPopover/Container.js +7 -90
  89. package/lib/ACM-AXN/Notifications/NotificationPopover/index.d.ts +0 -5
  90. package/lib/ACM-AXN/Notifications/Types.d.ts +2 -0
  91. package/lib/ACM-AXN/Page/Constant.js +2 -0
  92. package/lib/ACM-AXN/Page/Container.js +3 -3
  93. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.d.ts +6 -0
  94. package/lib/ACM-AXN/Page/CreateOrEdit/ListenTemplate.js +63 -0
  95. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.d.ts +11 -2
  96. package/lib/ACM-AXN/Page/CreateOrEdit/Recoil.js +16 -12
  97. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/TrackingCode.js +1 -1
  98. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/Utils.js +1 -1
  99. package/lib/ACM-AXN/Page/CreateOrEdit/TabInfo/index.js +1 -0
  100. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.d.ts +1 -9
  101. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/Components/Panel.js +0 -9
  102. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewContent.js +11 -44
  103. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.d.ts +2 -3
  104. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/ViewInfo.js +39 -61
  105. package/lib/ACM-AXN/Page/CreateOrEdit/Tabview/index.js +29 -32
  106. package/lib/ACM-AXN/Page/CreateOrEdit/Utils.js +6 -6
  107. package/lib/ACM-AXN/Page/CreateOrEdit/index.js +19 -4
  108. package/lib/ACM-AXN/Page/Import/index.js +2 -2
  109. package/lib/ACM-AXN/Page/Types.d.ts +3 -0
  110. package/lib/ACM-AXN/Page/enums.d.ts +5 -0
  111. package/lib/ACM-AXN/Page/enums.js +7 -1
  112. package/lib/ACM-AXN/Permission/Components/Styles.d.ts +1 -2
  113. package/lib/ACM-AXN/PlaceFilter/DataTable/component/index.js +2 -5
  114. package/lib/ACM-AXN/PlaceFilter/Input/component/index.js +1 -2
  115. package/lib/ACM-AXN/PlaceFilter/Tag/component/TagChip.js +1 -1
  116. package/lib/ACM-AXN/PlaceFilter/interface.d.ts +1 -0
  117. package/lib/ACM-AXN/ScheduleCompletionRate/Container.js +16 -16
  118. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.d.ts +14 -9
  119. package/lib/ACM-AXN/ScheduleCompletionRate/DataSetConfig.js +19 -18
  120. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRate.js +16 -6
  121. package/lib/ACM-AXN/ScheduleCompletionRate/Detail/CompletionRateDate.js +17 -10
  122. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.d.ts +2 -1
  123. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.js +30 -51
  124. package/lib/ACM-AXN/ScheduleCompletionRate/Filter.test.js +1 -1
  125. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.d.ts +2 -2
  126. package/lib/ACM-AXN/ScheduleCompletionRate/SearchCampaign.js +3 -9
  127. package/lib/ACM-AXN/ScheduleCompletionRate/Types.d.ts +16 -36
  128. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.d.ts +5 -5
  129. package/lib/ACM-AXN/ScheduleCompletionRate/Utils.js +13 -10
  130. package/lib/ACM-AXN/Statistics/ControlPanel.js +17 -5
  131. package/lib/ACM-AXN/Statistics/Enums.d.ts +2 -1
  132. package/lib/ACM-AXN/Statistics/Enums.js +1 -0
  133. package/lib/ACM-AXN/StatisticsAudienceDemographic/Tabs/AgeRange.js +1 -0
  134. package/lib/ACM-AXN/StatisticsByProvince/DataTable.js +1 -1
  135. package/lib/ACM-AXN/TaskScheduler/CreateOrEdit.js +4 -4
  136. package/lib/ACM-AXN/Template/Container.js +2 -2
  137. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.d.ts +1 -0
  138. package/lib/ACM-AXN/Template/CreateOrEdit/Recoils.js +5 -1
  139. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.d.ts +2 -2
  140. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.js +56 -37
  141. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.d.ts +1 -1
  142. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Parameter.test.js +62 -51
  143. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.d.ts +28 -4
  144. package/lib/ACM-AXN/Template/CreateOrEdit/Template/Utils.js +43 -15
  145. package/lib/ACM-AXN/Template/CreateOrEdit/index.js +8 -4
  146. package/lib/ACM-AXN/Template/Import.js +2 -2
  147. package/lib/ACM-AXN/Template/Types.d.ts +9 -9
  148. package/lib/ACM-AXN/TransactionLog/Detail.js +1 -1
  149. package/lib/ACM-AXN/ViewTemplate/Preview.js +5 -6
  150. package/lib/ACM-AXN/ViewTemplate/TemplateField/Event.js +23 -11
  151. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.d.ts +18 -0
  152. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/Utils.js +170 -0
  153. package/lib/ACM-AXN/ViewTemplate/TemplateField/Fields/BasicField/index.js +42 -129
  154. package/lib/ACM-AXN/ViewTemplate/common.d.ts +2 -1
  155. package/lib/ACM-AXN/ViewTemplate/common.js +47 -7
  156. package/lib/ACM-AXN/ViewTemplate/container.js +8 -2
  157. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.d.ts +3 -1
  158. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.js +18 -28
  159. package/lib/ACM-AXN/Wizard/CreateOrEdit/PageTemplate.test.js +2 -0
  160. package/lib/ACM-AXN/Wizard/CreateOrEdit/RowTemplate.js +1 -1
  161. package/lib/ACM-AXN/Wizard/CreateOrEdit/index.js +17 -1
  162. package/lib/ACM-AXN/index.d.ts +1 -0
  163. package/lib/ACM-AXN/index.js +1 -0
  164. package/lib/AWING/AsyncAutocomplete/index.js +2 -2
  165. package/lib/AWING/BasicDataForm/BasicDataForm.js +9 -6
  166. package/lib/AWING/BasicDataForm/interface.d.ts +3 -0
  167. package/lib/AWING/Chart/BarLineComponent.js +20 -24
  168. package/lib/AWING/Chart/PieComponent.d.ts +3 -4
  169. package/lib/AWING/Chart/PieComponent.js +16 -16
  170. package/lib/AWING/Chart/Styles.js +51 -16
  171. package/lib/AWING/DataForm/DataInput.js +105 -23
  172. package/lib/AWING/DataForm/interface.d.ts +2 -0
  173. package/lib/AWING/DataGrid/index.js +8 -13
  174. package/lib/AWING/DateRangePicker/component.js +80 -32
  175. package/lib/AWING/DateRangePicker/configDate.d.ts +1 -2
  176. package/lib/AWING/DateRangePicker/configDate.js +12 -12
  177. package/lib/AWING/DateRangePicker/interface.d.ts +1 -0
  178. package/lib/AWING/Form/useForm.js +3 -2
  179. package/lib/AWING/GoogleMap/GGMap.d.ts +3 -0
  180. package/lib/AWING/GoogleMap/GGMap.js +256 -0
  181. package/lib/AWING/GoogleMap/index.d.ts +4 -0
  182. package/lib/AWING/GoogleMap/index.js +41 -0
  183. package/lib/AWING/GoogleMap/interface.d.ts +21 -0
  184. package/lib/AWING/GoogleMap/interface.js +2 -0
  185. package/lib/AWING/GoogleMap/utils.d.ts +25 -0
  186. package/lib/AWING/GoogleMap/utils.js +135 -0
  187. package/lib/AWING/GroupTable/GroupTable.js +2 -2
  188. package/lib/AWING/GroupTable/component.d.ts +1 -0
  189. package/lib/AWING/GroupTable/component.js +2 -2
  190. package/lib/AWING/NumberFormat/index.d.ts +3 -1
  191. package/lib/AWING/NumberFormat/index.js +2 -2
  192. package/lib/AWING/PageManagement/PageManagement.js +4 -3
  193. package/lib/AWING/Pagination/index.js +11 -3
  194. package/lib/AWING/index.d.ts +1 -0
  195. package/lib/AWING/index.js +1 -0
  196. package/lib/AWING/ultis/validation.d.ts +1 -0
  197. package/lib/AWING/ultis/validation.js +25 -6
  198. package/lib/Commons/Components/ClassicDrawer.js +5 -4
  199. package/lib/Commons/Components/HighlightedCode/MarkdownElement.js +6 -1
  200. package/lib/Commons/Hooks/usePath.js +3 -3
  201. package/lib/Utils/Helpers.d.ts +3 -2
  202. package/lib/Utils/Helpers.js +50 -14
  203. package/lib/i18n.js +31 -2
  204. package/lib/translate/en/translation.json +131 -71
  205. package/lib/translate/id/translation.json +893 -0
  206. package/lib/translate/ind/translation.json +893 -0
  207. package/lib/translate/ja/translation.json +893 -0
  208. package/lib/translate/lao/translation.json +893 -0
  209. package/lib/translate/mys/translation.json +893 -0
  210. package/lib/translate/phl/translation.json +893 -0
  211. package/lib/translate/th/translation.json +893 -0
  212. package/lib/translate/vi/translation.json +91 -31
  213. package/package.json +9 -4
@@ -10,6 +10,29 @@ var __assign = (this && this.__assign) || function () {
10
10
  };
11
11
  return __assign.apply(this, arguments);
12
12
  };
13
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ var desc = Object.getOwnPropertyDescriptor(m, k);
16
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
17
+ desc = { enumerable: true, get: function() { return m[k]; } };
18
+ }
19
+ Object.defineProperty(o, k2, desc);
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
13
36
  var __rest = (this && this.__rest) || function (s, e) {
14
37
  var t = {};
15
38
  for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
@@ -28,7 +51,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
28
51
  var react_1 = require("react");
29
52
  var jsx_runtime_1 = require("react/jsx-runtime");
30
53
  // @ts-nocheck
31
- var react_2 = __importDefault(require("react"));
54
+ var react_2 = __importStar(require("react"));
32
55
  var moment_1 = __importDefault(require("moment"));
33
56
  var react_i18next_1 = require("react-i18next");
34
57
  var material_1 = require("@mui/material");
@@ -41,16 +64,25 @@ var AsyncAutocomplete_1 = __importDefault(require("../../AWING/AsyncAutocomplete
41
64
  var LogicExpression_1 = __importDefault(require("../../AWING/LogicExpression"));
42
65
  var GeoFencing_1 = __importDefault(require("../../ACM-AXN/GeoFencing"));
43
66
  var i18n_1 = __importDefault(require("../../i18n"));
67
+ var icons_material_1 = require("@mui/icons-material");
44
68
  var omit = require('lodash/omit');
45
69
  function DataInput(props) {
46
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
70
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
47
71
  var t = (0, react_i18next_1.useTranslation)(undefined, { i18n: i18n_1.default }).t;
48
72
  var fieldDefinition = props.fieldDefinition, onChange = props.onChange, value = props.value, error = props.error, disableHelperText = props.disableHelperText;
49
73
  var fieldName = fieldDefinition.fieldName, type = fieldDefinition.type, onValidate = fieldDefinition.onValidate, min = fieldDefinition.min, max = fieldDefinition.max, pattern = fieldDefinition.pattern, other = __rest(fieldDefinition, ["fieldName", "type", "onValidate", "min", "max", "pattern"]);
50
- var _k = react_2.default.useState(t('Common.InvalidData')), errorText = _k[0], setErrorText = _k[1];
74
+ var _o = react_2.default.useState(t('Common.InvalidData')), errorText = _o[0], setErrorText = _o[1];
75
+ var _p = react_2.default.useState(type === 'number' ? value : ''), numberValue = _p[0], setNumberValue = _p[1];
76
+ var _q = react_2.default.useState(false), showPassword = _q[0], setShowPassword = _q[1];
77
+ var handleClickShowPassword = function () {
78
+ setShowPassword(!showPassword);
79
+ };
51
80
  var checkValidationValue = function (fieldDefinition, val) {
52
81
  if (!fieldDefinition.required &&
53
- (val === undefined || val === null || val === '' || (Array.isArray(val) && val.length === 0)))
82
+ (val === undefined ||
83
+ val === null ||
84
+ val === '' ||
85
+ (Array.isArray(val) && val.length === 0)))
54
86
  return true;
55
87
  if (fieldDefinition.onValidate)
56
88
  return fieldDefinition.onValidate(val, fieldDefinition === null || fieldDefinition === void 0 ? void 0 : fieldDefinition.length, fieldDefinition === null || fieldDefinition === void 0 ? void 0 : fieldDefinition.pattern);
@@ -94,6 +126,18 @@ function DataInput(props) {
94
126
  return (0, validation_1.notNullValid)(val);
95
127
  }
96
128
  };
129
+ (0, react_2.useEffect)(function () {
130
+ if (type === 'number' && Number(value) !== Number(numberValue))
131
+ setNumberValue(Number(value));
132
+ // eslint-disable-next-line react-hooks/exhaustive-deps
133
+ }, [type, value]);
134
+ var handleParamValueChange = function () {
135
+ var newValue = Number(numberValue);
136
+ setNumberValue(newValue);
137
+ if (type === 'number' && Number(value) !== newValue) {
138
+ onChange(newValue, checkValidationValue(fieldDefinition, newValue));
139
+ }
140
+ };
97
141
  switch (type) {
98
142
  case 'logic-expression': {
99
143
  return ((0, jsx_runtime_1.jsx)(LogicExpression_1.default, __assign({ cf: function (newValue, valid) {
@@ -108,6 +152,7 @@ function DataInput(props) {
108
152
  : '' }) }));
109
153
  }
110
154
  case 'autocomplete': {
155
+ var autocompleteValue_1 = (_b = fieldDefinition.value) !== null && _b !== void 0 ? _b : value;
111
156
  return ((0, jsx_runtime_1.jsx)(material_1.Autocomplete, { multiple: fieldDefinition.multiple, options: fieldDefinition.options, getOptionLabel: function (option) { var _a, _b; return (_b = (_a = option.label) !== null && _a !== void 0 ? _a : option.text) !== null && _b !== void 0 ? _b : ''; }, isOptionEqualToValue: function (option, value) {
112
157
  return (option === null || option === void 0 ? void 0 : option.value) === (value === null || value === void 0 ? void 0 : value.value);
113
158
  }, getOptionKey: function (option) { return option.value; }, disableclearable: fieldDefinition.disableClearable, getOptionDisabled: function (option) { return option === null || option === void 0 ? void 0 : option.disabled; }, onChange: function (e, value) {
@@ -117,9 +162,11 @@ function DataInput(props) {
117
162
  onChange(newValue, checkValidationValue(fieldDefinition, newValue));
118
163
  }, value: fieldDefinition.multiple
119
164
  ? fieldDefinition.options.filter(function (x) {
120
- return (value !== null && value !== void 0 ? value : []).includes(x.value);
165
+ return (autocompleteValue_1 !== null && autocompleteValue_1 !== void 0 ? autocompleteValue_1 : []).includes(x.value);
121
166
  })
122
- : fieldDefinition.options.find(function (x) { return x.value === value; }) || null, clearOnEscape: true, fullWidth: true, disableCloseOnSelect: fieldDefinition.multiple, readOnly: fieldDefinition.readOnly, renderInput: function (params) {
167
+ : (_c = fieldDefinition.options.find(function (x) {
168
+ return x.value === autocompleteValue_1;
169
+ })) !== null && _c !== void 0 ? _c : '', clearOnEscape: true, fullWidth: true, disableCloseOnSelect: fieldDefinition.multiple, readOnly: fieldDefinition.readOnly, renderInput: function (params) {
123
170
  var _a;
124
171
  return ((0, jsx_runtime_1.jsx)(material_1.TextField, __assign({}, params, other, { variant: "standard", error: error, helperText: !disableHelperText && error
125
172
  ? (_a = fieldDefinition.helperText) !== null && _a !== void 0 ? _a : t('Common.InvalidData')
@@ -134,7 +181,7 @@ function DataInput(props) {
134
181
  : undefined }));
135
182
  }
136
183
  case 'checkbox': {
137
- return ((0, jsx_runtime_1.jsx)(material_1.FormControl, { fullWidth: true, children: (0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { id: fieldName.toString(), name: fieldName.toString(), checked: value, onChange: function (event) {
184
+ return ((0, jsx_runtime_1.jsx)(material_1.FormControl, { fullWidth: true, children: (0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { disabled: (_d = fieldDefinition.disabled) !== null && _d !== void 0 ? _d : false, id: fieldName.toString(), name: fieldName.toString(), checked: value, onChange: function (event) {
138
185
  return onChange(event.target.checked, checkValidationValue(fieldDefinition, event.target.checked));
139
186
  }, color: "primary", readOnly: fieldDefinition.readOnly }), label: fieldDefinition.label }) }));
140
187
  }
@@ -143,7 +190,7 @@ function DataInput(props) {
143
190
  return onChange(date === null || date === void 0 ? void 0 : date.toDate(), checkValidationValue(fieldDefinition, date === null || date === void 0 ? void 0 : date.toDate()));
144
191
  }, readOnly: fieldDefinition.readOnly, slotProps: {
145
192
  textField: __assign(__assign({ required: fieldDefinition.required, fullWidth: true, variant: 'standard' }, other), { error: error, helperText: !disableHelperText && error
146
- ? (_b = fieldDefinition.helperText) !== null && _b !== void 0 ? _b : t('Common.InvalidData')
193
+ ? (_e = fieldDefinition.helperText) !== null && _e !== void 0 ? _e : t('Common.InvalidData')
147
194
  : '' }),
148
195
  } }));
149
196
  }
@@ -152,12 +199,12 @@ function DataInput(props) {
152
199
  return onChange(date === null || date === void 0 ? void 0 : date.toDate(), checkValidationValue(fieldDefinition, date === null || date === void 0 ? void 0 : date.toDate()));
153
200
  }, slotProps: {
154
201
  textField: __assign(__assign({ required: fieldDefinition.required, fullWidth: true, variant: 'standard' }, other), { error: error, helperText: !disableHelperText && error
155
- ? (_c = fieldDefinition.helperText) !== null && _c !== void 0 ? _c : t('Common.InvalidData')
202
+ ? (_f = fieldDefinition.helperText) !== null && _f !== void 0 ? _f : t('Common.InvalidData')
156
203
  : '' }),
157
204
  }, readOnly: fieldDefinition.readOnly }));
158
205
  }
159
206
  case 'date-range': {
160
- var _l = other, isDayBlocked = _l.isDayBlocked, isOutsideRange = _l.isOutsideRange;
207
+ var _r = other, isDayBlocked = _r.isDayBlocked, isOutsideRange = _r.isOutsideRange;
161
208
  return ((0, jsx_runtime_1.jsx)(AWING_1.DateRangePicker, { noBorder: true, variant: "standard", textFieldProps: __assign({ fullWidth: true, style: { margin: '8px 0px' } }, omit(other, ['isDayBlocked', 'isOutsideRange'])), value: {
162
209
  startDate: (value === null || value === void 0 ? void 0 : value[0]) || null,
163
210
  endDate: (value === null || value === void 0 ? void 0 : value[1]) || null,
@@ -165,15 +212,16 @@ function DataInput(props) {
165
212
  var newValue = [dateRange.startDate, dateRange.endDate];
166
213
  onChange(newValue, checkValidationValue(fieldDefinition, newValue));
167
214
  }, label: fieldDefinition.label, error: error, helperText: !disableHelperText && error
168
- ? (_d = fieldDefinition.helperText) !== null && _d !== void 0 ? _d : t('Common.InvalidData')
215
+ ? (_g = fieldDefinition.helperText) !== null && _g !== void 0 ? _g : t('Common.InvalidData')
169
216
  : '', disableHelperText: disableHelperText, isDayBlocked: isDayBlocked, isOutsideRange: isOutsideRange }));
170
217
  }
171
218
  case 'number': {
172
- return ((0, jsx_runtime_1.jsx)(AWING_1.NumberFormat, __assign({ id: fieldName.toString(), name: fieldName.toString(), fullWidth: true, variant: "standard" }, other, { value: value !== null && value !== void 0 ? value : '', onChange: function (event) {
173
- var newValue = Number(event.target.value);
174
- onChange(newValue, checkValidationValue(fieldDefinition, newValue));
175
- }, error: error, helperText: !disableHelperText && error
176
- ? (_e = fieldDefinition.helperText) !== null && _e !== void 0 ? _e : t('Common.InvalidData')
219
+ return ((0, jsx_runtime_1.jsx)(AWING_1.NumberFormat, __assign({ id: fieldName.toString(), name: fieldName.toString(), fullWidth: true, variant: "standard" }, other, { value: numberValue !== null && numberValue !== void 0 ? numberValue : '', onChange: function (event) {
220
+ var newValue = event.target.value;
221
+ setNumberValue(newValue);
222
+ onChange(Number(newValue), checkValidationValue(fieldDefinition, Number(newValue)));
223
+ }, onBlur: handleParamValueChange, error: error, helperText: !disableHelperText && error
224
+ ? (_h = fieldDefinition.helperText) !== null && _h !== void 0 ? _h : t('Common.InvalidData')
177
225
  : '' })));
178
226
  }
179
227
  case 'radio': {
@@ -188,19 +236,19 @@ function DataInput(props) {
188
236
  case 'text':
189
237
  case 'text-area': {
190
238
  return ((0, jsx_runtime_1.jsx)(material_1.TextField, __assign({ id: fieldName.toString(), name: fieldName.toString(), type: 'text', fullWidth: true, variant: "standard", multiline: fieldDefinition.type === 'text-area', error: error, helperText: !disableHelperText && error
191
- ? (_f = fieldDefinition.helperText) !== null && _f !== void 0 ? _f : errorText
239
+ ? (_j = fieldDefinition.helperText) !== null && _j !== void 0 ? _j : errorText
192
240
  : '' }, other, { value: value !== null && value !== void 0 ? value : '', onChange: function (event) {
193
241
  return onChange(event.target.value, checkValidationValue(fieldDefinition, event.target.value));
194
242
  } })));
195
243
  }
196
244
  case 'select': {
197
- return ((0, jsx_runtime_1.jsxs)(material_1.TextField, __assign({ id: fieldName.toString(), name: fieldName.toString(), fullWidth: true, select: true, variant: "standard", value: value !== null && value !== void 0 ? value : "", onChange: function (event) {
245
+ return ((0, jsx_runtime_1.jsxs)(material_1.TextField, __assign({ id: fieldName.toString(), name: fieldName.toString(), fullWidth: true, select: true, variant: "standard", value: value !== null && value !== void 0 ? value : '', onChange: function (event) {
198
246
  var newValue = fieldDefinition.multiple
199
247
  ? event.target.value.split(',')
200
248
  : event.target.value;
201
249
  onChange(event.target.value, checkValidationValue(fieldDefinition, newValue));
202
250
  }, error: error, helperText: !disableHelperText && error
203
- ? (_g = fieldDefinition.helperText) !== null && _g !== void 0 ? _g : t('Common.InvalidData')
251
+ ? (_k = fieldDefinition.helperText) !== null && _k !== void 0 ? _k : t('Common.InvalidData')
204
252
  : '' }, other, { children: [!fieldDefinition.required && ((0, jsx_runtime_1.jsx)(material_1.MenuItem, { value: "", children: (0, jsx_runtime_1.jsx)("em", { children: t('Common.None') }) })), fieldDefinition.options.map(function (item, index) {
205
253
  var _a;
206
254
  return ((0, jsx_runtime_1.jsx)(material_1.MenuItem, __assign({ value: item.value, disabled: item.disabled ||
@@ -214,7 +262,7 @@ function DataInput(props) {
214
262
  return ((0, jsx_runtime_1.jsx)(AWING_1.MultipleHierarchicalChoice, __assign({}, fieldDefinition, { variant: "standard", value: value, onChange: function (value) {
215
263
  onChange(value, checkValidationValue(fieldDefinition, value));
216
264
  }, error: error, helperText: !disableHelperText && error
217
- ? (_h = fieldDefinition.helperText) !== null && _h !== void 0 ? _h : t('Common.InvalidData')
265
+ ? (_l = fieldDefinition.helperText) !== null && _l !== void 0 ? _l : t('Common.InvalidData')
218
266
  : '' })));
219
267
  }
220
268
  case 'geo-fencing': {
@@ -224,10 +272,44 @@ function DataInput(props) {
224
272
  } }) }));
225
273
  }
226
274
  default: {
227
- return ((0, jsx_runtime_1.jsx)(material_1.TextField, __assign({ id: fieldName.toString(), name: fieldName.toString(), type: fieldDefinition.type, fullWidth: true, variant: "standard" }, other, { value: value !== null && value !== void 0 ? value : '', onChange: function (event) {
275
+ return ((0, jsx_runtime_1.jsx)(material_1.TextField, __assign({ id: fieldName.toString(), name: fieldName.toString(), type: showPassword ? 'text' : fieldDefinition.type, fullWidth: true, variant: "standard" }, other, { value: value !== null && value !== void 0 ? value : '', onChange: function (event) {
228
276
  return onChange(event.target.value, checkValidationValue(fieldDefinition, event.target.value));
229
- }, error: error, helperText: !disableHelperText && error
230
- ? (_j = fieldDefinition.helperText) !== null && _j !== void 0 ? _j : t('Common.InvalidData')
277
+ }, autoComplete: "new-password", InputProps: fieldDefinition.type === 'password'
278
+ ? {
279
+ endAdornment: ((0, jsx_runtime_1.jsxs)(material_1.InputAdornment, { position: "end", children: [(0, jsx_runtime_1.jsx)(material_1.IconButton, { "aria-label": "toggle password visibility", onClick: handleClickShowPassword, edge: "end", disabled: fieldDefinition.disabled, children: showPassword ? ((0, jsx_runtime_1.jsx)(icons_material_1.VisibilityOff, {})) : ((0, jsx_runtime_1.jsx)(icons_material_1.Visibility, {})) }), (0, jsx_runtime_1.jsx)(material_1.Button, { size: "small", variant: "outlined", onClick: function () {
280
+ var password = fieldDefinition.onGeneratePassword();
281
+ onChange(password, checkValidationValue(fieldDefinition, password));
282
+ if (!showPassword)
283
+ setShowPassword(true);
284
+ }, disabled: !fieldDefinition.onGeneratePassword ||
285
+ fieldDefinition.disabled, sx: {
286
+ height: '24px',
287
+ fontSize: 14,
288
+ lineHeight: 1.5,
289
+ marginRight: '0px',
290
+ marginLeft: '8px',
291
+ marginBottom: '2px',
292
+ color: '#0000008a',
293
+ borderColor: '#0000008a',
294
+ '&:hover': {
295
+ boxShadow: 'none',
296
+ borderColor: '#0000008a',
297
+ backgroundColor: 'unset',
298
+ },
299
+ '&:active': {
300
+ boxShadow: 'none',
301
+ borderColor: '#0000008a',
302
+ backgroundColor: 'unset',
303
+ },
304
+ '&:focus': {
305
+ boxShadow: 'none',
306
+ borderColor: '#0000008a',
307
+ backgroundColor: 'unset',
308
+ },
309
+ }, children: t('Campaign.Password.AutoGenerate') })] })),
310
+ }
311
+ : undefined, error: error, helperText: !disableHelperText && error
312
+ ? (_m = fieldDefinition.helperText) !== null && _m !== void 0 ? _m : t('Common.InvalidData')
231
313
  : '' })));
232
314
  }
233
315
  }
@@ -68,6 +68,7 @@ export interface NumberFieldDefinition<T extends DataObject> extends BaseFieldDe
68
68
  onValidate?(value?: number): boolean;
69
69
  defaultValue?: number;
70
70
  autoFormula?: string;
71
+ isFloat?: boolean;
71
72
  min?: number;
72
73
  max?: number;
73
74
  }
@@ -97,6 +98,7 @@ export interface TextFieldDefinition<T extends DataObject> extends BaseFieldDefi
97
98
  onValidate?(value?: string, length?: number, pattern?: RegExp | false): boolean;
98
99
  defaultValue?: string;
99
100
  autoFormula?: string;
101
+ onGeneratePassword?: () => void;
100
102
  }
101
103
  export interface LogicExpressionDefinition<T extends DataObject> extends BaseFieldDefinition<T> {
102
104
  type: 'logic-expression';
@@ -38,7 +38,8 @@ var NoData_1 = __importDefault(require("../NoData"));
38
38
  var constants_1 = require("../constants");
39
39
  var Helpers_1 = require("../../Utils/Helpers");
40
40
  var get_1 = __importDefault(require("../Form/Utils/get"));
41
- var i18n_1 = __importDefault(require("../../i18n"));
41
+ var lodash_1 = require("lodash");
42
+ var Constant_1 = require("../../ACM-AXN/Common/Constant");
42
43
  var StyledTableRow = (0, styles_1.styled)(material_1.TableRow)({
43
44
  '& .MuiTableCell-root:last-child .MuiButtonBase-root': {
44
45
  visibility: 'hidden',
@@ -74,13 +75,6 @@ var SpanSortIndex = (0, styles_1.styled)('span')({
74
75
  });
75
76
  var DataGrid = function (props) {
76
77
  var columns = props.columns, rows = props.rows, _a = props.hideHeader, hideHeader = _a === void 0 ? false : _a, spanningRows = props.spanningRows, _b = props.spanningRowsPosition, spanningRowsPosition = _b === void 0 ? 'bottom' : _b, getRowId = props.getRowId, onRowClick = props.onRowClick, rowActions = props.rowActions, sortModel = props.sortModel, onSortModelChange = props.onSortModelChange, selected = props.selected, onSelectedChange = props.onSelectedChange, selectionActions = props.selectionActions, _c = props.pageIndex, pageIndex = _c === void 0 ? constants_1.PAGE_INDEX_DEFAULT : _c, _d = props.pageSize, pageSize = _d === void 0 ? constants_1.PAGE_SIZE_DEFAULT : _d, _e = props.totalOfRows, totalOfRows = _e === void 0 ? rows.length : _e, _f = props.rowsPerPageOptions, rowsPerPageOptions = _f === void 0 ? [10, 20, 30] : _f, onPageIndexChange = props.onPageIndexChange, onPageSizeChange = props.onPageSizeChange;
77
- var _g = react_1.default.useState(), forceUpdate = _g[1];
78
- react_1.default.useEffect(function () {
79
- var language = localStorage.getItem('i18nextLng');
80
- i18n_1.default.changeLanguage(language || 'vi');
81
- forceUpdate({});
82
- // eslint-disable-next-line react-hooks/exhaustive-deps
83
- }, [localStorage.getItem('i18nextLng')]);
84
78
  var createSortHandler = function (fieldName) { return function (event) {
85
79
  var _a, _b, _c;
86
80
  if (onSortModelChange) {
@@ -177,6 +171,10 @@ var DataGrid = function (props) {
177
171
  }
178
172
  };
179
173
  var calcOrder = function (index) { return pageIndex * pageSize + 1 + index; };
174
+ // eslint-disable-next-line react-hooks/exhaustive-deps
175
+ var handleAction = react_1.default.useCallback((0, lodash_1.debounce)(function (rowAction, id) {
176
+ rowAction.action(id);
177
+ }, Constant_1.Constants.DEBOUNCE_TIME_300), []);
180
178
  return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)(material_1.TableContainer, { component: material_1.Paper, children: [(0, jsx_runtime_1.jsxs)(material_1.Table, { "aria-label": "simple table", style: { tableLayout: 'fixed' }, children: [!hideHeader && ((0, jsx_runtime_1.jsx)(material_1.TableHead, { children: (0, jsx_runtime_1.jsxs)(material_1.TableRow, { children: [selected && onSelectedChange && ((0, jsx_runtime_1.jsx)(material_1.TableCell, { padding: "checkbox", children: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { color: "primary", indeterminate: selected.length > 0 &&
181
179
  selected.length < rows.length, checked: selected.length > 0 &&
182
180
  selected.length === rows.length, onChange: function () { return handleSelectAll(); }, inputProps: {
@@ -255,7 +253,7 @@ var DataGrid = function (props) {
255
253
  : undefined, title: actionDef.tooltipTitle, children: (0, jsx_runtime_1.jsx)(material_1.IconButton, { onClick: function (e) {
256
254
  if (!isShouldHide) {
257
255
  e.stopPropagation();
258
- actionDef.action(id);
256
+ handleAction(actionDef, id);
259
257
  }
260
258
  }, style: {
261
259
  marginLeft: '4px',
@@ -273,10 +271,7 @@ var DataGrid = function (props) {
273
271
  })
274
272
  : actionDef.icon }) }, "".concat(id, "-").concat(actIdx)));
275
273
  }) }))] }), id));
276
- }), spanningRowsPosition == 'bottom' && spanningRows] })] }), !rows.length && (0, jsx_runtime_1.jsx)(NoData_1.default, {})] }), onPageIndexChange && onPageSizeChange && ((0, jsx_runtime_1.jsx)(Pagination_1.default, { rowsPerPageOptions: rowsPerPageOptions, colSpan: 3, count: totalOfRows, rowsPerPage: pageSize, page: pageIndex, SelectProps: {
277
- inputProps: { 'aria-label': 'rows per page' },
278
- native: true,
279
- }, onPageChange: function (e, page) { return onPageIndexChange(page); }, onRowsPerPageChange: function (e) {
274
+ }), spanningRowsPosition == 'bottom' && spanningRows] })] }), !rows.length && (0, jsx_runtime_1.jsx)(NoData_1.default, {})] }), onPageIndexChange && onPageSizeChange && ((0, jsx_runtime_1.jsx)(Pagination_1.default, { rowsPerPageOptions: rowsPerPageOptions, colSpan: 3, count: totalOfRows, rowsPerPage: pageSize, page: pageIndex, onPageChange: function (e, page) { return onPageIndexChange(page); }, onRowsPerPageChange: function (e) {
280
275
  return onPageSizeChange(parseInt(e.target.value, 10));
281
276
  } }))] }));
282
277
  };
@@ -50,6 +50,18 @@ var icons_material_1 = require("@mui/icons-material");
50
50
  var react_input_mask_1 = __importDefault(require("react-input-mask"));
51
51
  var styles_1 = require("@mui/styles");
52
52
  var configDate_1 = __importDefault(require("./configDate"));
53
+ var i18n_1 = __importDefault(require("../../i18n"));
54
+ var languageMap = {
55
+ "tha": "th",
56
+ "jpn": "ja",
57
+ "phl": "tl-ph",
58
+ "vi": "vi",
59
+ "en": "en",
60
+ "ind": "hi",
61
+ "mys": "ms",
62
+ "id": "id",
63
+ "lao": "lo"
64
+ };
53
65
  var moment = require('moment');
54
66
  require('moment/locale/vi');
55
67
  var omit = require('lodash/omit');
@@ -143,8 +155,9 @@ var defaultProps = {
143
155
  handleDateRangePopover: function () { },
144
156
  };
145
157
  var DateRangePickerWrapper = function (props) {
158
+ var _a;
146
159
  var classes = useStyles();
147
- var value = props.value, error = props.error, helperText = props.helperText, _a = props.autoFocus, autoFocus = _a === void 0 ? false : _a, _b = props.autoFocusEndDate, autoFocusEndDate = _b === void 0 ? false : _b, _c = props.initialStartDate, initialStartDate = _c === void 0 ? null : _c, _d = props.initialEndDate, initialEndDate = _d === void 0 ? null : _d, _e = props.callback, callback = _e === void 0 ? function () { } : _e, _f = props.label, label = _f === void 0 ? null : _f, _g = props.isShowCalendarInfo, isShowCalendarInfo = _g === void 0 ? false : _g, variant = props.variant, openDirection = props.openDirection, _h = props.isDayBlocked, isDayBlocked = _h === void 0 ? function (day) { return false; } : _h, _j = props.handleValid, handleValid = _j === void 0 ? function () { } : _j, _k = props.handleDateRangePopover, handleDateRangePopover = _k === void 0 ? function () { } : _k, disableHelperText = props.disableHelperText, _l = props.isFutureDate, isFutureDate = _l === void 0 ? false : _l;
160
+ var value = props.value, error = props.error, helperText = props.helperText, _b = props.autoFocus, autoFocus = _b === void 0 ? false : _b, _c = props.autoFocusEndDate, autoFocusEndDate = _c === void 0 ? false : _c, _d = props.initialStartDate, initialStartDate = _d === void 0 ? null : _d, _e = props.initialEndDate, initialEndDate = _e === void 0 ? null : _e, _f = props.callback, callback = _f === void 0 ? function () { } : _f, _g = props.label, label = _g === void 0 ? null : _g, _h = props.isShowCalendarInfo, isShowCalendarInfo = _h === void 0 ? false : _h, variant = props.variant, openDirection = props.openDirection, _j = props.isDayBlocked, isDayBlocked = _j === void 0 ? function (day) { return false; } : _j, _k = props.handleValid, handleValid = _k === void 0 ? function () { } : _k, _l = props.handleDateRangePopover, handleDateRangePopover = _l === void 0 ? function () { } : _l, disableHelperText = props.disableHelperText, _m = props.isFutureDate, isFutureDate = _m === void 0 ? false : _m, _o = props.required, required = _o === void 0 ? false : _o;
148
161
  var initialFocusedInput = null;
149
162
  if (autoFocus) {
150
163
  initialFocusedInput = constants_1.START_DATE;
@@ -152,12 +165,12 @@ var DateRangePickerWrapper = function (props) {
152
165
  else if (autoFocusEndDate) {
153
166
  initialFocusedInput = constants_1.END_DATE;
154
167
  }
155
- var _m = (0, react_1.useState)(initialFocusedInput), focusedInput = _m[0], setFocusedInput = _m[1];
156
- var _o = (0, react_1.useState)(initialStartDate), startDate = _o[0], setStartDate = _o[1];
157
- var _p = (0, react_1.useState)(initialEndDate), endDate = _p[0], setEndDate = _p[1];
158
- var _q = (0, react_1.useState)(true), isValid = _q[0], setIsValid = _q[1];
159
- var _r = (0, react_1.useState)("".concat(moment(value ? value === null || value === void 0 ? void 0 : value.startDate : startDate).format('DD/MM/YYYY'), " - ").concat(moment(value ? value === null || value === void 0 ? void 0 : value.endDate : endDate).format('DD/MM/YYYY'))), inputValue = _r[0], setInputValue = _r[1];
160
- var _s = (0, react_i18next_1.useTranslation)(), i18n = _s.i18n, t = _s.t;
168
+ var _p = (0, react_1.useState)(initialFocusedInput), focusedInput = _p[0], setFocusedInput = _p[1];
169
+ var _q = (0, react_1.useState)(initialStartDate), startDate = _q[0], setStartDate = _q[1];
170
+ var _r = (0, react_1.useState)(initialEndDate), endDate = _r[0], setEndDate = _r[1];
171
+ var _s = (0, react_1.useState)(true), isValid = _s[0], setIsValid = _s[1];
172
+ var _t = (0, react_1.useState)("".concat(moment(value ? value === null || value === void 0 ? void 0 : value.startDate : startDate).format('DD/MM/YYYY'), " - ").concat(moment(value ? value === null || value === void 0 ? void 0 : value.endDate : endDate).format('DD/MM/YYYY'))), inputValue = _t[0], setInputValue = _t[1];
173
+ var _u = (0, react_i18next_1.useTranslation)(undefined, { i18n: i18n_1.default }), i18n = _u.i18n, t = _u.t;
161
174
  var momentLanguage = (0, react_1.useMemo)(function () { var _a, _b; return ((_b = (_a = i18n === null || i18n === void 0 ? void 0 : i18n.language) === null || _a === void 0 ? void 0 : _a.split('-')) === null || _b === void 0 ? void 0 : _b[0]) || 'en'; }, [i18n.language]);
162
175
  (0, react_1.useEffect)(function () {
163
176
  if (value !== undefined) {
@@ -177,10 +190,11 @@ var DateRangePickerWrapper = function (props) {
177
190
  }
178
191
  }, [value]);
179
192
  (0, react_1.useEffect)(function () {
180
- if (momentLanguage !== 'en') {
193
+ var lang = languageMap[momentLanguage] || momentLanguage;
194
+ if (lang !== 'en') {
181
195
  try {
182
- Promise.resolve("".concat("moment/locale/".concat(momentLanguage))).then(function (s) { return __importStar(require(s)); }).then(function () {
183
- moment.locale(momentLanguage);
196
+ Promise.resolve("".concat("moment/locale/".concat(lang))).then(function (s) { return __importStar(require(s)); }).then(function () {
197
+ moment.locale(lang);
184
198
  })
185
199
  .catch(function (error) {
186
200
  console.warn(error);
@@ -191,12 +205,12 @@ var DateRangePickerWrapper = function (props) {
191
205
  }
192
206
  }
193
207
  else {
194
- moment.locale(momentLanguage);
208
+ moment.locale(lang);
195
209
  }
196
210
  if ((value ? value === null || value === void 0 ? void 0 : value.startDate : startDate) !== null &&
197
211
  moment(value ? value === null || value === void 0 ? void 0 : value.startDate : startDate).locale() !==
198
- momentLanguage) {
199
- setStartDate(moment(value ? value === null || value === void 0 ? void 0 : value.startDate : startDate).locale(momentLanguage));
212
+ lang) {
213
+ setStartDate(moment(value ? value === null || value === void 0 ? void 0 : value.startDate : startDate).locale(lang));
200
214
  }
201
215
  }, [momentLanguage, i18n.language, value ? value === null || value === void 0 ? void 0 : value.startDate : startDate]);
202
216
  (0, react_1.useEffect)(function () {
@@ -235,42 +249,60 @@ var DateRangePickerWrapper = function (props) {
235
249
  onDatesChange(daterange);
236
250
  // setFocusedInput(null);
237
251
  };
252
+ var getDataSet = function (moment) {
253
+ return moment.set({
254
+ hour: 0,
255
+ minute: 0,
256
+ second: 0,
257
+ millisecond: 0,
258
+ });
259
+ };
260
+ var resetDate = function () {
261
+ setStartDate(initialStartDate);
262
+ setEndDate(initialEndDate);
263
+ setInputValue("".concat(moment(initialStartDate).format('DD/MM/YYYY'), " - ").concat(moment(initialEndDate).format('DD/MM/YYYY')));
264
+ callback({
265
+ startDate: getDataSet(moment(initialStartDate, 'DD/MM/YYYY')),
266
+ endDate: getDataSet(moment(initialEndDate, 'DD/MM/YYYY')),
267
+ });
268
+ };
238
269
  var handleChangeInput = function (e) {
239
270
  var fieldValue = e.target.value;
240
271
  setInputValue(fieldValue);
241
272
  var fieldValueArr = (fieldValue === null || fieldValue === void 0 ? void 0 : fieldValue.split(' - ')) || [];
242
273
  var year1900 = moment('1900-01-01');
243
274
  var momentStartDate = moment(fieldValueArr[0], 'DD/MM/YYYY');
275
+ var momentEndDate = moment(fieldValueArr[1], 'DD/MM/YYYY');
276
+ if (isDayBlocked && isDayBlocked(momentStartDate)) {
277
+ setIsValid(true);
278
+ resetDate();
279
+ return;
280
+ }
281
+ if (isDayBlocked && isDayBlocked(momentEndDate)) {
282
+ setIsValid(true);
283
+ resetDate();
284
+ return;
285
+ }
244
286
  if (momentStartDate.isValid() && momentStartDate.diff(year1900) >= 0) {
245
287
  setStartDate(momentStartDate);
246
288
  }
247
- var momentEndDate = moment(fieldValueArr[1], 'DD/MM/YYYY');
248
289
  if (momentEndDate.isValid() && momentEndDate.diff(year1900) >= 0) {
249
290
  setEndDate(momentEndDate);
250
291
  }
251
292
  if (moment(fieldValueArr[0], 'DD/MM/YYYY', true).isValid() &&
252
293
  moment(fieldValueArr[1], 'DD/MM/YYYY', true).isValid() &&
253
294
  momentEndDate.diff(momentStartDate) >= 0) {
254
- momentStartDate.set({
255
- hour: 0,
256
- minute: 0,
257
- second: 0,
258
- millisecond: 0,
259
- });
260
- momentEndDate.set({
261
- hour: 0,
262
- minute: 0,
263
- second: 0,
264
- millisecond: 0,
265
- });
266
- callback({ startDate: momentStartDate, endDate: momentEndDate });
267
295
  setIsValid(true);
296
+ callback({
297
+ startDate: getDataSet(momentStartDate),
298
+ endDate: getDataSet(momentEndDate),
299
+ });
268
300
  }
269
301
  else
270
302
  setIsValid(false);
271
303
  };
272
304
  var nextProps = __assign({}, props);
273
- var presets = (0, configDate_1.default)(t, isFutureDate);
305
+ var presets = (0, configDate_1.default)(isFutureDate).map(function (item) { return (item.text = i18n.t(item.text), item); });
274
306
  var renderDatePresets = function () {
275
307
  return ((0, jsx_runtime_1.jsx)("div", { className: classes.CustomDateRangePicker_panel, children: presets.map(function (_a) {
276
308
  var text = _a.text, start = _a.start, end = _a.end;
@@ -312,8 +344,10 @@ var DateRangePickerWrapper = function (props) {
312
344
  'isDayBlocked',
313
345
  'handleValid',
314
346
  'handleDateRangePopover',
347
+ 'required',
315
348
  ]);
316
- var _t = react_1.default.useState(null), anchorElPopover = _t[0], setAnchorElPopover = _t[1];
349
+ var isHindi = (0, react_1.useMemo)(function () { return momentLanguage === 'ind'; }, [momentLanguage]);
350
+ var _v = react_1.default.useState(null), anchorElPopover = _v[0], setAnchorElPopover = _v[1];
317
351
  var openPopper = Boolean(anchorElPopover);
318
352
  var id = openPopper ? 'datePicker-popper' : undefined;
319
353
  var popperRef = react_1.default.useRef();
@@ -332,9 +366,23 @@ var DateRangePickerWrapper = function (props) {
332
366
  setAnchorElPopover(null);
333
367
  handleDateRangePopover(null);
334
368
  };
335
- return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(react_input_mask_1.default, { mask: "99/99/9999 - 99/99/9999", maskplaceholder: "dd/mm/yyyy - dd/mm/yyyy", value: inputValue, onChange: handleChangeInput, disabled: props.disabled, children: function () {
369
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [isHindi ? ((0, jsx_runtime_1.jsx)(material_1.TextField, __assign({ required: required, "aria-describedby": id, variant: variant, label: label, error: !isValid || error, helperText: !disableHelperText
370
+ ? error
371
+ ? helperText || t('Common.InvalidData')
372
+ : !isValid
373
+ ? t('DatePicker.InvalidDateRange')
374
+ : ''
375
+ : '' }, omit(props.textFieldProps, ['readOnly']), { inputProps: {
376
+ readOnly: (_a = props.textFieldProps) === null || _a === void 0 ? void 0 : _a.readOnly,
377
+ }, disabled: props.disabled, onClick: function (e) {
378
+ var _a;
379
+ !((_a = props.textFieldProps) === null || _a === void 0 ? void 0 : _a.readOnly) &&
380
+ handleClickInput(e);
381
+ }, inputRef: inputRef, InputProps: {
382
+ endAdornment: ((0, jsx_runtime_1.jsx)(material_1.InputAdornment, { position: "end", children: (0, jsx_runtime_1.jsx)(material_1.IconButton, { children: (0, jsx_runtime_1.jsx)(icons_material_1.CalendarTodaySharp, {}) }) })),
383
+ } }))) : ((0, jsx_runtime_1.jsx)(react_input_mask_1.default, { mask: "99/99/9999 - 99/99/9999", maskplaceholder: "dd/mm/yyyy - dd/mm/yyyy", value: inputValue, onChange: handleChangeInput, disabled: props.disabled, children: function () {
336
384
  var _a;
337
- return ((0, jsx_runtime_1.jsx)(material_1.TextField, __assign({ "aria-describedby": id, variant: variant, label: label, error: !isValid || error, helperText: !disableHelperText
385
+ return ((0, jsx_runtime_1.jsx)(material_1.TextField, __assign({ required: required, "aria-describedby": id, variant: variant, label: label, error: !isValid || error, helperText: !disableHelperText
338
386
  ? error
339
387
  ? helperText || t('Common.InvalidData')
340
388
  : !isValid
@@ -349,7 +397,7 @@ var DateRangePickerWrapper = function (props) {
349
397
  }, inputRef: inputRef, InputProps: {
350
398
  endAdornment: ((0, jsx_runtime_1.jsx)(material_1.InputAdornment, { position: "end", children: (0, jsx_runtime_1.jsx)(material_1.IconButton, { children: (0, jsx_runtime_1.jsx)(icons_material_1.CalendarTodaySharp, {}) }) })),
351
399
  } })));
352
- } }), (0, jsx_runtime_1.jsx)(material_1.Popper, { id: id, open: openPopper, anchorEl: anchorElPopover, onClose: handleClosePopover, style: { zIndex: 30000 }, placement: openDirection === 'up' ? 'top-start' : 'bottom-start', popperRef: popperRef, children: (0, jsx_runtime_1.jsx)(material_1.ClickAwayListener, { onClickAway: handleClosePopover, children: (0, jsx_runtime_1.jsx)(material_1.Paper, { elevation: 8, className: classes.CustomPickerSelected, children: (0, jsx_runtime_1.jsx)(react_dates_1.DayPickerRangeController, __assign({}, nextProps, { calendarInfoPosition: "before", renderCalendarInfo: isShowCalendarInfo ? renderDatePresets : null, onDatesChange: onDatesChange, onFocusChange: onFocusChange, focusedInput: focusedInput, startDate: value ? value === null || value === void 0 ? void 0 : value.startDate : startDate, endDate: value ? value === null || value === void 0 ? void 0 : value.endDate : endDate, hideKeyboardShortcutsPanel: true, numberOfMonths: 2, daySize: 32, transitionDuration: 0, isDayBlocked: function (day) {
400
+ } })), (0, jsx_runtime_1.jsx)(material_1.Popper, { id: id, open: openPopper, anchorEl: anchorElPopover, onClose: handleClosePopover, style: { zIndex: 30000 }, placement: openDirection === 'up' ? 'top-start' : 'bottom-start', popperRef: popperRef, children: (0, jsx_runtime_1.jsx)(material_1.ClickAwayListener, { onClickAway: handleClosePopover, children: (0, jsx_runtime_1.jsx)(material_1.Paper, { elevation: 8, className: classes.CustomPickerSelected, children: (0, jsx_runtime_1.jsx)(react_dates_1.DayPickerRangeController, __assign({}, nextProps, { calendarInfoPosition: "before", renderCalendarInfo: isShowCalendarInfo ? renderDatePresets : null, onDatesChange: onDatesChange, onFocusChange: onFocusChange, focusedInput: focusedInput, startDate: value ? value === null || value === void 0 ? void 0 : value.startDate : startDate, endDate: value ? value === null || value === void 0 ? void 0 : value.endDate : endDate, hideKeyboardShortcutsPanel: true, numberOfMonths: 2, daySize: 32, transitionDuration: 0, isDayBlocked: function (day) {
353
401
  if (value ? value === null || value === void 0 ? void 0 : value.startDate : startDate) {
354
402
  if (isDayBlocked(value ? value === null || value === void 0 ? void 0 : value.startDate : startDate))
355
403
  setIsValid(false);
@@ -1,6 +1,5 @@
1
- import { TFunction } from 'i18next';
2
1
  import moment from 'moment';
3
- declare const configInitialDate: (t: TFunction<'translation', undefined>, isFutureDate: boolean) => {
2
+ declare const configInitialDate: (isFutureDate: boolean) => {
4
3
  text: string;
5
4
  start: moment.Moment;
6
5
  end: moment.Moment;
@@ -4,63 +4,63 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  var moment_1 = __importDefault(require("moment"));
7
- var configInitialDate = function (t, isFutureDate) {
7
+ var configInitialDate = function (isFutureDate) {
8
8
  var today = (0, moment_1.default)();
9
9
  var initDatePast = [
10
10
  {
11
- text: t('DatePicker.ToDay'),
11
+ text: 'DatePicker.ToDay',
12
12
  start: today,
13
13
  end: today,
14
14
  },
15
15
  {
16
- text: t('DatePicker.Yesterday'),
16
+ text: 'DatePicker.Yesterday',
17
17
  start: (0, moment_1.default)().subtract(1, 'days'),
18
18
  end: (0, moment_1.default)().subtract(1, 'days'),
19
19
  },
20
20
  {
21
- text: t('DatePicker.LastSevenDay'),
21
+ text: 'DatePicker.LastSevenDay',
22
22
  start: (0, moment_1.default)().subtract(6, 'days'),
23
23
  end: today,
24
24
  },
25
25
  {
26
- text: t('DatePicker.LastThirtyDay'),
26
+ text: 'DatePicker.LastThirtyDay',
27
27
  start: (0, moment_1.default)().subtract(29, 'days'),
28
28
  end: today,
29
29
  },
30
30
  {
31
- text: t('DatePicker.ThisMonth'),
31
+ text: 'DatePicker.ThisMonth',
32
32
  start: (0, moment_1.default)().startOf('month'),
33
33
  end: (0, moment_1.default)().endOf('month'),
34
34
  },
35
35
  {
36
- text: t('DatePicker.LastMonth'),
36
+ text: 'DatePicker.LastMonth',
37
37
  start: (0, moment_1.default)().subtract(1, 'month').startOf('month'),
38
38
  end: (0, moment_1.default)().subtract(1, 'month').endOf('month'),
39
39
  },
40
40
  ];
41
41
  var initDateFuture = [
42
42
  {
43
- text: t('DatePicker.ToDay'),
43
+ text: 'DatePicker.ToDay',
44
44
  start: today,
45
45
  end: today,
46
46
  },
47
47
  {
48
- text: t('DatePicker.Tomorrow'),
48
+ text: 'DatePicker.Tomorrow',
49
49
  start: (0, moment_1.default)(),
50
50
  end: (0, moment_1.default)().add(1, 'days'),
51
51
  },
52
52
  {
53
- text: t('DatePicker.NextSevenDay'),
53
+ text: 'DatePicker.NextSevenDay',
54
54
  start: today,
55
55
  end: (0, moment_1.default)().add(6, 'days'),
56
56
  },
57
57
  {
58
- text: t('DatePicker.NextThirtyDay'),
58
+ text: 'DatePicker.NextThirtyDay',
59
59
  start: today,
60
60
  end: (0, moment_1.default)().add(29, 'days'),
61
61
  },
62
62
  {
63
- text: t('DatePicker.NextMonth'),
63
+ text: 'DatePicker.NextMonth',
64
64
  start: (0, moment_1.default)().add(1, 'month').startOf('month'),
65
65
  end: (0, moment_1.default)().add(1, 'month').endOf('month'),
66
66
  },
@@ -1,5 +1,6 @@
1
1
  import { MomentInput, Moment } from "moment";
2
2
  export interface DateRangePickerProps {
3
+ required?: boolean;
3
4
  disabled?: boolean;
4
5
  autoFocus?: boolean;
5
6
  autoFocusEndDate?: boolean;