mario-core 2.8.0 → 2.8.3

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.
@@ -19,5 +19,6 @@ declare const useUserDetail: (id?: string | undefined) => {
19
19
  setEdited: import("react").Dispatch<import("react").SetStateAction<boolean>>;
20
20
  setEditedTrue: () => Promise<void>;
21
21
  confirmChangePassword: (data: any) => Promise<void>;
22
+ forgotPasswordRequest: (data: any) => Promise<void>;
22
23
  };
23
24
  export default useUserDetail;
package/dist/index.js CHANGED
@@ -315,9 +315,6 @@ var checkResetToken = function checkResetToken(token) {
315
315
  var resetPassword = function resetPassword(data) {
316
316
  return api.post(ACCOUNT_URL + "/resetpassword", data);
317
317
  };
318
- var logInTwoFactor = function logInTwoFactor(data) {
319
- return api.post(ACCOUNT_URL + "/logintwostep", data);
320
- };
321
318
 
322
319
  var defaultInfo = {
323
320
  email: "",
@@ -356,10 +353,7 @@ var useLogin = function useLogin() {
356
353
  var isDistrict = window.location.host.includes("-district");
357
354
  var userLogin = React.useCallback(function (data) {
358
355
  try {
359
- var _exit2 = false;
360
-
361
- var _temp3 = function _temp3(_result) {
362
- if (_exit2) return _result;
356
+ var _temp3 = function _temp3() {
363
357
  dispatch(setLoading(false));
364
358
  };
365
359
 
@@ -367,23 +361,14 @@ var useLogin = function useLogin() {
367
361
 
368
362
  var _temp4 = _catch(function () {
369
363
  return Promise.resolve(logIn(data)).then(function (res) {
370
- var _res$data;
371
-
372
- if ((_res$data = res.data) !== null && _res$data !== void 0 && _res$data.isTwoFactor) {
373
- history.push("/2fa?id=" + res.data.id);
374
- dispatch(setLoading(false));
375
- _exit2 = true;
376
- return;
377
- }
378
-
379
- var _res$data2 = res.data,
380
- token = _res$data2.token,
381
- id = _res$data2.id,
382
- firstName = _res$data2.firstName,
383
- lastName = _res$data2.lastName,
384
- roles = _res$data2.roles,
385
- email = _res$data2.email,
386
- profileImageFileName = _res$data2.profileImageFileName;
364
+ var _res$data = res.data,
365
+ token = _res$data.token,
366
+ id = _res$data.id,
367
+ firstName = _res$data.firstName,
368
+ lastName = _res$data.lastName,
369
+ roles = _res$data.roles,
370
+ email = _res$data.email,
371
+ profileImageFileName = _res$data.profileImageFileName;
387
372
  localStorage.setItem(ACCESS_TOKEN, token);
388
373
  dispatch(setUser({
389
374
  id: id,
@@ -853,7 +838,8 @@ var BlockResetPassword = function BlockResetPassword() {
853
838
  }, "Reset Password"), React__default.createElement("div", {
854
839
  className: "w-100"
855
840
  }, validLink ? React__default.createElement(React__default.Fragment, null, React__default.createElement(reactstrap.Label, {
856
- "for": "emailForgot"
841
+ "for": "emailForgot",
842
+ className: "mb-3"
857
843
  }, "New password"), React__default.createElement(PasswordInput, {
858
844
  isShowPassword: isShowNewPassword,
859
845
  togglePasswordVisible: function togglePasswordVisible() {
@@ -865,7 +851,8 @@ var BlockResetPassword = function BlockResetPassword() {
865
851
  }), touched.password && errors.password && React__default.createElement(ErrorHandler, {
866
852
  text: errors.password
867
853
  }), React__default.createElement(reactstrap.Label, {
868
- "for": "emailForgot"
854
+ "for": "emailForgot",
855
+ className: "mt-3 mb-3"
869
856
  }, "Re-enter new password"), React__default.createElement(PasswordInput, {
870
857
  isShowPassword: isShowReTypePassword,
871
858
  togglePasswordVisible: function togglePasswordVisible() {
@@ -907,6 +894,47 @@ var BlockResetPassword = function BlockResetPassword() {
907
894
  });
908
895
  };
909
896
 
897
+ var LOGIN_TITLE = "Log in";
898
+ var FORGOT_PASSWORD_TITLE = "Forgot password";
899
+ var RESET_PASSWORD_TITLE = "Reset password";
900
+
901
+ var Login = function Login(props) {
902
+ var isLogin = props.isLogin,
903
+ isForgotPassword = props.isForgotPassword,
904
+ isResetPassword = props.isResetPassword;
905
+
906
+ var _useLogin = useLogin(),
907
+ defaultInfo = _useLogin.defaultInfo,
908
+ userLogin = _useLogin.userLogin;
909
+
910
+ React.useEffect(function () {
911
+ isLogin && (document.title = LOGIN_TITLE);
912
+ isForgotPassword && (document.title = FORGOT_PASSWORD_TITLE);
913
+ isResetPassword && (document.title = RESET_PASSWORD_TITLE);
914
+ }, [isLogin, isForgotPassword, isResetPassword]);
915
+ return React__default.createElement("div", {
916
+ className: styles["login"] + " container-fluid font-family-lato"
917
+ }, React__default.createElement(reactstrap.Row, {
918
+ className: "h-100"
919
+ }, React__default.createElement(reactstrap.Col, {
920
+ lg: 12,
921
+ md: 12,
922
+ xs: 12,
923
+ className: "d-flex justify-content-center h-100 align-items-center"
924
+ }, React__default.createElement(reactGoogleRecaptchaV3.GoogleReCaptchaProvider, {
925
+ useRecaptchaNet: true,
926
+ reCaptchaKey: GOOGLE_RECAPTCHA_KEY,
927
+ scriptProps: {
928
+ async: true,
929
+ defer: true,
930
+ appendTo: "body"
931
+ }
932
+ }, isLogin && React__default.createElement(BlockLogin, {
933
+ userLogin: userLogin,
934
+ defaultInfo: defaultInfo
935
+ }), isForgotPassword && React__default.createElement(BlockForgetPassword, null)), isResetPassword && React__default.createElement(BlockResetPassword, null))));
936
+ };
937
+
910
938
  function _extends() {
911
939
  _extends = Object.assign || function (target) {
912
940
  for (var i = 1; i < arguments.length; i++) {
@@ -986,210 +1014,6 @@ function _createForOfIteratorHelperLoose(o, allowArrayLike) {
986
1014
  return it.next.bind(it);
987
1015
  }
988
1016
 
989
- var HOMEPAGE_TEACHER$1 = "/my-one-to-one/up-coming";
990
- var HOMEPAGE_STUDENT$1 = "/my-one-to-one/up-coming";
991
- var HOMEPAGE_ADMIN$1 = "/admin/dashboard";
992
- var HOMEPAGE_PARENT$1 = "/parent";
993
- var HOMEPAGE_DISTRICT$1 = "/admin/schools";
994
- var TITLE$2 = "2FA";
995
-
996
- var useLoginTwoFactor = function useLoginTwoFactor() {
997
- var dispatch = reactRedux.useDispatch();
998
- var history = reactRouterDom.useHistory();
999
- var isDistrict = window.location.host.includes("-district");
1000
- var userLoginTwoFactor = React.useCallback(function (data) {
1001
- try {
1002
- var _temp3 = function _temp3() {
1003
- dispatch(setLoading(false));
1004
- };
1005
-
1006
- dispatch(setLoading(true));
1007
-
1008
- var _temp4 = _catch(function () {
1009
- return Promise.resolve(logInTwoFactor(data)).then(function (res) {
1010
- var _res$data = res.data,
1011
- token = _res$data.token,
1012
- id = _res$data.id,
1013
- firstName = _res$data.firstName,
1014
- lastName = _res$data.lastName,
1015
- roles = _res$data.roles,
1016
- email = _res$data.email,
1017
- profileImageFileName = _res$data.profileImageFileName;
1018
- localStorage.setItem(ACCESS_TOKEN, token);
1019
- dispatch(setUser({
1020
- id: id,
1021
- firstName: firstName,
1022
- lastName: lastName,
1023
- roles: roles,
1024
- email: email,
1025
- profileImageFileName: profileImageFileName
1026
- }));
1027
-
1028
- if (isDistrict) {
1029
- history.push(HOMEPAGE_DISTRICT$1);
1030
- } else if (roles.includes("Admin")) {
1031
- history.push(HOMEPAGE_ADMIN$1);
1032
- } else if (roles.includes("Teacher")) {
1033
- history.push(HOMEPAGE_TEACHER$1);
1034
- } else if (roles.includes("Student")) {
1035
- history.push(HOMEPAGE_STUDENT$1);
1036
- } else if (roles.includes("Parent")) {
1037
- history.push(HOMEPAGE_PARENT$1);
1038
- }
1039
- });
1040
- }, function (err) {
1041
- var _err$response, _err$response$data;
1042
-
1043
- dispatch(setAlert({
1044
- type: "danger",
1045
- message: ((_err$response = err.response) === null || _err$response === void 0 ? void 0 : (_err$response$data = _err$response.data) === null || _err$response$data === void 0 ? void 0 : _err$response$data.title) || err.message || "Login failed"
1046
- }));
1047
- });
1048
-
1049
- return Promise.resolve(_temp4 && _temp4.then ? _temp4.then(_temp3) : _temp3(_temp4));
1050
- } catch (e) {
1051
- return Promise.reject(e);
1052
- }
1053
- }, []);
1054
- React.useEffect(function () {
1055
- document.title = TITLE$2;
1056
- }, []);
1057
- return {
1058
- userLoginTwoFactor: userLoginTwoFactor
1059
- };
1060
- };
1061
-
1062
- var initialValues$2 = {
1063
- twoFactorCode: "",
1064
- id: "",
1065
- rememberMe: false
1066
- };
1067
- var schema$1 = yup.object({
1068
- id: yup.string().required("Bad credential"),
1069
- twoFactorCode: yup.string().required("Additional Verification is required"),
1070
- rememberMe: yup.boolean()
1071
- });
1072
-
1073
- var BlockTwoFactorLogin = function BlockTwoFactorLogin() {
1074
- var query = new URLSearchParams(reactRouterDom.useLocation().search);
1075
- var id = query.get("id");
1076
-
1077
- var _useLoginTwoFactor = useLoginTwoFactor(),
1078
- userLoginTwoFactor = _useLoginTwoFactor.userLoginTwoFactor;
1079
-
1080
- return React__default.createElement(formik.Formik, {
1081
- initialValues: _extends({}, initialValues$2, {
1082
- id: id
1083
- }),
1084
- enableReinitialize: true,
1085
- validationSchema: schema$1,
1086
- onSubmit: function onSubmit(values) {
1087
- userLoginTwoFactor(values);
1088
- }
1089
- }, function (formikProps) {
1090
- var values = formikProps.values,
1091
- setFieldValue = formikProps.setFieldValue,
1092
- handleChange = formikProps.handleChange,
1093
- handleSubmit = formikProps.handleSubmit,
1094
- touched = formikProps.touched,
1095
- errors = formikProps.errors;
1096
- return React__default.createElement(reactstrap.Row, {
1097
- className: "" + styles["box-login"]
1098
- }, React__default.createElement(reactstrap.Col, {
1099
- className: "p-0"
1100
- }, React__default.createElement("div", {
1101
- className: "" + styles["block-login"]
1102
- }, React__default.createElement("div", {
1103
- className: "" + styles["block-form"]
1104
- }, React__default.createElement("p", {
1105
- className: "" + styles["title-login"]
1106
- }, "Additional Verification"), React__default.createElement("p", {
1107
- className: "recover-account"
1108
- }, "Check your email to get Additional Verification. This code will be expired in 5 minutes"), React__default.createElement("div", null, React__default.createElement(reactstrap.FormGroup, null, React__default.createElement(reactstrap.Label, null, "Additional Verification"), React__default.createElement(reactstrap.Input, {
1109
- name: "twoFactorCode",
1110
- value: values.twoFactorCode,
1111
- onChange: handleChange
1112
- }), touched.twoFactorCode && errors.twoFactorCode && React__default.createElement(ErrorHandler, {
1113
- text: errors.twoFactorCode
1114
- })), React__default.createElement(reactstrap.FormGroup, null, React__default.createElement(reactstrap.Input, {
1115
- type: "checkbox",
1116
- className: "" + styles["checkbox-remember"],
1117
- id: "remember",
1118
- onChange: function onChange(e) {
1119
- return setFieldValue("rememberMe", e.target.checked);
1120
- }
1121
- }), React__default.createElement(reactstrap.Label, {
1122
- "for": "rememberMe",
1123
- className: "" + styles["remember"]
1124
- }, "Remember my browser & IP"))), React__default.createElement(reactstrap.Col, {
1125
- className: "p-0 mt-5"
1126
- }, React__default.createElement("button", {
1127
- className: styles["btn-login"] + " ",
1128
- onClick: function onClick() {
1129
- return handleSubmit();
1130
- }
1131
- }, "Confirm")), React__default.createElement("p", {
1132
- className: "d-flex justify-content-between"
1133
- }, React__default.createElement(reactRouterDom.Link, {
1134
- to: "/login",
1135
- className: "" + styles["link-to-login"]
1136
- }, "Return to login"), React__default.createElement("a", {
1137
- href: "https://marioframework.com/privacy-policy/",
1138
- target: "blank",
1139
- className: "" + styles["link-to-login"]
1140
- }, "Privacy Policy"))))), React__default.createElement(reactstrap.Col, {
1141
- lg: 4,
1142
- md: 4,
1143
- className: "" + styles["img-box"]
1144
- }, React__default.createElement("img", {
1145
- src: "/images/img-login.jpg",
1146
- className: "" + styles["img-login"]
1147
- })));
1148
- });
1149
- };
1150
-
1151
- var LOGIN_TITLE = "Log in";
1152
- var FORGOT_PASSWORD_TITLE = "Forgot password";
1153
- var RESET_PASSWORD_TITLE = "Reset password";
1154
-
1155
- var Login = function Login(props) {
1156
- var isLogin = props.isLogin,
1157
- isForgotPassword = props.isForgotPassword,
1158
- isResetPassword = props.isResetPassword,
1159
- isLoginTwoFactor = props.isLoginTwoFactor;
1160
-
1161
- var _useLogin = useLogin(),
1162
- defaultInfo = _useLogin.defaultInfo,
1163
- userLogin = _useLogin.userLogin;
1164
-
1165
- React.useEffect(function () {
1166
- isLogin && (document.title = LOGIN_TITLE);
1167
- isForgotPassword && (document.title = FORGOT_PASSWORD_TITLE);
1168
- isResetPassword && (document.title = RESET_PASSWORD_TITLE);
1169
- }, [isLogin, isForgotPassword, isResetPassword]);
1170
- return React__default.createElement("div", {
1171
- className: styles["login"] + " container-fluid font-family-lato"
1172
- }, React__default.createElement(reactstrap.Row, {
1173
- className: "h-100"
1174
- }, React__default.createElement(reactstrap.Col, {
1175
- lg: 12,
1176
- md: 12,
1177
- xs: 12,
1178
- className: "d-flex justify-content-center h-100 align-items-center"
1179
- }, React__default.createElement(reactGoogleRecaptchaV3.GoogleReCaptchaProvider, {
1180
- useRecaptchaNet: true,
1181
- reCaptchaKey: GOOGLE_RECAPTCHA_KEY,
1182
- scriptProps: {
1183
- async: true,
1184
- defer: true,
1185
- appendTo: "body"
1186
- }
1187
- }, isLogin && React__default.createElement(BlockLogin, {
1188
- userLogin: userLogin,
1189
- defaultInfo: defaultInfo
1190
- }), isForgotPassword && React__default.createElement(BlockForgetPassword, null)), isResetPassword && React__default.createElement(BlockResetPassword, null), isLoginTwoFactor && React__default.createElement(BlockTwoFactorLogin, null))));
1191
- };
1192
-
1193
1017
  var QuoteContent = function QuoteContent(_ref) {
1194
1018
  var descriptions = _ref.descriptions;
1195
1019
  return React__default.createElement("div", {
@@ -1598,11 +1422,11 @@ var TheHeader = function TheHeader() {
1598
1422
  }, "Privacy Policy"), !isDistrict && React__default.createElement(NotificationButton, null), React__default.createElement(TheHeaderDropdown, null)));
1599
1423
  };
1600
1424
 
1601
- var TITLE$3 = "Not found";
1425
+ var TITLE$2 = "Not found";
1602
1426
 
1603
1427
  var NotFound = function NotFound() {
1604
1428
  React.useEffect(function () {
1605
- document.title = TITLE$3;
1429
+ document.title = TITLE$2;
1606
1430
  });
1607
1431
  return React__default.createElement("div", {
1608
1432
  className: "not-found"
@@ -1966,7 +1790,7 @@ var useFilters = function useFilters() {
1966
1790
 
1967
1791
  var EMAIL_TEMPLATE_URL$1 = "/admin/email-template";
1968
1792
  var CREATE_TEMPLATE_URL = "/admin/create-email-template";
1969
- var TITLE$4 = "Email template list";
1793
+ var TITLE$3 = "Email template list";
1970
1794
 
1971
1795
  var useEmailTemplateList = function useEmailTemplateList() {
1972
1796
  var history = reactRouterDom.useHistory();
@@ -2067,7 +1891,7 @@ var useEmailTemplateList = function useEmailTemplateList() {
2067
1891
  history.push(url);
2068
1892
  }, []);
2069
1893
  React.useEffect(function () {
2070
- document.title = TITLE$4;
1894
+ document.title = TITLE$3;
2071
1895
  }, []);
2072
1896
  React.useEffect(function () {
2073
1897
  getData();
@@ -2553,7 +2377,7 @@ var initValue = {
2553
2377
  attachments: []
2554
2378
  };
2555
2379
  var EMAIL_TEMPLATE_LIST_URL = "/admin/email-template";
2556
- var TITLE$5 = "Email template detail";
2380
+ var TITLE$4 = "Email template detail";
2557
2381
  var MAX_FILES_SIZE = 4194304;
2558
2382
 
2559
2383
  var useEmailTemplateDetail = function useEmailTemplateDetail(id) {
@@ -2588,7 +2412,7 @@ var useEmailTemplateDetail = function useEmailTemplateDetail(id) {
2588
2412
  setFileUpload = _useState4[1];
2589
2413
 
2590
2414
  React.useEffect(function () {
2591
- document.title = TITLE$5;
2415
+ document.title = TITLE$4;
2592
2416
  setEdited(false);
2593
2417
  if (!!localStorage.getItem(window.location.href)) localStorage.removeItem(window.location.href);
2594
2418
  }, []);
@@ -2819,7 +2643,7 @@ var useEmailTemplateDetail = function useEmailTemplateDetail(id) {
2819
2643
  };
2820
2644
  };
2821
2645
 
2822
- var schema$2 = yup.object({
2646
+ var schema$1 = yup.object({
2823
2647
  subject: yup.string().required("Template subject is required"),
2824
2648
  categoryId: yup.number().required("Template category is required").test("test category id", "Template category is required", function (value) {
2825
2649
  return value >= 1;
@@ -2856,7 +2680,7 @@ var EmailTemplateDetail = function EmailTemplateDetail() {
2856
2680
  return React__default.createElement(formik.Formik, {
2857
2681
  initialValues: emailTemplateDetail,
2858
2682
  enableReinitialize: true,
2859
- validationSchema: schema$2,
2683
+ validationSchema: schema$1,
2860
2684
  onSubmit: function onSubmit(values) {
2861
2685
  confirmData(values);
2862
2686
  setEdited(false);
@@ -3073,7 +2897,7 @@ var CommonModal = function CommonModal(props, ref) {
3073
2897
 
3074
2898
  var CommonModal$1 = React.forwardRef(CommonModal);
3075
2899
 
3076
- var schema$3 = yup.object({
2900
+ var schema$2 = yup.object({
3077
2901
  question: yup.string().required("Question is required"),
3078
2902
  answer: yup.string().required("Answer is required")
3079
2903
  });
@@ -3091,7 +2915,7 @@ var FaqDetailModal = function FaqDetailModal(props, ref) {
3091
2915
  return React__default.createElement(formik.Formik, {
3092
2916
  initialValues: faqDetail,
3093
2917
  enableReinitialize: true,
3094
- validationSchema: schema$3,
2918
+ validationSchema: schema$2,
3095
2919
  onSubmit: function onSubmit(values, actions) {
3096
2920
  onConfirm(values);
3097
2921
  actions.resetForm();
@@ -3173,7 +2997,7 @@ var remove$1 = function remove(id) {
3173
2997
  return api["delete"](FAQ_URL + "/" + id);
3174
2998
  };
3175
2999
 
3176
- var TITLE$6 = "FAQ list";
3000
+ var TITLE$5 = "FAQ list";
3177
3001
 
3178
3002
  var useFaqList = function useFaqList() {
3179
3003
  var faqList = reactRedux.useSelector(function (state) {
@@ -3256,7 +3080,7 @@ var useFaqList = function useFaqList() {
3256
3080
  dispatch(setLoading(false));
3257
3081
  }, [filters]);
3258
3082
  React.useEffect(function () {
3259
- document.title = TITLE$6;
3083
+ document.title = TITLE$5;
3260
3084
  }, []);
3261
3085
  React.useEffect(function () {
3262
3086
  getData();
@@ -3603,7 +3427,7 @@ var SkillSelector = function SkillSelector(props) {
3603
3427
  }));
3604
3428
  };
3605
3429
 
3606
- var schema$4 = yup.object({
3430
+ var schema$3 = yup.object({
3607
3431
  name: yup.string().required("Name is required"),
3608
3432
  description: yup.string()
3609
3433
  });
@@ -3622,7 +3446,7 @@ var SkillDetailModal = function SkillDetailModal(props, ref) {
3622
3446
  return React__default.createElement(formik.Formik, {
3623
3447
  initialValues: skillDetail,
3624
3448
  enableReinitialize: true,
3625
- validationSchema: schema$4,
3449
+ validationSchema: schema$3,
3626
3450
  onSubmit: function onSubmit(values, actions) {
3627
3451
  onConfirm(values);
3628
3452
  actions.resetForm();
@@ -3696,7 +3520,7 @@ var SkillDetailModal$1 = React.forwardRef(SkillDetailModal);
3696
3520
 
3697
3521
  var setSkillList = toolkit.createAction("skills/setSkillList");
3698
3522
 
3699
- var TITLE$7 = "Skill list";
3523
+ var TITLE$6 = "Skill list";
3700
3524
 
3701
3525
  var useSkillList = function useSkillList() {
3702
3526
  var skillList = reactRedux.useSelector(function (state) {
@@ -3790,7 +3614,7 @@ var useSkillList = function useSkillList() {
3790
3614
  dispatch(setLoading(false));
3791
3615
  }, [filters]);
3792
3616
  React.useEffect(function () {
3793
- document.title = TITLE$7;
3617
+ document.title = TITLE$6;
3794
3618
  }, []);
3795
3619
  React.useEffect(function () {
3796
3620
  getData();
@@ -4065,6 +3889,7 @@ var setStudentList = toolkit.createAction("users/setStudentList");
4065
3889
 
4066
3890
  var USER_URL = BASE_URL + "/api/user";
4067
3891
  var CHANGE_PASSWORD = BASE_URL + "/api/Account/changePassword";
3892
+ var ACCOUNT_URL$1 = BASE_URL + "/api/account";
4068
3893
  var get$5 = function get(filter) {
4069
3894
  return api.get("" + USER_URL, {
4070
3895
  params: filter
@@ -4085,10 +3910,13 @@ var remove$3 = function remove(id) {
4085
3910
  var changePassword = function changePassword(formData) {
4086
3911
  return api.post(CHANGE_PASSWORD, formData);
4087
3912
  };
3913
+ var forgotChangePassword = function forgotChangePassword(data) {
3914
+ return api.post(ACCOUNT_URL$1 + "/forgotchangepassword", data);
3915
+ };
4088
3916
 
4089
3917
  var USER_URL$1 = "/admin/user";
4090
3918
  var CREATE_USER_URL = "/admin/create-user";
4091
- var TITLE$8 = "User list";
3919
+ var TITLE$7 = "User list";
4092
3920
 
4093
3921
  var useUserList = function useUserList() {
4094
3922
  var history = reactRouterDom.useHistory();
@@ -4145,7 +3973,7 @@ var useUserList = function useUserList() {
4145
3973
  }
4146
3974
  }, [dispatch, filters]);
4147
3975
  React.useEffect(function () {
4148
- document.title = TITLE$8;
3976
+ document.title = TITLE$7;
4149
3977
  }, []);
4150
3978
  React.useEffect(function () {
4151
3979
  if (!!fullName) {
@@ -4470,7 +4298,7 @@ var initValue$3 = {
4470
4298
  profileImageFileName: ""
4471
4299
  };
4472
4300
  var USER_LIST_URL = "/admin/user";
4473
- var TITLE$9 = "User detail";
4301
+ var TITLE$8 = "User detail";
4474
4302
 
4475
4303
  var useUserDetail = function useUserDetail(id) {
4476
4304
  var dispatch = reactRedux.useDispatch();
@@ -4499,7 +4327,7 @@ var useUserDetail = function useUserDetail(id) {
4499
4327
  };
4500
4328
 
4501
4329
  React.useEffect(function () {
4502
- document.title = TITLE$9;
4330
+ document.title = TITLE$8;
4503
4331
  setEdited(false);
4504
4332
  if (!!localStorage.getItem(window.location.href)) localStorage.removeItem(window.location.href);
4505
4333
  }, []);
@@ -4626,6 +4454,35 @@ var useUserDetail = function useUserDetail(id) {
4626
4454
  }
4627
4455
  };
4628
4456
 
4457
+ var forgotPasswordRequest = React.useCallback(function (data) {
4458
+ try {
4459
+ var _temp17 = function _temp17() {
4460
+ dispatch(setLoading(false));
4461
+ };
4462
+
4463
+ dispatch(setLoading(true));
4464
+
4465
+ var _temp18 = _catch(function () {
4466
+ return Promise.resolve(forgotChangePassword(data)).then(function () {
4467
+ dispatch(setAlert({
4468
+ type: "success",
4469
+ message: "Send forgot password link successfully"
4470
+ }));
4471
+ });
4472
+ }, function (err) {
4473
+ var _err$response3, _err$response3$data;
4474
+
4475
+ dispatch(setAlert({
4476
+ type: "danger",
4477
+ message: ((_err$response3 = err.response) === null || _err$response3 === void 0 ? void 0 : (_err$response3$data = _err$response3.data) === null || _err$response3$data === void 0 ? void 0 : _err$response3$data.title) || err.message || "Error occured"
4478
+ }));
4479
+ });
4480
+
4481
+ return Promise.resolve(_temp18 && _temp18.then ? _temp18.then(_temp17) : _temp17(_temp18));
4482
+ } catch (e) {
4483
+ return Promise.reject(e);
4484
+ }
4485
+ }, []);
4629
4486
  return {
4630
4487
  userDetail: userDetail,
4631
4488
  backToList: backToList,
@@ -4635,7 +4492,8 @@ var useUserDetail = function useUserDetail(id) {
4635
4492
  edited: edited,
4636
4493
  setEdited: setEdited,
4637
4494
  setEditedTrue: setEditedTrue,
4638
- confirmChangePassword: confirmChangePassword
4495
+ confirmChangePassword: confirmChangePassword,
4496
+ forgotPasswordRequest: forgotPasswordRequest
4639
4497
  };
4640
4498
  };
4641
4499
 
@@ -4681,7 +4539,8 @@ var UserDetail = function UserDetail() {
4681
4539
  edited = _useUserDetail.edited,
4682
4540
  setEdited = _useUserDetail.setEdited,
4683
4541
  setEditedTrue = _useUserDetail.setEditedTrue,
4684
- confirmChangePassword = _useUserDetail.confirmChangePassword;
4542
+ confirmChangePassword = _useUserDetail.confirmChangePassword,
4543
+ forgotPasswordRequest = _useUserDetail.forgotPasswordRequest;
4685
4544
 
4686
4545
  var initialValueForm = {
4687
4546
  oldPassword: "",
@@ -4696,6 +4555,18 @@ var UserDetail = function UserDetail() {
4696
4555
  window.open(url);
4697
4556
  };
4698
4557
 
4558
+ var onResetPw = function onResetPw(email) {
4559
+ try {
4560
+ var data = {
4561
+ email: email
4562
+ };
4563
+ forgotPasswordRequest(data);
4564
+ return Promise.resolve();
4565
+ } catch (e) {
4566
+ return Promise.reject(e);
4567
+ }
4568
+ };
4569
+
4699
4570
  return React__default.createElement(formik.Formik, {
4700
4571
  initialValues: userDetail,
4701
4572
  enableReinitialize: true,
@@ -4738,14 +4609,21 @@ var UserDetail = function UserDetail() {
4738
4609
  }), !!id && React__default.createElement(reactstrap.Row, {
4739
4610
  className: "pt-2"
4740
4611
  }, React__default.createElement(reactstrap.Col, {
4741
- md: 10
4612
+ md: 6
4742
4613
  }, " "), React__default.createElement(reactstrap.Col, {
4743
- md: 2
4614
+ md: 5,
4615
+ className: "text-right"
4744
4616
  }, React__default.createElement(reactstrap.Button, {
4617
+ color: "primary",
4618
+ onClick: function onClick() {
4619
+ onResetPw(values.email || "");
4620
+ }
4621
+ }, "Send forgot password link"), " ", React__default.createElement(reactstrap.Button, {
4745
4622
  color: "success",
4746
4623
  onClick: function onClick() {
4747
4624
  getFile();
4748
- }
4625
+ },
4626
+ className: "ml-4"
4749
4627
  }, "Download user data"), " ")), React__default.createElement("h5", {
4750
4628
  className: "mb-2"
4751
4629
  }, header), React__default.createElement(reactstrap.Row, {
@@ -5339,7 +5217,7 @@ var defaultFilters = {
5339
5217
  searchString: "",
5340
5218
  isRead: false
5341
5219
  };
5342
- var TITLE$a = "Notification list";
5220
+ var TITLE$9 = "Notification list";
5343
5221
  var NOTIFICATION_CHANNEL$1 = "NOTIFICATION_CHANNEL";
5344
5222
  var NEW_NOTIFICATION$1 = "NEW_NOTIFICATION";
5345
5223
 
@@ -5432,7 +5310,7 @@ var useNotificationList = function useNotificationList() {
5432
5310
  }
5433
5311
  }, [filters]);
5434
5312
  React.useEffect(function () {
5435
- document.title = TITLE$a;
5313
+ document.title = TITLE$9;
5436
5314
  }, []);
5437
5315
  React.useEffect(function () {
5438
5316
  getData();
@@ -5682,7 +5560,7 @@ var CommonAlert = function CommonAlert() {
5682
5560
  }, alert.message)) : null;
5683
5561
  };
5684
5562
 
5685
- var schema$5 = yup.object({
5563
+ var schema$4 = yup.object({
5686
5564
  name: yup.string().required("Name is required")
5687
5565
  });
5688
5566
 
@@ -5696,7 +5574,7 @@ var ActionModal = function ActionModal(props, ref) {
5696
5574
  name: targetMedia === null || targetMedia === void 0 ? void 0 : targetMedia.name
5697
5575
  },
5698
5576
  enableReinitialize: true,
5699
- validationSchema: schema$5,
5577
+ validationSchema: schema$4,
5700
5578
  onSubmit: function onSubmit(values, actions) {
5701
5579
  onConfirm && onConfirm(values);
5702
5580
  actions.resetForm();
@@ -5994,7 +5872,7 @@ var get$8 = function get(filter) {
5994
5872
  });
5995
5873
  };
5996
5874
 
5997
- var TITLE$b = "Gallery";
5875
+ var TITLE$a = "Gallery";
5998
5876
  var defaultFilter = {
5999
5877
  searchString: ""
6000
5878
  };
@@ -6231,7 +6109,7 @@ var useGalleryList = function useGalleryList(isLibrary) {
6231
6109
  }
6232
6110
  }, [dispatch, filters]);
6233
6111
  React.useEffect(function () {
6234
- document.title = TITLE$b;
6112
+ document.title = TITLE$a;
6235
6113
  dispatch(setTargetMedia({
6236
6114
  targetMedia: undefined
6237
6115
  }));