mario-core 2.9.108-beta → 2.9.111-beta

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.
@@ -11,6 +11,7 @@ import { useDispatch, useSelector } from 'react-redux';
11
11
  import { createAction, createReducer, configureStore } from '@reduxjs/toolkit';
12
12
  import axios from 'axios';
13
13
  import amplitude from 'amplitude-js';
14
+ import moment from 'moment';
14
15
  import { useGoogleReCaptcha, GoogleReCaptcha, GoogleReCaptchaProvider } from 'react-google-recaptcha-v3';
15
16
  import GoogleLogin from 'react-google-login';
16
17
  import Select from 'react-select';
@@ -31,7 +32,6 @@ import Creatable from 'react-select/creatable';
31
32
  import ReactNotification$1 from 'react-notifications-component';
32
33
  import 'react-notifications-component/dist/theme.css';
33
34
  import { AiOutlineEye } from 'react-icons/ai';
34
- import moment from 'moment';
35
35
 
36
36
  var dashboard = "Dashboard";
37
37
  var user = "User";
@@ -2713,6 +2713,7 @@ var apiUpload = axios.create({
2713
2713
 
2714
2714
  if (token) {
2715
2715
  config.headers.Authorization = "Bearer " + token;
2716
+ localStorage.setItem("LAST_TIME_REQUETST", moment().utc().format("YYYY-MM-DD HH:mm:ss"));
2716
2717
  }
2717
2718
 
2718
2719
  return config;
@@ -4382,6 +4383,7 @@ var Loading = function Loading() {
4382
4383
  var isLoading = useSelector(function (state) {
4383
4384
  return state.common.isLoading;
4384
4385
  });
4386
+ localStorage.setItem("LAST_TIME_REQUETST", moment().utc().format("YYYY-MM-DD HH:mm:ss"));
4385
4387
  return isLoading ? React.createElement("div", {
4386
4388
  style: loadingStyle
4387
4389
  }, React.createElement("div", {
@@ -7559,6 +7561,78 @@ var CommonHeader = function CommonHeader(_ref) {
7559
7561
  }, header))));
7560
7562
  };
7561
7563
 
7564
+ var utcToLocalTime = (function (time, FORMAT) {
7565
+ if (time === DATE_MIN_VALUE) return "";
7566
+
7567
+ try {
7568
+ return moment.utc(time).local().format(FORMAT || "yyyy-MM-DD");
7569
+ } catch (_unused) {
7570
+ return "";
7571
+ }
7572
+ });
7573
+
7574
+ var NotificationLogoutModal = function NotificationLogoutModal() {
7575
+ var _useState = useState(false),
7576
+ isOpen = _useState[0],
7577
+ setIsOpen = _useState[1];
7578
+
7579
+ var _useState2 = useState({
7580
+ minutes: 0,
7581
+ timeLogout: ""
7582
+ }),
7583
+ objTime = _useState2[0],
7584
+ setObjTime = _useState2[1];
7585
+
7586
+ var checkOpenModalLogout = function checkOpenModalLogout() {
7587
+ var lastTimeOut = localStorage.getItem("LAST_TIME_REQUETST");
7588
+ var timeMoment = moment(lastTimeOut, "YYYY-MM-DD HH:mm");
7589
+ var currentTime = moment(moment().utc().format("YYYY-MM-DD HH:mm"));
7590
+ var minutes = currentTime.diff(timeMoment, "minutes");
7591
+ var timeLogout = utcToLocalTime(currentTime.add(16 - minutes, 'minutes').format("YYYY-MM-DD HH:mm"), "HH:mm");
7592
+
7593
+ if (minutes == 13) {
7594
+ var dataTime = {
7595
+ minutes: minutes,
7596
+ timeLogout: timeLogout
7597
+ };
7598
+ setObjTime(dataTime);
7599
+ onToggle();
7600
+ }
7601
+ };
7602
+
7603
+ useEffect(function () {
7604
+ var getAccessToken = localStorage.getItem(ACCESS_TOKEN);
7605
+
7606
+ if (getAccessToken) {
7607
+ var interval = setInterval(function () {
7608
+ checkOpenModalLogout();
7609
+ }, 60 * 1000);
7610
+ return function () {
7611
+ return clearInterval(interval);
7612
+ };
7613
+ }
7614
+
7615
+ return;
7616
+ }, []);
7617
+
7618
+ var onToggle = function onToggle() {
7619
+ setIsOpen(!isOpen);
7620
+ };
7621
+
7622
+ return React.createElement(Modal, {
7623
+ isOpen: isOpen,
7624
+ toggle: onToggle,
7625
+ size: "xs"
7626
+ }, React.createElement(ModalHeader, {
7627
+ toggle: onToggle
7628
+ }, "Notification Logout"), React.createElement(ModalBody, null, "Are you still here? You have had no action for " + (objTime === null || objTime === void 0 ? void 0 : objTime.minutes) + " mins. \n Your account could be log out after " + (15 - (objTime === null || objTime === void 0 ? void 0 : objTime.minutes)) + " mins at " + (objTime === null || objTime === void 0 ? void 0 : objTime.timeLogout) + " if you don't action."), React.createElement(ModalFooter, {
7629
+ className: "text-right"
7630
+ }, React.createElement(Button, {
7631
+ color: "primary",
7632
+ onClick: onToggle
7633
+ }, "Confirm")));
7634
+ };
7635
+
7562
7636
  var EditButtonIcon = function EditButtonIcon(_ref) {
7563
7637
  var onClick = _ref.onClick;
7564
7638
  return React.createElement("div", {
@@ -7984,16 +8058,6 @@ var NotificationStatusSelector = function NotificationStatusSelector(_ref) {
7984
8058
 
7985
8059
  var NotificationStatusSelector$1 = memo(NotificationStatusSelector);
7986
8060
 
7987
- var utcToLocalTime = (function (time, FORMAT) {
7988
- if (time === DATE_MIN_VALUE) return "";
7989
-
7990
- try {
7991
- return moment.utc(time).local().format(FORMAT || "yyyy-MM-DD");
7992
- } catch (_unused) {
7993
- return "";
7994
- }
7995
- });
7996
-
7997
8061
  var defaultFilters = {
7998
8062
  currentPage: 1,
7999
8063
  pageSize: 30,
@@ -10892,5 +10956,5 @@ var UserList = function UserList() {
10892
10956
 
10893
10957
  var amplitudeClient$1 = amplitude.getInstance();
10894
10958
 
10895
- export { ACCESS_TOKEN, ANSWER_EDITOR_HEIGHT, AcademicClassSelector, AddButton, BASE_URL, CHAT_CHANNEL, CategorySelector, CommonAlert, CommonHeader, CommonModal$1 as CommonModal, CreatableSelector, CustomPagination, CustomSelector, CustomTabs as CustomTab, DATE_FORMAT, DATE_RESULT, DEFAULT_FILTER, Dashboard, DeleteButtonIcon, DetailActionButtons, EMOTIONS, EditButtonIcon, EmailTemplateDetail, EmailTemplateList, EmptyDataAlert, ErrorHandler, FULL_DATE_RESULT, FaqList, InputFile as FileInput, GOOGLE_RECAPTCHA_KEY, GalleryList, INIT_AMPLITUDE_KEY_PROD, INIT_AMPLITUDE_KEY_STAGE, Images, LICENSE_AGGRID, LinkEditButton, Loading, Login, MediaList, NOTIFICATION_ALERT_KEY, NOTIFICATION_CHANNEL, NotFound, NotificationList, NotificationModal, QUESTION_TYPES, QUESTION_TYPES_OPTIONS, QuestionCategorySelector, QuestionTypeSelector, QuitPrompt, ReactNotification, RequiredLabel$1 as RequiredLabel, SchoolList, ScrollToTop, SearchBox$1 as SearchBox, SearchBoxContainer, SkillList, StarRatingSelector, SuggestionCategorySelector, TAB_COLORS, TINY_MCE_API_KEY, TheContent$1 as TheContent, TheLayout, ToggleButton, UploadFileButton, UserDetail, UserList, addTab, amplitudeClient$1 as amplitudeClient, answerQuestion, answerQuestionDataPlayer, api, apiUpload, canAccess as canAccessRoute, changeNote, changeTags, clearTab, closeTab, debounce, editTab, editorConfig, firstCheckToken, generateRandomString, getFileUrl, getInfo, getTextFromHTML, i18n, initAmplitude, isInViewport, isLocalhost, reset, setAlert, setAssessmentList, setAssignmentList, setAssistantList, setBadgeList, setBandScoreList, setCertificateList, setClassList, setConferenceRubricList, setConversationOneToOne, setCurrentStudentId, setCurrentStudentName, setCurrentStudentUserId, setCustomAlertList, setDataPlayer, setEditItemQuesion, setEnableIEP, setEnableSurvey, setFeedbackList, setFilterWidget, setGoalExampleList, setImproveMyClass, setLanguage, setLearningSupportCategoryList, setLoading, setMailCategory, setModal, setMoveItemQuestion, setMyStudent, setQuestionByCategory, setQuestionCateList, setQuestionList, setReflectionList, setReflectionResultList, setResetQuestionList, setSchoolBlankDayList, setSelectQuestion, setSemesterList, setSessionPlayer, setSessionTemplateGeneralClassList, setSessionTemplateList, setStartTime, setStrategyList, setStudentIdSelectedByTeacher, setStudentList, setSubjectList, setSuggestionList, setTurnOffPassWhenChangeMode, setTutorialScreenList, setUser, setUserList, showFontSize, showMenuBar, store, systemCertificateUpload, systemStudentBadge, uploadFile, useFilters, useGalleryList, utcToLocalTime };
10959
+ export { ACCESS_TOKEN, ANSWER_EDITOR_HEIGHT, AcademicClassSelector, AddButton, BASE_URL, CHAT_CHANNEL, CategorySelector, CommonAlert, CommonHeader, CommonModal$1 as CommonModal, CreatableSelector, CustomPagination, CustomSelector, CustomTabs as CustomTab, DATE_FORMAT, DATE_RESULT, DEFAULT_FILTER, Dashboard, DeleteButtonIcon, DetailActionButtons, EMOTIONS, EditButtonIcon, EmailTemplateDetail, EmailTemplateList, EmptyDataAlert, ErrorHandler, FULL_DATE_RESULT, FaqList, InputFile as FileInput, GOOGLE_RECAPTCHA_KEY, GalleryList, INIT_AMPLITUDE_KEY_PROD, INIT_AMPLITUDE_KEY_STAGE, Images, LICENSE_AGGRID, LinkEditButton, Loading, Login, MediaList, NOTIFICATION_ALERT_KEY, NOTIFICATION_CHANNEL, NotFound, NotificationList, NotificationLogoutModal, NotificationModal, QUESTION_TYPES, QUESTION_TYPES_OPTIONS, QuestionCategorySelector, QuestionTypeSelector, QuitPrompt, ReactNotification, RequiredLabel$1 as RequiredLabel, SchoolList, ScrollToTop, SearchBox$1 as SearchBox, SearchBoxContainer, SkillList, StarRatingSelector, SuggestionCategorySelector, TAB_COLORS, TINY_MCE_API_KEY, TheContent$1 as TheContent, TheLayout, ToggleButton, UploadFileButton, UserDetail, UserList, addTab, amplitudeClient$1 as amplitudeClient, answerQuestion, answerQuestionDataPlayer, api, apiUpload, canAccess as canAccessRoute, changeNote, changeTags, clearTab, closeTab, debounce, editTab, editorConfig, firstCheckToken, generateRandomString, getFileUrl, getInfo, getTextFromHTML, i18n, initAmplitude, isInViewport, isLocalhost, reset, setAlert, setAssessmentList, setAssignmentList, setAssistantList, setBadgeList, setBandScoreList, setCertificateList, setClassList, setConferenceRubricList, setConversationOneToOne, setCurrentStudentId, setCurrentStudentName, setCurrentStudentUserId, setCustomAlertList, setDataPlayer, setEditItemQuesion, setEnableIEP, setEnableSurvey, setFeedbackList, setFilterWidget, setGoalExampleList, setImproveMyClass, setLanguage, setLearningSupportCategoryList, setLoading, setMailCategory, setModal, setMoveItemQuestion, setMyStudent, setQuestionByCategory, setQuestionCateList, setQuestionList, setReflectionList, setReflectionResultList, setResetQuestionList, setSchoolBlankDayList, setSelectQuestion, setSemesterList, setSessionPlayer, setSessionTemplateGeneralClassList, setSessionTemplateList, setStartTime, setStrategyList, setStudentIdSelectedByTeacher, setStudentList, setSubjectList, setSuggestionList, setTurnOffPassWhenChangeMode, setTutorialScreenList, setUser, setUserList, showFontSize, showMenuBar, store, systemCertificateUpload, systemStudentBadge, uploadFile, useFilters, useGalleryList, utcToLocalTime };
10896
10960
  //# sourceMappingURL=index.modern.js.map