mario-core 2.9.325-release → 2.9.326-release

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/dist/index.js CHANGED
@@ -20177,7 +20177,7 @@ var handleUserRole = function handleUserRole(userRoles) {
20177
20177
 
20178
20178
  return userRoles;
20179
20179
  };
20180
- var MARIO_SUCCESS_BASE_URL = "https://mariosuccess.com";
20180
+ var MARIO_SUCCESS_BASE_URL = "https://www.mariosuccess.com";
20181
20181
  var LANGUAGES = [{
20182
20182
  code: "en-US",
20183
20183
  fullName: "English (United States)",
@@ -39768,6 +39768,212 @@ var TheHeaderDropdown = function TheHeaderDropdown(_ref) {
39768
39768
  })), t("log_out")))));
39769
39769
  };
39770
39770
 
39771
+ var apiGetLanguage = function apiGetLanguage() {
39772
+ return api.get(BASE_URL + "/api/language");
39773
+ };
39774
+
39775
+ var apiUpdateLanguage = function apiUpdateLanguage(lang) {
39776
+ return api.put(BASE_URL + "/api/language?lang=" + lang);
39777
+ };
39778
+
39779
+ var LANGUAGE_SYSTEM = "LANGUAGE_SYSTEM";
39780
+
39781
+ var useLanguages = function useLanguages() {
39782
+ var dispatch = reactRedux.useDispatch();
39783
+
39784
+ var _useTranslation = reactI18next.useTranslation(),
39785
+ i18n = _useTranslation.i18n;
39786
+
39787
+ var language = reactRedux.useSelector(function (state) {
39788
+ return state.common.language;
39789
+ });
39790
+ var defaultLanguage = getCookieValue(LANGUAGE_SYSTEM) != null ? getCookieValue(LANGUAGE_SYSTEM) : DEFAULT_LANGUAGE_CODE;
39791
+
39792
+ var _useState = React.useState([]),
39793
+ languageList = _useState[0],
39794
+ setLanguageList = _useState[1];
39795
+
39796
+ var _useState2 = React.useState(false),
39797
+ dropdownOpen = _useState2[0],
39798
+ setDropdownOpen = _useState2[1];
39799
+
39800
+ var _useState3 = React.useState(defaultLanguage),
39801
+ currentLang = _useState3[0],
39802
+ setCurrentLang = _useState3[1];
39803
+
39804
+ var toggle = function toggle() {
39805
+ return setDropdownOpen(function (prevState) {
39806
+ return !prevState;
39807
+ });
39808
+ };
39809
+
39810
+ var changeLanguageApp = function changeLanguageApp(lang) {
39811
+ try {
39812
+ var _temp3 = function _temp3() {
39813
+ dispatch(setLoading(false));
39814
+ };
39815
+
39816
+ dispatch(setLoading(true));
39817
+
39818
+ var _temp4 = _catch(function () {
39819
+ return Promise.resolve(apiUpdateLanguage(lang)).then(function () {
39820
+ i18n.changeLanguage(lang);
39821
+ setCurrentLang(lang);
39822
+ dispatch(setLanguage(lang));
39823
+ });
39824
+ }, function (err) {
39825
+ var _err$response, _err$response$data;
39826
+
39827
+ dispatch(setAlert({
39828
+ type: "danger",
39829
+ 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
39830
+ }));
39831
+ });
39832
+
39833
+ return Promise.resolve(_temp4 && _temp4.then ? _temp4.then(_temp3) : _temp3(_temp4));
39834
+ } catch (e) {
39835
+ return Promise.reject(e);
39836
+ }
39837
+ };
39838
+
39839
+ var getListLanguage = function getListLanguage() {
39840
+ try {
39841
+ var _temp6 = _catch(function () {
39842
+ return Promise.resolve(apiGetLanguage()).then(function (res) {
39843
+ setLanguageList(res.data);
39844
+ });
39845
+ }, function (err) {
39846
+ var _err$response2, _err$response2$data;
39847
+
39848
+ dispatch(setAlert({
39849
+ type: "danger",
39850
+ message: ((_err$response2 = err.response) === null || _err$response2 === void 0 ? void 0 : (_err$response2$data = _err$response2.data) === null || _err$response2$data === void 0 ? void 0 : _err$response2$data.title) || err.message
39851
+ }));
39852
+ });
39853
+
39854
+ return Promise.resolve(_temp6 && _temp6.then ? _temp6.then(function () {}) : void 0);
39855
+ } catch (e) {
39856
+ return Promise.reject(e);
39857
+ }
39858
+ };
39859
+
39860
+ React.useEffect(function () {
39861
+ defaultLanguage != language && changeLanguageApp(defaultLanguage);
39862
+ getListLanguage();
39863
+ }, []);
39864
+ return {
39865
+ languageList: languageList,
39866
+ toggle: toggle,
39867
+ dropdownOpen: dropdownOpen,
39868
+ currentLang: currentLang,
39869
+ changeLanguageApp: changeLanguageApp,
39870
+ setCurrentLang: setCurrentLang
39871
+ };
39872
+ };
39873
+
39874
+ var TheLanguageDropdown = function TheLanguageDropdown() {
39875
+ var _useLanguages = useLanguages(),
39876
+ languageList = _useLanguages.languageList,
39877
+ toggle = _useLanguages.toggle,
39878
+ dropdownOpen = _useLanguages.dropdownOpen,
39879
+ currentLang = _useLanguages.currentLang,
39880
+ changeLanguageApp = _useLanguages.changeLanguageApp;
39881
+
39882
+ var currentLanguage = React.useMemo(function () {
39883
+ var current = languageList.find(function (i) {
39884
+ return i.code === currentLang;
39885
+ });
39886
+ if (!current) return null;
39887
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement("img", {
39888
+ className: "mr-2 " + styles['dropdown-menu-flag'],
39889
+ src: "" + getStaticFileUrl(current.image)
39890
+ }), " ", current.name);
39891
+ }, [currentLang, languageList]);
39892
+ return React__default.createElement(reactstrap.Dropdown, {
39893
+ isOpen: dropdownOpen,
39894
+ toggle: toggle,
39895
+ className: "" + styles["dropdown-menu"]
39896
+ }, React__default.createElement(reactstrap.DropdownToggle, {
39897
+ className: styles["header-avatar"] + " d-flex align-items-center"
39898
+ }, React__default.createElement("span", {
39899
+ style: {
39900
+ color: "#000",
39901
+ textTransform: "capitalize",
39902
+ display: 'flex',
39903
+ alignItems: 'center'
39904
+ }
39905
+ }, currentLanguage, React__default.createElement(bs.BsChevronDown, {
39906
+ className: "ml-2",
39907
+ style: {
39908
+ fontSize: '10px'
39909
+ }
39910
+ }))), React__default.createElement(reactstrap.DropdownMenu, {
39911
+ className: styles["dropdown-content-language"]
39912
+ }, !!languageList && languageList.length > 0 && languageList.map(function (lang, index) {
39913
+ return React__default.createElement(reactstrap.DropdownItem, {
39914
+ key: lang.code,
39915
+ className: styles["dropdown-change"] + " px-0 py-0 " + (index === languageList.length - 1 ? "pb-2" : "pt-2"),
39916
+ onClick: function onClick() {
39917
+ return changeLanguageApp(lang.code);
39918
+ }
39919
+ }, React__default.createElement("div", {
39920
+ className: styles["dropdown-item-language"] + " " + styles["item-logout"] + " " + (currentLang == lang.code ? styles['dropdown-item-language-active'] : "") + " d-flex align-items-center w-100"
39921
+ }, React__default.createElement("span", {
39922
+ className: "mr-2 d-flex hover-opacity"
39923
+ }, React__default.createElement("img", {
39924
+ style: {
39925
+ width: "30px",
39926
+ height: "25px",
39927
+ borderRadius: "5px"
39928
+ },
39929
+ src: getStaticFileUrl(lang.image)
39930
+ })), lang.name));
39931
+ })));
39932
+ };
39933
+
39934
+ var TheHeader = function TheHeader(_ref) {
39935
+ var onToggleModel = _ref.onToggleModel;
39936
+ var dispatch = reactRedux.useDispatch();
39937
+ var sidebarShow = reactRedux.useSelector(function (state) {
39938
+ return state.common.sidebarShow;
39939
+ });
39940
+
39941
+ var _useTranslation = reactI18next.useTranslation(),
39942
+ t = _useTranslation.t;
39943
+
39944
+ var toggleSidebarMobile = function toggleSidebarMobile() {
39945
+ var val = [false, "responsive"].includes(sidebarShow) ? true : "responsive";
39946
+ dispatch(setSidebar(val));
39947
+ };
39948
+
39949
+ var isDistrict = window.location.host.includes("-district");
39950
+ return React__default.createElement(react.CHeader, {
39951
+ withSubheader: true,
39952
+ className: "d-flex align-items-center justify-content-end"
39953
+ }, React__default.createElement(react.CToggler, {
39954
+ inHeader: true,
39955
+ className: "ml-md-3 d-lg-none",
39956
+ onClick: toggleSidebarMobile
39957
+ }), React__default.createElement(react.CHeaderBrand, {
39958
+ className: "mx-auto flex-grow-1 d-lg-none",
39959
+ to: "/"
39960
+ }, React__default.createElement("img", {
39961
+ src: getStaticFileUrl(Images.LOGO_HEADER),
39962
+ className: styles["header-logo"]
39963
+ })), React__default.createElement(react.CHeaderNav, {
39964
+ className: "pr-3"
39965
+ }, React__default.createElement(TheLanguageDropdown, null), React__default.createElement("a", {
39966
+ className: "mr-3",
39967
+ style: {
39968
+ color: '#000'
39969
+ },
39970
+ href: '/privacy-policy',
39971
+ target: "blank"
39972
+ }, t("privacy_policy")), !isDistrict && React__default.createElement(NotificationButton, null), React__default.createElement(TheHeaderDropdown, {
39973
+ onToggleModel: onToggleModel
39974
+ })));
39975
+ };
39976
+
39771
39977
  var TITLE$3 = "Not found";
39772
39978
 
39773
39979
  var NotFound = function NotFound() {
@@ -39825,25 +40031,277 @@ var TheContent = function TheContent(_ref) {
39825
40031
 
39826
40032
  var TheContent$1 = React__default.memo(TheContent);
39827
40033
 
39828
- var buttonTextStyle = {
39829
- fontWeight: 500
40034
+ var loadingStyle = {
40035
+ minWidth: "100vw",
40036
+ minHeight: "100vh",
40037
+ position: "fixed",
40038
+ top: 0,
40039
+ left: 0,
40040
+ zIndex: 999999999,
40041
+ backgroundColor: "rgba(0, 0, 0, 0.4)",
40042
+ display: "flex",
40043
+ justifyContent: "center",
40044
+ alignItems: "center"
39830
40045
  };
39831
- var buttonStyle = {
39832
- height: 38
40046
+
40047
+ var Loading = function Loading() {
40048
+ var isLoading = reactRedux.useSelector(function (state) {
40049
+ return state.common.isLoading;
40050
+ });
40051
+ localStorage.setItem("LAST_TIME_REQUETST", moment().utc().format("YYYY-MM-DD HH:mm:ss"));
40052
+ return isLoading ? React__default.createElement("div", {
40053
+ style: loadingStyle
40054
+ }, React__default.createElement("div", {
40055
+ className: "spinner-border text-secondary",
40056
+ role: "status"
40057
+ }, React__default.createElement("span", {
40058
+ className: "sr-only"
40059
+ }, "Loading..."))) : null;
39833
40060
  };
39834
40061
 
39835
- var AddButton = function AddButton(_ref) {
39836
- var text = _ref.text,
39837
- onClick = _ref.onClick;
39838
- return React__default.createElement(reactstrap.Button, {
39839
- onClick: onClick,
39840
- color: 'success',
39841
- style: buttonStyle,
39842
- className: 'd-flex align-items-center'
39843
- }, React__default.createElement(fa.FaPlus, null), React__default.createElement("span", {
39844
- className: 'ml-2',
39845
- style: buttonTextStyle
39846
- }, text));
40062
+ var firstCheckToken = function firstCheckToken() {
40063
+ return Promise.resolve(_catch(function () {
40064
+ var token = getAccessToken();
40065
+ return token ? Promise.resolve(checkToken(token)).then(function (tokenStatus) {
40066
+ return tokenStatus.data ? true : false;
40067
+ }) : false;
40068
+ }, function () {
40069
+ return false;
40070
+ }));
40071
+ };
40072
+
40073
+ var canAccess = function canAccess(userRoles, componentRoles) {
40074
+ if (!Array.isArray(userRoles)) {
40075
+ return false;
40076
+ }
40077
+
40078
+ if (Array.isArray(componentRoles)) {
40079
+ var intersects = userRoles.filter(function (i) {
40080
+ return componentRoles.includes(i);
40081
+ });
40082
+ return intersects.length > 0;
40083
+ }
40084
+
40085
+ return true;
40086
+ };
40087
+
40088
+ var ModelSelectRole = function ModelSelectRole(_ref) {
40089
+ var _handleUserRole;
40090
+
40091
+ var open = _ref.open,
40092
+ onToggleModel = _ref.onToggleModel;
40093
+ var dispatch = reactRedux.useDispatch();
40094
+
40095
+ var _useTranslation = reactI18next.useTranslation(),
40096
+ t = _useTranslation.t;
40097
+
40098
+ var history = reactRouterDom.useHistory();
40099
+ var pathname = window.location.pathname;
40100
+ var user = reactRedux.useSelector(function (state) {
40101
+ return state.common.user;
40102
+ });
40103
+ var roles = user === null || user === void 0 ? void 0 : user.roles;
40104
+
40105
+ var handleSelectUserRoles = function handleSelectUserRoles(roles) {
40106
+ dispatch(setLoading(true));
40107
+ var roleSelect = roles.includes("Teacher/Assistant") ? ["Teacher", "Assistant"] : roles;
40108
+ dispatch(setUser(_extends({}, user, {
40109
+ roles: roleSelect
40110
+ })));
40111
+ localStorage.setItem("ROLES", roleSelect.toString());
40112
+ onToggleModel();
40113
+
40114
+ if (roles.includes("Parent")) {
40115
+ history.push("/parent");
40116
+ } else if (roles.includes("Admin")) {
40117
+ history.push("/admin/home");
40118
+ } else {
40119
+ pathname !== "/home" ? history.push("/home") : window.location.reload();
40120
+ }
40121
+ };
40122
+
40123
+ return React__default.createElement(reactstrap.Modal, {
40124
+ isOpen: open,
40125
+ toggle: function toggle() {
40126
+ return onToggleModel();
40127
+ },
40128
+ className: "" + styles["model-switch-roles"],
40129
+ centered: true
40130
+ }, React__default.createElement("p", {
40131
+ className: "" + styles["title"]
40132
+ }, t("continue_as")), React__default.createElement("div", null, (_handleUserRole = handleUserRole(user === null || user === void 0 ? void 0 : user.roles)) === null || _handleUserRole === void 0 ? void 0 : _handleUserRole.map(function (r) {
40133
+ return React__default.createElement("p", {
40134
+ key: r,
40135
+ className: styles["item-select-role"] + " " + styles[roles.includes("Teacher") && roles.includes("Assistant") && r === "Teacher/Assistant" && !roles.includes("Admin") || roles.includes("Admin") && r === "Admin" || roles.includes(r) && !roles.includes("Admin") ? "item-role-active" : ""],
40136
+ onClick: function onClick() {
40137
+ return handleSelectUserRoles([r]);
40138
+ }
40139
+ }, r == "SecondaryTeacher" ? "Support Teacher" : r);
40140
+ })));
40141
+ };
40142
+
40143
+ var TheLayout = function TheLayout(_ref) {
40144
+ var routes = _ref.routes,
40145
+ navigation = _ref.navigation;
40146
+ var history = reactRouterDom.useHistory();
40147
+ var dispatch = reactRedux.useDispatch();
40148
+ var user = reactRedux.useSelector(function (state) {
40149
+ return state.common.user;
40150
+ });
40151
+ var language = reactRedux.useSelector(function (state) {
40152
+ return state.common.language;
40153
+ });
40154
+
40155
+ var _useState = React.useState(false),
40156
+ openModelSelectRole = _useState[0],
40157
+ setOpenModelSelectRole = _useState[1];
40158
+
40159
+ var _useTranslation = reactI18next.useTranslation(),
40160
+ t = _useTranslation.t;
40161
+
40162
+ var location = reactRouterDom.useLocation();
40163
+ var isNotification = location.pathname.includes("notifications");
40164
+ var isDistrict = window.location.host.includes("-district");
40165
+
40166
+ var handleToggleModel = function handleToggleModel() {
40167
+ setOpenModelSelectRole(!openModelSelectRole);
40168
+ };
40169
+
40170
+ var authRoutes = React.useMemo(function () {
40171
+ return routes.filter(function (route) {
40172
+ return canAccess(user === null || user === void 0 ? void 0 : user.roles, route.roles);
40173
+ }).filter(function (route) {
40174
+ return !!route.isDistrict === isDistrict;
40175
+ });
40176
+ }, [user, language]);
40177
+ var authNavigations = React.useMemo(function () {
40178
+ return navigation.map(function (item) {
40179
+ var _item$_children, _item$_children2;
40180
+
40181
+ return _extends({}, item, {
40182
+ name: t(item.name),
40183
+ _children: item !== null && item !== void 0 && (_item$_children = item._children) !== null && _item$_children !== void 0 && _item$_children.length ? item === null || item === void 0 ? void 0 : (_item$_children2 = item._children) === null || _item$_children2 === void 0 ? void 0 : _item$_children2.map(function (x) {
40184
+ return _extends({}, x, {
40185
+ name: t(x.name)
40186
+ });
40187
+ }) : undefined
40188
+ });
40189
+ }).filter(function (nav) {
40190
+ return canAccess(user === null || user === void 0 ? void 0 : user.roles, nav.roles);
40191
+ }).filter(function (nav) {
40192
+ return !!nav.isDistrict === isDistrict;
40193
+ });
40194
+ }, [user, language]);
40195
+
40196
+ var getInformationSetting = function getInformationSetting() {
40197
+ try {
40198
+ var _temp2 = _catch(function () {
40199
+ return Promise.resolve(getSchoolSettings()).then(function (res) {
40200
+ dispatch(setSandboxMode(res.data.isSandboxMode));
40201
+ });
40202
+ }, function (err) {
40203
+ console.error(err);
40204
+ });
40205
+
40206
+ return Promise.resolve(_temp2 && _temp2.then ? _temp2.then(function () {}) : void 0);
40207
+ } catch (e) {
40208
+ return Promise.reject(e);
40209
+ }
40210
+ };
40211
+
40212
+ React.useEffect(function () {
40213
+ checkAuthentication();
40214
+ }, []);
40215
+ React.useEffect(function () {
40216
+ getInformationSetting();
40217
+ }, [location.pathname]);
40218
+
40219
+ var checkAuthentication = function checkAuthentication() {
40220
+ try {
40221
+ var _temp4 = _catch(function () {
40222
+ return Promise.resolve(firstCheckToken()).then(function (tokenStatus) {
40223
+ tokenStatus ? loadInfo() : resetAuth();
40224
+ });
40225
+ }, function () {
40226
+ resetAuth();
40227
+ });
40228
+
40229
+ return Promise.resolve(_temp4 && _temp4.then ? _temp4.then(function () {}) : void 0);
40230
+ } catch (e) {
40231
+ return Promise.reject(e);
40232
+ }
40233
+ };
40234
+
40235
+ var loadInfo = function loadInfo() {
40236
+ try {
40237
+ var _temp6 = _catch(function () {
40238
+ return Promise.resolve(getInfo()).then(function (info) {
40239
+ var _info$data, _info$data$roles;
40240
+
40241
+ if (!info || !(info !== null && info !== void 0 && (_info$data = info.data) !== null && _info$data !== void 0 && (_info$data$roles = _info$data.roles) !== null && _info$data$roles !== void 0 && _info$data$roles.includes("Admin"))) {
40242
+ resetAuth();
40243
+ }
40244
+
40245
+ dispatch(setUser(info.data));
40246
+ });
40247
+ }, function () {
40248
+ resetAuth();
40249
+ });
40250
+
40251
+ return Promise.resolve(_temp6 && _temp6.then ? _temp6.then(function () {}) : void 0);
40252
+ } catch (e) {
40253
+ return Promise.reject(e);
40254
+ }
40255
+ };
40256
+
40257
+ var resetAuth = function resetAuth() {
40258
+ localStorage.removeItem(ACCESS_TOKEN);
40259
+ sessionStorage.removeItem(ACCESS_TOKEN);
40260
+ localStorage.removeItem("ROLES");
40261
+ history.push("/");
40262
+ };
40263
+
40264
+ if (!user) {
40265
+ return React__default.createElement(Loading, null);
40266
+ }
40267
+
40268
+ return React__default.createElement("div", {
40269
+ className: "c-app c-default-layout"
40270
+ }, !isNotification && React__default.createElement(TheSidebar, {
40271
+ navigation: authNavigations
40272
+ }), React__default.createElement("div", {
40273
+ className: "c-wrapper"
40274
+ }, !isNotification && React__default.createElement(TheHeader, {
40275
+ onToggleModel: handleToggleModel
40276
+ }), React__default.createElement("div", {
40277
+ className: "c-body bg-white"
40278
+ }, React__default.createElement(TheContent$1, {
40279
+ routes: authRoutes
40280
+ }))), React__default.createElement(ModelSelectRole, {
40281
+ open: openModelSelectRole,
40282
+ onToggleModel: handleToggleModel
40283
+ }));
40284
+ };
40285
+
40286
+ var buttonTextStyle = {
40287
+ fontWeight: 500
40288
+ };
40289
+ var buttonStyle = {
40290
+ height: 38
40291
+ };
40292
+
40293
+ var AddButton = function AddButton(_ref) {
40294
+ var text = _ref.text,
40295
+ onClick = _ref.onClick;
40296
+ return React__default.createElement(reactstrap.Button, {
40297
+ onClick: onClick,
40298
+ color: 'success',
40299
+ style: buttonStyle,
40300
+ className: 'd-flex align-items-center'
40301
+ }, React__default.createElement(fa.FaPlus, null), React__default.createElement("span", {
40302
+ className: 'ml-2',
40303
+ style: buttonTextStyle
40304
+ }, text));
39847
40305
  };
39848
40306
 
39849
40307
  var DeleteButtonIcon = function DeleteButtonIcon(_ref) {
@@ -45637,42 +46095,14 @@ var UserDetail = function UserDetail() {
45637
46095
  });
45638
46096
  };
45639
46097
 
45640
- var loadingStyle = {
45641
- minWidth: "100vw",
45642
- minHeight: "100vh",
45643
- position: "fixed",
45644
- top: 0,
45645
- left: 0,
45646
- zIndex: 999999999,
45647
- backgroundColor: "rgba(0, 0, 0, 0.4)",
45648
- display: "flex",
45649
- justifyContent: "center",
45650
- alignItems: "center"
45651
- };
45652
-
45653
- var Loading = function Loading() {
45654
- var isLoading = reactRedux.useSelector(function (state) {
45655
- return state.common.isLoading;
45656
- });
45657
- localStorage.setItem("LAST_TIME_REQUETST", moment().utc().format("YYYY-MM-DD HH:mm:ss"));
45658
- return isLoading ? React__default.createElement("div", {
45659
- style: loadingStyle
45660
- }, React__default.createElement("div", {
45661
- className: "spinner-border text-secondary",
45662
- role: "status"
45663
- }, React__default.createElement("span", {
45664
- className: "sr-only"
45665
- }, "Loading..."))) : null;
45666
- };
45667
-
45668
- var ScrollToTop = function ScrollToTop() {
45669
- var _useLocation = reactRouterDom.useLocation(),
45670
- pathname = _useLocation.pathname;
45671
-
45672
- React.useEffect(function () {
45673
- window.scrollTo(0, 0);
45674
- }, [pathname]);
45675
- return null;
46098
+ var ScrollToTop = function ScrollToTop() {
46099
+ var _useLocation = reactRouterDom.useLocation(),
46100
+ pathname = _useLocation.pathname;
46101
+
46102
+ React.useEffect(function () {
46103
+ window.scrollTo(0, 0);
46104
+ }, [pathname]);
46105
+ return null;
45676
46106
  };
45677
46107
 
45678
46108
  var modalInfo = function modalInfo(type) {
@@ -48684,32 +49114,6 @@ var store = toolkit.configureStore({
48684
49114
  }
48685
49115
  });
48686
49116
 
48687
- var firstCheckToken = function firstCheckToken() {
48688
- return Promise.resolve(_catch(function () {
48689
- var token = getAccessToken();
48690
- return token ? Promise.resolve(checkToken(token)).then(function (tokenStatus) {
48691
- return tokenStatus.data ? true : false;
48692
- }) : false;
48693
- }, function () {
48694
- return false;
48695
- }));
48696
- };
48697
-
48698
- var canAccess = function canAccess(userRoles, componentRoles) {
48699
- if (!Array.isArray(userRoles)) {
48700
- return false;
48701
- }
48702
-
48703
- if (Array.isArray(componentRoles)) {
48704
- var intersects = userRoles.filter(function (i) {
48705
- return componentRoles.includes(i);
48706
- });
48707
- return intersects.length > 0;
48708
- }
48709
-
48710
- return true;
48711
- };
48712
-
48713
49117
  var isInViewport = function isInViewport(el) {
48714
49118
  var rect = el === null || el === void 0 ? void 0 : el.getBoundingClientRect();
48715
49119
  return rect.top >= 0 && rect.left >= 0 && rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && rect.right <= (window.innerWidth || document.documentElement.clientWidth);
@@ -48745,412 +49149,6 @@ var generateRandomString = (function () {
48745
49149
 
48746
49150
  var amplitudeClient = amplitude.getInstance();
48747
49151
 
48748
- var apiGetLanguage = function apiGetLanguage() {
48749
- return api.get(BASE_URL + "/api/language");
48750
- };
48751
-
48752
- var apiUpdateLanguage = function apiUpdateLanguage(lang) {
48753
- return api.put(BASE_URL + "/api/language?lang=" + lang);
48754
- };
48755
-
48756
- var LANGUAGE_SYSTEM = "LANGUAGE_SYSTEM";
48757
-
48758
- var useLanguages = function useLanguages() {
48759
- var dispatch = reactRedux.useDispatch();
48760
-
48761
- var _useTranslation = reactI18next.useTranslation(),
48762
- i18n = _useTranslation.i18n;
48763
-
48764
- var language = reactRedux.useSelector(function (state) {
48765
- return state.common.language;
48766
- });
48767
- var defaultLanguage = getCookieValue(LANGUAGE_SYSTEM) != null ? getCookieValue(LANGUAGE_SYSTEM) : DEFAULT_LANGUAGE_CODE;
48768
-
48769
- var _useState = React.useState([]),
48770
- languageList = _useState[0],
48771
- setLanguageList = _useState[1];
48772
-
48773
- var _useState2 = React.useState(false),
48774
- dropdownOpen = _useState2[0],
48775
- setDropdownOpen = _useState2[1];
48776
-
48777
- var _useState3 = React.useState(defaultLanguage),
48778
- currentLang = _useState3[0],
48779
- setCurrentLang = _useState3[1];
48780
-
48781
- var toggle = function toggle() {
48782
- return setDropdownOpen(function (prevState) {
48783
- return !prevState;
48784
- });
48785
- };
48786
-
48787
- var changeLanguageApp = function changeLanguageApp(lang) {
48788
- try {
48789
- var _temp3 = function _temp3() {
48790
- dispatch(setLoading(false));
48791
- };
48792
-
48793
- dispatch(setLoading(true));
48794
-
48795
- var _temp4 = _catch(function () {
48796
- return Promise.resolve(apiUpdateLanguage(lang)).then(function () {
48797
- i18n.changeLanguage(lang);
48798
- setCurrentLang(lang);
48799
- dispatch(setLanguage(lang));
48800
- });
48801
- }, function (err) {
48802
- var _err$response, _err$response$data;
48803
-
48804
- dispatch(setAlert({
48805
- type: "danger",
48806
- 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
48807
- }));
48808
- });
48809
-
48810
- return Promise.resolve(_temp4 && _temp4.then ? _temp4.then(_temp3) : _temp3(_temp4));
48811
- } catch (e) {
48812
- return Promise.reject(e);
48813
- }
48814
- };
48815
-
48816
- var getListLanguage = function getListLanguage() {
48817
- try {
48818
- var _temp6 = _catch(function () {
48819
- return Promise.resolve(apiGetLanguage()).then(function (res) {
48820
- setLanguageList(res.data);
48821
- });
48822
- }, function (err) {
48823
- var _err$response2, _err$response2$data;
48824
-
48825
- dispatch(setAlert({
48826
- type: "danger",
48827
- message: ((_err$response2 = err.response) === null || _err$response2 === void 0 ? void 0 : (_err$response2$data = _err$response2.data) === null || _err$response2$data === void 0 ? void 0 : _err$response2$data.title) || err.message
48828
- }));
48829
- });
48830
-
48831
- return Promise.resolve(_temp6 && _temp6.then ? _temp6.then(function () {}) : void 0);
48832
- } catch (e) {
48833
- return Promise.reject(e);
48834
- }
48835
- };
48836
-
48837
- React.useEffect(function () {
48838
- defaultLanguage != language && changeLanguageApp(defaultLanguage);
48839
- getListLanguage();
48840
- }, []);
48841
- return {
48842
- languageList: languageList,
48843
- toggle: toggle,
48844
- dropdownOpen: dropdownOpen,
48845
- currentLang: currentLang,
48846
- changeLanguageApp: changeLanguageApp,
48847
- setCurrentLang: setCurrentLang
48848
- };
48849
- };
48850
-
48851
- var TheLanguageDropdown = function TheLanguageDropdown() {
48852
- var _useLanguages = useLanguages(),
48853
- languageList = _useLanguages.languageList,
48854
- toggle = _useLanguages.toggle,
48855
- dropdownOpen = _useLanguages.dropdownOpen,
48856
- currentLang = _useLanguages.currentLang,
48857
- changeLanguageApp = _useLanguages.changeLanguageApp;
48858
-
48859
- var currentLanguage = React.useMemo(function () {
48860
- var current = languageList.find(function (i) {
48861
- return i.code === currentLang;
48862
- });
48863
- if (!current) return null;
48864
- return React__default.createElement(React__default.Fragment, null, React__default.createElement("img", {
48865
- className: "mr-2 " + styles['dropdown-menu-flag'],
48866
- src: "" + getStaticFileUrl(current.image)
48867
- }), " ", current.name);
48868
- }, [currentLang, languageList]);
48869
- return React__default.createElement(reactstrap.Dropdown, {
48870
- isOpen: dropdownOpen,
48871
- toggle: toggle,
48872
- className: "" + styles["dropdown-menu"]
48873
- }, React__default.createElement(reactstrap.DropdownToggle, {
48874
- className: styles["header-avatar"] + " d-flex align-items-center"
48875
- }, React__default.createElement("span", {
48876
- style: {
48877
- color: "#000",
48878
- textTransform: "capitalize",
48879
- display: 'flex',
48880
- alignItems: 'center'
48881
- }
48882
- }, currentLanguage, React__default.createElement(bs.BsChevronDown, {
48883
- className: "ml-2",
48884
- style: {
48885
- fontSize: '10px'
48886
- }
48887
- }))), React__default.createElement(reactstrap.DropdownMenu, {
48888
- className: styles["dropdown-content-language"]
48889
- }, !!languageList && languageList.length > 0 && languageList.map(function (lang, index) {
48890
- return React__default.createElement(reactstrap.DropdownItem, {
48891
- key: lang.code,
48892
- className: styles["dropdown-change"] + " px-0 py-0 " + (index === languageList.length - 1 ? "pb-2" : "pt-2"),
48893
- onClick: function onClick() {
48894
- return changeLanguageApp(lang.code);
48895
- }
48896
- }, React__default.createElement("div", {
48897
- className: styles["dropdown-item-language"] + " " + styles["item-logout"] + " " + (currentLang == lang.code ? styles['dropdown-item-language-active'] : "") + " d-flex align-items-center w-100"
48898
- }, React__default.createElement("span", {
48899
- className: "mr-2 d-flex hover-opacity"
48900
- }, React__default.createElement("img", {
48901
- style: {
48902
- width: "30px",
48903
- height: "25px",
48904
- borderRadius: "5px"
48905
- },
48906
- src: getStaticFileUrl(lang.image)
48907
- })), lang.name));
48908
- })));
48909
- };
48910
-
48911
- var TheHeader = function TheHeader(_ref) {
48912
- var onToggleModel = _ref.onToggleModel;
48913
- var dispatch = reactRedux.useDispatch();
48914
- var sidebarShow = reactRedux.useSelector(function (state) {
48915
- return state.common.sidebarShow;
48916
- });
48917
-
48918
- var _useTranslation = reactI18next.useTranslation(),
48919
- t = _useTranslation.t;
48920
-
48921
- var toggleSidebarMobile = function toggleSidebarMobile() {
48922
- var val = [false, "responsive"].includes(sidebarShow) ? true : "responsive";
48923
- dispatch(setSidebar(val));
48924
- };
48925
-
48926
- var isDistrict = window.location.host.includes("-district");
48927
- return React__default.createElement(react.CHeader, {
48928
- withSubheader: true,
48929
- className: "d-flex align-items-center justify-content-end"
48930
- }, React__default.createElement(react.CToggler, {
48931
- inHeader: true,
48932
- className: "ml-md-3 d-lg-none",
48933
- onClick: toggleSidebarMobile
48934
- }), React__default.createElement(react.CHeaderBrand, {
48935
- className: "mx-auto flex-grow-1 d-lg-none",
48936
- to: "/"
48937
- }, React__default.createElement("img", {
48938
- src: getStaticFileUrl(Images.LOGO_HEADER),
48939
- className: styles["header-logo"]
48940
- })), React__default.createElement(react.CHeaderNav, {
48941
- className: "pr-3"
48942
- }, React__default.createElement(TheLanguageDropdown, null), React__default.createElement("a", {
48943
- className: "mr-3",
48944
- style: {
48945
- color: '#000'
48946
- },
48947
- href: '/privacy-policy',
48948
- target: "blank"
48949
- }, t("privacy_policy")), !isDistrict && React__default.createElement(NotificationButton, null), React__default.createElement(TheHeaderDropdown, {
48950
- onToggleModel: onToggleModel
48951
- })));
48952
- };
48953
-
48954
- var ModelSelectRole = function ModelSelectRole(_ref) {
48955
- var _handleUserRole;
48956
-
48957
- var open = _ref.open,
48958
- onToggleModel = _ref.onToggleModel;
48959
- var dispatch = reactRedux.useDispatch();
48960
-
48961
- var _useTranslation = reactI18next.useTranslation(),
48962
- t = _useTranslation.t;
48963
-
48964
- var history = reactRouterDom.useHistory();
48965
- var pathname = window.location.pathname;
48966
- var user = reactRedux.useSelector(function (state) {
48967
- return state.common.user;
48968
- });
48969
- var roles = user === null || user === void 0 ? void 0 : user.roles;
48970
-
48971
- var handleSelectUserRoles = function handleSelectUserRoles(roles) {
48972
- dispatch(setLoading(true));
48973
- var roleSelect = roles.includes("Teacher/Assistant") ? ["Teacher", "Assistant"] : roles;
48974
- dispatch(setUser(_extends({}, user, {
48975
- roles: roleSelect
48976
- })));
48977
- localStorage.setItem("ROLES", roleSelect.toString());
48978
- onToggleModel();
48979
-
48980
- if (roles.includes("Parent")) {
48981
- history.push("/parent");
48982
- } else if (roles.includes("Admin")) {
48983
- history.push("/admin/home");
48984
- } else {
48985
- pathname !== "/home" ? history.push("/home") : window.location.reload();
48986
- }
48987
- };
48988
-
48989
- return React__default.createElement(reactstrap.Modal, {
48990
- isOpen: open,
48991
- toggle: function toggle() {
48992
- return onToggleModel();
48993
- },
48994
- className: "" + styles["model-switch-roles"],
48995
- centered: true
48996
- }, React__default.createElement("p", {
48997
- className: "" + styles["title"]
48998
- }, t("continue_as")), React__default.createElement("div", null, (_handleUserRole = handleUserRole(user === null || user === void 0 ? void 0 : user.roles)) === null || _handleUserRole === void 0 ? void 0 : _handleUserRole.map(function (r) {
48999
- return React__default.createElement("p", {
49000
- key: r,
49001
- className: styles["item-select-role"] + " " + styles[roles.includes("Teacher") && roles.includes("Assistant") && r === "Teacher/Assistant" && !roles.includes("Admin") || roles.includes("Admin") && r === "Admin" || roles.includes(r) && !roles.includes("Admin") ? "item-role-active" : ""],
49002
- onClick: function onClick() {
49003
- return handleSelectUserRoles([r]);
49004
- }
49005
- }, r == "SecondaryTeacher" ? "Support Teacher" : r);
49006
- })));
49007
- };
49008
-
49009
- var TheLayout = function TheLayout(_ref) {
49010
- var routes = _ref.routes,
49011
- navigation = _ref.navigation;
49012
- var history = reactRouterDom.useHistory();
49013
- var dispatch = reactRedux.useDispatch();
49014
- var user = reactRedux.useSelector(function (state) {
49015
- return state.common.user;
49016
- });
49017
- var language = reactRedux.useSelector(function (state) {
49018
- return state.common.language;
49019
- });
49020
-
49021
- var _useState = React.useState(false),
49022
- openModelSelectRole = _useState[0],
49023
- setOpenModelSelectRole = _useState[1];
49024
-
49025
- var _useTranslation = reactI18next.useTranslation(),
49026
- t = _useTranslation.t;
49027
-
49028
- var location = reactRouterDom.useLocation();
49029
- var isNotification = location.pathname.includes("notifications");
49030
- var isDistrict = window.location.host.includes("-district");
49031
-
49032
- var handleToggleModel = function handleToggleModel() {
49033
- setOpenModelSelectRole(!openModelSelectRole);
49034
- };
49035
-
49036
- var authRoutes = React.useMemo(function () {
49037
- return routes.filter(function (route) {
49038
- return canAccess(user === null || user === void 0 ? void 0 : user.roles, route.roles);
49039
- }).filter(function (route) {
49040
- return !!route.isDistrict === isDistrict;
49041
- });
49042
- }, [user, language]);
49043
- var authNavigations = React.useMemo(function () {
49044
- return navigation.map(function (item) {
49045
- var _item$_children, _item$_children2;
49046
-
49047
- return _extends({}, item, {
49048
- name: t(item.name),
49049
- _children: item !== null && item !== void 0 && (_item$_children = item._children) !== null && _item$_children !== void 0 && _item$_children.length ? item === null || item === void 0 ? void 0 : (_item$_children2 = item._children) === null || _item$_children2 === void 0 ? void 0 : _item$_children2.map(function (x) {
49050
- return _extends({}, x, {
49051
- name: t(x.name)
49052
- });
49053
- }) : undefined
49054
- });
49055
- }).filter(function (nav) {
49056
- return canAccess(user === null || user === void 0 ? void 0 : user.roles, nav.roles);
49057
- }).filter(function (nav) {
49058
- return !!nav.isDistrict === isDistrict;
49059
- });
49060
- }, [user, language]);
49061
-
49062
- var getInformationSetting = function getInformationSetting() {
49063
- try {
49064
- var _temp2 = _catch(function () {
49065
- return Promise.resolve(getSchoolSettings()).then(function (res) {
49066
- dispatch(setSandboxMode(res.data.isSandboxMode));
49067
- });
49068
- }, function (err) {
49069
- console.error(err);
49070
- });
49071
-
49072
- return Promise.resolve(_temp2 && _temp2.then ? _temp2.then(function () {}) : void 0);
49073
- } catch (e) {
49074
- return Promise.reject(e);
49075
- }
49076
- };
49077
-
49078
- React.useEffect(function () {
49079
- checkAuthentication();
49080
- }, []);
49081
- React.useEffect(function () {
49082
- getInformationSetting();
49083
- }, [location.pathname]);
49084
-
49085
- var checkAuthentication = function checkAuthentication() {
49086
- try {
49087
- var _temp4 = _catch(function () {
49088
- return Promise.resolve(firstCheckToken()).then(function (tokenStatus) {
49089
- tokenStatus ? loadInfo() : resetAuth();
49090
- });
49091
- }, function () {
49092
- resetAuth();
49093
- });
49094
-
49095
- return Promise.resolve(_temp4 && _temp4.then ? _temp4.then(function () {}) : void 0);
49096
- } catch (e) {
49097
- return Promise.reject(e);
49098
- }
49099
- };
49100
-
49101
- var loadInfo = function loadInfo() {
49102
- try {
49103
- var _temp6 = _catch(function () {
49104
- return Promise.resolve(getInfo()).then(function (info) {
49105
- var _info$data, _info$data$roles;
49106
-
49107
- if (!info || !(info !== null && info !== void 0 && (_info$data = info.data) !== null && _info$data !== void 0 && (_info$data$roles = _info$data.roles) !== null && _info$data$roles !== void 0 && _info$data$roles.includes("Admin"))) {
49108
- resetAuth();
49109
- }
49110
-
49111
- dispatch(setUser(info.data));
49112
- });
49113
- }, function () {
49114
- resetAuth();
49115
- });
49116
-
49117
- return Promise.resolve(_temp6 && _temp6.then ? _temp6.then(function () {}) : void 0);
49118
- } catch (e) {
49119
- return Promise.reject(e);
49120
- }
49121
- };
49122
-
49123
- var resetAuth = function resetAuth() {
49124
- localStorage.removeItem(ACCESS_TOKEN);
49125
- sessionStorage.removeItem(ACCESS_TOKEN);
49126
- localStorage.removeItem("ROLES");
49127
- history.push("/");
49128
- };
49129
-
49130
- if (!user) {
49131
- return React__default.createElement(Loading, null);
49132
- }
49133
-
49134
- return React__default.createElement("div", {
49135
- className: "c-app c-default-layout"
49136
- }, !isNotification && React__default.createElement(TheSidebar, {
49137
- navigation: authNavigations
49138
- }), React__default.createElement("div", {
49139
- className: "c-wrapper"
49140
- }, !isNotification && React__default.createElement(TheHeader, {
49141
- onToggleModel: handleToggleModel
49142
- }), React__default.createElement("div", {
49143
- className: "c-body bg-white"
49144
- }, React__default.createElement(TheContent$1, {
49145
- routes: authRoutes
49146
- }))), React__default.createElement(ModelSelectRole, {
49147
- open: openModelSelectRole,
49148
- onToggleModel: handleToggleModel
49149
- }));
49150
- };
49151
-
49152
- var amplitudeClient$1 = amplitude.getInstance();
49153
-
49154
49152
  Object.defineProperty(exports, 'I18nextProvider', {
49155
49153
  enumerable: true,
49156
49154
  get: function () {
@@ -49238,7 +49236,7 @@ exports.UserContainer = UserContainer;
49238
49236
  exports.UserDetail = UserDetail;
49239
49237
  exports.UserList = UserList;
49240
49238
  exports.addTab = addTab;
49241
- exports.amplitudeClient = amplitudeClient$1;
49239
+ exports.amplitudeClient = amplitudeClient;
49242
49240
  exports.answerQuestion = answerQuestion;
49243
49241
  exports.answerQuestionDataPlayer = answerQuestionDataPlayer;
49244
49242
  exports.api = api;