touchstudy-core 0.1.33 → 0.1.35
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/containers/Textbooks/apiClient/examService.d.ts +6 -0
- package/dist/containers/Textbooks/apiClient/examSessionService.d.ts +10 -0
- package/dist/containers/Textbooks/components/dialog/ChapterNameDialog.d.ts +10 -0
- package/dist/containers/Textbooks/components/dialog/CreateExamDrawer.d.ts +11 -0
- package/dist/containers/Textbooks/configs/constants.d.ts +4 -0
- package/dist/containers/Textbooks/configs/interfaces.d.ts +2 -0
- package/dist/containers/Textbooks/configs/types.d.ts +36 -0
- package/dist/containers/Textbooks/hooks/useExam.d.ts +16 -0
- package/dist/containers/Textbooks/hooks/useTextbookDetail.d.ts +9 -0
- package/dist/index.css +280 -51
- package/dist/index.d.ts +2 -1
- package/dist/index.js +1868 -1195
- package/dist/index.js.map +1 -1
- package/dist/index.modern.js +1871 -1199
- package/dist/index.modern.js.map +1 -1
- package/dist/layouts/Header.d.ts +13 -0
- package/dist/layouts/TheAcademyDropdown.d.ts +1 -0
- package/dist/utils/types/tab.d.ts +8 -0
- package/package.json +1 -1
package/dist/index.modern.js
CHANGED
@@ -9,7 +9,7 @@ import { useDispatch, useSelector } from 'react-redux';
|
|
9
9
|
import axios from 'axios';
|
10
10
|
import { useTranslation, initReactI18next } from 'react-i18next';
|
11
11
|
export { I18nextProvider, useTranslation } from 'react-i18next';
|
12
|
-
import { Grid, Dialog, DialogTitle, IconButton, DialogContent, TextField, DialogActions, Button, Box, Typography, Pagination, styled, Tooltip, tooltipClasses, Stack, ClickAwayListener, useMediaQuery, CircularProgress, FormControl, RadioGroup, FormControlLabel, Radio, FormGroup, FormLabel, InputLabel, Container, Table, TableBody, TableRow, TableCell, TableHead, Paper, InputBase } from '@mui/material';
|
12
|
+
import { Grid, Dialog, DialogTitle, IconButton, DialogContent, TextField, DialogActions, Button, Box, Typography, Pagination, styled, Tooltip, tooltipClasses, Stack, ClickAwayListener, useTheme, useMediaQuery, CircularProgress, FormControl, RadioGroup, FormControlLabel, Radio, FormGroup, FormLabel, Checkbox, InputLabel, Container, Table, TableBody, TableRow, TableCell, TableHead, Paper, InputBase } from '@mui/material';
|
13
13
|
import { gapi } from 'gapi-script';
|
14
14
|
import Pusher from 'pusher-js';
|
15
15
|
import { IoClose, IoCloseOutline, IoSearch } from 'react-icons/io5';
|
@@ -24,9 +24,9 @@ import { GoArrowSwitch } from 'react-icons/go';
|
|
24
24
|
import { toast } from 'react-toastify';
|
25
25
|
export { ToastContainer, toast } from 'react-toastify';
|
26
26
|
import Select, { components } from 'react-select';
|
27
|
-
import { FaCaretDown, FaTrash, FaPlus, FaSave, FaPencilAlt, FaSortUp, FaSortDown, FaEye
|
27
|
+
import { FaCaretDown, FaTrash, FaPlus, FaSave, FaPencilAlt, FaPlusCircle, FaTimes, FaSortUp, FaSortDown, FaEye } from 'react-icons/fa';
|
28
28
|
import { PiDotsNineLight } from 'react-icons/pi';
|
29
|
-
import { IoMdArrowBack } from 'react-icons/io';
|
29
|
+
import { IoMdArrowBack, IoIosLogOut } from 'react-icons/io';
|
30
30
|
import _ from 'lodash';
|
31
31
|
import { FaPencil } from 'react-icons/fa6';
|
32
32
|
import CreatableSelect from 'react-select/creatable';
|
@@ -37,6 +37,7 @@ import DialogTitle$1 from '@mui/material/DialogTitle';
|
|
37
37
|
import DialogContent$1 from '@mui/material/DialogContent';
|
38
38
|
import DialogActions$1 from '@mui/material/DialogActions';
|
39
39
|
import Typography$1 from '@mui/material/Typography';
|
40
|
+
import { useLocation, Link } from 'react-router-dom';
|
40
41
|
|
41
42
|
var setLoading = createAction("common/setLoading");
|
42
43
|
var setAlert = createAction("common/setAlert");
|
@@ -136,7 +137,7 @@ function _objectWithoutPropertiesLoose(source, excluded) {
|
|
136
137
|
return target;
|
137
138
|
}
|
138
139
|
|
139
|
-
var
|
140
|
+
var styles = {"btn-login-google":"_2HqmH","block-login":"_wWIyO","box-login":"_38Lo1","btn-primary":"_rd4Uy","dropdown-menu":"_1krbH","header-avatar":"_RQaHE","dropdown-menu-flag":"_XK8oS","dropdown-content":"_3ys4W","dropdown-change":"_ToOW_","item-address":"_3sQlR","item-logout":"_3bqSM","title-address":"_1jgSI","img-avatar":"_35Ttz","item-contact":"_1wc7o","content-text":"_3S4f2","dropdown-content-language":"_3ajui","dropdown-item-language":"_3Y_y4","dropdown-item-language-active":"_CzNMi","dropdown-academy":"_3CMVp","image-academy":"_2ibYC","image-academy--item":"_3RDWF","academy-btn":"_1JMRU","switch-icon":"_N4FNf","dropdown-content-academy":"_31Dr0","dropdown-academy-item":"_3bjcz","noGutters":"_31ZQk","custom-col-2":"_3yXyK","custom-col-3":"_1RsJQ","custom-col-5":"_L42CP","custom-col-10":"_2u6eL","custom-row":"_8x7OP","custom-col":"_1JmTh","custom-col-4":"_3HO1e","custom-col-8":"_Oy31M","custom-col-12":"_3aUKo","custom-container":"_39LRs","form-label":"__Ut-u","form-control":"_2k4dX","btn-outline-primary":"_2PWdX","sort-icons":"_mQvLF","active":"_3oAH-","form-select":"_3W3aw","truncate":"_3NJzN","headers":"_3xnI5","logo-container":"_3YG70","tabBox":"_1CQPn","routerBox":"_3hx2T","tabText":"_3UyhW","router-link-active":"_1TGKA","router-link":"_1AqMh","userImg":"_2RI6G","disabled-link":"_3aVHg"};
|
140
141
|
|
141
142
|
var AuthenticationMessage;
|
142
143
|
(function (AuthenticationMessage) {
|
@@ -463,18 +464,18 @@ var BlockLogin = function BlockLogin(_ref) {
|
|
463
464
|
var handleSubmit = formikProps.handleSubmit;
|
464
465
|
return React.createElement(Grid, {
|
465
466
|
container: true,
|
466
|
-
className: "" +
|
467
|
+
className: "" + styles["box-login"]
|
467
468
|
}, React.createElement(Grid, {
|
468
469
|
item: true,
|
469
470
|
className: "p-0 d-flex justify-content-center"
|
470
471
|
}, React.createElement("form", {
|
471
|
-
className: "" +
|
472
|
+
className: "" + styles["block-login"],
|
472
473
|
onSubmit: handleSubmit
|
473
474
|
}, React.createElement("div", {
|
474
|
-
className: "" +
|
475
|
+
className: "" + styles["block-form"]
|
475
476
|
}, React.createElement("img", {
|
476
477
|
src: "/images/logo.jpeg",
|
477
|
-
className: "" +
|
478
|
+
className: "" + styles["img-login-rectangle"]
|
478
479
|
}), React.createElement("div", {
|
479
480
|
className: "p-0 mt-1 mb-4"
|
480
481
|
}, React.createElement(GoogleLogin, {
|
@@ -483,7 +484,7 @@ var BlockLogin = function BlockLogin(_ref) {
|
|
483
484
|
onSuccess: onSuccessGoogle,
|
484
485
|
onFailure: onFailureGoogle,
|
485
486
|
cookiePolicy: "single_host_origin",
|
486
|
-
className: "" +
|
487
|
+
className: "" + styles["btn-login-google"],
|
487
488
|
isSignedIn: true
|
488
489
|
}))))));
|
489
490
|
});
|
@@ -547,7 +548,7 @@ var Login = function Login(_ref) {
|
|
547
548
|
var _useLogin = useLogin$1(onNavigate),
|
548
549
|
defaultInfo = _useLogin.defaultInfo;
|
549
550
|
return React.createElement("div", {
|
550
|
-
className:
|
551
|
+
className: styles["login"] + " container-fluid font-family-lato"
|
551
552
|
}, React.createElement(Grid, {
|
552
553
|
container: true,
|
553
554
|
spacing: 3,
|
@@ -880,6 +881,7 @@ var switchAcademy = function switchAcademy(academyId) {
|
|
880
881
|
};
|
881
882
|
|
882
883
|
var LayoutContext = function LayoutContext(_ref) {
|
884
|
+
var _currentPusher$connec, _currentPusher$connec3;
|
883
885
|
var children = _ref.children,
|
884
886
|
role = _ref.role,
|
885
887
|
_ref$pusherRegisterUr = _ref.pusherRegisterUrls,
|
@@ -904,6 +906,7 @@ var LayoutContext = function LayoutContext(_ref) {
|
|
904
906
|
var _state$common3;
|
905
907
|
return state === null || state === void 0 ? void 0 : (_state$common3 = state.common) === null || _state$common3 === void 0 ? void 0 : _state$common3.concurrentConnectionPusher;
|
906
908
|
});
|
909
|
+
var currentPusher = concurrentConnectionPusher === null || concurrentConnectionPusher === void 0 ? void 0 : concurrentConnectionPusher.pusher;
|
907
910
|
var roles = (user === null || user === void 0 ? void 0 : user.roles) || [];
|
908
911
|
var academyDomain = user === null || user === void 0 ? void 0 : user.academyDomain;
|
909
912
|
var pathname = window.location.pathname;
|
@@ -970,31 +973,41 @@ var LayoutContext = function LayoutContext(_ref) {
|
|
970
973
|
return Promise.reject(e);
|
971
974
|
}
|
972
975
|
};
|
976
|
+
console.log({
|
977
|
+
connection: currentPusher === null || currentPusher === void 0 ? void 0 : (_currentPusher$connec = currentPusher.connection) === null || _currentPusher$connec === void 0 ? void 0 : _currentPusher$connec.state,
|
978
|
+
pusherRegisterUrls: pusherRegisterUrls,
|
979
|
+
pathname: pathname
|
980
|
+
});
|
973
981
|
var registerPusher = useCallback(function () {
|
974
|
-
if (pusherRegisterUrls.includes(pathname.toLocaleLowerCase())
|
975
|
-
var
|
976
|
-
if (concurrentConnectionPusher.
|
977
|
-
|
978
|
-
|
979
|
-
|
980
|
-
var pusher = new Pusher(PUSHER_CONFIG.key, {
|
981
|
-
cluster: PUSHER_CONFIG.cluster,
|
982
|
-
authEndpoint: BASE_URL + "/api/auth/pusher",
|
983
|
-
auth: {
|
984
|
-
params: {},
|
985
|
-
headers: (_headers = {
|
986
|
-
Authorization: "Bearer " + token
|
987
|
-
}, _headers[AcademyHeaders] = academyDomain, _headers)
|
982
|
+
if (pusherRegisterUrls.includes(pathname.toLocaleLowerCase())) {
|
983
|
+
var _currentPusher$connec2;
|
984
|
+
if (academyDomain && academyDomain !== (concurrentConnectionPusher === null || concurrentConnectionPusher === void 0 ? void 0 : concurrentConnectionPusher.academyDomain) && isReadyRegisterPusher) {
|
985
|
+
var _headers;
|
986
|
+
if (currentPusher) {
|
987
|
+
currentPusher.disconnect();
|
988
988
|
}
|
989
|
-
|
990
|
-
|
991
|
-
|
992
|
-
|
993
|
-
|
989
|
+
var token = getAccessToken();
|
990
|
+
var pusher = new Pusher(PUSHER_CONFIG.key, {
|
991
|
+
cluster: PUSHER_CONFIG.cluster,
|
992
|
+
authEndpoint: BASE_URL + "/api/auth/pusher",
|
993
|
+
auth: {
|
994
|
+
params: {},
|
995
|
+
headers: (_headers = {
|
996
|
+
Authorization: "Bearer " + token
|
997
|
+
}, _headers[AcademyHeaders] = academyDomain, _headers)
|
998
|
+
}
|
999
|
+
});
|
1000
|
+
dispatch(setConcurrentConnectionPusher({
|
1001
|
+
pusher: pusher,
|
1002
|
+
academyDomain: academyDomain
|
1003
|
+
}));
|
1004
|
+
} else if ((currentPusher === null || currentPusher === void 0 ? void 0 : (_currentPusher$connec2 = currentPusher.connection) === null || _currentPusher$connec2 === void 0 ? void 0 : _currentPusher$connec2.state) === "disconnected") {
|
1005
|
+
currentPusher.connect();
|
1006
|
+
}
|
994
1007
|
}
|
995
|
-
if (
|
996
|
-
if (
|
997
|
-
|
1008
|
+
if (!pusherRegisterUrls.includes(pathname.toLocaleLowerCase()) && !!currentPusher) {
|
1009
|
+
if (currentPusher) {
|
1010
|
+
currentPusher.disconnect();
|
998
1011
|
}
|
999
1012
|
dispatch(setConcurrentConnectionPusher({
|
1000
1013
|
pusher: null,
|
@@ -1004,7 +1017,7 @@ var LayoutContext = function LayoutContext(_ref) {
|
|
1004
1017
|
if (!pusherRegisterUrls.includes(pathname.toLocaleLowerCase()) && isReadyRegisterPusher) {
|
1005
1018
|
dispatch(setReadyRegisterPusher(false));
|
1006
1019
|
}
|
1007
|
-
}, [pusherRegisterUrls.join(","), academyDomain, pathname, isReadyRegisterPusher]);
|
1020
|
+
}, [pusherRegisterUrls.join(","), academyDomain, pathname, isReadyRegisterPusher, currentPusher === null || currentPusher === void 0 ? void 0 : (_currentPusher$connec3 = currentPusher.connection) === null || _currentPusher$connec3 === void 0 ? void 0 : _currentPusher$connec3.state]);
|
1008
1021
|
useEffect(function () {
|
1009
1022
|
!user && loadInfo();
|
1010
1023
|
!!user && checkRoleUser();
|
@@ -1015,8 +1028,8 @@ var LayoutContext = function LayoutContext(_ref) {
|
|
1015
1028
|
useEffect(function () {
|
1016
1029
|
registerPusher();
|
1017
1030
|
return function () {
|
1018
|
-
if (
|
1019
|
-
|
1031
|
+
if (currentPusher) {
|
1032
|
+
currentPusher.disconnect();
|
1020
1033
|
}
|
1021
1034
|
};
|
1022
1035
|
}, [registerPusher]);
|
@@ -1305,6 +1318,7 @@ var recent_exam_results = "최근 시험 결과";
|
|
1305
1318
|
var instructor_name = "강사이름";
|
1306
1319
|
var academy_name = "학원 이름";
|
1307
1320
|
var total_students = "총 학생수";
|
1321
|
+
var total_class = "반 수";
|
1308
1322
|
var total_number_students = "총 학생수";
|
1309
1323
|
var student = "학생";
|
1310
1324
|
var students = "재학생";
|
@@ -1321,8 +1335,9 @@ var mins_mins_seconds_seconds = "{{mins}}분 {{seconds}}초";
|
|
1321
1335
|
var mins_mins = "{{mins}}분";
|
1322
1336
|
var class_name = "반 이름";
|
1323
1337
|
var create_new_exam = "새 시험 생성";
|
1338
|
+
var live_exam = "시험 생성";
|
1324
1339
|
var there_are_no_recent_exams = "최근 시험이 없습니다";
|
1325
|
-
var
|
1340
|
+
var you_have_started_an_exam_with_code_code_do_you_want_to_continue = "{{code}} 코드로 시험을 시작했습니다. 계속하시겠습니까?";
|
1326
1341
|
var here = "여기";
|
1327
1342
|
var do_you_want_to_complete_the_exam = "시험을 완료처리 하시겠습니까?";
|
1328
1343
|
var are_you_sure_you_want_to_delete_the_exam = "시험을 삭제하시겠습니까?";
|
@@ -1561,6 +1576,7 @@ var course = "진로";
|
|
1561
1576
|
var etc = "그 외";
|
1562
1577
|
var consultation_category = "상담 카테고리";
|
1563
1578
|
var points = "{{number}} 점";
|
1579
|
+
var noun_number_of_people = "인원 수";
|
1564
1580
|
var number_of_people = "{{ number }} 명";
|
1565
1581
|
var total_classes = "반수";
|
1566
1582
|
var number_of_classes = "{{ number }} 개";
|
@@ -1579,6 +1595,30 @@ var comparison_of_top_rankings_and_problem_solving_order = "상위권과 문제
|
|
1579
1595
|
var my_answers = "내 해답";
|
1580
1596
|
var request_for_consultation = "상담요청";
|
1581
1597
|
var ask_a_question_with_a_problem = "문제로 질문하기";
|
1598
|
+
var live = "살다";
|
1599
|
+
var user_email = "사용자 이메일";
|
1600
|
+
var user_academy = {
|
1601
|
+
add: "사용자 추가",
|
1602
|
+
update_user_roles: "사용자 역할 업데이트",
|
1603
|
+
add_failed: "아카데미에 사용자 추가 실패",
|
1604
|
+
add_successfully: "사용자를 아카데미에 추가했습니다",
|
1605
|
+
remove_failed: "아카데미에서 사용자를 제거하지 못했습니다",
|
1606
|
+
remove_successfully: "아카데미에서 사용자를 성공적으로 제거했습니다",
|
1607
|
+
update_user_roles_failed: "아카데미 사용자 역할 업데이트에 실패했습니다",
|
1608
|
+
update_user_roles__successfully: "아카데미 사용자 역할을 성공적으로 제거했습니다",
|
1609
|
+
get_failed: "아카데미 사용자 가져오기 실패"
|
1610
|
+
};
|
1611
|
+
var get_users_failed = "사용자 가져오기 실패";
|
1612
|
+
var status_of_each_class = "각 반별 현황";
|
1613
|
+
var attendance_rate = "출석률";
|
1614
|
+
var select_article_create_exam = "시험을 만들 기사를 선택하세요.";
|
1615
|
+
var comprehensive_analysis = "내 해답";
|
1616
|
+
var solution_order = "풀이 순서";
|
1617
|
+
var compare_solution = "풀이 비교";
|
1618
|
+
var problem_analysis = "문제 분석";
|
1619
|
+
var class_information = "수업정보";
|
1620
|
+
var teachers = "교사";
|
1621
|
+
var lessons = "수업";
|
1582
1622
|
var lang_ko = {
|
1583
1623
|
problem_solving: problem_solving,
|
1584
1624
|
my_story: my_story,
|
@@ -1596,6 +1636,7 @@ var lang_ko = {
|
|
1596
1636
|
instructor_name: instructor_name,
|
1597
1637
|
academy_name: academy_name,
|
1598
1638
|
total_students: total_students,
|
1639
|
+
total_class: total_class,
|
1599
1640
|
total_number_students: total_number_students,
|
1600
1641
|
student: student,
|
1601
1642
|
students: students,
|
@@ -1614,8 +1655,9 @@ var lang_ko = {
|
|
1614
1655
|
mins_mins: mins_mins,
|
1615
1656
|
class_name: class_name,
|
1616
1657
|
create_new_exam: create_new_exam,
|
1658
|
+
live_exam: live_exam,
|
1617
1659
|
there_are_no_recent_exams: there_are_no_recent_exams,
|
1618
|
-
|
1660
|
+
you_have_started_an_exam_with_code_code_do_you_want_to_continue: you_have_started_an_exam_with_code_code_do_you_want_to_continue,
|
1619
1661
|
here: here,
|
1620
1662
|
do_you_want_to_complete_the_exam: do_you_want_to_complete_the_exam,
|
1621
1663
|
are_you_sure_you_want_to_delete_the_exam: are_you_sure_you_want_to_delete_the_exam,
|
@@ -1851,6 +1893,7 @@ var lang_ko = {
|
|
1851
1893
|
etc: etc,
|
1852
1894
|
consultation_category: consultation_category,
|
1853
1895
|
points: points,
|
1896
|
+
noun_number_of_people: noun_number_of_people,
|
1854
1897
|
number_of_people: number_of_people,
|
1855
1898
|
total_classes: total_classes,
|
1856
1899
|
number_of_classes: number_of_classes,
|
@@ -1868,7 +1911,21 @@ var lang_ko = {
|
|
1868
1911
|
comparison_of_top_rankings_and_problem_solving_order: comparison_of_top_rankings_and_problem_solving_order,
|
1869
1912
|
my_answers: my_answers,
|
1870
1913
|
request_for_consultation: request_for_consultation,
|
1871
|
-
ask_a_question_with_a_problem: ask_a_question_with_a_problem
|
1914
|
+
ask_a_question_with_a_problem: ask_a_question_with_a_problem,
|
1915
|
+
live: live,
|
1916
|
+
user_email: user_email,
|
1917
|
+
user_academy: user_academy,
|
1918
|
+
get_users_failed: get_users_failed,
|
1919
|
+
status_of_each_class: status_of_each_class,
|
1920
|
+
attendance_rate: attendance_rate,
|
1921
|
+
select_article_create_exam: select_article_create_exam,
|
1922
|
+
comprehensive_analysis: comprehensive_analysis,
|
1923
|
+
solution_order: solution_order,
|
1924
|
+
compare_solution: compare_solution,
|
1925
|
+
problem_analysis: problem_analysis,
|
1926
|
+
class_information: class_information,
|
1927
|
+
teachers: teachers,
|
1928
|
+
lessons: lessons
|
1872
1929
|
};
|
1873
1930
|
|
1874
1931
|
var problem_solving$1 = "Problem Solving";
|
@@ -1887,6 +1944,7 @@ var recent_exam_results$1 = "Recent exam";
|
|
1887
1944
|
var instructor_name$1 = "Instructor name";
|
1888
1945
|
var academy_name$1 = "Academy name";
|
1889
1946
|
var total_students$1 = "Total students";
|
1947
|
+
var total_class$1 = "Total Class";
|
1890
1948
|
var total_number_students$1 = "Total number of students";
|
1891
1949
|
var students$1 = "Students";
|
1892
1950
|
var student$1 = "Student";
|
@@ -1903,8 +1961,9 @@ var mins_mins_seconds_seconds$1 = "{{mins}}m {{seconds}}s";
|
|
1903
1961
|
var mins_mins$1 = "{{mins}}m";
|
1904
1962
|
var class_name$1 = "Class name";
|
1905
1963
|
var create_new_exam$1 = "Create exam";
|
1964
|
+
var live_exam$1 = "Live exam";
|
1906
1965
|
var there_are_no_recent_exams$1 = "There are no recent exams";
|
1907
|
-
var
|
1966
|
+
var you_have_started_an_exam_with_code_code_do_you_want_to_continue$1 = "You have started an exam with code {{code}}, do you want to continue?";
|
1908
1967
|
var here$1 = "here";
|
1909
1968
|
var do_you_want_to_complete_the_exam$1 = "Do you want to complete the exam?";
|
1910
1969
|
var are_you_sure_you_want_to_delete_the_exam$1 = "Are you sure you want to delete the exam?";
|
@@ -2178,6 +2237,7 @@ var course$1 = "Course";
|
|
2178
2237
|
var etc$1 = "Etc";
|
2179
2238
|
var consultation_category$1 = "Consultation Category";
|
2180
2239
|
var points$1 = "{{number}} points";
|
2240
|
+
var noun_number_of_people$1 = "Number of people";
|
2181
2241
|
var number_of_people$1 = "{{ number }} students";
|
2182
2242
|
var total_classes$1 = "Total classes";
|
2183
2243
|
var number_of_classes$1 = "{{ number }} classes";
|
@@ -2196,6 +2256,30 @@ var comparison_of_top_rankings_and_problem_solving_order$1 = "Comparison of top
|
|
2196
2256
|
var my_answers$1 = "My answers";
|
2197
2257
|
var request_for_consultation$1 = "Request for consultation";
|
2198
2258
|
var ask_a_question_with_a_problem$1 = "Ask a question with a problem";
|
2259
|
+
var live$1 = "live";
|
2260
|
+
var user_email$1 = "User email";
|
2261
|
+
var user_academy$1 = {
|
2262
|
+
add: "Add user",
|
2263
|
+
update_user_roles: "Update user roles",
|
2264
|
+
add_failed: "Add user to academy failed",
|
2265
|
+
add_successfully: "Add user to academy successfully",
|
2266
|
+
remove_failed: "Remove user from academy failed",
|
2267
|
+
remove_successfully: "Remove user from academy successfully",
|
2268
|
+
update_user_roles_failed: "Update academy user roles failed",
|
2269
|
+
update_user_roles_successfully: "Update academy user roles successfully",
|
2270
|
+
get_failed: "Get academy users failed"
|
2271
|
+
};
|
2272
|
+
var get_users_failed$1 = "Get users failed";
|
2273
|
+
var status_of_each_class$1 = "Status of each class";
|
2274
|
+
var attendance_rate$1 = "Attendance Rate";
|
2275
|
+
var select_article_create_exam$1 = "Select article to create exam";
|
2276
|
+
var comprehensive_analysis$1 = "Comprehensive analysis";
|
2277
|
+
var solution_order$1 = "Solution order";
|
2278
|
+
var compare_solution$1 = "Compare solution";
|
2279
|
+
var problem_analysis$1 = "Problem analysis";
|
2280
|
+
var class_information$1 = "Class Information";
|
2281
|
+
var teachers$1 = "Teachers";
|
2282
|
+
var lessons$1 = "Lessons";
|
2199
2283
|
var lang_en = {
|
2200
2284
|
problem_solving: problem_solving$1,
|
2201
2285
|
my_story: my_story$1,
|
@@ -2213,6 +2297,7 @@ var lang_en = {
|
|
2213
2297
|
instructor_name: instructor_name$1,
|
2214
2298
|
academy_name: academy_name$1,
|
2215
2299
|
total_students: total_students$1,
|
2300
|
+
total_class: total_class$1,
|
2216
2301
|
total_number_students: total_number_students$1,
|
2217
2302
|
students: students$1,
|
2218
2303
|
student: student$1,
|
@@ -2231,8 +2316,9 @@ var lang_en = {
|
|
2231
2316
|
mins_mins: mins_mins$1,
|
2232
2317
|
class_name: class_name$1,
|
2233
2318
|
create_new_exam: create_new_exam$1,
|
2319
|
+
live_exam: live_exam$1,
|
2234
2320
|
there_are_no_recent_exams: there_are_no_recent_exams$1,
|
2235
|
-
|
2321
|
+
you_have_started_an_exam_with_code_code_do_you_want_to_continue: you_have_started_an_exam_with_code_code_do_you_want_to_continue$1,
|
2236
2322
|
here: here$1,
|
2237
2323
|
do_you_want_to_complete_the_exam: do_you_want_to_complete_the_exam$1,
|
2238
2324
|
are_you_sure_you_want_to_delete_the_exam: are_you_sure_you_want_to_delete_the_exam$1,
|
@@ -2503,6 +2589,7 @@ var lang_en = {
|
|
2503
2589
|
etc: etc$1,
|
2504
2590
|
consultation_category: consultation_category$1,
|
2505
2591
|
points: points$1,
|
2592
|
+
noun_number_of_people: noun_number_of_people$1,
|
2506
2593
|
number_of_people: number_of_people$1,
|
2507
2594
|
total_classes: total_classes$1,
|
2508
2595
|
number_of_classes: number_of_classes$1,
|
@@ -2520,7 +2607,21 @@ var lang_en = {
|
|
2520
2607
|
comparison_of_top_rankings_and_problem_solving_order: comparison_of_top_rankings_and_problem_solving_order$1,
|
2521
2608
|
my_answers: my_answers$1,
|
2522
2609
|
request_for_consultation: request_for_consultation$1,
|
2523
|
-
ask_a_question_with_a_problem: ask_a_question_with_a_problem$1
|
2610
|
+
ask_a_question_with_a_problem: ask_a_question_with_a_problem$1,
|
2611
|
+
live: live$1,
|
2612
|
+
user_email: user_email$1,
|
2613
|
+
user_academy: user_academy$1,
|
2614
|
+
get_users_failed: get_users_failed$1,
|
2615
|
+
status_of_each_class: status_of_each_class$1,
|
2616
|
+
attendance_rate: attendance_rate$1,
|
2617
|
+
select_article_create_exam: select_article_create_exam$1,
|
2618
|
+
comprehensive_analysis: comprehensive_analysis$1,
|
2619
|
+
solution_order: solution_order$1,
|
2620
|
+
compare_solution: compare_solution$1,
|
2621
|
+
problem_analysis: problem_analysis$1,
|
2622
|
+
class_information: class_information$1,
|
2623
|
+
teachers: teachers$1,
|
2624
|
+
lessons: lessons$1
|
2524
2625
|
};
|
2525
2626
|
|
2526
2627
|
i18n.use(initReactI18next).init({
|
@@ -2801,7 +2902,8 @@ var TheAcademyDropdown = function TheAcademyDropdown(_ref) {
|
|
2801
2902
|
var role = _ref.role,
|
2802
2903
|
navigate = _ref.navigate,
|
2803
2904
|
homeAcademyUrl = _ref.homeAcademyUrl,
|
2804
|
-
homeUrl = _ref.homeUrl
|
2905
|
+
homeUrl = _ref.homeUrl,
|
2906
|
+
hideAcademyName = _ref.hideAcademyName;
|
2805
2907
|
var _useSwitchAcademy = useSwitchAcademy(role, navigate, homeAcademyUrl, homeUrl),
|
2806
2908
|
academyList = _useSwitchAcademy.academyList,
|
2807
2909
|
handleSwitchAcademy = _useSwitchAcademy.handleSwitchAcademy,
|
@@ -2835,15 +2937,15 @@ var TheAcademyDropdown = function TheAcademyDropdown(_ref) {
|
|
2835
2937
|
};
|
2836
2938
|
return React.createElement(Fragment$1, null, React.createElement(Button, {
|
2837
2939
|
onClick: handleOpen,
|
2838
|
-
className: "" +
|
2940
|
+
className: "" + styles["academy-btn"],
|
2839
2941
|
sx: _extends({}, popoverStyle)
|
2840
2942
|
}, React.createElement("div", {
|
2841
|
-
className: "" +
|
2943
|
+
className: styles["image-academy"] + " me-0 me-lg-2"
|
2842
2944
|
}, selectedAcademy !== null && selectedAcademy !== void 0 && selectedAcademy.image ? React.createElement("img", {
|
2843
2945
|
src: selectedAcademy === null || selectedAcademy === void 0 ? void 0 : selectedAcademy.image,
|
2844
2946
|
alt: selectedAcademy === null || selectedAcademy === void 0 ? void 0 : selectedAcademy.name
|
2845
|
-
}) : React.createElement("span", null, firstLetter)), React.createElement(Typography, {
|
2846
|
-
className: "text-start",
|
2947
|
+
}) : React.createElement("span", null, firstLetter)), !hideAcademyName && React.createElement(Typography, {
|
2948
|
+
className: "text-start d-none d-lg-block",
|
2847
2949
|
sx: {
|
2848
2950
|
fontSize: 14,
|
2849
2951
|
fontWeight: 600,
|
@@ -2851,7 +2953,7 @@ var TheAcademyDropdown = function TheAcademyDropdown(_ref) {
|
|
2851
2953
|
minWidth: 150
|
2852
2954
|
}
|
2853
2955
|
}, (selectedAcademy === null || selectedAcademy === void 0 ? void 0 : selectedAcademy.name) || t(role === Role.Admin ? "switch_academy_admin" : "switch_academy")), React.createElement("div", {
|
2854
|
-
className: "" +
|
2956
|
+
className: styles["switch-icon"] + " d-none d-lg-flex"
|
2855
2957
|
}, React.createElement(GoArrowSwitch, {
|
2856
2958
|
size: 14
|
2857
2959
|
}))), (isSuperAdmin || !isAdmin) && React.createElement(Popover, {
|
@@ -2872,7 +2974,10 @@ var TheAcademyDropdown = function TheAcademyDropdown(_ref) {
|
|
2872
2974
|
p: 0.5,
|
2873
2975
|
mt: 1,
|
2874
2976
|
ml: 0.75,
|
2875
|
-
width:
|
2977
|
+
width: {
|
2978
|
+
xs: 200,
|
2979
|
+
lg: 300
|
2980
|
+
},
|
2876
2981
|
minWidth: "unset!important"
|
2877
2982
|
}
|
2878
2983
|
}
|
@@ -2893,7 +2998,7 @@ var TheAcademyDropdown = function TheAcademyDropdown(_ref) {
|
|
2893
2998
|
fontWeight: 600
|
2894
2999
|
}
|
2895
3000
|
}, React.createElement("div", {
|
2896
|
-
className: "" +
|
3001
|
+
className: styles["image-academy"] + " " + styles["image-academy--item"]
|
2897
3002
|
}, option.image ? React.createElement(Box$1, {
|
2898
3003
|
component: "img",
|
2899
3004
|
alt: option.name,
|
@@ -3003,7 +3108,7 @@ var CustomSelect = function CustomSelect(_ref) {
|
|
3003
3108
|
}, rest));
|
3004
3109
|
};
|
3005
3110
|
|
3006
|
-
var styles = {"header__avatar":"_2oGcJ","header__select":"_2y2XV","body":"_ntGyI","list":"_m7Fwt","list__item__header":"_3BM8N","list__item__avatar":"_1ReOK","list__item__avatar-container":"_2qbld","list__item__message":"_3s01i","list__item__message--reply-from":"_2Qxi3","list__item__message--reply-from-right":"_34Vx4","list__item__message--reply":"_3uheq","list__item__message--reply-right":"_2iBr7","reply-text":"_3ZPjO","container-custom":"_38A9k","student-row-col-1":"_Jt5t0","student-row-col-1-active":"_14DKj","row-col-2":"_qHGiR","inputBox":"_2iY67","inputBoxTable":"_3pCw0","background-chat":"_zILbw","wrap-content":"_38gsM","name-sender":"_Lfzyw","content-chat-sender":"_1X73E","content-chat-receiver":"_32V7T","custom-scroll":"_2Uul2","btn-send":"_395lb","btn-chat":"_gDYwm","input-chat":"_22TX5","btn-cancel":"_1u-eg","btn-register":"_22r6_","form-label-dialog":"_jADIA","form-select-width":"_WncPd","padding-content":"_3hz3H","form-label":"_MMQxP","form-control":"_1mJfc"};
|
3111
|
+
var styles$1 = {"header__avatar":"_2oGcJ","header__select":"_2y2XV","body":"_ntGyI","list":"_m7Fwt","list__item__header":"_3BM8N","list__item__avatar":"_1ReOK","list__item__avatar-container":"_2qbld","list__item__message":"_3s01i","list__item__message--reply-from":"_2Qxi3","list__item__message--reply-from-right":"_34Vx4","list__item__message--reply":"_3uheq","list__item__message--reply-right":"_2iBr7","reply-text":"_3ZPjO","container-custom":"_38A9k","student-row-col-1":"_Jt5t0","student-row-col-1-active":"_14DKj","row-col-2":"_qHGiR","inputBox":"_2iY67","inputBoxTable":"_3pCw0","background-chat":"_zILbw","wrap-content":"_38gsM","name-sender":"_Lfzyw","content-chat-sender":"_1X73E","content-chat-receiver":"_32V7T","custom-scroll":"_2Uul2","btn-send":"_395lb","btn-chat":"_gDYwm","input-chat":"_22TX5","btn-cancel":"_1u-eg","btn-register":"_22r6_","form-label-dialog":"_jADIA","form-select-width":"_WncPd","padding-content":"_3hz3H","form-label":"_MMQxP","form-control":"_1mJfc"};
|
3007
3112
|
|
3008
3113
|
var iconPersonNoActive = function iconPersonNoActive(_ref) {
|
3009
3114
|
var _ref$width = _ref.width,
|
@@ -3149,7 +3254,7 @@ var ChatRightItem = function ChatRightItem(_ref) {
|
|
3149
3254
|
padding: "4px 0"
|
3150
3255
|
}, React.createElement(Box, null, showName && isStudent && React.createElement(Box, {
|
3151
3256
|
gap: "8px",
|
3152
|
-
className: " " + styles["name-sender"],
|
3257
|
+
className: " " + styles$1["name-sender"],
|
3153
3258
|
display: "flex",
|
3154
3259
|
alignItems: "center",
|
3155
3260
|
flexDirection: "row"
|
@@ -3204,7 +3309,7 @@ var ChatRightItem = function ChatRightItem(_ref) {
|
|
3204
3309
|
objectFit: "contain"
|
3205
3310
|
}
|
3206
3311
|
})) : React.createElement("div", {
|
3207
|
-
className: styles["wrap-content"] + " " + styles["content-chat-receiver"],
|
3312
|
+
className: styles$1["wrap-content"] + " " + styles$1["content-chat-receiver"],
|
3208
3313
|
style: {
|
3209
3314
|
"float": "inline-end"
|
3210
3315
|
}
|
@@ -3242,7 +3347,7 @@ var ChatLeftItem = function ChatLeftItem(_ref) {
|
|
3242
3347
|
display: "flex",
|
3243
3348
|
padding: "4px",
|
3244
3349
|
flexDirection: "row",
|
3245
|
-
className: "" + styles["name-sender"]
|
3350
|
+
className: "" + styles$1["name-sender"]
|
3246
3351
|
}, isStudent ? React.createElement(Fragment$1, null, React.createElement(Typography, {
|
3247
3352
|
fontWeight: 500,
|
3248
3353
|
fontSize: 14,
|
@@ -3282,7 +3387,7 @@ var ChatLeftItem = function ChatLeftItem(_ref) {
|
|
3282
3387
|
objectFit: "contain"
|
3283
3388
|
}
|
3284
3389
|
})) : React.createElement("div", {
|
3285
|
-
className: styles["wrap-content"] + " " + styles["content-chat-sender"]
|
3390
|
+
className: styles$1["wrap-content"] + " " + styles$1["content-chat-sender"]
|
3286
3391
|
}, React.createElement(Typography, {
|
3287
3392
|
fontWeight: 500,
|
3288
3393
|
fontSize: "14px",
|
@@ -3495,7 +3600,7 @@ var UpdateMessageDialog = function UpdateMessageDialog(_ref) {
|
|
3495
3600
|
_objectDestructuringEmpty(_ref2);
|
3496
3601
|
return React.createElement(Form, null, React.createElement("label", {
|
3497
3602
|
htmlFor: "content",
|
3498
|
-
className: styles['form-label'] + " " + styles['form-label-dialog']
|
3603
|
+
className: styles$1['form-label'] + " " + styles$1['form-label-dialog']
|
3499
3604
|
}, "\uC9C8\uBB38\uD560 \uBB38\uC81C"), React.createElement(Field, {
|
3500
3605
|
id: "content",
|
3501
3606
|
style: {
|
@@ -3504,7 +3609,7 @@ var UpdateMessageDialog = function UpdateMessageDialog(_ref) {
|
|
3504
3609
|
name: "content",
|
3505
3610
|
validate: validate,
|
3506
3611
|
placeholder: "\uBB38\uC81C\uAC00 \uC5B4\uB824\uC6CC\uC694",
|
3507
|
-
className: styles['form-control']
|
3612
|
+
className: styles$1['form-control']
|
3508
3613
|
}), React.createElement(DialogActions, {
|
3509
3614
|
sx: {
|
3510
3615
|
display: 'flex',
|
@@ -3513,14 +3618,14 @@ var UpdateMessageDialog = function UpdateMessageDialog(_ref) {
|
|
3513
3618
|
padding: '12px'
|
3514
3619
|
}
|
3515
3620
|
}, React.createElement(Button, {
|
3516
|
-
className: styles['btn-cancel'],
|
3621
|
+
className: styles$1['btn-cancel'],
|
3517
3622
|
onClick: onClose
|
3518
3623
|
}, React.createElement(Typography, {
|
3519
3624
|
fontWeight: 700,
|
3520
3625
|
fontSize: '14px',
|
3521
3626
|
lineHeight: '16.71px'
|
3522
3627
|
}, "\uCDE8\uC18C")), React.createElement(Button, {
|
3523
|
-
className: styles['btn-register'],
|
3628
|
+
className: styles$1['btn-register'],
|
3524
3629
|
type: "submit"
|
3525
3630
|
}, React.createElement(Typography, {
|
3526
3631
|
fontWeight: 700,
|
@@ -3569,14 +3674,14 @@ var UpdateMessageDialog = function UpdateMessageDialog(_ref) {
|
|
3569
3674
|
padding: '12px'
|
3570
3675
|
}
|
3571
3676
|
}, React.createElement(Button, {
|
3572
|
-
className: styles['btn-cancel'],
|
3677
|
+
className: styles$1['btn-cancel'],
|
3573
3678
|
onClick: onClose
|
3574
3679
|
}, React.createElement(Typography, {
|
3575
3680
|
fontWeight: 700,
|
3576
3681
|
fontSize: '14px',
|
3577
3682
|
lineHeight: '16.71px'
|
3578
3683
|
}, "\uCDE8\uC18C")), React.createElement(Button, {
|
3579
|
-
className: styles['btn-register'],
|
3684
|
+
className: styles$1['btn-register'],
|
3580
3685
|
sx: {
|
3581
3686
|
bgcolor: !(selectedFile !== null && selectedFile !== void 0 && selectedFile.content) ? "#EBEBFF !important" : "#5458D5 !important"
|
3582
3687
|
},
|
@@ -3750,7 +3855,7 @@ var ChatList = function ChatList(_ref) {
|
|
3750
3855
|
var isStudent = roles === null || roles === void 0 ? void 0 : roles.includes(Roles$1.Student);
|
3751
3856
|
return React.createElement("ul", {
|
3752
3857
|
ref: listItemRef,
|
3753
|
-
className: styles["list"] + " " + styles["padding-content"] + " d-flex h-100 flex-column mb-0 " + (!(filterMessage !== null && filterMessage !== void 0 && filterMessage.length) ? 'justify-content-center' : '')
|
3858
|
+
className: styles$1["list"] + " " + styles$1["padding-content"] + " d-flex h-100 flex-column mb-0 " + (!(filterMessage !== null && filterMessage !== void 0 && filterMessage.length) ? 'justify-content-center' : '')
|
3754
3859
|
}, !(filterMessage !== null && filterMessage !== void 0 && filterMessage.length) && React.createElement("li", {
|
3755
3860
|
className: "text-muted text-center fst-italic fs-6"
|
3756
3861
|
}, "No message"), !!(filterMessage !== null && filterMessage !== void 0 && filterMessage.length) && filterMessage.map(function (message) {
|
@@ -3857,7 +3962,7 @@ var InputChat = function InputChat(_ref) {
|
|
3857
3962
|
color: "#fff",
|
3858
3963
|
size: 30
|
3859
3964
|
}))), React.createElement("input", {
|
3860
|
-
className: styles["input-chat"],
|
3965
|
+
className: styles$1["input-chat"],
|
3861
3966
|
style: {
|
3862
3967
|
border: "none"
|
3863
3968
|
},
|
@@ -3884,7 +3989,7 @@ var InputChat = function InputChat(_ref) {
|
|
3884
3989
|
sx: {
|
3885
3990
|
bgcolor: isCompleted ? "#EBEBFF !important" : "#5458D5 !important"
|
3886
3991
|
},
|
3887
|
-
className: styles["btn-send"],
|
3992
|
+
className: styles$1["btn-send"],
|
3888
3993
|
disabled: isCompleted,
|
3889
3994
|
onClick: handleSubmit
|
3890
3995
|
}, React.createElement(iconSendMessage, null), React.createElement(Typography, {
|
@@ -3939,7 +4044,8 @@ var iconChecked = function iconChecked(_ref) {
|
|
3939
4044
|
};
|
3940
4045
|
|
3941
4046
|
var ellipsisText = function ellipsisText(text, maxLength) {
|
3942
|
-
|
4047
|
+
if (!text) return text;
|
4048
|
+
return (text === null || text === void 0 ? void 0 : text.length) > maxLength ? text.slice(0, maxLength) + " ..." : text;
|
3943
4049
|
};
|
3944
4050
|
var formatDataMyAnswer = function formatDataMyAnswer(inputData, categories) {
|
3945
4051
|
var uniqueCategories = new Set();
|
@@ -3988,7 +4094,8 @@ var ChatHeader = function ChatHeader(_ref) {
|
|
3988
4094
|
handleConfirm = _useDialog.handleConfirm;
|
3989
4095
|
var _useTranslation = useTranslation(),
|
3990
4096
|
t = _useTranslation.t;
|
3991
|
-
var
|
4097
|
+
var theme = useTheme();
|
4098
|
+
var isTabletUp = useMediaQuery(theme.breakpoints.up('lg'));
|
3992
4099
|
var isStudent = roles === null || roles === void 0 ? void 0 : roles.includes(Roles$1.Student);
|
3993
4100
|
var filterDurationExam = useMemo(function () {
|
3994
4101
|
if (!durationExam) return;
|
@@ -4037,7 +4144,7 @@ var ChatHeader = function ChatHeader(_ref) {
|
|
4037
4144
|
fontWeight: 600,
|
4038
4145
|
fontSize: "12px",
|
4039
4146
|
lineHeight: "14.32px"
|
4040
|
-
}, ellipsisText(examTitle, 15)), React.createElement(Box, {
|
4147
|
+
}, ellipsisText(examTitle || "", 15)), React.createElement(Box, {
|
4041
4148
|
display: "flex",
|
4042
4149
|
flexDirection: "row",
|
4043
4150
|
gap: "4px"
|
@@ -4117,7 +4224,7 @@ var ChatHeader = function ChatHeader(_ref) {
|
|
4117
4224
|
alignItems: "center",
|
4118
4225
|
gap: "24px",
|
4119
4226
|
color: "#5458D5"
|
4120
|
-
}, React.createElement(Box, {
|
4227
|
+
}, isTabletUp && React.createElement(Box, {
|
4121
4228
|
display: "flex",
|
4122
4229
|
justifyContent: "space-between",
|
4123
4230
|
alignItems: "center",
|
@@ -4130,7 +4237,7 @@ var ChatHeader = function ChatHeader(_ref) {
|
|
4130
4237
|
fontWeight: 700,
|
4131
4238
|
fontSize: "14px",
|
4132
4239
|
lineHeight: "16.71px"
|
4133
|
-
}, fullName)), React.createElement(Box, {
|
4240
|
+
}, ellipsisText(fullName || "", 10))), React.createElement(Box, {
|
4134
4241
|
display: "flex",
|
4135
4242
|
alignItems: "center",
|
4136
4243
|
gap: "24px",
|
@@ -4139,7 +4246,7 @@ var ChatHeader = function ChatHeader(_ref) {
|
|
4139
4246
|
fontWeight: 600,
|
4140
4247
|
fontSize: "12px",
|
4141
4248
|
lineHeight: "14.32px"
|
4142
|
-
}, examTitle) : React.createElement(Box, {
|
4249
|
+
}, ellipsisText(examTitle || "", 10)) : React.createElement(Box, {
|
4143
4250
|
display: "flex",
|
4144
4251
|
alignItems: "end",
|
4145
4252
|
gap: "16px",
|
@@ -4284,7 +4391,7 @@ var ChatContainer = function ChatContainer(_ref) {
|
|
4284
4391
|
container: true
|
4285
4392
|
}, React.createElement(ChatHeader, Object.assign({}, chatHeaderProps)), React.createElement("div", {
|
4286
4393
|
ref: listRef,
|
4287
|
-
className: "flex-grow-1 " + styles["body"],
|
4394
|
+
className: "flex-grow-1 " + styles$1["body"],
|
4288
4395
|
style: {
|
4289
4396
|
height: "60vh",
|
4290
4397
|
overflowY: "scroll",
|
@@ -4789,7 +4896,7 @@ var InputText = function InputText(props) {
|
|
4789
4896
|
}, props));
|
4790
4897
|
};
|
4791
4898
|
|
4792
|
-
var styles$
|
4899
|
+
var styles$2 = {"question":"_2uc_W","question-article":"_2p7kY","question-title":"_2tHmc","question--active":"_3IHYm","question-label":"_26ATj","question-input":"_3R8PR","question-btn":"_1VZac"};
|
4793
4900
|
|
4794
4901
|
var SCORE_OPTIONS = Array.from({
|
4795
4902
|
length: 10
|
@@ -4846,12 +4953,15 @@ var QuestionView = function QuestionView(_ref) {
|
|
4846
4953
|
var handleChangeCorrectAnswer = function handleChangeCorrectAnswer(e) {
|
4847
4954
|
return onChangeCorrectAnswers(e.target.value, index);
|
4848
4955
|
};
|
4849
|
-
return React.createElement(
|
4850
|
-
|
4851
|
-
|
4852
|
-
|
4956
|
+
return React.createElement(Grid, {
|
4957
|
+
container: true,
|
4958
|
+
spacing: "16px"
|
4959
|
+
}, React.createElement(Grid, {
|
4960
|
+
item: true,
|
4961
|
+
xs: 12,
|
4962
|
+
lg: 9
|
4853
4963
|
}, React.createElement("div", {
|
4854
|
-
className: styles$
|
4964
|
+
className: styles$2["question-title"] + " me-2 text-nowrap"
|
4855
4965
|
}, t("problem_number_question", {
|
4856
4966
|
number: question.questionOrder + 1
|
4857
4967
|
})), React.createElement(FormControl, {
|
@@ -4867,7 +4977,7 @@ var QuestionView = function QuestionView(_ref) {
|
|
4867
4977
|
}).map(function (i) {
|
4868
4978
|
return React.createElement(FormControlLabel, {
|
4869
4979
|
key: i,
|
4870
|
-
className: styles$
|
4980
|
+
className: styles$2["question-label"] + " w-fit",
|
4871
4981
|
labelPlacement: "top",
|
4872
4982
|
value: i,
|
4873
4983
|
onChange: handleChangeCorrectAnswer,
|
@@ -4879,10 +4989,12 @@ var QuestionView = function QuestionView(_ref) {
|
|
4879
4989
|
number: i
|
4880
4990
|
})
|
4881
4991
|
});
|
4882
|
-
})))), React.createElement(
|
4883
|
-
|
4992
|
+
})))), React.createElement(Grid, {
|
4993
|
+
item: true,
|
4994
|
+
xs: 12,
|
4995
|
+
lg: 3,
|
4996
|
+
mb: "16px"
|
4884
4997
|
}, React.createElement(FormControl, {
|
4885
|
-
className: "mx-3",
|
4886
4998
|
style: {
|
4887
4999
|
width: "140px"
|
4888
5000
|
}
|
@@ -5086,6 +5198,8 @@ var ArticleGroupView = function ArticleGroupView(_ref) {
|
|
5086
5198
|
subjectId: defaultCategoryOptions === undefined ? selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id : undefined
|
5087
5199
|
}),
|
5088
5200
|
categoryOptions = _useCategorySelect.categoryOptions;
|
5201
|
+
var theme = useTheme();
|
5202
|
+
var isTabletUp = useMediaQuery(theme.breakpoints.up('lg'));
|
5089
5203
|
var handleChangeQuestionCount = function handleChangeQuestionCount(value) {
|
5090
5204
|
onChangeQuestionCount(article, value === null || value === void 0 ? void 0 : value.value, answerCount);
|
5091
5205
|
};
|
@@ -5105,7 +5219,7 @@ var ArticleGroupView = function ArticleGroupView(_ref) {
|
|
5105
5219
|
onDelete === null || onDelete === void 0 ? void 0 : onDelete(article);
|
5106
5220
|
};
|
5107
5221
|
return React.createElement("div", {
|
5108
|
-
className: "d-flex " + styles$
|
5222
|
+
className: "d-flex " + styles$2["question"] + " " + (isActive ? styles$2["question--active"] : "")
|
5109
5223
|
}, React.createElement("div", {
|
5110
5224
|
className: "py-1"
|
5111
5225
|
}, React.createElement(PiDotsNineLight, {
|
@@ -5113,20 +5227,30 @@ var ArticleGroupView = function ArticleGroupView(_ref) {
|
|
5113
5227
|
})), React.createElement("div", {
|
5114
5228
|
className: "px-4"
|
5115
5229
|
}, React.createElement("p", {
|
5116
|
-
className: "mb-0 " + styles$
|
5230
|
+
className: "mb-0 " + styles$2["question-article"]
|
5117
5231
|
}, t("article_number")), React.createElement("p", {
|
5118
|
-
className: "text-center " + styles$
|
5232
|
+
className: "text-center " + styles$2["question-article"]
|
5119
5233
|
}, article)), React.createElement("div", {
|
5120
5234
|
className: "flex-grow-1"
|
5121
5235
|
}, React.createElement(Grid, {
|
5122
5236
|
container: true,
|
5123
5237
|
spacing: 3
|
5124
|
-
}, React.createElement(Grid, {
|
5238
|
+
}, !isTabletUp && React.createElement(Grid, {
|
5239
|
+
item: true,
|
5240
|
+
xs: 12,
|
5241
|
+
className: "d-flex justify-content-end"
|
5242
|
+
}, isDeletable && !isDisabled && React.createElement("div", null, React.createElement(IconButton, {
|
5243
|
+
onClick: handleDelete
|
5244
|
+
}, React.createElement(FaTrash, {
|
5245
|
+
size: 16,
|
5246
|
+
className: "text-danger"
|
5247
|
+
})))), React.createElement(Grid, {
|
5125
5248
|
item: true,
|
5126
|
-
xs:
|
5249
|
+
xs: 12,
|
5250
|
+
lg: 3
|
5127
5251
|
}, React.createElement(FormGroup, null, React.createElement(FormLabel, {
|
5128
5252
|
htmlFor: "question_count",
|
5129
|
-
className: styles$
|
5253
|
+
className: styles$2["question-label"] + " form-label"
|
5130
5254
|
}, t("question_count")), React.createElement(QuestionCountSelector, {
|
5131
5255
|
id: "question_count",
|
5132
5256
|
value: questionCount,
|
@@ -5134,10 +5258,11 @@ var ArticleGroupView = function ArticleGroupView(_ref) {
|
|
5134
5258
|
isDisabled: isDisabled
|
5135
5259
|
}))), React.createElement(Grid, {
|
5136
5260
|
item: true,
|
5137
|
-
xs:
|
5261
|
+
xs: 12,
|
5262
|
+
lg: 3
|
5138
5263
|
}, React.createElement(FormGroup, null, React.createElement(FormLabel, {
|
5139
5264
|
htmlFor: "category",
|
5140
|
-
className: styles$
|
5265
|
+
className: styles$2["question-label"] + " form-label"
|
5141
5266
|
}, t("category")), React.createElement(ArticleCategorySelector, {
|
5142
5267
|
id: "category",
|
5143
5268
|
value: categoryId,
|
@@ -5147,16 +5272,17 @@ var ArticleGroupView = function ArticleGroupView(_ref) {
|
|
5147
5272
|
placeholder: t("select_category")
|
5148
5273
|
}))), React.createElement(Grid, {
|
5149
5274
|
item: true,
|
5150
|
-
xs:
|
5275
|
+
xs: 12,
|
5276
|
+
lg: 3
|
5151
5277
|
}, React.createElement(FormGroup, null, React.createElement(FormLabel, {
|
5152
5278
|
htmlFor: "answer_count",
|
5153
|
-
className: styles$
|
5279
|
+
className: styles$2["question-label"] + " form-label"
|
5154
5280
|
}, t("answer_count")), React.createElement(AnswerCountSelector, {
|
5155
5281
|
id: "answer_count",
|
5156
5282
|
value: answerCount,
|
5157
5283
|
onChange: handleChangeAnswerCount,
|
5158
5284
|
isDisabled: isDisabled
|
5159
|
-
}))), React.createElement(Grid, {
|
5285
|
+
}))), isTabletUp && React.createElement(Grid, {
|
5160
5286
|
item: true,
|
5161
5287
|
xs: 3,
|
5162
5288
|
className: "d-flex justify-content-end"
|
@@ -5193,6 +5319,7 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5193
5319
|
onChangePageTo = _ref.onChangePageTo,
|
5194
5320
|
onAddArticle = _ref.onAddArticle,
|
5195
5321
|
onRemoveArticle = _ref.onRemoveArticle,
|
5322
|
+
handleCheckArticle = _ref.handleCheckArticle,
|
5196
5323
|
onUpdateArticleQuestionCount = _ref.onUpdateArticleQuestionCount,
|
5197
5324
|
onUpdateArticleCategory = _ref.onUpdateArticleCategory,
|
5198
5325
|
onUpdateArticleQuestionAnswerCount = _ref.onUpdateArticleQuestionAnswerCount,
|
@@ -5248,6 +5375,8 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5248
5375
|
var handleUpdateArticleQuestionScore = function handleUpdateArticleQuestionScore(article, index, score) {
|
5249
5376
|
onUpdateArticleQuestion === null || onUpdateArticleQuestion === void 0 ? void 0 : onUpdateArticleQuestion(article, index, score, "score", data.articles, data.id, parentChapterId);
|
5250
5377
|
};
|
5378
|
+
var theme = useTheme();
|
5379
|
+
var isTabletUp = useMediaQuery(theme.breakpoints.up('lg'));
|
5251
5380
|
var handleChangeName = function handleChangeName(e) {
|
5252
5381
|
var text = e.target.value;
|
5253
5382
|
onChangeName === null || onChangeName === void 0 ? void 0 : onChangeName(text, data.id, parentChapterId);
|
@@ -5295,17 +5424,52 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5295
5424
|
className: "text-danger"
|
5296
5425
|
}))), React.createElement("div", {
|
5297
5426
|
className: "p-3 d-flex justify-content-between"
|
5427
|
+
}, React.createElement(Grid, {
|
5428
|
+
container: true
|
5429
|
+
}, React.createElement(Grid, {
|
5430
|
+
item: true,
|
5431
|
+
xs: 12
|
5432
|
+
}, React.createElement(Grid, {
|
5433
|
+
container: true,
|
5434
|
+
spacing: 2
|
5435
|
+
}, !isTabletUp && React.createElement(Grid, {
|
5436
|
+
item: true,
|
5437
|
+
xs: 12
|
5298
5438
|
}, React.createElement(Stack, {
|
5299
|
-
|
5300
|
-
|
5301
|
-
|
5439
|
+
direction: "row",
|
5440
|
+
justifyContent: "end",
|
5441
|
+
spacing: 2
|
5442
|
+
}, !parentChapterId && !data.articles.length && React.createElement(Button, {
|
5443
|
+
className: "mx-1",
|
5444
|
+
variant: "contained",
|
5445
|
+
color: "primary",
|
5446
|
+
disabled: isReadonly,
|
5447
|
+
startIcon: React.createElement(FaPlus, {
|
5448
|
+
size: 12
|
5449
|
+
}),
|
5450
|
+
onClick: handleClickAddSubchapter
|
5451
|
+
}, t("add_subchapter")), data.subChapters.length === 0 && React.createElement(Button, {
|
5452
|
+
className: "mx-1",
|
5453
|
+
variant: "contained",
|
5454
|
+
color: "success",
|
5455
|
+
disabled: isReadonly,
|
5456
|
+
startIcon: React.createElement(FaPlus, {
|
5457
|
+
size: 12
|
5458
|
+
}),
|
5459
|
+
onClick: handleAddArticle
|
5460
|
+
}, t("add_article")))), React.createElement(Grid, {
|
5461
|
+
item: true,
|
5462
|
+
xs: 12,
|
5463
|
+
lg: 4,
|
5302
5464
|
sx: {
|
5303
5465
|
display: "flex",
|
5304
5466
|
alignItems: "center",
|
5305
|
-
marginRight: "16px",
|
5306
5467
|
width: "50%"
|
5307
5468
|
}
|
5308
5469
|
}, React.createElement("label", {
|
5470
|
+
style: {
|
5471
|
+
minWidth: "90px"
|
5472
|
+
},
|
5309
5473
|
className: "fw-bold text-nowrap me-2"
|
5310
5474
|
}, t("page.from"), ":"), React.createElement(InputText, {
|
5311
5475
|
type: "number",
|
@@ -5315,13 +5479,19 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5315
5479
|
onChange: handleChangePageFrom,
|
5316
5480
|
placeholder: t("page.from_placeholder"),
|
5317
5481
|
error: data.pageFrom > data.pageTo || data.pageFrom < 0
|
5318
|
-
})), React.createElement(
|
5482
|
+
})), React.createElement(Grid, {
|
5483
|
+
item: true,
|
5484
|
+
xs: 12,
|
5485
|
+
lg: 4,
|
5319
5486
|
sx: {
|
5320
5487
|
display: "flex",
|
5321
5488
|
alignItems: "center",
|
5322
5489
|
width: "50%"
|
5323
5490
|
}
|
5324
5491
|
}, React.createElement("label", {
|
5492
|
+
style: {
|
5493
|
+
minWidth: "90px"
|
5494
|
+
},
|
5325
5495
|
className: "fw-bold text-nowrap me-2"
|
5326
5496
|
}, t("page.to"), ":"), React.createElement(InputText, {
|
5327
5497
|
type: "number",
|
@@ -5331,7 +5501,10 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5331
5501
|
onChange: handleChangePageTo,
|
5332
5502
|
placeholder: t("page.to_placeholder"),
|
5333
5503
|
error: data.pageTo < data.pageFrom
|
5334
|
-
}))
|
5504
|
+
})), isTabletUp && React.createElement(Grid, {
|
5505
|
+
item: true,
|
5506
|
+
lg: 4
|
5507
|
+
}, React.createElement(Stack, {
|
5335
5508
|
direction: "row",
|
5336
5509
|
justifyContent: "end",
|
5337
5510
|
spacing: 2
|
@@ -5353,7 +5526,7 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5353
5526
|
size: 12
|
5354
5527
|
}),
|
5355
5528
|
onClick: handleAddArticle
|
5356
|
-
}, t("add_article")))), React.createElement("div", {
|
5529
|
+
}, t("add_article")))))))), React.createElement("div", {
|
5357
5530
|
className: "p-3"
|
5358
5531
|
}, React.createElement(Stack, {
|
5359
5532
|
spacing: 2
|
@@ -5368,6 +5541,7 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5368
5541
|
onChangeName: onChangeName,
|
5369
5542
|
onChangePageFrom: onChangePageFrom,
|
5370
5543
|
onChangePageTo: onChangePageTo,
|
5544
|
+
handleCheckArticle: handleCheckArticle,
|
5371
5545
|
onAddArticle: onAddArticle,
|
5372
5546
|
onRemoveArticle: onRemoveArticle,
|
5373
5547
|
onUpdateArticleQuestionCount: onUpdateArticleQuestionCount,
|
@@ -5378,7 +5552,24 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5378
5552
|
});
|
5379
5553
|
}), data.subChapters.length === 0 && data.articles.map(function (article) {
|
5380
5554
|
var _article$category;
|
5381
|
-
return React.createElement(
|
5555
|
+
return React.createElement(Stack, null, React.createElement(Stack, {
|
5556
|
+
display: "flex",
|
5557
|
+
flexDirection: "row",
|
5558
|
+
gap: "8px",
|
5559
|
+
alignItems: "center"
|
5560
|
+
}, React.createElement(Checkbox, {
|
5561
|
+
id: "textbook",
|
5562
|
+
sx: {
|
5563
|
+
display: "flex",
|
5564
|
+
justifyContent: "start",
|
5565
|
+
width: "fit-content"
|
5566
|
+
},
|
5567
|
+
onChange: function onChange(e) {
|
5568
|
+
return handleCheckArticle(e, article);
|
5569
|
+
}
|
5570
|
+
}), React.createElement("label", {
|
5571
|
+
htmlFor: "textbook"
|
5572
|
+
}, t("select_article_create_exam"))), React.createElement(ArticleGroupView, {
|
5382
5573
|
key: article.id,
|
5383
5574
|
categoryOptions: categoryOptions,
|
5384
5575
|
article: article.articleNumber,
|
@@ -5395,7 +5586,7 @@ var ChapterBox = function ChapterBox(_ref) {
|
|
5395
5586
|
onChangeScoreAnswer: handleUpdateArticleQuestionScore,
|
5396
5587
|
onDelete: handleRemoveArticle,
|
5397
5588
|
isDeletable: true
|
5398
|
-
});
|
5589
|
+
}));
|
5399
5590
|
}))));
|
5400
5591
|
};
|
5401
5592
|
|
@@ -5455,6 +5646,25 @@ var TextbookSortBy;
|
|
5455
5646
|
TextbookSortBy["Title"] = "Name";
|
5456
5647
|
TextbookSortBy["SubjectName"] = "Subject.Name";
|
5457
5648
|
})(TextbookSortBy || (TextbookSortBy = {}));
|
5649
|
+
var ExamType;
|
5650
|
+
(function (ExamType) {
|
5651
|
+
ExamType["Normal"] = "Normal";
|
5652
|
+
ExamType["Standard"] = "Standard";
|
5653
|
+
})(ExamType || (ExamType = {}));
|
5654
|
+
var ExamStatus$1;
|
5655
|
+
(function (ExamStatus) {
|
5656
|
+
ExamStatus["Default"] = "Default";
|
5657
|
+
ExamStatus["Pending"] = "Pending";
|
5658
|
+
ExamStatus["InProgress"] = "InProgress";
|
5659
|
+
ExamStatus["Completed"] = "Completed";
|
5660
|
+
})(ExamStatus$1 || (ExamStatus$1 = {}));
|
5661
|
+
var ExamStatusNumber;
|
5662
|
+
(function (ExamStatusNumber) {
|
5663
|
+
ExamStatusNumber[ExamStatusNumber["Default"] = 0] = "Default";
|
5664
|
+
ExamStatusNumber[ExamStatusNumber["Pending"] = 1] = "Pending";
|
5665
|
+
ExamStatusNumber[ExamStatusNumber["InProgress"] = 2] = "InProgress";
|
5666
|
+
ExamStatusNumber[ExamStatusNumber["Completed"] = 3] = "Completed";
|
5667
|
+
})(ExamStatusNumber || (ExamStatusNumber = {}));
|
5458
5668
|
|
5459
5669
|
var TEXTBOOK_HEADERS = [{
|
5460
5670
|
title: "#"
|
@@ -5472,6 +5682,19 @@ var TEXTBOOK_HEADERS = [{
|
|
5472
5682
|
}, {
|
5473
5683
|
title: "actions"
|
5474
5684
|
}];
|
5685
|
+
var DEFAULT_ANSWER_COUNT = 5;
|
5686
|
+
var DEFAULT_EXAM_REQUEST = {
|
5687
|
+
questions: [{
|
5688
|
+
article: 1,
|
5689
|
+
correctAnswers: [1],
|
5690
|
+
numberOfAnswers: DEFAULT_ANSWER_COUNT,
|
5691
|
+
score: 2,
|
5692
|
+
questionOrder: 0
|
5693
|
+
}],
|
5694
|
+
title: "",
|
5695
|
+
duration: 10,
|
5696
|
+
subjectId: 0
|
5697
|
+
};
|
5475
5698
|
var TEXTBOOK_PAGE_TITLE = "textbooks";
|
5476
5699
|
var TEXT_BOOK_SEARCH_PLACEHOLDER = "enter_student_name_to_search";
|
5477
5700
|
var TextbookDefaultQuery = {
|
@@ -5538,6 +5761,133 @@ var deleteArticleApi = function deleteArticleApi(articleId, role) {
|
|
5538
5761
|
});
|
5539
5762
|
};
|
5540
5763
|
|
5764
|
+
var EXAM_URL = BASE_URL + "/api/exam";
|
5765
|
+
var createExam = function createExam(data) {
|
5766
|
+
return api.post("" + EXAM_URL, data, {
|
5767
|
+
params: {
|
5768
|
+
roles: [Role.Teacher]
|
5769
|
+
}
|
5770
|
+
});
|
5771
|
+
};
|
5772
|
+
var apiCreateExamSession = function apiCreateExamSession(examId) {
|
5773
|
+
return api.post(EXAM_URL + "/" + examId);
|
5774
|
+
};
|
5775
|
+
|
5776
|
+
var useExam = function useExam(props) {
|
5777
|
+
var callback = props.callback,
|
5778
|
+
navigate = props.navigate;
|
5779
|
+
var dispatch = useDispatch();
|
5780
|
+
var _useState = useState(false),
|
5781
|
+
isOpenDialog = _useState[0],
|
5782
|
+
setOpenDialog = _useState[1];
|
5783
|
+
var _useState2 = useState(DEFAULT_EXAM_REQUEST),
|
5784
|
+
examRequest = _useState2[0],
|
5785
|
+
setExamRequest = _useState2[1];
|
5786
|
+
var isTeacher = useSelector(function (state) {
|
5787
|
+
var _state$common, _state$common$user;
|
5788
|
+
return state === null || state === void 0 ? void 0 : (_state$common = state.common) === null || _state$common === void 0 ? void 0 : (_state$common$user = _state$common.user) === null || _state$common$user === void 0 ? void 0 : _state$common$user.roles.includes(Roles.Teacher);
|
5789
|
+
});
|
5790
|
+
var _useTranslation = useTranslation(),
|
5791
|
+
t = _useTranslation.t;
|
5792
|
+
var handleChangeExamRequest = function handleChangeExamRequest(value) {
|
5793
|
+
setExamRequest(value);
|
5794
|
+
};
|
5795
|
+
var handleOpenCreateExamDialog = function handleOpenCreateExamDialog() {
|
5796
|
+
setOpenDialog(true);
|
5797
|
+
};
|
5798
|
+
var handleCloseDialog = function handleCloseDialog() {
|
5799
|
+
setExamRequest(DEFAULT_EXAM_REQUEST);
|
5800
|
+
setOpenDialog(false);
|
5801
|
+
callback === null || callback === void 0 ? void 0 : callback();
|
5802
|
+
};
|
5803
|
+
var validateExam = function validateExam(exam) {
|
5804
|
+
if (!exam.subjectId) return t("Please select an exam subject");
|
5805
|
+
if (!exam.title.trim().length) return t("Please enter exam title");
|
5806
|
+
if (!exam.questions.length) return t("Exam required at least one question");
|
5807
|
+
for (var i = 0; i < exam.questions.length; i++) {
|
5808
|
+
var question = exam.questions[i];
|
5809
|
+
if (!question.categoryId) return t("Please select category for article " + question.article);
|
5810
|
+
}
|
5811
|
+
return false;
|
5812
|
+
};
|
5813
|
+
var handleCreateExam = function handleCreateExam() {
|
5814
|
+
try {
|
5815
|
+
var _temp3 = function _temp3() {
|
5816
|
+
dispatch(setLoading(false));
|
5817
|
+
};
|
5818
|
+
if (!examRequest) return Promise.resolve();
|
5819
|
+
var errorMessage = validateExam(examRequest);
|
5820
|
+
if (errorMessage) {
|
5821
|
+
toast.error(errorMessage);
|
5822
|
+
return Promise.resolve();
|
5823
|
+
}
|
5824
|
+
dispatch(setLoading(true));
|
5825
|
+
var _temp2 = _catch(function () {
|
5826
|
+
return Promise.resolve(createExam(_extends({}, examRequest, {
|
5827
|
+
duration: minutesToTimeSpan(examRequest.duration || 0)
|
5828
|
+
}))).then(function (res) {
|
5829
|
+
var _temp = function (_res$data, _res$data$data) {
|
5830
|
+
if (!((_res$data = res.data) !== null && _res$data !== void 0 && (_res$data$data = _res$data.data) !== null && _res$data$data !== void 0 && _res$data$data.id)) {
|
5831
|
+
toast.error("Create exam failed");
|
5832
|
+
} else {
|
5833
|
+
var _res$data2, _res$data2$data;
|
5834
|
+
return Promise.resolve(apiCreateExamSession((_res$data2 = res.data) === null || _res$data2 === void 0 ? void 0 : (_res$data2$data = _res$data2.data) === null || _res$data2$data === void 0 ? void 0 : _res$data2$data.id)).then(function () {
|
5835
|
+
setExamRequest(DEFAULT_EXAM_REQUEST);
|
5836
|
+
toast.success("Create exam successfully");
|
5837
|
+
});
|
5838
|
+
}
|
5839
|
+
}();
|
5840
|
+
if (_temp && _temp.then) return _temp.then(function () {});
|
5841
|
+
});
|
5842
|
+
}, function (error) {
|
5843
|
+
var _error$response;
|
5844
|
+
toast.error((error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : _error$response.data) || "Create exam failed");
|
5845
|
+
});
|
5846
|
+
return Promise.resolve(_temp2 && _temp2.then ? _temp2.then(_temp3) : _temp3(_temp2));
|
5847
|
+
} catch (e) {
|
5848
|
+
return Promise.reject(e);
|
5849
|
+
}
|
5850
|
+
};
|
5851
|
+
var handleSaveExam = function handleSaveExam() {
|
5852
|
+
try {
|
5853
|
+
var _temp5 = function _temp5() {
|
5854
|
+
dispatch(setLoading(false));
|
5855
|
+
};
|
5856
|
+
if (!examRequest) return Promise.resolve();
|
5857
|
+
var errorMessage = validateExam(examRequest);
|
5858
|
+
if (errorMessage) {
|
5859
|
+
toast.error(errorMessage);
|
5860
|
+
return Promise.resolve();
|
5861
|
+
}
|
5862
|
+
dispatch(setLoading(true));
|
5863
|
+
var _temp4 = _catch(function () {
|
5864
|
+
return Promise.resolve(createExam(_extends({}, examRequest, {
|
5865
|
+
duration: minutesToTimeSpan(examRequest.duration || 0)
|
5866
|
+
}))).then(function () {
|
5867
|
+
handleCloseDialog();
|
5868
|
+
toast.success("Save exam successfully");
|
5869
|
+
isTeacher ? navigate('/teacher/exam-list') : navigate('/exams');
|
5870
|
+
});
|
5871
|
+
}, function (error) {
|
5872
|
+
var _error$response2;
|
5873
|
+
toast.error((error === null || error === void 0 ? void 0 : (_error$response2 = error.response) === null || _error$response2 === void 0 ? void 0 : _error$response2.data) || "Save exam failed");
|
5874
|
+
});
|
5875
|
+
return Promise.resolve(_temp4 && _temp4.then ? _temp4.then(_temp5) : _temp5(_temp4));
|
5876
|
+
} catch (e) {
|
5877
|
+
return Promise.reject(e);
|
5878
|
+
}
|
5879
|
+
};
|
5880
|
+
return {
|
5881
|
+
isOpenDialog: isOpenDialog,
|
5882
|
+
examRequest: examRequest,
|
5883
|
+
handleChangeExamRequest: handleChangeExamRequest,
|
5884
|
+
handleOpenCreateExamDialog: handleOpenCreateExamDialog,
|
5885
|
+
handleSaveExam: handleSaveExam,
|
5886
|
+
handleCloseDialog: handleCloseDialog,
|
5887
|
+
handleCreateExam: handleCreateExam
|
5888
|
+
};
|
5889
|
+
};
|
5890
|
+
|
5541
5891
|
var useTextbookDetail = function useTextbookDetail(props) {
|
5542
5892
|
var role = props.role,
|
5543
5893
|
isReadonlyParam = props.isReadonlyParam,
|
@@ -5561,18 +5911,31 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
5561
5911
|
var _useState5 = useState(),
|
5562
5912
|
parentChapter = _useState5[0],
|
5563
5913
|
setParentChapter = _useState5[1];
|
5564
|
-
var _useState6 = useState(),
|
5565
|
-
|
5566
|
-
|
5914
|
+
var _useState6 = useState([]),
|
5915
|
+
articlesSelected = _useState6[0],
|
5916
|
+
setArticlesSelected = _useState6[1];
|
5567
5917
|
var _useState7 = useState(),
|
5568
|
-
|
5569
|
-
|
5918
|
+
selectedChapter = _useState7[0],
|
5919
|
+
setSelectedChapter = _useState7[1];
|
5920
|
+
var _useState8 = useState(),
|
5921
|
+
selectedDeleteItem = _useState8[0],
|
5922
|
+
setSelectedDeleteItem = _useState8[1];
|
5570
5923
|
var updateChapterRef = useRef();
|
5571
5924
|
var updateArticleRef = useRef();
|
5572
|
-
var
|
5573
|
-
isEditedTitle =
|
5574
|
-
setEditedTitle =
|
5925
|
+
var _useState9 = useState(false),
|
5926
|
+
isEditedTitle = _useState9[0],
|
5927
|
+
setEditedTitle = _useState9[1];
|
5575
5928
|
var textbookUrl = role === Role.Teacher ? TEXTBOOK_URL$1 : ADMIN_TEXTBOOK_URL;
|
5929
|
+
var _useExam = useExam({
|
5930
|
+
navigate: navigate
|
5931
|
+
}),
|
5932
|
+
isOpenDialog = _useExam.isOpenDialog,
|
5933
|
+
examRequest = _useExam.examRequest,
|
5934
|
+
handleChangeExamRequest = _useExam.handleChangeExamRequest,
|
5935
|
+
handleOpenCreateExamDialog = _useExam.handleOpenCreateExamDialog,
|
5936
|
+
handleSaveExam = _useExam.handleSaveExam,
|
5937
|
+
handleCloseDialog = _useExam.handleCloseDialog,
|
5938
|
+
handleCreateExam = _useExam.handleCreateExam;
|
5576
5939
|
var handleOpenAddArticleDialog = function handleOpenAddArticleDialog(chapter) {
|
5577
5940
|
setSelectedChapter(chapter);
|
5578
5941
|
};
|
@@ -5823,7 +6186,6 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
5823
6186
|
}
|
5824
6187
|
};
|
5825
6188
|
return Promise.resolve(handleCreateArticle(newArticle, function (article) {
|
5826
|
-
console.log("created article: ", article);
|
5827
6189
|
handleUpdateChapterValue([].concat(articles, [article]), "articles", selectedChapter.id, selectedChapter.parentChapterId);
|
5828
6190
|
setSelectedChapter(undefined);
|
5829
6191
|
})).then(function () {});
|
@@ -5913,12 +6275,14 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
5913
6275
|
};
|
5914
6276
|
});
|
5915
6277
|
newArticle = _extends({}, thisArticles, {
|
6278
|
+
chapterId: chapterId,
|
5916
6279
|
questions: [].concat(thisQuestions, additionalQuestionArticles)
|
5917
6280
|
});
|
5918
6281
|
newArticles = [].concat(articles.slice(0, articleNumber - 1), [newArticle], articles.slice(articleNumber));
|
5919
6282
|
}
|
5920
6283
|
if (questionCount < thisQuestions.length) {
|
5921
6284
|
newArticle = _extends({}, thisArticles, {
|
6285
|
+
chapterId: chapterId,
|
5922
6286
|
questions: [].concat(thisQuestions.slice(0, questionCount))
|
5923
6287
|
});
|
5924
6288
|
newArticles = [].concat(articles.slice(0, articleNumber - 1), [newArticle], articles.slice(articleNumber));
|
@@ -5930,6 +6294,7 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
5930
6294
|
};
|
5931
6295
|
var handleUpdateArticleCategory = function handleUpdateArticleCategory(articleNumber, categoryId, articles, chapterId, parentChapterId) {
|
5932
6296
|
var newArticle = _extends({}, articles[articleNumber - 1], {
|
6297
|
+
chapterId: chapterId,
|
5933
6298
|
category: {
|
5934
6299
|
id: categoryId
|
5935
6300
|
}
|
@@ -5946,6 +6311,7 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
5946
6311
|
if (newAnswerCount > answerCount) {
|
5947
6312
|
newArticle = _extends({}, articles[articleNumber - 1], {
|
5948
6313
|
answerCount: newAnswerCount,
|
6314
|
+
chapterId: chapterId,
|
5949
6315
|
questions: articles[articleNumber - 1].questions.map(function (i) {
|
5950
6316
|
return _extends({}, i, {
|
5951
6317
|
numberOfAnswers: newAnswerCount
|
@@ -5955,6 +6321,7 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
5955
6321
|
} else if (newAnswerCount < answerCount) {
|
5956
6322
|
newArticle = _extends({}, articles[articleNumber - 1], {
|
5957
6323
|
answerCount: newAnswerCount,
|
6324
|
+
chapterId: chapterId,
|
5958
6325
|
questions: articles[articleNumber - 1].questions.map(function (i) {
|
5959
6326
|
return _extends({}, i, {
|
5960
6327
|
numberOfAnswers: newAnswerCount,
|
@@ -5974,6 +6341,7 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
5974
6341
|
var _extends4;
|
5975
6342
|
var thisQuestions = articles[articleNumber - 1].questions;
|
5976
6343
|
var newArticle = _extends({}, articles[articleNumber - 1], {
|
6344
|
+
chapterId: chapterId,
|
5977
6345
|
questions: [].concat(thisQuestions.slice(0, index), [_extends({}, thisQuestions[index], (_extends4 = {}, _extends4[key] = value, _extends4))], thisQuestions.slice(index + 1))
|
5978
6346
|
});
|
5979
6347
|
var newArticles = [].concat(articles.slice(0, articleNumber - 1), [newArticle], articles.slice(articleNumber));
|
@@ -6134,6 +6502,19 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
6134
6502
|
replace: true
|
6135
6503
|
});
|
6136
6504
|
};
|
6505
|
+
var handleCheckArticle = function handleCheckArticle(e, article) {
|
6506
|
+
var checked = e.target.checked;
|
6507
|
+
if (!(article !== null && article !== void 0 && article.id)) return;
|
6508
|
+
if (!checked) {
|
6509
|
+
var _newArticles = articlesSelected.filter(function (item) {
|
6510
|
+
return item !== article.id;
|
6511
|
+
});
|
6512
|
+
setArticlesSelected(_newArticles);
|
6513
|
+
return;
|
6514
|
+
}
|
6515
|
+
var newArticles = [].concat(articlesSelected, [article.id]);
|
6516
|
+
setArticlesSelected(newArticles);
|
6517
|
+
};
|
6137
6518
|
useEffect(function () {
|
6138
6519
|
var getTextbookDetail = function getTextbookDetail() {
|
6139
6520
|
try {
|
@@ -6158,6 +6539,53 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
6158
6539
|
};
|
6159
6540
|
if (id) getTextbookDetail();
|
6160
6541
|
}, [dispatch, id]);
|
6542
|
+
var handleChangeExamRequestBeforeOpenDialog = function handleChangeExamRequestBeforeOpenDialog() {
|
6543
|
+
var _textbookSubject$valu;
|
6544
|
+
handleOpenCreateExamDialog();
|
6545
|
+
var articles = textbook.chapters.map(function (chapter) {
|
6546
|
+
var isSubChapters = !!chapter.subChapters.length;
|
6547
|
+
if (isSubChapters) {
|
6548
|
+
var _articles = chapter.subChapters.map(function (chapter) {
|
6549
|
+
return chapter.articles;
|
6550
|
+
});
|
6551
|
+
return _articles.filter(Boolean).flat();
|
6552
|
+
}
|
6553
|
+
return chapter.articles;
|
6554
|
+
});
|
6555
|
+
var articlesAfterFlat = articles.flat();
|
6556
|
+
var questionCount = 0;
|
6557
|
+
var articleCount = 1;
|
6558
|
+
var questions = articlesAfterFlat.map(function (article) {
|
6559
|
+
if (articlesSelected.findIndex(function (item) {
|
6560
|
+
return item === article.id;
|
6561
|
+
}) !== -1) {
|
6562
|
+
var _questions = article.questions.map(function (question) {
|
6563
|
+
var _article$category3;
|
6564
|
+
var newQuestion = {
|
6565
|
+
article: articleCount,
|
6566
|
+
id: question === null || question === void 0 ? void 0 : question.id,
|
6567
|
+
correctAnswers: question.correctAnswers,
|
6568
|
+
numberOfAnswers: question.numberOfAnswers,
|
6569
|
+
score: question.score,
|
6570
|
+
questionOrder: questionCount,
|
6571
|
+
categoryId: (_article$category3 = article.category) === null || _article$category3 === void 0 ? void 0 : _article$category3.id
|
6572
|
+
};
|
6573
|
+
questionCount++;
|
6574
|
+
return newQuestion;
|
6575
|
+
});
|
6576
|
+
articleCount++;
|
6577
|
+
return _questions;
|
6578
|
+
}
|
6579
|
+
return [];
|
6580
|
+
});
|
6581
|
+
var exam = {
|
6582
|
+
title: "",
|
6583
|
+
duration: 10,
|
6584
|
+
subjectId: (_textbookSubject$valu = textbookSubject === null || textbookSubject === void 0 ? void 0 : textbookSubject.value) != null ? _textbookSubject$valu : 0,
|
6585
|
+
questions: questions.flat().filter(Boolean)
|
6586
|
+
};
|
6587
|
+
handleChangeExamRequest(exam);
|
6588
|
+
};
|
6161
6589
|
useEffect(function () {
|
6162
6590
|
document.title = t("textbooks") + " | " + t(id ? "textbook_detail" : "create_textbook");
|
6163
6591
|
}, [id, t]);
|
@@ -6177,6 +6605,15 @@ var useTextbookDetail = function useTextbookDetail(props) {
|
|
6177
6605
|
selectedDeleteItem: selectedDeleteItem,
|
6178
6606
|
isEditedTitle: isEditedTitle,
|
6179
6607
|
isReadonlyParam: isReadonlyParam,
|
6608
|
+
articlesSelected: articlesSelected,
|
6609
|
+
isOpenDialog: isOpenDialog,
|
6610
|
+
examRequest: examRequest,
|
6611
|
+
handleChangeExamRequest: handleChangeExamRequest,
|
6612
|
+
handleCheckArticle: handleCheckArticle,
|
6613
|
+
handleOpenCreateExamDialog: handleChangeExamRequestBeforeOpenDialog,
|
6614
|
+
handleSaveExam: handleSaveExam,
|
6615
|
+
handleCloseDialog: handleCloseDialog,
|
6616
|
+
handleCreateExam: handleCreateExam,
|
6180
6617
|
handleChangeTextbookTitle: handleChangeTextbookTitle,
|
6181
6618
|
handleCreateOrUpdateTextbook: handleCreateOrUpdateTextbook,
|
6182
6619
|
handleChangeTextbookSubject: handleChangeTextbookSubject,
|
@@ -6616,9 +7053,9 @@ var SubjectSelector = function SubjectSelector(_ref) {
|
|
6616
7053
|
!minimumTextSearchLength && defaultValueAtFirst && options.length && onChange(options[0], subjects[0]);
|
6617
7054
|
}, [JSON.stringify(options), JSON.stringify(subjects), defaultValueAtFirst, minimumTextSearchLength]);
|
6618
7055
|
return React.createElement(FormGroup, {
|
6619
|
-
className: "" +
|
7056
|
+
className: "" + styles["filter-item"]
|
6620
7057
|
}, !!title && React.createElement("label", {
|
6621
|
-
className: "" +
|
7058
|
+
className: "" + styles["title-form"]
|
6622
7059
|
}, title), React.createElement(CustomSelectOption, {
|
6623
7060
|
options: options,
|
6624
7061
|
inputValue: searchString,
|
@@ -6634,1036 +7071,1115 @@ var SubjectSelector = function SubjectSelector(_ref) {
|
|
6634
7071
|
}));
|
6635
7072
|
};
|
6636
7073
|
|
6637
|
-
var
|
6638
|
-
var _textbook$chapters;
|
6639
|
-
var _useTextbookDetail = useTextbookDetail(props),
|
6640
|
-
id = _useTextbookDetail.id,
|
6641
|
-
t = _useTextbookDetail.t,
|
6642
|
-
textbook = _useTextbookDetail.textbook,
|
6643
|
-
textbookSubject = _useTextbookDetail.textbookSubject,
|
6644
|
-
isReadonly = _useTextbookDetail.isReadonly,
|
6645
|
-
isNotFound = _useTextbookDetail.isNotFound,
|
6646
|
-
parentChapter = _useTextbookDetail.parentChapter,
|
6647
|
-
textbookId = _useTextbookDetail.textbookId,
|
6648
|
-
selectedChapter = _useTextbookDetail.selectedChapter,
|
6649
|
-
selectedDeleteItem = _useTextbookDetail.selectedDeleteItem,
|
6650
|
-
isEditedTitle = _useTextbookDetail.isEditedTitle,
|
6651
|
-
handleChangeTextbookTitle = _useTextbookDetail.handleChangeTextbookTitle,
|
6652
|
-
handleChangeTextbookSubject = _useTextbookDetail.handleChangeTextbookSubject,
|
6653
|
-
handleGoToTextbookList = _useTextbookDetail.handleGoToTextbookList,
|
6654
|
-
handleCreateOrUpdateTextbook = _useTextbookDetail.handleCreateOrUpdateTextbook,
|
6655
|
-
handleCloseChapterNameDialog = _useTextbookDetail.handleCloseChapterNameDialog,
|
6656
|
-
handleCreateChapter = _useTextbookDetail.handleCreateChapter,
|
6657
|
-
handleAddChapterToTextbook = _useTextbookDetail.handleAddChapterToTextbook,
|
6658
|
-
handleAddChapterToParentSubchapter = _useTextbookDetail.handleAddChapterToParentSubchapter,
|
6659
|
-
handleChangeChapterName = _useTextbookDetail.handleChangeChapterName,
|
6660
|
-
handleChangeChapterPageFrom = _useTextbookDetail.handleChangeChapterPageFrom,
|
6661
|
-
handleChangeChapterPageTo = _useTextbookDetail.handleChangeChapterPageTo,
|
6662
|
-
handleAddArticleToChapter = _useTextbookDetail.handleAddArticleToChapter,
|
6663
|
-
handleUpdateArticleQuestionCountFromChapter = _useTextbookDetail.handleUpdateArticleQuestionCountFromChapter,
|
6664
|
-
handleUpdateArticleCategory = _useTextbookDetail.handleUpdateArticleCategory,
|
6665
|
-
handleUpdateArticleAnswerCount = _useTextbookDetail.handleUpdateArticleAnswerCount,
|
6666
|
-
handleUpdateArticleQuestion = _useTextbookDetail.handleUpdateArticleQuestion,
|
6667
|
-
handleCloseArticleDialog = _useTextbookDetail.handleCloseArticleDialog,
|
6668
|
-
handleOpenAddArticleDialog = _useTextbookDetail.handleOpenAddArticleDialog,
|
6669
|
-
handleOpenRemoveArticleConfirmDialog = _useTextbookDetail.handleOpenRemoveArticleConfirmDialog,
|
6670
|
-
handleCloseConfirmDeleteDialog = _useTextbookDetail.handleCloseConfirmDeleteDialog,
|
6671
|
-
handleRemoveSelectedItem = _useTextbookDetail.handleRemoveSelectedItem,
|
6672
|
-
handleOpenRemoveChapterConfirmDialog = _useTextbookDetail.handleOpenRemoveChapterConfirmDialog;
|
6673
|
-
var _useCategorySelect = useCategorySelect({
|
6674
|
-
subjectId: id ? textbookSubject === null || textbookSubject === void 0 ? void 0 : textbookSubject.value : undefined
|
6675
|
-
}),
|
6676
|
-
categoryOptions = _useCategorySelect.categoryOptions;
|
6677
|
-
if (isNotFound) return React.createElement(NotFound, null);
|
6678
|
-
return React.createElement(Container, {
|
6679
|
-
maxWidth: "xl",
|
6680
|
-
className: "bg-white py-5 p-4 rounded-4 h-100 d-flex flex-column"
|
6681
|
-
}, React.createElement(Stack, {
|
6682
|
-
direction: "row",
|
6683
|
-
alignItems: "center",
|
6684
|
-
justifyContent: "space-between",
|
6685
|
-
mb: 2
|
6686
|
-
}, React.createElement(Typography, {
|
6687
|
-
variant: "h3"
|
6688
|
-
}, t(id ? isReadonly ? "view_textbook" : "update_textbook" : "create_textbook"))), React.createElement(Grid, {
|
6689
|
-
container: true,
|
6690
|
-
spacing: 3
|
6691
|
-
}, React.createElement(Grid, {
|
6692
|
-
item: true,
|
6693
|
-
xs: 4,
|
6694
|
-
className: "d-flex align-items-center"
|
6695
|
-
}, React.createElement(Table, null, React.createElement(TableBody, null, React.createElement(TableRow, {
|
6696
|
-
sx: {
|
6697
|
-
"& td": {
|
6698
|
-
border: 0
|
6699
|
-
}
|
6700
|
-
}
|
6701
|
-
}, React.createElement(TableCell, {
|
6702
|
-
className: "p-2 pe-0",
|
6703
|
-
sx: {
|
6704
|
-
width: "15%"
|
6705
|
-
}
|
6706
|
-
}, React.createElement(InputLabel, null, React.createElement("span", {
|
6707
|
-
className: "fw-bold"
|
6708
|
-
}, t("name")), React.createElement("span", {
|
6709
|
-
className: "text-danger"
|
6710
|
-
}, "*"))), React.createElement(TableCell, {
|
6711
|
-
sx: {
|
6712
|
-
width: 0,
|
6713
|
-
px: 1
|
6714
|
-
}
|
6715
|
-
}, ":"), React.createElement(TableCell, {
|
6716
|
-
className: "p-2"
|
6717
|
-
}, React.createElement(InputText, {
|
6718
|
-
className: "w-100",
|
6719
|
-
value: textbook === null || textbook === void 0 ? void 0 : textbook.name,
|
6720
|
-
placeholder: t("enter_textbook_title"),
|
6721
|
-
onChange: handleChangeTextbookTitle,
|
6722
|
-
disabled: isReadonly
|
6723
|
-
}))), React.createElement(TableRow, {
|
6724
|
-
sx: {
|
6725
|
-
"& td": {
|
6726
|
-
border: 0
|
6727
|
-
}
|
6728
|
-
}
|
6729
|
-
}, React.createElement(TableCell, {
|
6730
|
-
className: "p-2 pe-0"
|
6731
|
-
}, React.createElement(InputLabel, null, React.createElement("span", {
|
6732
|
-
className: "fw-bold"
|
6733
|
-
}, t("subject")), React.createElement("span", {
|
6734
|
-
className: "text-danger"
|
6735
|
-
}, "*"))), React.createElement(TableCell, {
|
6736
|
-
sx: {
|
6737
|
-
width: 0,
|
6738
|
-
px: 1
|
6739
|
-
}
|
6740
|
-
}, ":"), React.createElement(TableCell, {
|
6741
|
-
className: "p-2"
|
6742
|
-
}, React.createElement(SubjectSelector, {
|
6743
|
-
value: textbookSubject,
|
6744
|
-
onChange: handleChangeTextbookSubject,
|
6745
|
-
isDisabled: isReadonly || !!id
|
6746
|
-
})))))), React.createElement(Grid, {
|
6747
|
-
item: true,
|
6748
|
-
xs: 8,
|
6749
|
-
className: "d-flex justify-content-end"
|
6750
|
-
}, React.createElement("div", null, React.createElement(TextbookActionButtons, {
|
6751
|
-
isReadonly: isReadonly,
|
6752
|
-
textbook: textbook,
|
6753
|
-
onBack: handleGoToTextbookList,
|
6754
|
-
onSave: handleCreateOrUpdateTextbook,
|
6755
|
-
hideSave: !isEditedTitle && !!id && !isReadonly || textbook.isCreatedByAdmin
|
6756
|
-
}))), React.createElement(Grid, {
|
6757
|
-
item: true,
|
6758
|
-
xs: 12,
|
6759
|
-
className: "d-flex justify-content-end"
|
6760
|
-
}, !!id && React.createElement(Button, {
|
6761
|
-
className: "mx-1",
|
6762
|
-
variant: "contained",
|
6763
|
-
color: "primary",
|
6764
|
-
startIcon: React.createElement(FaPlus, {
|
6765
|
-
size: 12
|
6766
|
-
}),
|
6767
|
-
onClick: handleAddChapterToTextbook,
|
6768
|
-
disabled: isReadonly
|
6769
|
-
}, t("add_chapter"))), React.createElement(Grid, {
|
6770
|
-
item: true,
|
6771
|
-
xs: 12
|
6772
|
-
}, React.createElement(Stack, {
|
6773
|
-
spacing: 3
|
6774
|
-
}, !!(textbook !== null && textbook !== void 0 && textbook.subject) && (textbook === null || textbook === void 0 ? void 0 : (_textbook$chapters = textbook.chapters) === null || _textbook$chapters === void 0 ? void 0 : _textbook$chapters.map(function (chapter) {
|
6775
|
-
return React.createElement(ChapterBox, {
|
6776
|
-
key: chapter.id,
|
6777
|
-
subject: textbook.subject,
|
6778
|
-
data: chapter,
|
6779
|
-
categoryOptions: categoryOptions || [],
|
6780
|
-
onClickAddSubchapter: handleAddChapterToParentSubchapter,
|
6781
|
-
onChangeName: handleChangeChapterName,
|
6782
|
-
onChangePageFrom: handleChangeChapterPageFrom,
|
6783
|
-
onChangePageTo: handleChangeChapterPageTo,
|
6784
|
-
onAddArticle: handleOpenAddArticleDialog,
|
6785
|
-
onRemoveArticle: handleOpenRemoveArticleConfirmDialog,
|
6786
|
-
onUpdateArticleQuestionCount: handleUpdateArticleQuestionCountFromChapter,
|
6787
|
-
onUpdateArticleCategory: handleUpdateArticleCategory,
|
6788
|
-
onUpdateArticleQuestionAnswerCount: handleUpdateArticleAnswerCount,
|
6789
|
-
onUpdateArticleQuestion: handleUpdateArticleQuestion,
|
6790
|
-
onRemoveChapter: handleOpenRemoveChapterConfirmDialog,
|
6791
|
-
isReadonly: isReadonly
|
6792
|
-
});
|
6793
|
-
}))))), React.createElement(ChapterNameDialog, {
|
6794
|
-
open: !!(parentChapter !== null && parentChapter !== void 0 && parentChapter.id) || !!textbookId,
|
6795
|
-
chapter: parentChapter,
|
6796
|
-
onClose: handleCloseChapterNameDialog,
|
6797
|
-
onSubmitForm: handleCreateChapter
|
6798
|
-
}), React.createElement(ArticleDialog, {
|
6799
|
-
open: !!selectedChapter,
|
6800
|
-
chapter: selectedChapter,
|
6801
|
-
categoryOptions: categoryOptions || [],
|
6802
|
-
onClose: handleCloseArticleDialog,
|
6803
|
-
onSubmitForm: handleAddArticleToChapter
|
6804
|
-
}), selectedDeleteItem && React.createElement(ConfirmDialog, {
|
6805
|
-
open: true,
|
6806
|
-
toggle: handleCloseConfirmDeleteDialog,
|
6807
|
-
text: selectedDeleteItem.confirmText,
|
6808
|
-
confirmText: selectedDeleteItem.name,
|
6809
|
-
onConfirm: handleRemoveSelectedItem,
|
6810
|
-
isDelete: true
|
6811
|
-
}));
|
6812
|
-
};
|
7074
|
+
var styles$3 = {"drawer":"_11aYm","open":"_3Ydwm","drawer-overlay":"_3SQDf","drawer-header":"_2BwOx","drawer-form":"_2Zo7R","dropdown-content-academy":"_1lzjD","dropdown-change":"_1y7K9","dropdown-academy-item":"_1Y-55","dropdown-content-language":"_1fBXY","dropdown-item-language":"_3Szun","dropdown-item-language-active":"_2HhLb","item-address":"_3WYHC","item-logout":"_2-9ix","title-address":"_1r4pn","image-academy":"_2ZozT"};
|
6813
7075
|
|
6814
|
-
var
|
6815
|
-
|
6816
|
-
|
6817
|
-
|
6818
|
-
|
6819
|
-
|
6820
|
-
|
6821
|
-
|
6822
|
-
|
6823
|
-
|
6824
|
-
|
6825
|
-
|
6826
|
-
|
6827
|
-
|
6828
|
-
|
6829
|
-
|
6830
|
-
|
6831
|
-
|
6832
|
-
|
6833
|
-
|
6834
|
-
|
6835
|
-
|
6836
|
-
|
6837
|
-
|
6838
|
-
|
6839
|
-
|
7076
|
+
var DURATION_OPTIONS = Array.from({
|
7077
|
+
length: 120
|
7078
|
+
}, function (_, i) {
|
7079
|
+
return i + 1;
|
7080
|
+
});
|
7081
|
+
var DEFAULT_ANSWER_COUNT$1 = 5;
|
7082
|
+
|
7083
|
+
var useExamDetailView = function useExamDetailView(props) {
|
7084
|
+
var exam = props.exam,
|
7085
|
+
selectedSubject = props.selectedSubject,
|
7086
|
+
onChangeExam = props.onChangeExam;
|
7087
|
+
var _useTranslation = useTranslation(),
|
7088
|
+
t = _useTranslation.t;
|
7089
|
+
var handleChangeQuestionCount = function handleChangeQuestionCount(article, questionCount, answerCount) {
|
7090
|
+
if (!exam) return;
|
7091
|
+
var examQuestions = exam.questions;
|
7092
|
+
var questions = examQuestions.filter(function (i) {
|
7093
|
+
return i.article === +article;
|
7094
|
+
});
|
7095
|
+
var prevQuestions = examQuestions.filter(function (i) {
|
7096
|
+
return i.article < +article;
|
7097
|
+
});
|
7098
|
+
var nextQuestions = examQuestions.filter(function (i) {
|
7099
|
+
return i.article > +article;
|
7100
|
+
});
|
7101
|
+
var lastOrder = questions[questions.length - 1].questionOrder;
|
7102
|
+
if (questions.length === questionCount) return;
|
7103
|
+
if (questions.length < questionCount) {
|
7104
|
+
var additionalQuestions = Array.from({
|
7105
|
+
length: questionCount - questions.length
|
7106
|
+
}).map(function (_, index) {
|
7107
|
+
var _questions$;
|
7108
|
+
return {
|
7109
|
+
article: +article,
|
7110
|
+
correctAnswers: [1],
|
7111
|
+
numberOfAnswers: answerCount,
|
7112
|
+
categoryId: (_questions$ = questions[0]) === null || _questions$ === void 0 ? void 0 : _questions$.categoryId,
|
7113
|
+
score: DEFAULT_SCORE,
|
7114
|
+
questionOrder: lastOrder + index + 1
|
7115
|
+
};
|
7116
|
+
});
|
7117
|
+
var newQuestions = [].concat(prevQuestions, questions, additionalQuestions, nextQuestions.map(function (i) {
|
7118
|
+
return _extends({}, i, {
|
7119
|
+
questionOrder: i.questionOrder + questionCount - questions.length
|
6840
7120
|
});
|
6841
|
-
}
|
7121
|
+
}));
|
7122
|
+
onChangeExam(_extends({}, exam, {
|
7123
|
+
questions: [].concat(newQuestions)
|
7124
|
+
}));
|
6842
7125
|
} else {
|
6843
|
-
|
6844
|
-
|
6845
|
-
|
6846
|
-
|
6847
|
-
pathname: homeAcademyUrl,
|
6848
|
-
search: ""
|
7126
|
+
var remainQuestions = questions.slice(0, questionCount);
|
7127
|
+
var _newQuestions = [].concat(prevQuestions, remainQuestions, nextQuestions.map(function (i) {
|
7128
|
+
return _extends({}, i, {
|
7129
|
+
questionOrder: i.questionOrder - questions.length + questionCount
|
6849
7130
|
});
|
6850
|
-
}
|
6851
|
-
|
6852
|
-
|
6853
|
-
}
|
6854
|
-
if (!paramAcademyDomain && academyDomain) {
|
6855
|
-
searchParams.append("domain", academyDomain);
|
6856
|
-
pushTo(_extends({}, window.location, {
|
6857
|
-
search: searchParams.toString()
|
6858
|
-
}));
|
6859
|
-
}
|
7131
|
+
}));
|
7132
|
+
onChangeExam(_extends({}, exam, {
|
7133
|
+
questions: [].concat(_newQuestions)
|
7134
|
+
}));
|
6860
7135
|
}
|
6861
7136
|
};
|
6862
|
-
var
|
6863
|
-
if (
|
6864
|
-
|
6865
|
-
|
6866
|
-
|
6867
|
-
|
6868
|
-
|
6869
|
-
|
6870
|
-
|
6871
|
-
|
6872
|
-
|
6873
|
-
|
6874
|
-
|
6875
|
-
|
6876
|
-
|
6877
|
-
|
6878
|
-
var _useState3 = useState([]),
|
6879
|
-
data = _useState3[0],
|
6880
|
-
setData = _useState3[1];
|
6881
|
-
var _useState4 = useState(),
|
6882
|
-
selectedItem = _useState4[0],
|
6883
|
-
setSelectedItem = _useState4[1];
|
6884
|
-
var textSearchRef = useRef(null);
|
6885
|
-
var isFirstLoadRef = useRef(true);
|
6886
|
-
var handleChangeSelectedItem = function handleChangeSelectedItem(item) {
|
6887
|
-
setSelectedItem(item);
|
7137
|
+
var handleChangeCategory = function handleChangeCategory(article, categoryId) {
|
7138
|
+
if (!exam) return;
|
7139
|
+
var examQuestions = exam.questions;
|
7140
|
+
var questions = examQuestions.filter(function (i) {
|
7141
|
+
return i.article === +article;
|
7142
|
+
});
|
7143
|
+
var otherQuestions = examQuestions.filter(function (i) {
|
7144
|
+
return i.article !== +article;
|
7145
|
+
});
|
7146
|
+
onChangeExam(_extends({}, exam, {
|
7147
|
+
questions: [].concat(otherQuestions, questions.map(function (q) {
|
7148
|
+
return _extends({}, q, {
|
7149
|
+
categoryId: categoryId
|
7150
|
+
});
|
7151
|
+
}))
|
7152
|
+
}));
|
6888
7153
|
};
|
6889
|
-
var
|
6890
|
-
if (
|
6891
|
-
|
6892
|
-
|
6893
|
-
|
6894
|
-
|
6895
|
-
|
6896
|
-
|
6897
|
-
|
6898
|
-
|
6899
|
-
|
6900
|
-
|
6901
|
-
|
6902
|
-
|
6903
|
-
items = _res$data$items === void 0 ? [] : _res$data$items,
|
6904
|
-
_res$data$totalPages = _res$data.totalPages,
|
6905
|
-
totalPages = _res$data$totalPages === void 0 ? 0 : _res$data$totalPages;
|
6906
|
-
setTotalPages(totalPages);
|
6907
|
-
setData(items);
|
6908
|
-
});
|
6909
|
-
}, function (error) {
|
6910
|
-
var _error$response, _error$response$data;
|
6911
|
-
setTotalPages(0);
|
6912
|
-
setData([]);
|
6913
|
-
toast.error((error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : (_error$response$data = _error$response.data) === null || _error$response$data === void 0 ? void 0 : _error$response$data.title) || "Get data failed");
|
7154
|
+
var handleDeleteArticle = function handleDeleteArticle(article) {
|
7155
|
+
if (!exam) return;
|
7156
|
+
var removedQuestions = exam.questions.filter(function (i) {
|
7157
|
+
return i.article === +article;
|
7158
|
+
}).map(function (i) {
|
7159
|
+
return i.questionOrder;
|
7160
|
+
});
|
7161
|
+
var max = Math.max.apply(Math, removedQuestions);
|
7162
|
+
var examQuestions = exam.questions.filter(function (i) {
|
7163
|
+
return i.article !== +article;
|
7164
|
+
}).map(function (i) {
|
7165
|
+
return _extends({}, i, {
|
7166
|
+
article: i.article > article ? i.article - 1 : i.article,
|
7167
|
+
questionOrder: i.questionOrder > max ? i.questionOrder - removedQuestions.length : i.questionOrder
|
6914
7168
|
});
|
6915
|
-
|
6916
|
-
}
|
6917
|
-
|
7169
|
+
});
|
7170
|
+
onChangeExam(_extends({}, exam, {
|
7171
|
+
questions: [].concat(examQuestions)
|
7172
|
+
}));
|
7173
|
+
};
|
7174
|
+
var handleChangeAnswerCount = function handleChangeAnswerCount(article, newAnswerCount, answerCount) {
|
7175
|
+
if (!exam) return;
|
7176
|
+
if (newAnswerCount === answerCount) return;
|
7177
|
+
var examQuestions = exam.questions;
|
7178
|
+
var questions = examQuestions.filter(function (i) {
|
7179
|
+
return i.article === +article;
|
7180
|
+
});
|
7181
|
+
var otherQuestions = examQuestions.filter(function (i) {
|
7182
|
+
return i.article !== +article;
|
7183
|
+
});
|
7184
|
+
if (answerCount < newAnswerCount) {
|
7185
|
+
onChangeExam(_extends({}, exam, {
|
7186
|
+
questions: [].concat(otherQuestions, questions.map(function (q) {
|
7187
|
+
return _extends({}, q, {
|
7188
|
+
numberOfAnswers: newAnswerCount
|
7189
|
+
});
|
7190
|
+
}))
|
7191
|
+
}));
|
7192
|
+
} else {
|
7193
|
+
onChangeExam(_extends({}, exam, {
|
7194
|
+
questions: [].concat(otherQuestions, questions.map(function (q) {
|
7195
|
+
var _q$correctAnswers;
|
7196
|
+
return _extends({}, q, {
|
7197
|
+
numberOfAnswers: newAnswerCount,
|
7198
|
+
correctAnswers: (_q$correctAnswers = q.correctAnswers) === null || _q$correctAnswers === void 0 ? void 0 : _q$correctAnswers.filter(function (i) {
|
7199
|
+
return i <= newAnswerCount;
|
7200
|
+
})
|
7201
|
+
});
|
7202
|
+
}))
|
7203
|
+
}));
|
6918
7204
|
}
|
6919
7205
|
};
|
6920
|
-
var
|
6921
|
-
|
6922
|
-
|
6923
|
-
|
6924
|
-
|
7206
|
+
var handleChangeCorrectAnswers = function handleChangeCorrectAnswers(article, index, answer) {
|
7207
|
+
if (!exam) return;
|
7208
|
+
var examQuestions = exam.questions;
|
7209
|
+
var questions = examQuestions.filter(function (i) {
|
7210
|
+
return i.article === +article;
|
6925
7211
|
});
|
6926
|
-
|
6927
|
-
|
6928
|
-
|
6929
|
-
|
6930
|
-
|
7212
|
+
var otherQuestions = examQuestions.filter(function (i) {
|
7213
|
+
return i.article !== +article;
|
7214
|
+
});
|
7215
|
+
var selectedQuestion = questions[index];
|
7216
|
+
onChangeExam(_extends({}, exam, {
|
7217
|
+
questions: [].concat(otherQuestions, questions.slice(0, index), [_extends({}, selectedQuestion, {
|
7218
|
+
correctAnswers: [answer]
|
7219
|
+
})], questions.slice(index + 1))
|
6931
7220
|
}));
|
6932
7221
|
};
|
6933
|
-
var
|
6934
|
-
if (!
|
6935
|
-
|
6936
|
-
|
7222
|
+
var handleChangeScoreAnswer = function handleChangeScoreAnswer(article, index, score) {
|
7223
|
+
if (!exam) return;
|
7224
|
+
var examQuestions = exam.questions;
|
7225
|
+
var questions = examQuestions.filter(function (i) {
|
7226
|
+
return i.article === +article;
|
7227
|
+
});
|
7228
|
+
var otherQuestions = examQuestions.filter(function (i) {
|
7229
|
+
return i.article !== +article;
|
7230
|
+
});
|
7231
|
+
var selectedQuestion = questions[index];
|
7232
|
+
if (score === selectedQuestion.score) return;
|
7233
|
+
onChangeExam(_extends({}, exam, {
|
7234
|
+
questions: [].concat(otherQuestions, questions.slice(0, index), [_extends({}, selectedQuestion, {
|
7235
|
+
score: score
|
7236
|
+
})], questions.slice(index + 1))
|
7237
|
+
}));
|
6937
7238
|
};
|
6938
|
-
var
|
6939
|
-
|
6940
|
-
|
7239
|
+
var handleChangeDuration = function handleChangeDuration(value) {
|
7240
|
+
if (!exam) return;
|
7241
|
+
onChangeExam(_extends({}, exam, {
|
7242
|
+
duration: value === null || value === void 0 ? void 0 : value.value
|
6941
7243
|
}));
|
6942
7244
|
};
|
6943
|
-
var
|
6944
|
-
|
6945
|
-
|
7245
|
+
var handleChangeTitle = function handleChangeTitle(e) {
|
7246
|
+
if (!exam) return;
|
7247
|
+
onChangeExam(_extends({}, exam, {
|
7248
|
+
title: e.target.value
|
7249
|
+
}));
|
6946
7250
|
};
|
6947
|
-
var
|
6948
|
-
var
|
6949
|
-
|
6950
|
-
|
6951
|
-
|
7251
|
+
var handleAddArticle = function handleAddArticle() {
|
7252
|
+
var _$maxBy, _$maxBy2;
|
7253
|
+
if (!exam) return;
|
7254
|
+
var maxArticle = ((_$maxBy = _.maxBy(exam.questions, "article")) === null || _$maxBy === void 0 ? void 0 : _$maxBy.article) || 0;
|
7255
|
+
var maxOrder = ((_$maxBy2 = _.maxBy(exam.questions, "questionOrder")) === null || _$maxBy2 === void 0 ? void 0 : _$maxBy2.questionOrder) || 0;
|
7256
|
+
onChangeExam(_extends({}, exam, {
|
7257
|
+
questions: [].concat(exam.questions, [{
|
7258
|
+
article: maxArticle + 1,
|
7259
|
+
correctAnswers: [1],
|
7260
|
+
numberOfAnswers: DEFAULT_ANSWER_COUNT$1,
|
7261
|
+
score: DEFAULT_SCORE,
|
7262
|
+
questionOrder: maxOrder + 1
|
7263
|
+
}])
|
6952
7264
|
}));
|
6953
|
-
}
|
7265
|
+
};
|
7266
|
+
var examGroupByArticle = useMemo(function () {
|
7267
|
+
if (!exam) return [];
|
7268
|
+
var articles = [];
|
7269
|
+
var groupedArticle = _.groupBy(exam.questions, "article");
|
7270
|
+
for (var key in groupedArticle) {
|
7271
|
+
if (Object.prototype.hasOwnProperty.call(groupedArticle, key)) {
|
7272
|
+
var _questions$find, _$maxBy3;
|
7273
|
+
var questions = groupedArticle[key];
|
7274
|
+
articles.push({
|
7275
|
+
article: +key,
|
7276
|
+
categoryId: (_questions$find = questions.find(function (i) {
|
7277
|
+
return !!i.categoryId;
|
7278
|
+
})) === null || _questions$find === void 0 ? void 0 : _questions$find.categoryId,
|
7279
|
+
answerCount: ((_$maxBy3 = _.maxBy(questions, "numberOfAnswers")) === null || _$maxBy3 === void 0 ? void 0 : _$maxBy3.numberOfAnswers) || DEFAULT_ANSWER_COUNT$1,
|
7280
|
+
questionCount: questions.length,
|
7281
|
+
questions: questions
|
7282
|
+
});
|
7283
|
+
}
|
7284
|
+
}
|
7285
|
+
return _.sortBy(articles, "article");
|
7286
|
+
}, [JSON.stringify(exam)]);
|
7287
|
+
var durationOptions = useMemo(function () {
|
7288
|
+
var options = DURATION_OPTIONS.map(function (i) {
|
7289
|
+
return {
|
7290
|
+
label: i + "\uBD84",
|
7291
|
+
value: i
|
7292
|
+
};
|
7293
|
+
});
|
7294
|
+
if (!!exam.duration && exam.duration > DURATION_OPTIONS[DURATION_OPTIONS.length - 1]) return [].concat(options, [{
|
7295
|
+
label: exam.duration + "\uBD84",
|
7296
|
+
value: exam.duration
|
7297
|
+
}]);
|
7298
|
+
return options;
|
7299
|
+
}, [exam.duration]);
|
6954
7300
|
useEffect(function () {
|
6955
|
-
|
6956
|
-
|
7301
|
+
if ((selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id) !== exam.subjectId) onChangeExam(_extends({}, exam, {
|
7302
|
+
subjectId: (selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id) || 0
|
7303
|
+
}));
|
7304
|
+
}, [selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id, exam.subjectId]);
|
6957
7305
|
return {
|
6958
|
-
|
6959
|
-
|
6960
|
-
|
6961
|
-
|
6962
|
-
|
6963
|
-
|
6964
|
-
|
6965
|
-
|
6966
|
-
|
6967
|
-
|
6968
|
-
|
7306
|
+
t: t,
|
7307
|
+
durationOptions: durationOptions,
|
7308
|
+
examGroupByArticle: examGroupByArticle,
|
7309
|
+
handleAddArticle: handleAddArticle,
|
7310
|
+
handleChangeScoreAnswer: handleChangeScoreAnswer,
|
7311
|
+
handleChangeTitle: handleChangeTitle,
|
7312
|
+
handleChangeDuration: handleChangeDuration,
|
7313
|
+
handleChangeCorrectAnswers: handleChangeCorrectAnswers,
|
7314
|
+
handleChangeAnswerCount: handleChangeAnswerCount,
|
7315
|
+
handleChangeQuestionCount: handleChangeQuestionCount,
|
7316
|
+
handleChangeCategory: handleChangeCategory,
|
7317
|
+
handleDeleteArticle: handleDeleteArticle
|
6969
7318
|
};
|
6970
7319
|
};
|
6971
7320
|
|
6972
|
-
|
6973
|
-
|
6974
|
-
|
6975
|
-
|
6976
|
-
|
6977
|
-
|
6978
|
-
|
6979
|
-
|
6980
|
-
|
6981
|
-
|
6982
|
-
|
6983
|
-
|
6984
|
-
|
6985
|
-
|
6986
|
-
|
6987
|
-
|
6988
|
-
|
6989
|
-
|
6990
|
-
|
6991
|
-
|
6992
|
-
|
6993
|
-
|
6994
|
-
|
6995
|
-
|
6996
|
-
|
6997
|
-
|
6998
|
-
|
6999
|
-
|
7000
|
-
|
7001
|
-
|
7002
|
-
|
7003
|
-
|
7004
|
-
}
|
7005
|
-
|
7006
|
-
|
7007
|
-
|
7008
|
-
|
7009
|
-
|
7010
|
-
|
7011
|
-
|
7012
|
-
|
7013
|
-
|
7014
|
-
|
7015
|
-
|
7016
|
-
|
7017
|
-
|
7018
|
-
|
7019
|
-
|
7020
|
-
|
7021
|
-
|
7022
|
-
|
7023
|
-
|
7024
|
-
|
7025
|
-
|
7026
|
-
|
7027
|
-
|
7028
|
-
|
7029
|
-
|
7030
|
-
|
7031
|
-
|
7032
|
-
|
7033
|
-
|
7034
|
-
|
7035
|
-
|
7036
|
-
|
7037
|
-
|
7038
|
-
|
7039
|
-
|
7040
|
-
|
7041
|
-
|
7042
|
-
|
7043
|
-
|
7044
|
-
|
7045
|
-
|
7046
|
-
|
7047
|
-
|
7048
|
-
|
7049
|
-
|
7050
|
-
|
7051
|
-
|
7052
|
-
|
7053
|
-
|
7054
|
-
|
7055
|
-
|
7056
|
-
|
7057
|
-
|
7058
|
-
|
7059
|
-
|
7321
|
+
var ExamDetailView = function ExamDetailView(_ref) {
|
7322
|
+
var _ref$className = _ref.className,
|
7323
|
+
className = _ref$className === void 0 ? "" : _ref$className,
|
7324
|
+
exam = _ref.exam,
|
7325
|
+
isDisabled = _ref.isDisabled,
|
7326
|
+
isEdit = _ref.isEdit,
|
7327
|
+
onChangeExam = _ref.onChangeExam;
|
7328
|
+
var _useSubjectSelect = useSubjectSelect(),
|
7329
|
+
subjectOptions = _useSubjectSelect.subjectOptions,
|
7330
|
+
selectedSubject = _useSubjectSelect.selectedSubject,
|
7331
|
+
handleChangeSubject = _useSubjectSelect.handleChangeSubject;
|
7332
|
+
var _useExamDetailView = useExamDetailView({
|
7333
|
+
exam: exam,
|
7334
|
+
onChangeExam: onChangeExam,
|
7335
|
+
selectedSubject: selectedSubject
|
7336
|
+
}),
|
7337
|
+
t = _useExamDetailView.t,
|
7338
|
+
durationOptions = _useExamDetailView.durationOptions,
|
7339
|
+
examGroupByArticle = _useExamDetailView.examGroupByArticle,
|
7340
|
+
handleAddArticle = _useExamDetailView.handleAddArticle,
|
7341
|
+
handleChangeScoreAnswer = _useExamDetailView.handleChangeScoreAnswer,
|
7342
|
+
handleChangeTitle = _useExamDetailView.handleChangeTitle,
|
7343
|
+
handleChangeDuration = _useExamDetailView.handleChangeDuration,
|
7344
|
+
handleChangeCorrectAnswers = _useExamDetailView.handleChangeCorrectAnswers,
|
7345
|
+
handleChangeAnswerCount = _useExamDetailView.handleChangeAnswerCount,
|
7346
|
+
handleChangeQuestionCount = _useExamDetailView.handleChangeQuestionCount,
|
7347
|
+
handleChangeCategory = _useExamDetailView.handleChangeCategory,
|
7348
|
+
handleDeleteArticle = _useExamDetailView.handleDeleteArticle;
|
7349
|
+
return React.createElement(Grid, {
|
7350
|
+
container: true,
|
7351
|
+
spacing: 3,
|
7352
|
+
className: className + " " + styles["custom-row"]
|
7353
|
+
}, React.createElement(Grid, {
|
7354
|
+
item: true,
|
7355
|
+
xs: 5,
|
7356
|
+
className: 'mb-2'
|
7357
|
+
}, React.createElement("label", {
|
7358
|
+
className: styles["form-label"] + " " + styles$2["question-label"],
|
7359
|
+
htmlFor: "title"
|
7360
|
+
}, t("title")), React.createElement("input", {
|
7361
|
+
disabled: isDisabled,
|
7362
|
+
className: "" + styles["form-control"],
|
7363
|
+
value: exam.title,
|
7364
|
+
id: "title",
|
7365
|
+
placeholder: t("enter_title"),
|
7366
|
+
onChange: handleChangeTitle
|
7367
|
+
})), React.createElement(Grid, {
|
7368
|
+
item: true,
|
7369
|
+
xs: 3,
|
7370
|
+
className: 'mb-2'
|
7371
|
+
}, React.createElement("label", {
|
7372
|
+
className: styles["form-label"] + " " + styles$2["question-label"],
|
7373
|
+
htmlFor: "duration"
|
7374
|
+
}, t("duration")), React.createElement(CustomSelect, {
|
7375
|
+
inputId: "duration",
|
7376
|
+
value: exam.duration,
|
7377
|
+
options: durationOptions,
|
7378
|
+
onChange: handleChangeDuration,
|
7379
|
+
isDisabled: isDisabled
|
7380
|
+
})), React.createElement(Grid, {
|
7381
|
+
item: true,
|
7382
|
+
xs: 3,
|
7383
|
+
className: 'mb-2'
|
7384
|
+
}, React.createElement("label", {
|
7385
|
+
className: styles["form-label"] + " " + styles$2["question-label"],
|
7386
|
+
htmlFor: "duration"
|
7387
|
+
}, t("subject"), " ", selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.name), React.createElement(CustomSelect, {
|
7388
|
+
inputId: "subject",
|
7389
|
+
value: selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id,
|
7390
|
+
options: subjectOptions,
|
7391
|
+
onChange: handleChangeSubject,
|
7392
|
+
isDisabled: isDisabled || isEdit
|
7393
|
+
})), examGroupByArticle.map(function (i, index) {
|
7394
|
+
return React.createElement(Grid, {
|
7395
|
+
item: true,
|
7396
|
+
key: i.article,
|
7397
|
+
xs: 12,
|
7398
|
+
className: index === examGroupByArticle.length - 1 ? "mb-2" : ''
|
7399
|
+
}, React.createElement(ArticleGroupView, Object.assign({}, i, {
|
7400
|
+
isActive: index === examGroupByArticle.length - 1,
|
7401
|
+
onChangeQuestionCount: handleChangeQuestionCount,
|
7402
|
+
onChangeCategory: handleChangeCategory,
|
7403
|
+
onChangeAnswerCount: handleChangeAnswerCount,
|
7404
|
+
onChangeCorrectAnswers: handleChangeCorrectAnswers,
|
7405
|
+
onChangeScoreAnswer: handleChangeScoreAnswer,
|
7406
|
+
onDelete: handleDeleteArticle,
|
7407
|
+
isDisabled: isDisabled,
|
7408
|
+
selectedSubject: selectedSubject,
|
7409
|
+
isDeletable: examGroupByArticle.length > 1
|
7410
|
+
})));
|
7411
|
+
}), React.createElement(Grid, {
|
7412
|
+
item: true,
|
7413
|
+
xs: 12
|
7414
|
+
}, React.createElement("button", {
|
7415
|
+
disabled: isDisabled,
|
7416
|
+
className: styles["btn-outline-primary"] + " w-100 d-flex justify-content-center align-items-center " + styles$2["question-btn"] + " mt-3",
|
7417
|
+
onClick: handleAddArticle
|
7418
|
+
}, React.createElement(FaPlusCircle, {
|
7419
|
+
className: "me-2"
|
7420
|
+
}), "\uBB38\uD56D \uCD94\uAC00\uD558\uAE30")));
|
7060
7421
|
};
|
7061
7422
|
|
7062
|
-
var
|
7423
|
+
var _excluded$4 = ["isOpen", "onClose", "handleSaveExam"];
|
7424
|
+
var CreateExamDrawer = function CreateExamDrawer(props) {
|
7425
|
+
var isOpen = props.isOpen,
|
7426
|
+
onClose = props.onClose,
|
7427
|
+
handleSaveExam = props.handleSaveExam,
|
7428
|
+
examDetailViewProps = _objectWithoutPropertiesLoose(props, _excluded$4);
|
7063
7429
|
var _useTranslation = useTranslation(),
|
7064
7430
|
t = _useTranslation.t;
|
7065
|
-
|
7066
|
-
|
7067
|
-
|
7068
|
-
|
7431
|
+
var theme = useTheme();
|
7432
|
+
var isTabletUp = useMediaQuery(theme.breakpoints.up('lg'));
|
7433
|
+
return React.createElement("div", null, React.createElement("div", {
|
7434
|
+
className: styles$3["drawer-overlay"] + " " + (isOpen && styles$3["open"]),
|
7435
|
+
onClick: function onClick() {
|
7436
|
+
return onClose();
|
7437
|
+
}
|
7438
|
+
}), React.createElement("div", {
|
7439
|
+
className: styles$3["drawer"] + " bg-white " + (isOpen && styles$3["open"]),
|
7440
|
+
style: {
|
7441
|
+
width: "" + (isTabletUp ? "70vw" : "100vw")
|
7442
|
+
}
|
7443
|
+
}, React.createElement("div", {
|
7444
|
+
className: styles$3["drawer-header"] + " d-flex justify-content-between align-items-center"
|
7445
|
+
}, React.createElement("div", {
|
7446
|
+
style: {
|
7447
|
+
color: "#5458D5",
|
7448
|
+
cursor: "pointer",
|
7449
|
+
padding: "0.5rem 1rem",
|
7450
|
+
border: "1px solid #5458D5",
|
7451
|
+
backgroundColor: "white",
|
7452
|
+
justifyContent: "center",
|
7453
|
+
alignItems: "center",
|
7454
|
+
borderRadius: "6px"
|
7455
|
+
},
|
7456
|
+
onClick: handleSaveExam
|
7457
|
+
}, t("live_exam")), React.createElement("span", {
|
7458
|
+
className: "p-1 pointer",
|
7459
|
+
onClick: function onClick() {
|
7460
|
+
return onClose();
|
7461
|
+
}
|
7462
|
+
}, React.createElement(FaTimes, {
|
7463
|
+
size: 18
|
7464
|
+
}))), React.createElement("div", {
|
7465
|
+
className: "" + styles$3["drawer-form"]
|
7466
|
+
}, React.createElement(ExamDetailView, Object.assign({}, examDetailViewProps)))));
|
7069
7467
|
};
|
7070
7468
|
|
7071
|
-
var
|
7072
|
-
var
|
7073
|
-
|
7074
|
-
|
7075
|
-
|
7469
|
+
var TextbookViewDetail = function TextbookViewDetail(props) {
|
7470
|
+
var _textbook$chapters;
|
7471
|
+
var _useTextbookDetail = useTextbookDetail(props),
|
7472
|
+
id = _useTextbookDetail.id,
|
7473
|
+
t = _useTextbookDetail.t,
|
7474
|
+
textbook = _useTextbookDetail.textbook,
|
7475
|
+
textbookSubject = _useTextbookDetail.textbookSubject,
|
7476
|
+
isReadonly = _useTextbookDetail.isReadonly,
|
7477
|
+
isNotFound = _useTextbookDetail.isNotFound,
|
7478
|
+
parentChapter = _useTextbookDetail.parentChapter,
|
7479
|
+
textbookId = _useTextbookDetail.textbookId,
|
7480
|
+
selectedChapter = _useTextbookDetail.selectedChapter,
|
7481
|
+
articlesSelected = _useTextbookDetail.articlesSelected,
|
7482
|
+
selectedDeleteItem = _useTextbookDetail.selectedDeleteItem,
|
7483
|
+
isEditedTitle = _useTextbookDetail.isEditedTitle,
|
7484
|
+
isOpenDialog = _useTextbookDetail.isOpenDialog,
|
7485
|
+
examRequest = _useTextbookDetail.examRequest,
|
7486
|
+
handleChangeExamRequest = _useTextbookDetail.handleChangeExamRequest,
|
7487
|
+
handleSaveExam = _useTextbookDetail.handleSaveExam,
|
7488
|
+
handleCloseDialog = _useTextbookDetail.handleCloseDialog,
|
7489
|
+
handleCreateExam = _useTextbookDetail.handleCreateExam,
|
7490
|
+
handleCheckArticle = _useTextbookDetail.handleCheckArticle,
|
7491
|
+
handleChangeTextbookTitle = _useTextbookDetail.handleChangeTextbookTitle,
|
7492
|
+
handleOpenCreateExamDialog = _useTextbookDetail.handleOpenCreateExamDialog,
|
7493
|
+
handleChangeTextbookSubject = _useTextbookDetail.handleChangeTextbookSubject,
|
7494
|
+
handleGoToTextbookList = _useTextbookDetail.handleGoToTextbookList,
|
7495
|
+
handleCreateOrUpdateTextbook = _useTextbookDetail.handleCreateOrUpdateTextbook,
|
7496
|
+
handleCloseChapterNameDialog = _useTextbookDetail.handleCloseChapterNameDialog,
|
7497
|
+
handleCreateChapter = _useTextbookDetail.handleCreateChapter,
|
7498
|
+
handleAddChapterToTextbook = _useTextbookDetail.handleAddChapterToTextbook,
|
7499
|
+
handleAddChapterToParentSubchapter = _useTextbookDetail.handleAddChapterToParentSubchapter,
|
7500
|
+
handleChangeChapterName = _useTextbookDetail.handleChangeChapterName,
|
7501
|
+
handleChangeChapterPageFrom = _useTextbookDetail.handleChangeChapterPageFrom,
|
7502
|
+
handleChangeChapterPageTo = _useTextbookDetail.handleChangeChapterPageTo,
|
7503
|
+
handleAddArticleToChapter = _useTextbookDetail.handleAddArticleToChapter,
|
7504
|
+
handleUpdateArticleQuestionCountFromChapter = _useTextbookDetail.handleUpdateArticleQuestionCountFromChapter,
|
7505
|
+
handleUpdateArticleCategory = _useTextbookDetail.handleUpdateArticleCategory,
|
7506
|
+
handleUpdateArticleAnswerCount = _useTextbookDetail.handleUpdateArticleAnswerCount,
|
7507
|
+
handleUpdateArticleQuestion = _useTextbookDetail.handleUpdateArticleQuestion,
|
7508
|
+
handleCloseArticleDialog = _useTextbookDetail.handleCloseArticleDialog,
|
7509
|
+
handleOpenAddArticleDialog = _useTextbookDetail.handleOpenAddArticleDialog,
|
7510
|
+
handleOpenRemoveArticleConfirmDialog = _useTextbookDetail.handleOpenRemoveArticleConfirmDialog,
|
7511
|
+
handleCloseConfirmDeleteDialog = _useTextbookDetail.handleCloseConfirmDeleteDialog,
|
7512
|
+
handleRemoveSelectedItem = _useTextbookDetail.handleRemoveSelectedItem,
|
7513
|
+
handleOpenRemoveChapterConfirmDialog = _useTextbookDetail.handleOpenRemoveChapterConfirmDialog;
|
7514
|
+
var _useCategorySelect = useCategorySelect({
|
7515
|
+
subjectId: id ? textbookSubject === null || textbookSubject === void 0 ? void 0 : textbookSubject.value : undefined
|
7516
|
+
}),
|
7517
|
+
categoryOptions = _useCategorySelect.categoryOptions;
|
7518
|
+
if (isNotFound) return React.createElement(NotFound, null);
|
7519
|
+
return React.createElement(Container, {
|
7520
|
+
maxWidth: "xl",
|
7521
|
+
className: "bg-white py-5 p-4 rounded-4 h-100 d-flex flex-column"
|
7076
7522
|
}, React.createElement(Stack, {
|
7077
7523
|
direction: "row",
|
7078
7524
|
alignItems: "center",
|
7079
7525
|
justifyContent: "space-between",
|
7080
7526
|
mb: 2
|
7081
7527
|
}, React.createElement(Typography, {
|
7082
|
-
variant:
|
7083
|
-
},
|
7084
|
-
|
7085
|
-
|
7086
|
-
|
7087
|
-
|
7088
|
-
|
7089
|
-
|
7090
|
-
|
7091
|
-
onClick: onClick
|
7092
|
-
}, React.createElement(FaSortUp, {
|
7093
|
-
className: isAscending === true ? styleGlobal["active"] : ""
|
7094
|
-
}), React.createElement(FaSortDown, {
|
7095
|
-
className: isAscending === false ? styleGlobal["active"] : ""
|
7096
|
-
}));
|
7097
|
-
};
|
7098
|
-
|
7099
|
-
var TableHeader = function TableHeader(_ref) {
|
7100
|
-
var headerTemplates = _ref.headerTemplates,
|
7101
|
-
filter = _ref.filter,
|
7102
|
-
onSort = _ref.onSort;
|
7103
|
-
var _useTranslation = useTranslation(),
|
7104
|
-
t = _useTranslation.t;
|
7105
|
-
return React.createElement(TableHead, null, React.createElement(TableRow, null, headerTemplates.map(function (i, index$1) {
|
7106
|
-
return React.createElement(TableCell, {
|
7107
|
-
key: index$1,
|
7108
|
-
className: "" + (!!i.sortKey && "pointer"),
|
7109
|
-
onClick: !!i.sortKey ? function () {
|
7110
|
-
return onSort === null || onSort === void 0 ? void 0 : onSort(i.sortKey);
|
7111
|
-
} : undefined
|
7112
|
-
}, React.createElement("div", {
|
7113
|
-
className: "d-flex justify-content-between align-items-center text-nowrap"
|
7114
|
-
}, t(i.title), !!i.sortKey && React.createElement(SortIcon, {
|
7115
|
-
isAscending: filter.sortColumnName !== i.sortKey ? undefined : filter.sortColumnDirection === OrderType.ASC
|
7116
|
-
})));
|
7117
|
-
})));
|
7118
|
-
};
|
7119
|
-
|
7120
|
-
var SearchInput = function SearchInput(_ref) {
|
7121
|
-
var textSearchRef = _ref.textSearchRef,
|
7122
|
-
_ref$placeholder = _ref.placeholder,
|
7123
|
-
placeholder = _ref$placeholder === void 0 ? "Search for..." : _ref$placeholder,
|
7124
|
-
onChange = _ref.onChange,
|
7125
|
-
_ref$fit = _ref.fit,
|
7126
|
-
fit = _ref$fit === void 0 ? true : _ref$fit;
|
7127
|
-
return React.createElement(Paper, {
|
7128
|
-
component: "div",
|
7129
|
-
className: "bg-light w-100 " + (fit && "h-100"),
|
7528
|
+
variant: "h3"
|
7529
|
+
}, t(id ? isReadonly ? "view_textbook" : "update_textbook" : "create_textbook"))), React.createElement(Grid, {
|
7530
|
+
container: true,
|
7531
|
+
spacing: 3
|
7532
|
+
}, React.createElement(Grid, {
|
7533
|
+
item: true,
|
7534
|
+
xs: 4,
|
7535
|
+
className: "d-flex align-items-center"
|
7536
|
+
}, React.createElement(Table, null, React.createElement(TableBody, null, React.createElement(TableRow, {
|
7130
7537
|
sx: {
|
7131
|
-
|
7132
|
-
|
7133
|
-
alignItems: "center",
|
7134
|
-
width: 400,
|
7135
|
-
transition: "border 0.2s ease",
|
7136
|
-
outline: "1px solid transparent",
|
7137
|
-
":focus-within": {
|
7138
|
-
outlineColor: function outlineColor(theme) {
|
7139
|
-
return theme.palette.primary.main;
|
7140
|
-
}
|
7538
|
+
"& td": {
|
7539
|
+
border: 0
|
7141
7540
|
}
|
7142
7541
|
}
|
7143
|
-
}, React.createElement(
|
7542
|
+
}, React.createElement(TableCell, {
|
7543
|
+
className: "p-2 pe-0",
|
7144
7544
|
sx: {
|
7145
|
-
|
7146
|
-
}
|
7147
|
-
|
7148
|
-
|
7149
|
-
|
7150
|
-
className: "
|
7151
|
-
})), React.createElement(
|
7152
|
-
id: "searchText",
|
7153
|
-
className: "" + (fit && "h-100"),
|
7545
|
+
width: "15%"
|
7546
|
+
}
|
7547
|
+
}, React.createElement(InputLabel, null, React.createElement("span", {
|
7548
|
+
className: "fw-bold"
|
7549
|
+
}, t("name")), React.createElement("span", {
|
7550
|
+
className: "text-danger"
|
7551
|
+
}, "*"))), React.createElement(TableCell, {
|
7154
7552
|
sx: {
|
7155
|
-
|
7156
|
-
|
7157
|
-
|
7158
|
-
|
7159
|
-
|
7160
|
-
|
7161
|
-
|
7162
|
-
|
7163
|
-
|
7164
|
-
|
7165
|
-
|
7166
|
-
|
7167
|
-
|
7168
|
-
|
7169
|
-
|
7170
|
-
|
7171
|
-
|
7172
|
-
|
7173
|
-
|
7174
|
-
|
7175
|
-
|
7176
|
-
|
7177
|
-
|
7178
|
-
|
7179
|
-
|
7180
|
-
|
7181
|
-
|
7182
|
-
|
7183
|
-
|
7184
|
-
|
7185
|
-
|
7186
|
-
|
7187
|
-
|
7188
|
-
|
7553
|
+
width: 0,
|
7554
|
+
px: 1
|
7555
|
+
}
|
7556
|
+
}, ":"), React.createElement(TableCell, {
|
7557
|
+
className: "p-2"
|
7558
|
+
}, React.createElement(InputText, {
|
7559
|
+
className: "w-100",
|
7560
|
+
value: textbook === null || textbook === void 0 ? void 0 : textbook.name,
|
7561
|
+
placeholder: t("enter_textbook_title"),
|
7562
|
+
onChange: handleChangeTextbookTitle,
|
7563
|
+
disabled: isReadonly
|
7564
|
+
}))), React.createElement(TableRow, {
|
7565
|
+
sx: {
|
7566
|
+
"& td": {
|
7567
|
+
border: 0
|
7568
|
+
}
|
7569
|
+
}
|
7570
|
+
}, React.createElement(TableCell, {
|
7571
|
+
className: "p-2 pe-0"
|
7572
|
+
}, React.createElement(InputLabel, null, React.createElement("span", {
|
7573
|
+
className: "fw-bold"
|
7574
|
+
}, t("subject")), React.createElement("span", {
|
7575
|
+
className: "text-danger"
|
7576
|
+
}, "*"))), React.createElement(TableCell, {
|
7577
|
+
sx: {
|
7578
|
+
width: 0,
|
7579
|
+
px: 1
|
7580
|
+
}
|
7581
|
+
}, ":"), React.createElement(TableCell, {
|
7582
|
+
className: "p-2"
|
7583
|
+
}, React.createElement(SubjectSelector, {
|
7584
|
+
value: textbookSubject,
|
7585
|
+
onChange: handleChangeTextbookSubject,
|
7586
|
+
isDisabled: isReadonly || !!id
|
7587
|
+
})))))), React.createElement(Grid, {
|
7189
7588
|
item: true,
|
7190
|
-
xs:
|
7191
|
-
|
7192
|
-
|
7193
|
-
|
7194
|
-
|
7195
|
-
|
7589
|
+
xs: 8,
|
7590
|
+
className: "d-flex justify-content-end"
|
7591
|
+
}, React.createElement("div", null, React.createElement(TextbookActionButtons, {
|
7592
|
+
isReadonly: isReadonly,
|
7593
|
+
textbook: textbook,
|
7594
|
+
onBack: handleGoToTextbookList,
|
7595
|
+
onSave: handleCreateOrUpdateTextbook,
|
7596
|
+
hideSave: !isEditedTitle && !!id && !isReadonly || textbook.isCreatedByAdmin
|
7597
|
+
}))), React.createElement(Grid, {
|
7196
7598
|
item: true,
|
7197
|
-
xs:
|
7198
|
-
|
7199
|
-
|
7599
|
+
xs: 12,
|
7600
|
+
gap: "8px",
|
7601
|
+
className: "d-flex justify-content-end"
|
7200
7602
|
}, React.createElement(Button, {
|
7603
|
+
variant: "outlined",
|
7604
|
+
sx: {
|
7605
|
+
borderColor: "#5458D5",
|
7606
|
+
color: "#5458D5"
|
7607
|
+
},
|
7608
|
+
onClick: function onClick() {
|
7609
|
+
return handleOpenCreateExamDialog();
|
7610
|
+
},
|
7611
|
+
disabled: isReadonly || !articlesSelected.length,
|
7201
7612
|
startIcon: React.createElement(FaPlus, {
|
7202
7613
|
size: 12
|
7203
|
-
})
|
7614
|
+
})
|
7615
|
+
}, React.createElement(Typography, null, t("create_new_exam"))), !!id && React.createElement(Button, {
|
7616
|
+
className: "mx-1",
|
7204
7617
|
variant: "contained",
|
7205
7618
|
color: "primary",
|
7206
|
-
|
7207
|
-
}, t("create_textbook")))), React.createElement(Grid, {
|
7208
|
-
item: true,
|
7209
|
-
xs: 12,
|
7210
|
-
className: "mt-3"
|
7211
|
-
}, React.createElement(Table, null, React.createElement(TableHeader, {
|
7212
|
-
headerTemplates: TEXTBOOK_HEADERS,
|
7213
|
-
filter: filter,
|
7214
|
-
onSort: handleSort
|
7215
|
-
}), React.createElement(TableBody, null, textbooks.map(function (i, index) {
|
7216
|
-
return React.createElement(TableRow, {
|
7217
|
-
key: i.id
|
7218
|
-
}, React.createElement(TableCell, null, calcOrderNumber(index)), React.createElement(TableCell, null, i.name), React.createElement(TableCell, null, i.subject.name), React.createElement(TableCell, null, utcToLocalTime(i.createdAt, t("date_format"))), React.createElement(TableCell, null, i.totalChapters), React.createElement(TableCell, null, React.createElement(Stack, {
|
7219
|
-
direction: "row",
|
7220
|
-
spacing: 1,
|
7221
|
-
alignItems: "center"
|
7222
|
-
}, !i.isCreatedByAdmin && React.createElement(IconButton, {
|
7223
|
-
color: "default",
|
7224
|
-
className: "bg-warning text-white",
|
7225
|
-
onClick: function onClick() {
|
7226
|
-
return handleUpdateTextbook(i.id);
|
7227
|
-
}
|
7228
|
-
}, React.createElement(FaPencil, {
|
7229
|
-
size: 12
|
7230
|
-
})), React.createElement(IconButton, {
|
7231
|
-
color: "default",
|
7232
|
-
className: "bg-primary text-white",
|
7233
|
-
onClick: function onClick() {
|
7234
|
-
return handleViewTextbook(i.id);
|
7235
|
-
}
|
7236
|
-
}, React.createElement(FaEye, {
|
7237
|
-
size: 12
|
7238
|
-
})), !i.isCreatedByAdmin && React.createElement(IconButton, {
|
7239
|
-
color: "default",
|
7240
|
-
className: "bg-danger text-white",
|
7241
|
-
onClick: function onClick() {
|
7242
|
-
return handleSelectDeleteTextbook(i);
|
7243
|
-
}
|
7244
|
-
}, React.createElement(FaTrash, {
|
7619
|
+
startIcon: React.createElement(FaPlus, {
|
7245
7620
|
size: 12
|
7246
|
-
})
|
7247
|
-
|
7248
|
-
|
7249
|
-
},
|
7250
|
-
|
7251
|
-
|
7252
|
-
|
7253
|
-
|
7254
|
-
|
7255
|
-
|
7256
|
-
|
7257
|
-
|
7258
|
-
|
7621
|
+
}),
|
7622
|
+
onClick: handleAddChapterToTextbook,
|
7623
|
+
disabled: isReadonly
|
7624
|
+
}, t("add_chapter"))), React.createElement(Grid, {
|
7625
|
+
item: true,
|
7626
|
+
xs: 12
|
7627
|
+
}, React.createElement(Stack, {
|
7628
|
+
spacing: 3
|
7629
|
+
}, !!(textbook !== null && textbook !== void 0 && textbook.subject) && (textbook === null || textbook === void 0 ? void 0 : (_textbook$chapters = textbook.chapters) === null || _textbook$chapters === void 0 ? void 0 : _textbook$chapters.map(function (chapter) {
|
7630
|
+
return React.createElement(ChapterBox, {
|
7631
|
+
key: chapter.id,
|
7632
|
+
subject: textbook.subject,
|
7633
|
+
data: chapter,
|
7634
|
+
categoryOptions: categoryOptions || [],
|
7635
|
+
onClickAddSubchapter: handleAddChapterToParentSubchapter,
|
7636
|
+
onChangeName: handleChangeChapterName,
|
7637
|
+
onChangePageFrom: handleChangeChapterPageFrom,
|
7638
|
+
onChangePageTo: handleChangeChapterPageTo,
|
7639
|
+
handleCheckArticle: handleCheckArticle,
|
7640
|
+
onAddArticle: handleOpenAddArticleDialog,
|
7641
|
+
onRemoveArticle: handleOpenRemoveArticleConfirmDialog,
|
7642
|
+
onUpdateArticleQuestionCount: handleUpdateArticleQuestionCountFromChapter,
|
7643
|
+
onUpdateArticleCategory: handleUpdateArticleCategory,
|
7644
|
+
onUpdateArticleQuestionAnswerCount: handleUpdateArticleAnswerCount,
|
7645
|
+
onUpdateArticleQuestion: handleUpdateArticleQuestion,
|
7646
|
+
onRemoveChapter: handleOpenRemoveChapterConfirmDialog,
|
7647
|
+
isReadonly: isReadonly
|
7648
|
+
});
|
7649
|
+
}))))), React.createElement(ChapterNameDialog, {
|
7650
|
+
open: !!(parentChapter !== null && parentChapter !== void 0 && parentChapter.id) || !!textbookId,
|
7651
|
+
chapter: parentChapter,
|
7652
|
+
onClose: handleCloseChapterNameDialog,
|
7653
|
+
onSubmitForm: handleCreateChapter
|
7654
|
+
}), React.createElement(CreateExamDrawer, {
|
7655
|
+
isOpen: isOpenDialog,
|
7656
|
+
onClose: handleCloseDialog,
|
7657
|
+
onSubmit: handleCreateExam,
|
7658
|
+
handleSaveExam: handleSaveExam,
|
7659
|
+
exam: examRequest,
|
7660
|
+
onChangeExam: handleChangeExamRequest
|
7661
|
+
}), React.createElement(ArticleDialog, {
|
7662
|
+
open: !!selectedChapter,
|
7663
|
+
chapter: selectedChapter,
|
7664
|
+
categoryOptions: categoryOptions || [],
|
7665
|
+
onClose: handleCloseArticleDialog,
|
7666
|
+
onSubmitForm: handleAddArticleToChapter
|
7667
|
+
}), selectedDeleteItem && React.createElement(ConfirmDialog, {
|
7668
|
+
open: true,
|
7669
|
+
toggle: handleCloseConfirmDeleteDialog,
|
7670
|
+
text: selectedDeleteItem.confirmText,
|
7671
|
+
confirmText: selectedDeleteItem.name,
|
7672
|
+
onConfirm: handleRemoveSelectedItem,
|
7259
7673
|
isDelete: true
|
7260
7674
|
}));
|
7261
7675
|
};
|
7262
7676
|
|
7263
|
-
|
7264
|
-
|
7265
|
-
var
|
7266
|
-
|
7267
|
-
|
7268
|
-
TextbookDetail: TextbookViewDetail
|
7269
|
-
};
|
7270
|
-
|
7271
|
-
var _excluded$4 = ["defaultValue", "options", "isDisabled", "scrollBottom", "value", "isMulti"];
|
7272
|
-
var CustomCreatable = function CustomCreatable(_ref) {
|
7273
|
-
var options = _ref.options,
|
7274
|
-
isDisabled = _ref.isDisabled,
|
7275
|
-
scrollBottom = _ref.scrollBottom,
|
7276
|
-
value = _ref.value,
|
7277
|
-
isMulti = _ref.isMulti,
|
7278
|
-
rest = _objectWithoutPropertiesLoose(_ref, _excluded$4);
|
7279
|
-
var initialValues = Array.isArray(value) ? options.filter(function (i) {
|
7280
|
-
return value.includes(i.value);
|
7281
|
-
}) : isMulti ? options.filter(function (i) {
|
7282
|
-
return i.value == value;
|
7283
|
-
}) : options.find(function (i) {
|
7284
|
-
return i.value == value;
|
7677
|
+
var useAutoAcademyDomain = function useAutoAcademyDomain(logout, history, superUrls, homeUrl, homeAcademyUrl) {
|
7678
|
+
var searchParams = new URLSearchParams(window.location.search);
|
7679
|
+
var user = useSelector(function (state) {
|
7680
|
+
var _state$common;
|
7681
|
+
return state === null || state === void 0 ? void 0 : (_state$common = state.common) === null || _state$common === void 0 ? void 0 : _state$common.user;
|
7285
7682
|
});
|
7286
|
-
|
7287
|
-
|
7288
|
-
|
7289
|
-
|
7290
|
-
|
7291
|
-
|
7292
|
-
|
7293
|
-
|
7294
|
-
|
7295
|
-
|
7296
|
-
|
7297
|
-
|
7298
|
-
|
7299
|
-
options = _ref.options,
|
7300
|
-
isDisabled = _ref.isDisabled,
|
7301
|
-
scrollBottom = _ref.scrollBottom,
|
7302
|
-
value = _ref.value,
|
7303
|
-
isMulti = _ref.isMulti,
|
7304
|
-
rest = _objectWithoutPropertiesLoose(_ref, _excluded$5);
|
7305
|
-
var initialValues = Array.isArray(value) ? options.filter(function (i) {
|
7306
|
-
return value.includes(i.value);
|
7307
|
-
}) : isMulti ? options.filter(function (i) {
|
7308
|
-
return i.value == value;
|
7309
|
-
}) : options.find(function (i) {
|
7310
|
-
return i.value == value;
|
7311
|
-
});
|
7312
|
-
return React.createElement(Select, Object.assign({
|
7313
|
-
isDisabled: isDisabled,
|
7314
|
-
options: options,
|
7315
|
-
value: !isDefault ? initialValues : undefined,
|
7316
|
-
defaultValue: isDefault ? initialValues : undefined,
|
7317
|
-
menuPlacement: scrollBottom ? "top" : "auto",
|
7318
|
-
isMulti: isMulti
|
7319
|
-
}, rest));
|
7320
|
-
};
|
7321
|
-
|
7322
|
-
var DURATION_OPTIONS = Array.from({
|
7323
|
-
length: 120
|
7324
|
-
}, function (_, i) {
|
7325
|
-
return i + 1;
|
7326
|
-
});
|
7327
|
-
var DEFAULT_ANSWER_COUNT = 5;
|
7328
|
-
|
7329
|
-
var useExamDetailView = function useExamDetailView(props) {
|
7330
|
-
var exam = props.exam,
|
7331
|
-
selectedSubject = props.selectedSubject,
|
7332
|
-
onChangeExam = props.onChangeExam;
|
7333
|
-
var _useTranslation = useTranslation(),
|
7334
|
-
t = _useTranslation.t;
|
7335
|
-
var handleChangeQuestionCount = function handleChangeQuestionCount(article, questionCount, answerCount) {
|
7336
|
-
if (!exam) return;
|
7337
|
-
var examQuestions = exam.questions;
|
7338
|
-
var questions = examQuestions.filter(function (i) {
|
7339
|
-
return i.article === +article;
|
7340
|
-
});
|
7341
|
-
var prevQuestions = examQuestions.filter(function (i) {
|
7342
|
-
return i.article < +article;
|
7343
|
-
});
|
7344
|
-
var nextQuestions = examQuestions.filter(function (i) {
|
7345
|
-
return i.article > +article;
|
7346
|
-
});
|
7347
|
-
var lastOrder = questions[questions.length - 1].questionOrder;
|
7348
|
-
if (questions.length === questionCount) return;
|
7349
|
-
if (questions.length < questionCount) {
|
7350
|
-
var additionalQuestions = Array.from({
|
7351
|
-
length: questionCount - questions.length
|
7352
|
-
}).map(function (_, index) {
|
7353
|
-
var _questions$;
|
7354
|
-
return {
|
7355
|
-
article: +article,
|
7356
|
-
correctAnswers: [1],
|
7357
|
-
numberOfAnswers: answerCount,
|
7358
|
-
categoryId: (_questions$ = questions[0]) === null || _questions$ === void 0 ? void 0 : _questions$.categoryId,
|
7359
|
-
score: DEFAULT_SCORE,
|
7360
|
-
questionOrder: lastOrder + index + 1
|
7361
|
-
};
|
7362
|
-
});
|
7363
|
-
var newQuestions = [].concat(prevQuestions, questions, additionalQuestions, nextQuestions.map(function (i) {
|
7364
|
-
return _extends({}, i, {
|
7365
|
-
questionOrder: i.questionOrder + questionCount - questions.length
|
7683
|
+
var initialAcademySearchParam = function initialAcademySearchParam() {
|
7684
|
+
var paramAcademyDomain = searchParams.get("domain");
|
7685
|
+
var domain = getAcademyDomain();
|
7686
|
+
var pathname = window.location.pathname.toLowerCase();
|
7687
|
+
if (!user) return;
|
7688
|
+
var academyDomain = user.academyDomain;
|
7689
|
+
if (!academyDomain) {
|
7690
|
+
if (!superUrls.some(function (i) {
|
7691
|
+
return pathname.startsWith(i);
|
7692
|
+
})) {
|
7693
|
+
pushTo({
|
7694
|
+
pathname: homeUrl,
|
7695
|
+
search: ""
|
7366
7696
|
});
|
7367
|
-
}
|
7368
|
-
|
7369
|
-
|
7370
|
-
|
7697
|
+
}
|
7698
|
+
if (domain) {
|
7699
|
+
searchParams.append("domain", domain);
|
7700
|
+
pushTo({
|
7701
|
+
pathname: homeUrl,
|
7702
|
+
search: ""
|
7703
|
+
});
|
7704
|
+
}
|
7371
7705
|
} else {
|
7372
|
-
|
7373
|
-
|
7374
|
-
|
7375
|
-
|
7706
|
+
if (superUrls.some(function (i) {
|
7707
|
+
return pathname.startsWith(i);
|
7708
|
+
})) {
|
7709
|
+
pushTo({
|
7710
|
+
pathname: homeAcademyUrl,
|
7711
|
+
search: ""
|
7376
7712
|
});
|
7377
|
-
}
|
7378
|
-
|
7379
|
-
|
7380
|
-
}
|
7713
|
+
}
|
7714
|
+
if (paramAcademyDomain && academyDomain.trim().toLocaleLowerCase() != (paramAcademyDomain === null || paramAcademyDomain === void 0 ? void 0 : paramAcademyDomain.trim().toLocaleLowerCase())) {
|
7715
|
+
logout();
|
7716
|
+
}
|
7717
|
+
if (!paramAcademyDomain && academyDomain) {
|
7718
|
+
searchParams.append("domain", academyDomain);
|
7719
|
+
pushTo(_extends({}, window.location, {
|
7720
|
+
search: searchParams.toString()
|
7721
|
+
}));
|
7722
|
+
}
|
7381
7723
|
}
|
7382
7724
|
};
|
7383
|
-
var
|
7384
|
-
if (
|
7385
|
-
var examQuestions = exam.questions;
|
7386
|
-
var questions = examQuestions.filter(function (i) {
|
7387
|
-
return i.article === +article;
|
7388
|
-
});
|
7389
|
-
var otherQuestions = examQuestions.filter(function (i) {
|
7390
|
-
return i.article !== +article;
|
7391
|
-
});
|
7392
|
-
onChangeExam(_extends({}, exam, {
|
7393
|
-
questions: [].concat(otherQuestions, questions.map(function (q) {
|
7394
|
-
return _extends({}, q, {
|
7395
|
-
categoryId: categoryId
|
7396
|
-
});
|
7397
|
-
}))
|
7398
|
-
}));
|
7725
|
+
var pushTo = function pushTo(data) {
|
7726
|
+
if (history.push) history.push(data);else history(data);
|
7399
7727
|
};
|
7400
|
-
|
7401
|
-
|
7402
|
-
|
7403
|
-
|
7404
|
-
|
7405
|
-
|
7406
|
-
|
7407
|
-
|
7408
|
-
|
7409
|
-
|
7410
|
-
|
7411
|
-
|
7412
|
-
|
7413
|
-
|
7728
|
+
useEffect(function () {
|
7729
|
+
initialAcademySearchParam();
|
7730
|
+
}, [window.location.pathname, user === null || user === void 0 ? void 0 : user.academyDomain]);
|
7731
|
+
};
|
7732
|
+
|
7733
|
+
var useList = function useList(fetchData, defaultQuery) {
|
7734
|
+
var dispatch = useDispatch();
|
7735
|
+
var _useState = useState(defaultQuery),
|
7736
|
+
filter = _useState[0],
|
7737
|
+
setFilter = _useState[1];
|
7738
|
+
var _useState2 = useState(0),
|
7739
|
+
totalPages = _useState2[0],
|
7740
|
+
setTotalPages = _useState2[1];
|
7741
|
+
var _useState3 = useState([]),
|
7742
|
+
data = _useState3[0],
|
7743
|
+
setData = _useState3[1];
|
7744
|
+
var _useState4 = useState(),
|
7745
|
+
selectedItem = _useState4[0],
|
7746
|
+
setSelectedItem = _useState4[1];
|
7747
|
+
var textSearchRef = useRef(null);
|
7748
|
+
var isFirstLoadRef = useRef(true);
|
7749
|
+
var handleChangeSelectedItem = function handleChangeSelectedItem(item) {
|
7750
|
+
setSelectedItem(item);
|
7751
|
+
};
|
7752
|
+
var getData = function getData(isLoading) {
|
7753
|
+
if (isLoading === void 0) {
|
7754
|
+
isLoading = false;
|
7755
|
+
}
|
7756
|
+
try {
|
7757
|
+
var _temp2 = function _temp2() {
|
7758
|
+
isLoading && dispatch(setLoading(false));
|
7759
|
+
};
|
7760
|
+
if (isFirstLoadRef.current) isFirstLoadRef.current = false;
|
7761
|
+
isLoading && dispatch(setLoading(true));
|
7762
|
+
var _temp = _catch(function () {
|
7763
|
+
return Promise.resolve(fetchData(filter)).then(function (res) {
|
7764
|
+
var _res$data = res.data,
|
7765
|
+
_res$data$items = _res$data.items,
|
7766
|
+
items = _res$data$items === void 0 ? [] : _res$data$items,
|
7767
|
+
_res$data$totalPages = _res$data.totalPages,
|
7768
|
+
totalPages = _res$data$totalPages === void 0 ? 0 : _res$data$totalPages;
|
7769
|
+
setTotalPages(totalPages);
|
7770
|
+
setData(items);
|
7771
|
+
});
|
7772
|
+
}, function (error) {
|
7773
|
+
var _error$response, _error$response$data;
|
7774
|
+
setTotalPages(0);
|
7775
|
+
setData([]);
|
7776
|
+
toast.error((error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : (_error$response$data = _error$response.data) === null || _error$response$data === void 0 ? void 0 : _error$response$data.title) || "Get data failed");
|
7414
7777
|
});
|
7778
|
+
return Promise.resolve(_temp && _temp.then ? _temp.then(_temp2) : _temp2(_temp));
|
7779
|
+
} catch (e) {
|
7780
|
+
return Promise.reject(e);
|
7781
|
+
}
|
7782
|
+
};
|
7783
|
+
var handleSort = function handleSort(sortColumnName) {
|
7784
|
+
var sortColumnDirection = OrderType.ASC;
|
7785
|
+
console.log({
|
7786
|
+
sortColumnName: typeof sortColumnName,
|
7787
|
+
filter: typeof filter.sortColumnName
|
7415
7788
|
});
|
7416
|
-
|
7417
|
-
|
7789
|
+
if (filter.sortColumnName == sortColumnName && filter.sortColumnDirection === OrderType.ASC) sortColumnDirection = OrderType.DESC;
|
7790
|
+
setFilter(_extends({}, filter, {
|
7791
|
+
sortColumnName: sortColumnName,
|
7792
|
+
sortColumnDirection: sortColumnDirection,
|
7793
|
+
currentPage: 1
|
7418
7794
|
}));
|
7419
7795
|
};
|
7420
|
-
var
|
7421
|
-
if (!
|
7422
|
-
|
7423
|
-
|
7424
|
-
var questions = examQuestions.filter(function (i) {
|
7425
|
-
return i.article === +article;
|
7426
|
-
});
|
7427
|
-
var otherQuestions = examQuestions.filter(function (i) {
|
7428
|
-
return i.article !== +article;
|
7429
|
-
});
|
7430
|
-
if (answerCount < newAnswerCount) {
|
7431
|
-
onChangeExam(_extends({}, exam, {
|
7432
|
-
questions: [].concat(otherQuestions, questions.map(function (q) {
|
7433
|
-
return _extends({}, q, {
|
7434
|
-
numberOfAnswers: newAnswerCount
|
7435
|
-
});
|
7436
|
-
}))
|
7437
|
-
}));
|
7438
|
-
} else {
|
7439
|
-
onChangeExam(_extends({}, exam, {
|
7440
|
-
questions: [].concat(otherQuestions, questions.map(function (q) {
|
7441
|
-
var _q$correctAnswers;
|
7442
|
-
return _extends({}, q, {
|
7443
|
-
numberOfAnswers: newAnswerCount,
|
7444
|
-
correctAnswers: (_q$correctAnswers = q.correctAnswers) === null || _q$correctAnswers === void 0 ? void 0 : _q$correctAnswers.filter(function (i) {
|
7445
|
-
return i <= newAnswerCount;
|
7446
|
-
})
|
7447
|
-
});
|
7448
|
-
}))
|
7449
|
-
}));
|
7450
|
-
}
|
7796
|
+
var handleChangeSearchText = function handleChangeSearchText(e) {
|
7797
|
+
if (!textSearchRef.current) return;
|
7798
|
+
textSearchRef.current.value = e.target.value.trim();
|
7799
|
+
debounceSearch();
|
7451
7800
|
};
|
7452
|
-
var
|
7453
|
-
|
7454
|
-
|
7455
|
-
var questions = examQuestions.filter(function (i) {
|
7456
|
-
return i.article === +article;
|
7457
|
-
});
|
7458
|
-
var otherQuestions = examQuestions.filter(function (i) {
|
7459
|
-
return i.article !== +article;
|
7460
|
-
});
|
7461
|
-
var selectedQuestion = questions[index];
|
7462
|
-
onChangeExam(_extends({}, exam, {
|
7463
|
-
questions: [].concat(otherQuestions, questions.slice(0, index), [_extends({}, selectedQuestion, {
|
7464
|
-
correctAnswers: [answer]
|
7465
|
-
})], questions.slice(index + 1))
|
7801
|
+
var handleChangePage = function handleChangePage(_, page) {
|
7802
|
+
setFilter(_extends({}, filter, {
|
7803
|
+
currentPage: page
|
7466
7804
|
}));
|
7467
7805
|
};
|
7468
|
-
var
|
7469
|
-
|
7470
|
-
|
7471
|
-
|
7472
|
-
|
7806
|
+
var calcOrderNumber = function calcOrderNumber(index) {
|
7807
|
+
var _filter$currentPage, _filter$pageSize;
|
7808
|
+
return (((_filter$currentPage = filter.currentPage) != null ? _filter$currentPage : 0) - 1) * ((_filter$pageSize = filter.pageSize) != null ? _filter$pageSize : 0) + index + 1;
|
7809
|
+
};
|
7810
|
+
var debounceSearch = _.debounce(function () {
|
7811
|
+
var _textSearchRef$curren;
|
7812
|
+
setFilter(_extends({}, filter, {
|
7813
|
+
currentPage: 1,
|
7814
|
+
textSearch: (_textSearchRef$curren = textSearchRef.current) === null || _textSearchRef$curren === void 0 ? void 0 : _textSearchRef$curren.value
|
7815
|
+
}));
|
7816
|
+
}, 500);
|
7817
|
+
useEffect(function () {
|
7818
|
+
getData(isFirstLoadRef.current);
|
7819
|
+
}, [JSON.stringify(filter)]);
|
7820
|
+
return {
|
7821
|
+
filter: filter,
|
7822
|
+
textSearchRef: textSearchRef,
|
7823
|
+
totalPages: totalPages,
|
7824
|
+
data: data,
|
7825
|
+
selectedItem: selectedItem,
|
7826
|
+
handleSort: handleSort,
|
7827
|
+
handleChangeSearchText: handleChangeSearchText,
|
7828
|
+
handleChangePage: handleChangePage,
|
7829
|
+
calcOrderNumber: calcOrderNumber,
|
7830
|
+
handleChangeSelectedItem: handleChangeSelectedItem,
|
7831
|
+
getData: getData
|
7832
|
+
};
|
7833
|
+
};
|
7834
|
+
|
7835
|
+
|
7836
|
+
|
7837
|
+
var index$1 = {
|
7838
|
+
__proto__: null,
|
7839
|
+
useLogin: useLogin,
|
7840
|
+
useAutoAcademyDomain: useAutoAcademyDomain,
|
7841
|
+
useList: useList
|
7842
|
+
};
|
7843
|
+
|
7844
|
+
var useTextbookList = function useTextbookList(props) {
|
7845
|
+
var role = props.role,
|
7846
|
+
navigate = props.navigate;
|
7847
|
+
var _useList = useList(function (search) {
|
7848
|
+
return getTextbookListApi(search, role);
|
7849
|
+
}, TextbookDefaultQuery),
|
7850
|
+
filter = _useList.filter,
|
7851
|
+
textSearchRef = _useList.textSearchRef,
|
7852
|
+
totalPages = _useList.totalPages,
|
7853
|
+
textbooks = _useList.data,
|
7854
|
+
selectedTextbook = _useList.selectedItem,
|
7855
|
+
handleSort = _useList.handleSort,
|
7856
|
+
handleChangeSearchText = _useList.handleChangeSearchText,
|
7857
|
+
handleChangePage = _useList.handleChangePage,
|
7858
|
+
calcOrderNumber = _useList.calcOrderNumber,
|
7859
|
+
handleChangeSelectedItem = _useList.handleChangeSelectedItem,
|
7860
|
+
getData = _useList.getData;
|
7861
|
+
var textbookUrl = role === Role.Teacher ? TEXTBOOK_URL$1 : ADMIN_TEXTBOOK_URL;
|
7862
|
+
var dispatch = useDispatch();
|
7863
|
+
var handleViewTextbook = function handleViewTextbook(id) {
|
7864
|
+
navigate(textbookUrl + "/" + id + "?readonly=true", {
|
7865
|
+
replace: true
|
7473
7866
|
});
|
7474
|
-
|
7475
|
-
|
7867
|
+
};
|
7868
|
+
var handleUpdateTextbook = function handleUpdateTextbook(id) {
|
7869
|
+
navigate(textbookUrl + "/" + id, {
|
7870
|
+
replace: true
|
7476
7871
|
});
|
7477
|
-
var selectedQuestion = questions[index];
|
7478
|
-
if (score === selectedQuestion.score) return;
|
7479
|
-
onChangeExam(_extends({}, exam, {
|
7480
|
-
questions: [].concat(otherQuestions, questions.slice(0, index), [_extends({}, selectedQuestion, {
|
7481
|
-
score: score
|
7482
|
-
})], questions.slice(index + 1))
|
7483
|
-
}));
|
7484
7872
|
};
|
7485
|
-
var
|
7486
|
-
|
7487
|
-
|
7488
|
-
|
7489
|
-
}));
|
7873
|
+
var handleCreateTextbook = function handleCreateTextbook() {
|
7874
|
+
navigate(textbookUrl + "/create", {
|
7875
|
+
replace: true
|
7876
|
+
});
|
7490
7877
|
};
|
7491
|
-
var
|
7492
|
-
|
7493
|
-
onChangeExam(_extends({}, exam, {
|
7494
|
-
title: e.target.value
|
7495
|
-
}));
|
7878
|
+
var toggleConfirmDialog = function toggleConfirmDialog() {
|
7879
|
+
handleChangeSelectedItem(undefined);
|
7496
7880
|
};
|
7497
|
-
var
|
7498
|
-
|
7499
|
-
if (!exam) return;
|
7500
|
-
var maxArticle = ((_$maxBy = _.maxBy(exam.questions, "article")) === null || _$maxBy === void 0 ? void 0 : _$maxBy.article) || 0;
|
7501
|
-
var maxOrder = ((_$maxBy2 = _.maxBy(exam.questions, "questionOrder")) === null || _$maxBy2 === void 0 ? void 0 : _$maxBy2.questionOrder) || 0;
|
7502
|
-
onChangeExam(_extends({}, exam, {
|
7503
|
-
questions: [].concat(exam.questions, [{
|
7504
|
-
article: maxArticle + 1,
|
7505
|
-
correctAnswers: [1],
|
7506
|
-
numberOfAnswers: DEFAULT_ANSWER_COUNT,
|
7507
|
-
score: DEFAULT_SCORE,
|
7508
|
-
questionOrder: maxOrder + 1
|
7509
|
-
}])
|
7510
|
-
}));
|
7881
|
+
var handleSelectDeleteTextbook = function handleSelectDeleteTextbook(textbook) {
|
7882
|
+
return [handleChangeSelectedItem(textbook)];
|
7511
7883
|
};
|
7512
|
-
var
|
7513
|
-
|
7514
|
-
|
7515
|
-
|
7516
|
-
|
7517
|
-
if (
|
7518
|
-
|
7519
|
-
|
7520
|
-
|
7521
|
-
|
7522
|
-
|
7523
|
-
|
7524
|
-
})) === null || _questions$find === void 0 ? void 0 : _questions$find.categoryId,
|
7525
|
-
answerCount: ((_$maxBy3 = _.maxBy(questions, "numberOfAnswers")) === null || _$maxBy3 === void 0 ? void 0 : _$maxBy3.numberOfAnswers) || DEFAULT_ANSWER_COUNT,
|
7526
|
-
questionCount: questions.length,
|
7527
|
-
questions: questions
|
7884
|
+
var handleDeleteTextbook = function handleDeleteTextbook() {
|
7885
|
+
try {
|
7886
|
+
var _temp2 = function _temp2() {
|
7887
|
+
dispatch(setLoading(false));
|
7888
|
+
};
|
7889
|
+
if (!(selectedTextbook !== null && selectedTextbook !== void 0 && selectedTextbook.id)) return Promise.resolve();
|
7890
|
+
dispatch(setLoading(true));
|
7891
|
+
var _temp = _catch(function () {
|
7892
|
+
return Promise.resolve(deleteTextbookApi(selectedTextbook.id, role)).then(function () {
|
7893
|
+
return Promise.resolve(getData(false)).then(function () {
|
7894
|
+
toggleConfirmDialog();
|
7895
|
+
});
|
7528
7896
|
});
|
7529
|
-
}
|
7897
|
+
}, function (error) {
|
7898
|
+
var _error$response, _error$response$data;
|
7899
|
+
toast.error((error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : (_error$response$data = _error$response.data) === null || _error$response$data === void 0 ? void 0 : _error$response$data.title) || "Textbook deleted failed");
|
7900
|
+
});
|
7901
|
+
return Promise.resolve(_temp && _temp.then ? _temp.then(_temp2) : _temp2(_temp));
|
7902
|
+
} catch (e) {
|
7903
|
+
return Promise.reject(e);
|
7530
7904
|
}
|
7531
|
-
|
7532
|
-
}, [JSON.stringify(exam)]);
|
7533
|
-
var durationOptions = useMemo(function () {
|
7534
|
-
var options = DURATION_OPTIONS.map(function (i) {
|
7535
|
-
return {
|
7536
|
-
label: i + "\uBD84",
|
7537
|
-
value: i
|
7538
|
-
};
|
7539
|
-
});
|
7540
|
-
if (!!exam.duration && exam.duration > DURATION_OPTIONS[DURATION_OPTIONS.length - 1]) return [].concat(options, [{
|
7541
|
-
label: exam.duration + "\uBD84",
|
7542
|
-
value: exam.duration
|
7543
|
-
}]);
|
7544
|
-
return options;
|
7545
|
-
}, [exam.duration]);
|
7546
|
-
useEffect(function () {
|
7547
|
-
if ((selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id) !== exam.subjectId) onChangeExam(_extends({}, exam, {
|
7548
|
-
subjectId: (selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id) || 0
|
7549
|
-
}));
|
7550
|
-
}, [selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id, exam.subjectId]);
|
7905
|
+
};
|
7551
7906
|
return {
|
7552
|
-
|
7553
|
-
|
7554
|
-
|
7555
|
-
|
7556
|
-
|
7557
|
-
|
7558
|
-
|
7559
|
-
|
7560
|
-
|
7561
|
-
|
7562
|
-
|
7563
|
-
|
7907
|
+
filter: filter,
|
7908
|
+
textSearchRef: textSearchRef,
|
7909
|
+
totalPages: totalPages,
|
7910
|
+
textbooks: textbooks,
|
7911
|
+
selectedTextbook: selectedTextbook,
|
7912
|
+
handleSort: handleSort,
|
7913
|
+
handleChangeSearchText: handleChangeSearchText,
|
7914
|
+
handleChangePage: handleChangePage,
|
7915
|
+
calcOrderNumber: calcOrderNumber,
|
7916
|
+
handleViewTextbook: handleViewTextbook,
|
7917
|
+
handleUpdateTextbook: handleUpdateTextbook,
|
7918
|
+
handleCreateTextbook: handleCreateTextbook,
|
7919
|
+
toggleConfirmDialog: toggleConfirmDialog,
|
7920
|
+
handleDeleteTextbook: handleDeleteTextbook,
|
7921
|
+
handleSelectDeleteTextbook: handleSelectDeleteTextbook
|
7564
7922
|
};
|
7565
7923
|
};
|
7566
7924
|
|
7567
|
-
var
|
7568
|
-
var
|
7569
|
-
|
7570
|
-
|
7925
|
+
var EmptyRow = function EmptyRow() {
|
7926
|
+
var _useTranslation = useTranslation(),
|
7927
|
+
t = _useTranslation.t;
|
7928
|
+
return React.createElement(TableRow, null, React.createElement(TableCell, {
|
7929
|
+
colSpan: 12,
|
7930
|
+
className: "text-center text-muted"
|
7931
|
+
}, t("no_data")));
|
7932
|
+
};
|
7933
|
+
|
7934
|
+
var LayoutList = function LayoutList(_ref) {
|
7935
|
+
var children = _ref.children,
|
7936
|
+
title = _ref.title;
|
7937
|
+
return React.createElement(Box, {
|
7938
|
+
className: 'bg-white p-3'
|
7939
|
+
}, React.createElement(Stack, {
|
7940
|
+
direction: "row",
|
7941
|
+
alignItems: "center",
|
7942
|
+
justifyContent: "space-between",
|
7943
|
+
mb: 2
|
7944
|
+
}, React.createElement(Typography, {
|
7945
|
+
variant: 'h4'
|
7946
|
+
}, title)), React.createElement(Box, null, children));
|
7947
|
+
};
|
7948
|
+
|
7949
|
+
var SortIcon = function SortIcon(_ref) {
|
7950
|
+
var isAscending = _ref.isAscending,
|
7951
|
+
onClick = _ref.onClick;
|
7952
|
+
return React.createElement("div", {
|
7953
|
+
className: "d-flex flex-column " + styles["sort-icons"],
|
7954
|
+
onClick: onClick
|
7955
|
+
}, React.createElement(FaSortUp, {
|
7956
|
+
className: isAscending === true ? styles["active"] : ""
|
7957
|
+
}), React.createElement(FaSortDown, {
|
7958
|
+
className: isAscending === false ? styles["active"] : ""
|
7959
|
+
}));
|
7960
|
+
};
|
7961
|
+
|
7962
|
+
var TableHeader = function TableHeader(_ref) {
|
7963
|
+
var headerTemplates = _ref.headerTemplates,
|
7964
|
+
filter = _ref.filter,
|
7965
|
+
onSort = _ref.onSort;
|
7966
|
+
var _useTranslation = useTranslation(),
|
7967
|
+
t = _useTranslation.t;
|
7968
|
+
return React.createElement(TableHead, null, React.createElement(TableRow, null, headerTemplates.map(function (i, index$1) {
|
7969
|
+
return React.createElement(TableCell, {
|
7970
|
+
key: index$1,
|
7971
|
+
className: "" + (!!i.sortKey && "pointer"),
|
7972
|
+
onClick: !!i.sortKey ? function () {
|
7973
|
+
return onSort === null || onSort === void 0 ? void 0 : onSort(i.sortKey);
|
7974
|
+
} : undefined
|
7975
|
+
}, React.createElement("div", {
|
7976
|
+
className: "d-flex justify-content-between align-items-center text-nowrap"
|
7977
|
+
}, t(i.title), !!i.sortKey && React.createElement(SortIcon, {
|
7978
|
+
isAscending: filter.sortColumnName !== i.sortKey ? undefined : filter.sortColumnDirection === OrderType.ASC
|
7979
|
+
})));
|
7980
|
+
})));
|
7981
|
+
};
|
7982
|
+
|
7983
|
+
var SearchInput = function SearchInput(_ref) {
|
7984
|
+
var textSearchRef = _ref.textSearchRef,
|
7985
|
+
_ref$placeholder = _ref.placeholder,
|
7986
|
+
placeholder = _ref$placeholder === void 0 ? "Search for..." : _ref$placeholder,
|
7987
|
+
onChange = _ref.onChange,
|
7988
|
+
_ref$fit = _ref.fit,
|
7989
|
+
fit = _ref$fit === void 0 ? true : _ref$fit;
|
7990
|
+
return React.createElement(Paper, {
|
7991
|
+
component: "div",
|
7992
|
+
className: "bg-light w-100 " + (fit && "h-100"),
|
7993
|
+
sx: {
|
7994
|
+
p: "2px 4px",
|
7995
|
+
display: "flex",
|
7996
|
+
alignItems: "center",
|
7997
|
+
width: 400,
|
7998
|
+
transition: "border 0.2s ease",
|
7999
|
+
outline: "1px solid transparent",
|
8000
|
+
":focus-within": {
|
8001
|
+
outlineColor: function outlineColor(theme) {
|
8002
|
+
return theme.palette.primary.main;
|
8003
|
+
}
|
8004
|
+
}
|
8005
|
+
}
|
8006
|
+
}, React.createElement(Box, {
|
8007
|
+
sx: {
|
8008
|
+
p: "10px"
|
8009
|
+
},
|
8010
|
+
"aria-label": "search"
|
8011
|
+
}, React.createElement(IoSearch, {
|
8012
|
+
size: 24,
|
8013
|
+
className: "pb-1"
|
8014
|
+
})), React.createElement(InputBase, {
|
8015
|
+
id: "searchText",
|
8016
|
+
className: "" + (fit && "h-100"),
|
8017
|
+
sx: {
|
8018
|
+
ml: 1,
|
8019
|
+
flex: 1,
|
8020
|
+
lineHeight: 1
|
8021
|
+
},
|
8022
|
+
placeholder: placeholder,
|
8023
|
+
ref: textSearchRef,
|
8024
|
+
onChange: onChange
|
8025
|
+
}));
|
8026
|
+
};
|
8027
|
+
|
8028
|
+
var TextbookList = function TextbookList(props) {
|
8029
|
+
var _useTranslation = useTranslation(),
|
8030
|
+
t = _useTranslation.t;
|
8031
|
+
var _useTextbookList = useTextbookList(props),
|
8032
|
+
filter = _useTextbookList.filter,
|
8033
|
+
textbooks = _useTextbookList.textbooks,
|
8034
|
+
totalPages = _useTextbookList.totalPages,
|
8035
|
+
textSearchRef = _useTextbookList.textSearchRef,
|
8036
|
+
selectedTextbook = _useTextbookList.selectedTextbook,
|
8037
|
+
handleChangeSearchText = _useTextbookList.handleChangeSearchText,
|
8038
|
+
handleSort = _useTextbookList.handleSort,
|
8039
|
+
handleChangePage = _useTextbookList.handleChangePage,
|
8040
|
+
calcOrderNumber = _useTextbookList.calcOrderNumber,
|
8041
|
+
handleViewTextbook = _useTextbookList.handleViewTextbook,
|
8042
|
+
handleUpdateTextbook = _useTextbookList.handleUpdateTextbook,
|
8043
|
+
handleCreateTextbook = _useTextbookList.handleCreateTextbook,
|
8044
|
+
toggleConfirmDialog = _useTextbookList.toggleConfirmDialog,
|
8045
|
+
handleDeleteTextbook = _useTextbookList.handleDeleteTextbook,
|
8046
|
+
handleSelectDeleteTextbook = _useTextbookList.handleSelectDeleteTextbook;
|
8047
|
+
return React.createElement(LayoutList, {
|
8048
|
+
title: t(TEXTBOOK_PAGE_TITLE)
|
8049
|
+
}, React.createElement(Grid, {
|
8050
|
+
container: true
|
8051
|
+
}, React.createElement(Grid, {
|
8052
|
+
item: true,
|
8053
|
+
xs: 6
|
8054
|
+
}, React.createElement(SearchInput, {
|
8055
|
+
textSearchRef: textSearchRef,
|
8056
|
+
onChange: handleChangeSearchText,
|
8057
|
+
placeholder: t(TEXT_BOOK_SEARCH_PLACEHOLDER)
|
8058
|
+
})), React.createElement(Grid, {
|
8059
|
+
item: true,
|
8060
|
+
xs: 6
|
8061
|
+
}, React.createElement(Stack, {
|
8062
|
+
alignItems: "end"
|
8063
|
+
}, React.createElement(Button, {
|
8064
|
+
startIcon: React.createElement(FaPlus, {
|
8065
|
+
size: 12
|
8066
|
+
}),
|
8067
|
+
variant: "contained",
|
8068
|
+
color: "primary",
|
8069
|
+
onClick: handleCreateTextbook
|
8070
|
+
}, t("create_textbook")))), React.createElement(Grid, {
|
8071
|
+
item: true,
|
8072
|
+
xs: 12,
|
8073
|
+
className: "mt-3"
|
8074
|
+
}, React.createElement(Table, null, React.createElement(TableHeader, {
|
8075
|
+
headerTemplates: TEXTBOOK_HEADERS,
|
8076
|
+
filter: filter,
|
8077
|
+
onSort: handleSort
|
8078
|
+
}), React.createElement(TableBody, null, textbooks.map(function (i, index) {
|
8079
|
+
return React.createElement(TableRow, {
|
8080
|
+
key: i.id
|
8081
|
+
}, React.createElement(TableCell, null, calcOrderNumber(index)), React.createElement(TableCell, null, i.name), React.createElement(TableCell, null, i.subject.name), React.createElement(TableCell, null, utcToLocalTime(i.createdAt, t("date_format"))), React.createElement(TableCell, null, i.totalChapters), React.createElement(TableCell, null, React.createElement(Stack, {
|
8082
|
+
direction: "row",
|
8083
|
+
spacing: 1,
|
8084
|
+
alignItems: "center"
|
8085
|
+
}, !i.isCreatedByAdmin && React.createElement(IconButton, {
|
8086
|
+
color: "default",
|
8087
|
+
className: "bg-warning text-white",
|
8088
|
+
onClick: function onClick() {
|
8089
|
+
return handleUpdateTextbook(i.id);
|
8090
|
+
}
|
8091
|
+
}, React.createElement(FaPencil, {
|
8092
|
+
size: 12
|
8093
|
+
})), React.createElement(IconButton, {
|
8094
|
+
color: "default",
|
8095
|
+
className: "bg-primary text-white",
|
8096
|
+
onClick: function onClick() {
|
8097
|
+
return handleViewTextbook(i.id);
|
8098
|
+
}
|
8099
|
+
}, React.createElement(FaEye, {
|
8100
|
+
size: 12
|
8101
|
+
})), !i.isCreatedByAdmin && React.createElement(IconButton, {
|
8102
|
+
color: "default",
|
8103
|
+
className: "bg-danger text-white",
|
8104
|
+
onClick: function onClick() {
|
8105
|
+
return handleSelectDeleteTextbook(i);
|
8106
|
+
}
|
8107
|
+
}, React.createElement(FaTrash, {
|
8108
|
+
size: 12
|
8109
|
+
})))));
|
8110
|
+
}), !textbooks.length && React.createElement(EmptyRow, null))), React.createElement("div", {
|
8111
|
+
className: "d-flex justify-content-end mt-3"
|
8112
|
+
}, !!totalPages && React.createElement(Pagination, {
|
8113
|
+
count: totalPages,
|
8114
|
+
page: filter.currentPage,
|
8115
|
+
onChange: handleChangePage
|
8116
|
+
})))), React.createElement(ConfirmDialog, {
|
8117
|
+
open: !!(selectedTextbook !== null && selectedTextbook !== void 0 && selectedTextbook.id),
|
8118
|
+
toggle: toggleConfirmDialog,
|
8119
|
+
text: "" + t("are_you_sure_you_want_to_delete_the_textbook"),
|
8120
|
+
onConfirm: handleDeleteTextbook,
|
8121
|
+
confirmText: selectedTextbook === null || selectedTextbook === void 0 ? void 0 : selectedTextbook.name,
|
8122
|
+
isDelete: true
|
8123
|
+
}));
|
8124
|
+
};
|
8125
|
+
|
8126
|
+
|
8127
|
+
|
8128
|
+
var index$2 = {
|
8129
|
+
__proto__: null,
|
8130
|
+
TextbookList: TextbookList,
|
8131
|
+
TextbookDetail: TextbookViewDetail
|
8132
|
+
};
|
8133
|
+
|
8134
|
+
var _excluded$5 = ["defaultValue", "options", "isDisabled", "scrollBottom", "value", "isMulti"];
|
8135
|
+
var CustomCreatable = function CustomCreatable(_ref) {
|
8136
|
+
var options = _ref.options,
|
7571
8137
|
isDisabled = _ref.isDisabled,
|
7572
|
-
|
7573
|
-
|
7574
|
-
|
7575
|
-
|
7576
|
-
|
7577
|
-
|
7578
|
-
|
7579
|
-
|
7580
|
-
|
7581
|
-
|
7582
|
-
|
7583
|
-
|
7584
|
-
|
7585
|
-
|
7586
|
-
|
7587
|
-
|
7588
|
-
|
7589
|
-
|
7590
|
-
|
7591
|
-
|
7592
|
-
|
7593
|
-
|
7594
|
-
|
7595
|
-
|
7596
|
-
|
7597
|
-
|
7598
|
-
|
7599
|
-
|
7600
|
-
|
7601
|
-
|
7602
|
-
|
7603
|
-
|
7604
|
-
|
7605
|
-
|
7606
|
-
}
|
7607
|
-
|
7608
|
-
|
7609
|
-
|
7610
|
-
|
7611
|
-
|
7612
|
-
|
7613
|
-
|
7614
|
-
|
7615
|
-
|
7616
|
-
|
7617
|
-
}, React.createElement("label", {
|
7618
|
-
className: styleGlobal["form-label"] + " " + styles$1["question-label"],
|
7619
|
-
htmlFor: "duration"
|
7620
|
-
}, t("duration")), React.createElement(CustomSelect, {
|
7621
|
-
inputId: "duration",
|
7622
|
-
value: exam.duration,
|
7623
|
-
options: durationOptions,
|
7624
|
-
onChange: handleChangeDuration,
|
7625
|
-
isDisabled: isDisabled
|
7626
|
-
})), React.createElement(Grid, {
|
7627
|
-
item: true,
|
7628
|
-
xs: 3,
|
7629
|
-
className: 'mb-2'
|
7630
|
-
}, React.createElement("label", {
|
7631
|
-
className: styleGlobal["form-label"] + " " + styles$1["question-label"],
|
7632
|
-
htmlFor: "duration"
|
7633
|
-
}, t("subject"), " ", selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.name), React.createElement(CustomSelect, {
|
7634
|
-
inputId: "subject",
|
7635
|
-
value: selectedSubject === null || selectedSubject === void 0 ? void 0 : selectedSubject.id,
|
7636
|
-
options: subjectOptions,
|
7637
|
-
onChange: handleChangeSubject,
|
7638
|
-
isDisabled: isDisabled || isEdit
|
7639
|
-
})), examGroupByArticle.map(function (i, index) {
|
7640
|
-
return React.createElement(Grid, {
|
7641
|
-
item: true,
|
7642
|
-
key: i.article,
|
7643
|
-
xs: 12,
|
7644
|
-
className: index === examGroupByArticle.length - 1 ? "mb-2" : ''
|
7645
|
-
}, React.createElement(ArticleGroupView, Object.assign({}, i, {
|
7646
|
-
isActive: index === examGroupByArticle.length - 1,
|
7647
|
-
onChangeQuestionCount: handleChangeQuestionCount,
|
7648
|
-
onChangeCategory: handleChangeCategory,
|
7649
|
-
onChangeAnswerCount: handleChangeAnswerCount,
|
7650
|
-
onChangeCorrectAnswers: handleChangeCorrectAnswers,
|
7651
|
-
onChangeScoreAnswer: handleChangeScoreAnswer,
|
7652
|
-
onDelete: handleDeleteArticle,
|
7653
|
-
isDisabled: isDisabled,
|
7654
|
-
selectedSubject: selectedSubject,
|
7655
|
-
isDeletable: examGroupByArticle.length > 1
|
7656
|
-
})));
|
7657
|
-
}), React.createElement(Grid, {
|
7658
|
-
item: true,
|
7659
|
-
xs: 12
|
7660
|
-
}, React.createElement("button", {
|
7661
|
-
disabled: isDisabled,
|
7662
|
-
className: styleGlobal["btn-outline-primary"] + " w-100 d-flex justify-content-center align-items-center " + styles$1["question-btn"] + " mt-3",
|
7663
|
-
onClick: handleAddArticle
|
7664
|
-
}, React.createElement(FaPlusCircle, {
|
7665
|
-
className: "me-2"
|
7666
|
-
}), "\uBB38\uD56D \uCD94\uAC00\uD558\uAE30")));
|
8138
|
+
scrollBottom = _ref.scrollBottom,
|
8139
|
+
value = _ref.value,
|
8140
|
+
isMulti = _ref.isMulti,
|
8141
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$5);
|
8142
|
+
var initialValues = Array.isArray(value) ? options.filter(function (i) {
|
8143
|
+
return value.includes(i.value);
|
8144
|
+
}) : isMulti ? options.filter(function (i) {
|
8145
|
+
return i.value == value;
|
8146
|
+
}) : options.find(function (i) {
|
8147
|
+
return i.value == value;
|
8148
|
+
});
|
8149
|
+
return React.createElement(CreatableSelect, Object.assign({
|
8150
|
+
isClearable: true,
|
8151
|
+
isDisabled: isDisabled,
|
8152
|
+
options: options,
|
8153
|
+
value: initialValues,
|
8154
|
+
menuPlacement: scrollBottom ? "top" : "auto",
|
8155
|
+
isMulti: isMulti
|
8156
|
+
}, rest));
|
8157
|
+
};
|
8158
|
+
|
8159
|
+
var _excluded$6 = ["isDefault", "defaultValue", "options", "isDisabled", "scrollBottom", "value", "isMulti"];
|
8160
|
+
var CustomAsyncSelect = function CustomAsyncSelect(_ref) {
|
8161
|
+
var isDefault = _ref.isDefault,
|
8162
|
+
options = _ref.options,
|
8163
|
+
isDisabled = _ref.isDisabled,
|
8164
|
+
scrollBottom = _ref.scrollBottom,
|
8165
|
+
value = _ref.value,
|
8166
|
+
isMulti = _ref.isMulti,
|
8167
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$6);
|
8168
|
+
var initialValues = Array.isArray(value) ? options.filter(function (i) {
|
8169
|
+
return value.includes(i.value);
|
8170
|
+
}) : isMulti ? options.filter(function (i) {
|
8171
|
+
return i.value == value;
|
8172
|
+
}) : options.find(function (i) {
|
8173
|
+
return i.value == value;
|
8174
|
+
});
|
8175
|
+
return React.createElement(Select, Object.assign({
|
8176
|
+
isDisabled: isDisabled,
|
8177
|
+
options: options,
|
8178
|
+
value: !isDefault ? initialValues : undefined,
|
8179
|
+
defaultValue: isDefault ? initialValues : undefined,
|
8180
|
+
menuPlacement: scrollBottom ? "top" : "auto",
|
8181
|
+
isMulti: isMulti
|
8182
|
+
}, rest));
|
7667
8183
|
};
|
7668
8184
|
|
7669
8185
|
var EXAM_SESSION_URL = BASE_URL + "/api/examSession";
|
@@ -7721,16 +8237,16 @@ var ORDER_NUMBERS = {
|
|
7721
8237
|
10: "the_tenth"
|
7722
8238
|
};
|
7723
8239
|
var TabList = [{
|
7724
|
-
label: "
|
8240
|
+
label: "comprehensive_analysis",
|
7725
8241
|
value: 0
|
7726
8242
|
}, {
|
7727
|
-
label: "
|
8243
|
+
label: "solution_order",
|
7728
8244
|
value: 1
|
7729
8245
|
}, {
|
7730
|
-
label: "
|
8246
|
+
label: "compare_solution",
|
7731
8247
|
value: 2
|
7732
8248
|
}, {
|
7733
|
-
label: "
|
8249
|
+
label: "problem_analysis",
|
7734
8250
|
value: 3
|
7735
8251
|
}];
|
7736
8252
|
var Roles$2;
|
@@ -8592,7 +9108,7 @@ var useExamResult = function useExamResult(searchParam, navigate, examSessionId,
|
|
8592
9108
|
var questions = ((_timelyOrderQuestion$ = timelyOrderQuestion[dataChartIndex]) === null || _timelyOrderQuestion$ === void 0 ? void 0 : _timelyOrderQuestion$.questions) || null;
|
8593
9109
|
var questionLength = (_questions$length = questions === null || questions === void 0 ? void 0 : questions.length) != null ? _questions$length : 0;
|
8594
9110
|
return val != null ? t("problem_number_question", {
|
8595
|
-
number: questions !== null ? ((_questions = questions[questionLength - val]) === null || _questions === void 0 ? void 0 : _questions.questionOrder) + 1 : val
|
9111
|
+
number: questions !== null ? (((_questions = questions[questionLength - val]) === null || _questions === void 0 ? void 0 : _questions.questionOrder) || 0) + 1 : val
|
8596
9112
|
}) : t("no_data");
|
8597
9113
|
}
|
8598
9114
|
return null;
|
@@ -8659,7 +9175,7 @@ var useExamResult = function useExamResult(searchParam, navigate, examSessionId,
|
|
8659
9175
|
var questions = ((_timelyOrderQuestion$2 = timelyOrderQuestion[dataChartIndex]) === null || _timelyOrderQuestion$2 === void 0 ? void 0 : _timelyOrderQuestion$2.questions) || null;
|
8660
9176
|
var questionLength = (_questions$length2 = questions === null || questions === void 0 ? void 0 : questions.length) != null ? _questions$length2 : 0;
|
8661
9177
|
return val != null ? t("problem_number_question", {
|
8662
|
-
number: questions !== null ? ((_questions2 = questions[questionLength - val]) === null || _questions2 === void 0 ? void 0 : _questions2.questionOrder) + 1 : val
|
9178
|
+
number: questions !== null ? (((_questions2 = questions[questionLength - val]) === null || _questions2 === void 0 ? void 0 : _questions2.questionOrder) || 0) + 1 : val
|
8663
9179
|
}) : t("no_data");
|
8664
9180
|
},
|
8665
9181
|
style: {
|
@@ -8687,15 +9203,23 @@ var useExamResult = function useExamResult(searchParam, navigate, examSessionId,
|
|
8687
9203
|
topAnswerOrder: i.topAnswerOrder == null ? 0 : i.topAnswerOrder
|
8688
9204
|
});
|
8689
9205
|
});
|
8690
|
-
var mySeriesData = [null].concat(questionsData.
|
8691
|
-
return
|
8692
|
-
}).map(function (item) {
|
8693
|
-
return
|
9206
|
+
var mySeriesData = [null].concat(_.sortBy(questionsData.filter(function (i) {
|
9207
|
+
return i.answerOrder !== 0;
|
9208
|
+
}), ["answerOrder", "questionOrder"]).map(function (item) {
|
9209
|
+
return data.questions.length - item.questionOrder;
|
9210
|
+
}), questionsData.filter(function (i) {
|
9211
|
+
return i.answerOrder === 0;
|
9212
|
+
}).map(function () {
|
9213
|
+
return null;
|
8694
9214
|
}), [null]);
|
8695
|
-
var topSeriesData = [null].concat(questionsData.
|
8696
|
-
return
|
8697
|
-
}).map(function (item) {
|
8698
|
-
return
|
9215
|
+
var topSeriesData = [null].concat(_.sortBy(questionsData.filter(function (i) {
|
9216
|
+
return i.topAnswerOrder !== 0;
|
9217
|
+
}), ["topAnswerOrder", "questionOrder"]).map(function (item) {
|
9218
|
+
return data.questions.length - item.questionOrder;
|
9219
|
+
}), questionsData.filter(function (i) {
|
9220
|
+
return i.topAnswerOrder === 0;
|
9221
|
+
}).map(function () {
|
9222
|
+
return null;
|
8699
9223
|
}), [null]);
|
8700
9224
|
return [{
|
8701
9225
|
name: t("my_problem_solving_order"),
|
@@ -9861,7 +10385,7 @@ Object.defineProperty(exports,"__esModule",{value:!0});var _typeof="function"==t
|
|
9861
10385
|
|
9862
10386
|
var ReactApexChart = unwrapExports(reactApexcharts_min);
|
9863
10387
|
|
9864
|
-
var styles$
|
10388
|
+
var styles$4 = {"titleBox":"_1dveO","title":"_mxRxf","point":"_2fD-F","buttonGroup":"_2DGl3","btnFeedback":"_xGW1x","btnTerminate":"_3mLu2","myanswer":"_eDBpS","titleMyAnswer1":"_2fMq3","titleMyAnswer2":"_3gEYh","contentMyAnswer":"_2K_sx","myAnswerItem":"_2qiLh","time":"_6TCOK","timeCol":"_hmseC","answer-response":"_3GfJt","answer-response-0":"_3ut64","answer-response-1":"_2VtpD","answer-response-2":"_58lQU","answer-response-3":"_1ucMY","answer-response-4":"_1qkxy","answerCorrect":"_2jIeT","answerIncorrect":"_to2v0","answerNograss":"_1JSte","answerEasy":"_2_uTU","answerDiscrimination":"_1DBoA","answerTrap":"_1q3tD","answerNoTime":"_3iItu","questionOrder":"_1fNkS","myTimeLabel":"_1Z_F3","myPoolTime":"_4KwG0","topTimeLabel":"_245H-","topTime":"_3tZqw","meanTimeLabel":"_PlPLY","meanTime":"_12a7R","compareChart":"_3MW16","prevChart":"_1fNkb","chart":"_3K4oY","nextChart":"_3YKBp","titleChart":"_13BVP","compareGrass":"_1_fJu","titleCompareGrass":"_o1txm","tableCompareGrass":"_bT5nf","thcolumn1":"_3Umg0","tdcolumn1":"_3dRMF","tdcolumn3":"_2tcBP","classification":"_1AFeb","wrapperProblem":"_oTqG7","titleProblem":"_35eIx","titleProblemClose":"_3t4HO","titleTrickyProblem":"_1-oxK","wrongQuestions":"_2dpMR","question":"_1lSOX","assignedQuestions":"_1ONUt","wrapperContent":"_nPoR0","content":"_2zmZn","contentColumn1":"_334SY","span1":"_3Lf-U","span2":"_ZpMot","contentColumn2":"_16P3l","duration":"_1kT28","topDuration":"_1fVRi","overallCorrectRate":"_3jLGe","answer":"_VsZ0K","contentVulnerable":"_QxKMy","wrappContentProblem":"_nnqpW","contentProblem":"_3Z1nV","labelProblem":"_36Xpx","name":"_3ZJQW","percent":"_2J3MK","slider":"_1MPdO","track":"_3CV_y","noData":"__g-ff","loading":"_3j485","table-responsive":"_2O6RX","form-label":"_1RYOQ","form-control":"_3VRVT","form-label-dialog":"_3oCSh","btn-cancel":"_3USKq","btn-register":"_3y_iD","pdfBtnBox":"_3xZHo","pdfBtn":"_1DtWq","form-select":"_1a_vw"};
|
9865
10389
|
|
9866
10390
|
var iconStarQuestion = function iconStarQuestion(_ref) {
|
9867
10391
|
var _ref$width = _ref.width,
|
@@ -10152,7 +10676,7 @@ function CreateNewQuestionDialog(_ref) {
|
|
10152
10676
|
padding: "24px 24px 40px 24px"
|
10153
10677
|
}, React.createElement(Stack, null, React.createElement("label", {
|
10154
10678
|
htmlFor: "questions",
|
10155
|
-
className:
|
10679
|
+
className: styles['form-label'] + " " + styles$4['form-label-dialog']
|
10156
10680
|
}, "\uC9C8\uBB38\uD560 \uBB38\uC81C"), React.createElement(Field, {
|
10157
10681
|
as: "select",
|
10158
10682
|
id: "questions",
|
@@ -10160,7 +10684,7 @@ function CreateNewQuestionDialog(_ref) {
|
|
10160
10684
|
style: {
|
10161
10685
|
width: "100%"
|
10162
10686
|
},
|
10163
|
-
className: "" +
|
10687
|
+
className: "" + styles['form-select']
|
10164
10688
|
}, questions === null || questions === void 0 ? void 0 : questions.map(function (question) {
|
10165
10689
|
return React.createElement("option", {
|
10166
10690
|
value: question === null || question === void 0 ? void 0 : question.id
|
@@ -10169,7 +10693,7 @@ function CreateNewQuestionDialog(_ref) {
|
|
10169
10693
|
}));
|
10170
10694
|
}))), React.createElement(Stack, null, React.createElement("label", {
|
10171
10695
|
htmlFor: "content-question",
|
10172
|
-
className:
|
10696
|
+
className: styles['form-label'] + " " + styles$4['form-label-dialog']
|
10173
10697
|
}, "\uC9C8\uBB38 \uB0B4\uC6A9"), React.createElement(Box, {
|
10174
10698
|
position: 'relative',
|
10175
10699
|
display: 'flex',
|
@@ -10182,7 +10706,7 @@ function CreateNewQuestionDialog(_ref) {
|
|
10182
10706
|
},
|
10183
10707
|
name: "content",
|
10184
10708
|
placeholder: "\uBB38\uC81C\uAC00 \uC5B4\uB824\uC6CC\uC694",
|
10185
|
-
className:
|
10709
|
+
className: styles['form-control']
|
10186
10710
|
}), (errors === null || errors === void 0 ? void 0 : errors.content) && React.createElement(Box, {
|
10187
10711
|
position: 'absolute',
|
10188
10712
|
right: 0,
|
@@ -10205,14 +10729,14 @@ function CreateNewQuestionDialog(_ref) {
|
|
10205
10729
|
borderTop: "1px solid #CED2DA"
|
10206
10730
|
}
|
10207
10731
|
}, React.createElement(Button$1, {
|
10208
|
-
className: styles$
|
10732
|
+
className: styles$4['btn-cancel'],
|
10209
10733
|
onClick: toggleCreateQuestion
|
10210
10734
|
}, React.createElement(Typography$1, {
|
10211
10735
|
fontWeight: 700,
|
10212
10736
|
fontSize: '14px',
|
10213
10737
|
lineHeight: '16.71px'
|
10214
10738
|
}, "\uCDE8\uC18C")), React.createElement(Button$1, {
|
10215
|
-
className: styles$
|
10739
|
+
className: styles$4['btn-register'],
|
10216
10740
|
type: "submit"
|
10217
10741
|
}, React.createElement(Typography$1, {
|
10218
10742
|
fontWeight: 700,
|
@@ -10244,7 +10768,7 @@ function MyAnswer(_ref) {
|
|
10244
10768
|
toggleCreateQuestion();
|
10245
10769
|
};
|
10246
10770
|
return React.createElement("div", {
|
10247
|
-
className: styles$
|
10771
|
+
className: styles$4["myanswer"]
|
10248
10772
|
}, formattedData && formattedData.length > 0 && formattedData.map(function (item) {
|
10249
10773
|
return React.createElement("div", {
|
10250
10774
|
key: item.category.id
|
@@ -10252,9 +10776,9 @@ function MyAnswer(_ref) {
|
|
10252
10776
|
bgcolor: "#F9FAFB",
|
10253
10777
|
flexDirection: "row",
|
10254
10778
|
padding: "12px",
|
10255
|
-
className: styles$
|
10779
|
+
className: styles$4["myAnswerItem"] + " " + styles["noGutters"]
|
10256
10780
|
}, React.createElement("div", {
|
10257
|
-
className:
|
10781
|
+
className: styles["custom-col-2"],
|
10258
10782
|
style: {
|
10259
10783
|
display: "flex",
|
10260
10784
|
gap: "4px"
|
@@ -10266,7 +10790,7 @@ function MyAnswer(_ref) {
|
|
10266
10790
|
color: "#97A1AF"
|
10267
10791
|
}
|
10268
10792
|
}, "\uBB38\uC81C \uBC88\uD638")), React.createElement("div", {
|
10269
|
-
className:
|
10793
|
+
className: styles["custom-col-2"],
|
10270
10794
|
style: {
|
10271
10795
|
display: "flex",
|
10272
10796
|
gap: "4px"
|
@@ -10278,7 +10802,7 @@ function MyAnswer(_ref) {
|
|
10278
10802
|
color: "#97A1AF"
|
10279
10803
|
}
|
10280
10804
|
}, "\uC815\uB2F5")), React.createElement("div", {
|
10281
|
-
className:
|
10805
|
+
className: styles["custom-col-2"],
|
10282
10806
|
style: {
|
10283
10807
|
display: "flex",
|
10284
10808
|
gap: "4px"
|
@@ -10290,7 +10814,7 @@ function MyAnswer(_ref) {
|
|
10290
10814
|
color: "#97A1AF"
|
10291
10815
|
}
|
10292
10816
|
}, "\uD480\uC774 \uC2DC\uAC04")), React.createElement("div", {
|
10293
|
-
className:
|
10817
|
+
className: styles["custom-col-2"],
|
10294
10818
|
style: {
|
10295
10819
|
display: "flex",
|
10296
10820
|
alignItems: "center",
|
@@ -10303,7 +10827,7 @@ function MyAnswer(_ref) {
|
|
10303
10827
|
color: "#97A1AF"
|
10304
10828
|
}
|
10305
10829
|
}, "\uC0C1\uC704\uAD8C \uBE44\uAD50")), React.createElement("div", {
|
10306
|
-
className:
|
10830
|
+
className: styles["custom-col-2"],
|
10307
10831
|
style: {
|
10308
10832
|
display: "flex",
|
10309
10833
|
alignItems: "center",
|
@@ -10316,7 +10840,7 @@ function MyAnswer(_ref) {
|
|
10316
10840
|
color: "#97A1AF"
|
10317
10841
|
}
|
10318
10842
|
}, "\uC804\uCCB4 \uC815\uB2F5\uB960"))), React.createElement("div", {
|
10319
|
-
className: styles$
|
10843
|
+
className: styles$4["titleMyAnswer2"]
|
10320
10844
|
}, React.createElement(Typography, {
|
10321
10845
|
sx: {
|
10322
10846
|
color: "#97A1AF",
|
@@ -10329,7 +10853,7 @@ function MyAnswer(_ref) {
|
|
10329
10853
|
fontWeight: 700
|
10330
10854
|
}
|
10331
10855
|
}, item.category.name)), React.createElement("div", {
|
10332
|
-
className: styles$
|
10856
|
+
className: styles$4["contentMyAnswer"]
|
10333
10857
|
}, item.questions.map(function (question, index) {
|
10334
10858
|
return React.createElement("div", {
|
10335
10859
|
style: isOpenTime[question.id] ? {
|
@@ -10338,9 +10862,9 @@ function MyAnswer(_ref) {
|
|
10338
10862
|
} : {},
|
10339
10863
|
key: question.id
|
10340
10864
|
}, React.createElement("div", {
|
10341
|
-
className: styles$
|
10865
|
+
className: styles$4["myAnswerItem"] + " " + styles["noGutters"]
|
10342
10866
|
}, React.createElement("div", {
|
10343
|
-
className:
|
10867
|
+
className: styles["custom-col-2"],
|
10344
10868
|
style: {
|
10345
10869
|
display: "flex",
|
10346
10870
|
alignItems: "center",
|
@@ -10348,22 +10872,22 @@ function MyAnswer(_ref) {
|
|
10348
10872
|
padding: "4px 8px"
|
10349
10873
|
}
|
10350
10874
|
}, question.isStar ? React.createElement(iconStarQuestion, null) : React.createElement(iconNoStarQuestion, null), React.createElement("span", {
|
10351
|
-
className: styles$
|
10875
|
+
className: styles$4["questionOrder"]
|
10352
10876
|
}, question.questionOrder + 1, "\uBC88")), React.createElement("div", {
|
10353
|
-
className:
|
10877
|
+
className: styles["custom-col-2"],
|
10354
10878
|
style: {
|
10355
10879
|
display: "flex",
|
10356
10880
|
alignItems: "center",
|
10357
10881
|
gap: "4px"
|
10358
10882
|
}
|
10359
10883
|
}, question.isCorrect && question.selectedAnswers !== "" && React.createElement(Fragment$1, null, React.createElement(iconCorrectAnswer, null), React.createElement("span", {
|
10360
|
-
className: styles$
|
10884
|
+
className: styles$4["answerCorrect"]
|
10361
10885
|
}, "\uC815\uB2F5")), !question.isCorrect && question.selectedAnswers !== "" && React.createElement(Fragment$1, null, React.createElement(iconCorrectAnswer$1, null), React.createElement("span", {
|
10362
|
-
className: styles$
|
10886
|
+
className: styles$4["answerIncorrect"]
|
10363
10887
|
}, "\uC624\uB2F5")), question.selectedAnswers === "" && React.createElement(Fragment$1, null, React.createElement(iconNoGrass, null), React.createElement("span", {
|
10364
|
-
className: styles$
|
10888
|
+
className: styles$4["answerNograss"]
|
10365
10889
|
}, "\uD480\uC774 \uC5C6\uC74C"))), React.createElement("div", {
|
10366
|
-
className:
|
10890
|
+
className: styles["custom-col-2"],
|
10367
10891
|
style: {
|
10368
10892
|
display: "flex",
|
10369
10893
|
alignItems: "center"
|
@@ -10372,14 +10896,14 @@ function MyAnswer(_ref) {
|
|
10372
10896
|
style: {
|
10373
10897
|
margin: 0
|
10374
10898
|
},
|
10375
|
-
className: styles$
|
10899
|
+
className: styles$4["answer-response"] + " " + styles$4["answer-response-" + question.answerResponseSignal]
|
10376
10900
|
}, formatTimeSecond(Math.round(question.duration), t)) : React.createElement("p", {
|
10377
10901
|
style: {
|
10378
10902
|
margin: 0
|
10379
10903
|
},
|
10380
|
-
className: styles$
|
10904
|
+
className: styles$4["answerNoTime"]
|
10381
10905
|
}, "\uC2DC\uAC04 \uC5C6\uC74C")), React.createElement("div", {
|
10382
|
-
className:
|
10906
|
+
className: styles["custom-col-2"],
|
10383
10907
|
style: {
|
10384
10908
|
display: "flex",
|
10385
10909
|
alignItems: "center"
|
@@ -10388,15 +10912,15 @@ function MyAnswer(_ref) {
|
|
10388
10912
|
style: {
|
10389
10913
|
margin: 0
|
10390
10914
|
},
|
10391
|
-
className: styles$
|
10915
|
+
className: styles$4["answer-response"] + " " + styles$4["answer-response-" + question.answerResponseSignal]
|
10392
10916
|
}, formatTimeSecond(Math.round(question.topDuration - question.duration), t)) : React.createElement("p", {
|
10393
10917
|
style: {
|
10394
10918
|
margin: 0,
|
10395
10919
|
textAlign: "center"
|
10396
10920
|
},
|
10397
|
-
className: styles$
|
10921
|
+
className: styles$4["answerNoTime"]
|
10398
10922
|
}, "-")), React.createElement("div", {
|
10399
|
-
className:
|
10923
|
+
className: styles["custom-col-2"],
|
10400
10924
|
style: {
|
10401
10925
|
display: "flex",
|
10402
10926
|
alignItems: "center"
|
@@ -10405,14 +10929,14 @@ function MyAnswer(_ref) {
|
|
10405
10929
|
style: {
|
10406
10930
|
margin: 0
|
10407
10931
|
},
|
10408
|
-
className: styles$
|
10409
|
-
}, question.overallCorrectRate + "%") : React.createElement("p", {
|
10932
|
+
className: styles$4["answer-response"] + " " + styles$4["answer-response-" + question.answerResponseSignal]
|
10933
|
+
}, question.overallCorrectRate.toFixed(2) + "%") : React.createElement("p", {
|
10410
10934
|
style: {
|
10411
10935
|
margin: 0
|
10412
10936
|
},
|
10413
|
-
className: styles$
|
10937
|
+
className: styles$4["answerNoTime"]
|
10414
10938
|
}, "\uC2DC\uAC04 \uC5C6\uC74C")), isStudent && React.createElement("div", {
|
10415
|
-
className:
|
10939
|
+
className: styles["custom-col-2"],
|
10416
10940
|
style: {
|
10417
10941
|
display: "flex",
|
10418
10942
|
alignItems: "center",
|
@@ -10481,11 +11005,11 @@ var iconBtnNextChart = function iconBtnNextChart(_ref) {
|
|
10481
11005
|
function CompareGrass(_ref) {
|
10482
11006
|
var effectSize = _ref.effectSize;
|
10483
11007
|
return React.createElement("div", {
|
10484
|
-
className: styles$
|
11008
|
+
className: styles$4["compareGrass"]
|
10485
11009
|
}, React.createElement("div", {
|
10486
|
-
className: styles$
|
11010
|
+
className: styles$4["tableCompareGrass"]
|
10487
11011
|
}, React.createElement("div", {
|
10488
|
-
className: styles$
|
11012
|
+
className: styles$4["table-responsive"]
|
10489
11013
|
}, React.createElement(Table, {
|
10490
11014
|
style: {
|
10491
11015
|
width: "100%"
|
@@ -10495,7 +11019,7 @@ function CompareGrass(_ref) {
|
|
10495
11019
|
borderBottom: "1px solid #E4E7EC"
|
10496
11020
|
}
|
10497
11021
|
}, React.createElement("tr", null, React.createElement("th", {
|
10498
|
-
className: styles$
|
11022
|
+
className: styles$4["thcolumn1"]
|
10499
11023
|
}, "\uBB38\uC81C \uBC88\uD638"), React.createElement("th", {
|
10500
11024
|
style: {
|
10501
11025
|
textAlign: "center"
|
@@ -10519,14 +11043,14 @@ function CompareGrass(_ref) {
|
|
10519
11043
|
borderBottom: "1px solid #e4e7ec"
|
10520
11044
|
} : {}
|
10521
11045
|
}, React.createElement("td", {
|
10522
|
-
className: styles$
|
11046
|
+
className: styles$4["tdcolumn1"]
|
10523
11047
|
}, "\uBB38\uC81C ", item.questionOrder + 1), React.createElement("td", {
|
10524
11048
|
style: {
|
10525
11049
|
textAlign: "center",
|
10526
11050
|
color: "#202B37"
|
10527
11051
|
}
|
10528
11052
|
}, item.correctAnswers, "\uBC88"), React.createElement("td", {
|
10529
|
-
className: styles$
|
11053
|
+
className: styles$4["tdcolumn3"],
|
10530
11054
|
style: {
|
10531
11055
|
color: item.isCorrect ? "#1EE288" : "#F34B4B"
|
10532
11056
|
}
|
@@ -10536,7 +11060,7 @@ function CompareGrass(_ref) {
|
|
10536
11060
|
color: "#414E62"
|
10537
11061
|
}
|
10538
11062
|
}, item.mostSelectedAnswers ? item.mostSelectedAnswers + "\uBC88" : ""), React.createElement("td", null, React.createElement("div", {
|
10539
|
-
className: styles$
|
11063
|
+
className: styles$4["classification"]
|
10540
11064
|
}, item.problemCategories.map(function (problem, index) {
|
10541
11065
|
return React.createElement("div", {
|
10542
11066
|
key: index
|
@@ -10663,9 +11187,9 @@ function TrickyProblem(_ref) {
|
|
10663
11187
|
return i.isStar && i.isCorrect;
|
10664
11188
|
});
|
10665
11189
|
return React.createElement("div", {
|
10666
|
-
className: styles$
|
11190
|
+
className: styles$4["wrapperProblem"]
|
10667
11191
|
}, React.createElement("div", {
|
10668
|
-
className: !openProblem.problem1 ? styles$
|
11192
|
+
className: !openProblem.problem1 ? styles$4["titleProblemClose"] : styles$4["titleProblem"],
|
10669
11193
|
onClick: function onClick() {
|
10670
11194
|
return changeOpen(_extends({}, openProblem, {
|
10671
11195
|
problem1: !openProblem.problem1
|
@@ -10678,27 +11202,27 @@ function TrickyProblem(_ref) {
|
|
10678
11202
|
fontWeight: 700
|
10679
11203
|
}
|
10680
11204
|
}, "\uAE4C\uB2E4\uB85C\uC6E0\uB358 \uBB38\uC81C"), openProblem.problem1 ? React.createElement(iconUpArrow, null) : React.createElement(iconDownArrow, null)), openProblem.problem1 && React.createElement(Fragment$1, null, React.createElement("div", {
|
10681
|
-
className: styles$
|
11205
|
+
className: styles$4["titleTrickyProblem"]
|
10682
11206
|
}, React.createElement(iconX, null), React.createElement("span", null, "\uBCC4\uD45C \uCE5C \uBB38\uC81C \uC911 \uD2C0\uB9B0 \uBB38\uC81C")), React.createElement("div", {
|
10683
|
-
className: styles$
|
11207
|
+
className: styles$4["wrongQuestions"]
|
10684
11208
|
}, !!inCorrectQuestions.length && inCorrectQuestions.map(function (question) {
|
10685
11209
|
return React.createElement("span", {
|
10686
11210
|
key: question.id,
|
10687
|
-
className: styles$
|
11211
|
+
className: styles$4["question"]
|
10688
11212
|
}, question.questionOrder + 1, "\uBC88");
|
10689
11213
|
}), !data.questions.length && React.createElement("div", {
|
10690
|
-
className: styles$
|
11214
|
+
className: styles$4["noData"]
|
10691
11215
|
}, "\uB370\uC774\uD130 \uC5C6\uC74C")), React.createElement("div", {
|
10692
|
-
className: styles$
|
11216
|
+
className: styles$4["titleTrickyProblem"]
|
10693
11217
|
}, React.createElement(iconAssignedQuestions, null), React.createElement("span", null, "\uBCC4\uD45C \uCE5C \uBB38\uC81C \uC911 \uB9DE\uCD98 \uBB38\uC81C")), React.createElement("div", {
|
10694
|
-
className: styles$
|
11218
|
+
className: styles$4["assignedQuestions"]
|
10695
11219
|
}, !!correctQuestions.length && correctQuestions.map(function (question) {
|
10696
11220
|
return React.createElement("div", {
|
10697
11221
|
key: question.id,
|
10698
|
-
className: styles$
|
11222
|
+
className: styles$4["question"]
|
10699
11223
|
}, question.questionOrder + 1, "\uBC88");
|
10700
11224
|
}), !data.questions.length && React.createElement("div", {
|
10701
|
-
className: styles$
|
11225
|
+
className: styles$4["noData"]
|
10702
11226
|
}, "\uB370\uC774\uD130 \uC5C6\uC74C"))));
|
10703
11227
|
}
|
10704
11228
|
|
@@ -10709,9 +11233,9 @@ function ProtractedProblem(_ref) {
|
|
10709
11233
|
var _useTranslation = useTranslation(),
|
10710
11234
|
t = _useTranslation.t;
|
10711
11235
|
return React.createElement("div", {
|
10712
|
-
className: styles$
|
11236
|
+
className: styles$4["wrapperProblem"]
|
10713
11237
|
}, React.createElement("div", {
|
10714
|
-
className: !openProblem.problem2 ? styles$
|
11238
|
+
className: !openProblem.problem2 ? styles$4["titleProblemClose"] : styles$4["titleProblem"],
|
10715
11239
|
onClick: function onClick() {
|
10716
11240
|
return changeOpen(_extends({}, openProblem, {
|
10717
11241
|
problem2: !openProblem.problem2
|
@@ -10724,30 +11248,30 @@ function ProtractedProblem(_ref) {
|
|
10724
11248
|
fontWeight: 700
|
10725
11249
|
}
|
10726
11250
|
}, "\uC2DC\uAC04\uC774 \uC624\uB798 \uAC78\uB9B0 \uBB38\uC81C"), openProblem.problem2 ? React.createElement(iconUpArrow, null) : React.createElement(iconDownArrow, null)), openProblem.problem2 && React.createElement(Fragment$1, null, React.createElement("div", {
|
10727
|
-
className: styles$
|
11251
|
+
className: styles$4["wrapperContent"]
|
10728
11252
|
}, data.length ? data.map(function (item) {
|
10729
11253
|
return React.createElement("div", {
|
10730
|
-
className: styles$
|
11254
|
+
className: styles$4["content"],
|
10731
11255
|
key: item.id
|
10732
11256
|
}, React.createElement("div", {
|
10733
|
-
className: styles$
|
11257
|
+
className: styles$4["contentColumn1"]
|
10734
11258
|
}, React.createElement("div", null, React.createElement("span", {
|
10735
|
-
className: styles$
|
11259
|
+
className: styles$4["span1"]
|
10736
11260
|
}, "\uBB38\uC81C"), React.createElement("span", {
|
10737
|
-
className: styles$
|
11261
|
+
className: styles$4["span2"]
|
10738
11262
|
}, item.questionOrder + 1, "\uBC88"))), React.createElement("div", {
|
10739
|
-
className: styles$
|
11263
|
+
className: styles$4["contentColumn2"]
|
10740
11264
|
}, React.createElement("div", null, React.createElement("span", {
|
10741
|
-
className: styles$
|
11265
|
+
className: styles$4["span1"]
|
10742
11266
|
}, "\uB098\uC758 \uC2DC\uAC04"), React.createElement("span", {
|
10743
|
-
className: styles$
|
11267
|
+
className: styles$4["span2"]
|
10744
11268
|
}, "\uC0C1\uC704\uAD8C \uC2DC\uAC04")), React.createElement("div", null, React.createElement("span", {
|
10745
|
-
className: styles$
|
11269
|
+
className: styles$4["duration"]
|
10746
11270
|
}, formatTimeSecond(item.duration, t)), React.createElement("span", {
|
10747
|
-
className: styles$
|
11271
|
+
className: styles$4["topDuration"]
|
10748
11272
|
}, formatTimeSecond(item.topDuration, t)))));
|
10749
11273
|
}) : React.createElement("div", {
|
10750
|
-
className: styles$
|
11274
|
+
className: styles$4["noData"]
|
10751
11275
|
}, "\uB370\uC774\uD130 \uC5C6\uC74C"))));
|
10752
11276
|
}
|
10753
11277
|
|
@@ -10761,9 +11285,9 @@ function Vulnerable(_ref) {
|
|
10761
11285
|
return q2.overallCorrectRate === q1.overallCorrectRate ? q1.questionOrder - q2.questionOrder : q2.overallCorrectRate - q1.overallCorrectRate;
|
10762
11286
|
});
|
10763
11287
|
return React.createElement("div", {
|
10764
|
-
className: styles$
|
11288
|
+
className: styles$4["wrapperProblem"]
|
10765
11289
|
}, React.createElement("div", {
|
10766
|
-
className: !openProblem.problem3 ? styles$
|
11290
|
+
className: !openProblem.problem3 ? styles$4["titleProblemClose"] : styles$4["titleProblem"],
|
10767
11291
|
onClick: function onClick() {
|
10768
11292
|
return changeOpen(_extends({}, openProblem, {
|
10769
11293
|
problem3: !openProblem.problem3
|
@@ -10776,30 +11300,30 @@ function Vulnerable(_ref) {
|
|
10776
11300
|
fontWeight: 700
|
10777
11301
|
}
|
10778
11302
|
}, "\uB0B4\uAC00 \uCDE8\uC57D\uD55C \uBB38\uC81C"), openProblem.problem3 ? React.createElement(iconUpArrow, null) : React.createElement(iconDownArrow, null)), openProblem.problem3 && React.createElement(Fragment$1, null, React.createElement("div", {
|
10779
|
-
className: styles$
|
11303
|
+
className: styles$4["wrapperContent"]
|
10780
11304
|
}, incorrectQuestions.length ? React.createElement(Fragment$1, null, incorrectQuestions.map(function (question) {
|
10781
11305
|
return React.createElement("div", {
|
10782
|
-
className: styles$
|
11306
|
+
className: styles$4["content"],
|
10783
11307
|
key: question.id
|
10784
11308
|
}, React.createElement("div", {
|
10785
|
-
className: styles$
|
11309
|
+
className: styles$4["contentColumn1"]
|
10786
11310
|
}, React.createElement("div", null, React.createElement("span", {
|
10787
|
-
className: styles$
|
11311
|
+
className: styles$4["span1"]
|
10788
11312
|
}, "\uBB38\uC81C"), React.createElement("span", {
|
10789
|
-
className: styles$
|
11313
|
+
className: styles$4["span2"]
|
10790
11314
|
}, question.questionOrder + 1, "\uBC88"))), React.createElement("div", {
|
10791
|
-
className: styles$
|
11315
|
+
className: styles$4["contentColumn2"]
|
10792
11316
|
}, React.createElement("div", null, React.createElement("span", {
|
10793
|
-
className: styles$
|
11317
|
+
className: styles$4["span1"]
|
10794
11318
|
}, "\uC804\uCCB4 \uC815\uB2F5\uB960"), React.createElement("span", {
|
10795
|
-
className: styles$
|
11319
|
+
className: styles$4["span2"]
|
10796
11320
|
}, "\uB098\uC758 \uC624\uB2F5")), React.createElement("div", null, React.createElement("span", {
|
10797
|
-
className: styles$
|
11321
|
+
className: styles$4["overallCorrectRate"]
|
10798
11322
|
}, question.overallCorrectRate.toFixed(2), "%"), React.createElement("span", {
|
10799
|
-
className: styles$
|
11323
|
+
className: styles$4["answer"]
|
10800
11324
|
}, question.selectedAnswers, "\uBC88 (\uC815\uB2F5", " ", question.correctAnswers, "\uBC88)"))));
|
10801
11325
|
})) : React.createElement("div", {
|
10802
|
-
className: styles$
|
11326
|
+
className: styles$4["noData"]
|
10803
11327
|
}, "\uB370\uC774\uD130 \uC5C6\uC74C"))));
|
10804
11328
|
}
|
10805
11329
|
|
@@ -10808,9 +11332,9 @@ function GradesByTerritory(_ref) {
|
|
10808
11332
|
openProblem = _ref.openProblem,
|
10809
11333
|
changeOpen = _ref.changeOpen;
|
10810
11334
|
return React.createElement("div", {
|
10811
|
-
className: styles$
|
11335
|
+
className: styles$4["wrapperProblem"]
|
10812
11336
|
}, React.createElement("div", {
|
10813
|
-
className: !openProblem.problem4 ? styles$
|
11337
|
+
className: !openProblem.problem4 ? styles$4["titleProblemClose"] : styles$4["titleProblem"],
|
10814
11338
|
onClick: function onClick() {
|
10815
11339
|
return changeOpen(_extends({}, openProblem, {
|
10816
11340
|
problem4: !openProblem.problem4
|
@@ -10823,27 +11347,27 @@ function GradesByTerritory(_ref) {
|
|
10823
11347
|
fontWeight: 700
|
10824
11348
|
}
|
10825
11349
|
}, "\uC601\uC5ED\uBCC4 \uC131\uC801"), openProblem.problem4 ? React.createElement(iconUpArrow, null) : React.createElement(iconDownArrow, null)), openProblem.problem4 && React.createElement("div", {
|
10826
|
-
className: styles$
|
11350
|
+
className: styles$4["wrappContentProblem"]
|
10827
11351
|
}, data.length && data.map(function (item) {
|
10828
11352
|
return React.createElement("div", {
|
10829
|
-
className: styles$
|
11353
|
+
className: styles$4["contentProblem"],
|
10830
11354
|
key: item.id
|
10831
11355
|
}, React.createElement("div", {
|
10832
|
-
className: styles$
|
11356
|
+
className: styles$4["labelProblem"]
|
10833
11357
|
}, React.createElement("span", {
|
10834
|
-
className: styles$
|
11358
|
+
className: styles$4["name"]
|
10835
11359
|
}, item.name), React.createElement("div", {
|
10836
|
-
className: styles$
|
11360
|
+
className: styles$4["percent"]
|
10837
11361
|
}, React.createElement("span", null, item.percentageAmongStudents.toFixed(2), "%"), React.createElement("span", null, item.totalCorrectQuestions, "/", item.totalQuestions, "\uBB38\uC81C"))), React.createElement("div", {
|
10838
|
-
className: styles$
|
11362
|
+
className: styles$4["slider"]
|
10839
11363
|
}, React.createElement("span", {
|
10840
|
-
className: styles$
|
11364
|
+
className: styles$4["track"],
|
10841
11365
|
style: {
|
10842
11366
|
left: item.percentageAmongStudents + "%"
|
10843
11367
|
}
|
10844
11368
|
})));
|
10845
11369
|
}), openProblem.problem4 && !data.length && React.createElement("div", {
|
10846
|
-
className: styles$
|
11370
|
+
className: styles$4["noData"]
|
10847
11371
|
}, "\uB370\uC774\uD130 \uC5C6\uC74C")));
|
10848
11372
|
}
|
10849
11373
|
|
@@ -10936,7 +11460,7 @@ function CreateNewQuestionDialog$1(_ref) {
|
|
10936
11460
|
var errors = _ref2.errors;
|
10937
11461
|
return React.createElement(Form, null, React.createElement("label", {
|
10938
11462
|
htmlFor: "content-question",
|
10939
|
-
className:
|
11463
|
+
className: styles['form-label'] + " " + styles$4['form-label-dialog']
|
10940
11464
|
}, "\uC9C8\uBB38 \uB0B4\uC6A9"), React.createElement(Box, {
|
10941
11465
|
position: 'relative',
|
10942
11466
|
display: 'flex',
|
@@ -10949,7 +11473,7 @@ function CreateNewQuestionDialog$1(_ref) {
|
|
10949
11473
|
},
|
10950
11474
|
name: "content",
|
10951
11475
|
placeholder: "\uBB38\uC81C\uAC00 \uC5B4\uB824\uC6CC\uC694",
|
10952
|
-
className:
|
11476
|
+
className: styles['form-control']
|
10953
11477
|
}), (errors === null || errors === void 0 ? void 0 : errors.content) && React.createElement(Box, {
|
10954
11478
|
position: 'absolute',
|
10955
11479
|
right: 0,
|
@@ -10971,14 +11495,14 @@ function CreateNewQuestionDialog$1(_ref) {
|
|
10971
11495
|
padding: '12px'
|
10972
11496
|
}
|
10973
11497
|
}, React.createElement(Button$1, {
|
10974
|
-
className: styles$
|
11498
|
+
className: styles$4['btn-cancel'],
|
10975
11499
|
onClick: toggleCreateQuestion
|
10976
11500
|
}, React.createElement(Typography$1, {
|
10977
11501
|
fontWeight: 700,
|
10978
11502
|
fontSize: '14px',
|
10979
11503
|
lineHeight: '16.71px'
|
10980
11504
|
}, "\uCDE8\uC18C")), React.createElement(Button$1, {
|
10981
|
-
className: styles$
|
11505
|
+
className: styles$4['btn-register'],
|
10982
11506
|
type: "submit"
|
10983
11507
|
}, React.createElement(Typography$1, {
|
10984
11508
|
fontWeight: 700,
|
@@ -10989,12 +11513,12 @@ function CreateNewQuestionDialog$1(_ref) {
|
|
10989
11513
|
})));
|
10990
11514
|
}
|
10991
11515
|
|
10992
|
-
var _excluded$
|
11516
|
+
var _excluded$7 = ["children", "value", "index"];
|
10993
11517
|
var CustomTabPanel = function CustomTabPanel(props) {
|
10994
11518
|
var children = props.children,
|
10995
11519
|
value = props.value,
|
10996
11520
|
index = props.index,
|
10997
|
-
other = _objectWithoutPropertiesLoose(props, _excluded$
|
11521
|
+
other = _objectWithoutPropertiesLoose(props, _excluded$7);
|
10998
11522
|
return React.createElement("div", Object.assign({
|
10999
11523
|
role: "tabpanel",
|
11000
11524
|
hidden: value !== index,
|
@@ -11067,6 +11591,7 @@ var ExamResultV2 = function ExamResultV2(_ref) {
|
|
11067
11591
|
var _useTab = useTab(),
|
11068
11592
|
selected = _useTab.selected,
|
11069
11593
|
handleChangeTab = _useTab.handleChangeTab;
|
11594
|
+
var isTabletUp = useMediaQuery('(min-width:900px)');
|
11070
11595
|
return React.createElement(Fragment$1, null, timelyOrderQuestion[dataChartIndex] && longTimeSpend && resultDatas && effectSize ? React.createElement("div", {
|
11071
11596
|
style: {
|
11072
11597
|
width: "100%"
|
@@ -11164,7 +11689,28 @@ var ExamResultV2 = function ExamResultV2(_ref) {
|
|
11164
11689
|
container: true,
|
11165
11690
|
padding: "24px",
|
11166
11691
|
className: "position-relative overflow-hidden"
|
11167
|
-
}, React.createElement(Grid, {
|
11692
|
+
}, !isTabletUp && React.createElement(Grid, {
|
11693
|
+
item: true,
|
11694
|
+
xs: 12
|
11695
|
+
}, React.createElement(Box, {
|
11696
|
+
padding: "16px 24px",
|
11697
|
+
flexDirection: "row",
|
11698
|
+
justifyContent: "end",
|
11699
|
+
alignItems: "center",
|
11700
|
+
display: "flex",
|
11701
|
+
bgcolor: "#F9FAFB",
|
11702
|
+
borderTop: "1px solid #E4E7EC",
|
11703
|
+
borderBottom: "1px solid #E4E7EC"
|
11704
|
+
}, React.createElement(Stack, {
|
11705
|
+
padding: '12px 24px',
|
11706
|
+
alignItems: "end",
|
11707
|
+
bgcolor: "#F9FAFB"
|
11708
|
+
}, React.createElement("div", {
|
11709
|
+
className: styles$4["pdfBtnBox"]
|
11710
|
+
}, React.createElement("button", {
|
11711
|
+
className: styles$4["pdfBtn"] + " " + styles["truncate"],
|
11712
|
+
onClick: handleExportPdf
|
11713
|
+
}, React.createElement(iconPrintFill, null), React.createElement("p", null, t("print"))))))), React.createElement(Grid, {
|
11168
11714
|
item: true,
|
11169
11715
|
xs: 12
|
11170
11716
|
}, React.createElement(Box, {
|
@@ -11184,7 +11730,7 @@ var ExamResultV2 = function ExamResultV2(_ref) {
|
|
11184
11730
|
var label = _ref2.label,
|
11185
11731
|
value = _ref2.value;
|
11186
11732
|
return React.createElement(Button, {
|
11187
|
-
className:
|
11733
|
+
className: styles["truncate"],
|
11188
11734
|
disableTouchRipple: true,
|
11189
11735
|
sx: {
|
11190
11736
|
fontSize: "14px",
|
@@ -11197,14 +11743,14 @@ var ExamResultV2 = function ExamResultV2(_ref) {
|
|
11197
11743
|
return handleChangeTab(value);
|
11198
11744
|
}
|
11199
11745
|
}, label);
|
11200
|
-
})), React.createElement(Stack, {
|
11746
|
+
})), isTabletUp && React.createElement(Stack, {
|
11201
11747
|
padding: '12px 24px',
|
11202
11748
|
alignItems: "end",
|
11203
11749
|
bgcolor: "#F9FAFB"
|
11204
11750
|
}, React.createElement("div", {
|
11205
|
-
className: styles$
|
11751
|
+
className: styles$4["pdfBtnBox"]
|
11206
11752
|
}, React.createElement("button", {
|
11207
|
-
className: styles$
|
11753
|
+
className: styles$4["pdfBtn"] + " " + styles["truncate"],
|
11208
11754
|
onClick: handleExportPdf
|
11209
11755
|
}, React.createElement(iconPrintFill, null), React.createElement("p", null, t("print"))))))), React.createElement(Grid, {
|
11210
11756
|
item: true,
|
@@ -11220,18 +11766,18 @@ var ExamResultV2 = function ExamResultV2(_ref) {
|
|
11220
11766
|
value: selected,
|
11221
11767
|
index: 1
|
11222
11768
|
}, React.createElement("div", {
|
11223
|
-
className: styles$
|
11769
|
+
className: styles$4["compareChart"]
|
11224
11770
|
}, React.createElement("div", {
|
11225
|
-
className: styles$
|
11771
|
+
className: styles$4["prevChart"] + " " + (dataChartIndex > 0 && "pointer"),
|
11226
11772
|
onClick: handlePrevChart
|
11227
11773
|
}, React.createElement(iconBtnPrevChart, null)), React.createElement("div", {
|
11228
|
-
className: styles$
|
11774
|
+
className: styles$4["chart"] + " sr-line-chart"
|
11229
11775
|
}, React.createElement("div", null, React.createElement(ReactApexChart, {
|
11230
11776
|
height: 389,
|
11231
11777
|
options: chartOptions,
|
11232
11778
|
series: series
|
11233
11779
|
}))), React.createElement("div", {
|
11234
|
-
className: styles$
|
11780
|
+
className: styles$4["nextChart"] + " " + (dataChartIndex < timelyOrderQuestion.length - 1 && "pointer"),
|
11235
11781
|
onClick: handleNextChart
|
11236
11782
|
}, React.createElement(iconBtnNextChart, null)))), React.createElement(CustomTabPanel, {
|
11237
11783
|
value: selected,
|
@@ -11266,39 +11812,70 @@ var ExamResultV2 = function ExamResultV2(_ref) {
|
|
11266
11812
|
width: "100%"
|
11267
11813
|
},
|
11268
11814
|
id: "canvas"
|
11269
|
-
}, React.createElement(
|
11270
|
-
|
11271
|
-
|
11272
|
-
|
11815
|
+
}, React.createElement(Stack, {
|
11816
|
+
display: "flex",
|
11817
|
+
flexDirection: "column",
|
11818
|
+
gap: "12px"
|
11819
|
+
}, React.createElement(Typography, {
|
11820
|
+
sx: {
|
11821
|
+
fontSize: "16px",
|
11822
|
+
fontWeight: 700,
|
11823
|
+
color: "#414E62"
|
11824
|
+
}
|
11825
|
+
}, t(TabList[0].label)), React.createElement(MyAnswer, {
|
11273
11826
|
data: resultDatas,
|
11274
11827
|
categories: categoryResponses,
|
11275
11828
|
isStudent: isStudent
|
11276
|
-
})), React.createElement(
|
11277
|
-
|
11278
|
-
|
11279
|
-
|
11280
|
-
|
11829
|
+
})), React.createElement(Stack, {
|
11830
|
+
display: "flex",
|
11831
|
+
flexDirection: "column",
|
11832
|
+
gap: "12px",
|
11833
|
+
marginTop: "24px"
|
11834
|
+
}, React.createElement(Typography, {
|
11835
|
+
sx: {
|
11836
|
+
fontSize: "16px",
|
11837
|
+
fontWeight: 700,
|
11838
|
+
color: "#414E62"
|
11839
|
+
}
|
11840
|
+
}, t(TabList[1].label)), React.createElement("div", {
|
11841
|
+
className: styles$4["compareChart"]
|
11281
11842
|
}, React.createElement("div", {
|
11282
|
-
className: styles$
|
11843
|
+
className: styles$4["prevChart"] + " " + (dataChartIndex > 0 && "pointer"),
|
11283
11844
|
onClick: handlePrevChart
|
11284
11845
|
}, React.createElement(iconBtnPrevChart, null)), React.createElement("div", {
|
11285
|
-
className: styles$
|
11846
|
+
className: styles$4["chart"] + " sr-line-chart"
|
11286
11847
|
}, React.createElement("div", null, React.createElement(ReactApexChart, {
|
11287
11848
|
height: 389,
|
11288
11849
|
options: chartOptions,
|
11289
11850
|
series: series
|
11290
11851
|
}))), React.createElement("div", {
|
11291
|
-
className: styles$
|
11852
|
+
className: styles$4["nextChart"] + " " + (dataChartIndex < timelyOrderQuestion.length - 1 && "pointer"),
|
11292
11853
|
onClick: handleNextChart
|
11293
|
-
}, React.createElement(iconBtnNextChart, null)))), React.createElement(
|
11294
|
-
|
11295
|
-
|
11296
|
-
|
11854
|
+
}, React.createElement(iconBtnNextChart, null)))), React.createElement(Stack, {
|
11855
|
+
display: "flex",
|
11856
|
+
flexDirection: "column",
|
11857
|
+
gap: "12px",
|
11858
|
+
marginTop: "24px"
|
11859
|
+
}, React.createElement(Typography, {
|
11860
|
+
sx: {
|
11861
|
+
fontSize: "16px",
|
11862
|
+
fontWeight: 700,
|
11863
|
+
color: "#414E62"
|
11864
|
+
}
|
11865
|
+
}, t(TabList[2].label)), React.createElement(CompareGrass, {
|
11297
11866
|
effectSize: effectSize
|
11298
|
-
})), React.createElement(
|
11299
|
-
|
11300
|
-
|
11301
|
-
|
11867
|
+
})), React.createElement(Stack, {
|
11868
|
+
display: "flex",
|
11869
|
+
flexDirection: "column",
|
11870
|
+
gap: "12px",
|
11871
|
+
marginTop: "24px"
|
11872
|
+
}, React.createElement(Typography, {
|
11873
|
+
sx: {
|
11874
|
+
fontSize: "16px",
|
11875
|
+
fontWeight: 700,
|
11876
|
+
color: "#414E62"
|
11877
|
+
}
|
11878
|
+
}, t(TabList[3].label)), React.createElement(TrickyProblem, {
|
11302
11879
|
data: resultDatas,
|
11303
11880
|
openProblem: _extends({}, openProblem, {
|
11304
11881
|
problem1: true
|
@@ -11364,5 +11941,100 @@ var times = {
|
|
11364
11941
|
timeSpanToLocalMoment: timeSpanToLocalMoment
|
11365
11942
|
};
|
11366
11943
|
|
11367
|
-
|
11944
|
+
var Header = function Header(_ref) {
|
11945
|
+
var academyListRoute = _ref.academyListRoute,
|
11946
|
+
homeRoute = _ref.homeRoute,
|
11947
|
+
headerTabs = _ref.headerTabs,
|
11948
|
+
role = _ref.role,
|
11949
|
+
navigate = _ref.navigate,
|
11950
|
+
onSignOut = _ref.onSignOut;
|
11951
|
+
var _useTranslation = useTranslation(),
|
11952
|
+
t = _useTranslation.t;
|
11953
|
+
var location = useLocation();
|
11954
|
+
var theme = useTheme();
|
11955
|
+
var user = useSelector(function (state) {
|
11956
|
+
var _state$common;
|
11957
|
+
return state === null || state === void 0 ? void 0 : (_state$common = state.common) === null || _state$common === void 0 ? void 0 : _state$common.user;
|
11958
|
+
});
|
11959
|
+
var isLargerThanXL = useMediaQuery(theme.breakpoints.up("xl"));
|
11960
|
+
var academyDomain = useSelector(function (state) {
|
11961
|
+
var _state$common2, _state$common2$user;
|
11962
|
+
return state === null || state === void 0 ? void 0 : (_state$common2 = state.common) === null || _state$common2 === void 0 ? void 0 : (_state$common2$user = _state$common2.user) === null || _state$common2$user === void 0 ? void 0 : _state$common2$user.academyDomain;
|
11963
|
+
});
|
11964
|
+
var pathname = location.pathname.toLowerCase();
|
11965
|
+
return React.createElement("div", {
|
11966
|
+
className: "col-sm-12 col-xl-12 " + styles["tabBox"] + " " + styles["headers"]
|
11967
|
+
}, React.createElement(Link, {
|
11968
|
+
"aria-current": "page",
|
11969
|
+
to: homeRoute.path,
|
11970
|
+
className: "border-none " + styles["logo-container"]
|
11971
|
+
}, React.createElement("img", {
|
11972
|
+
className: styles["logo"] + " d-none d-lg-block",
|
11973
|
+
src: "",
|
11974
|
+
alt: ""
|
11975
|
+
}), React.createElement("img", {
|
11976
|
+
className: styles["logo"] + " d-block d-lg-none",
|
11977
|
+
src: "/images/logo-sm.png",
|
11978
|
+
alt: ""
|
11979
|
+
})), React.createElement("div", {
|
11980
|
+
className: styles["routerBox"] + " d-flex flex-grow-1 flex-nowrap px-3"
|
11981
|
+
}, headerTabs.map(function (_ref2) {
|
11982
|
+
var path = _ref2.path,
|
11983
|
+
icon = _ref2.icon,
|
11984
|
+
label = _ref2.label,
|
11985
|
+
isMain = _ref2.isMain,
|
11986
|
+
activePaths = _ref2.activePaths;
|
11987
|
+
return React.createElement(Link, {
|
11988
|
+
key: path,
|
11989
|
+
"aria-current": "page",
|
11990
|
+
to: !academyDomain && !isMain ? "#" : path,
|
11991
|
+
className: "text-decoration-none " + ((activePaths !== null && activePaths !== void 0 && activePaths.length ? activePaths.some(function (a) {
|
11992
|
+
return pathname.startsWith(a);
|
11993
|
+
}) : pathname.startsWith(path)) ? styles["router-link-active"] + " " + styles["router-link-exact-active"] : "") + " " + styles["tabText"] + " " + (!academyDomain && !isMain ? styles["disabled-link"] : "")
|
11994
|
+
}, React.createElement(Stack, {
|
11995
|
+
sx: {
|
11996
|
+
justifyContent: "center",
|
11997
|
+
flexDirection: "row",
|
11998
|
+
alignItems: "center",
|
11999
|
+
textOverflow: "ellipsis",
|
12000
|
+
overflow: "hidden",
|
12001
|
+
display: "flex",
|
12002
|
+
flexWrap: "nowrap"
|
12003
|
+
}
|
12004
|
+
}, icon, React.createElement("span", {
|
12005
|
+
className: "text-nowrap"
|
12006
|
+
}, isLargerThanXL || headerTabs.length < 4 ? t(label) : ellipsisText(t(label), 4))));
|
12007
|
+
})), React.createElement(Stack, {
|
12008
|
+
direction: "row",
|
12009
|
+
alignItems: "center"
|
12010
|
+
}, React.createElement(Typography, {
|
12011
|
+
className: "fw-bold text-primary me-2 text-nowrap",
|
12012
|
+
sx: {
|
12013
|
+
maxWidth: "120px",
|
12014
|
+
overflow: "hidden",
|
12015
|
+
textOverflow: "ellipsis"
|
12016
|
+
}
|
12017
|
+
}, user === null || user === void 0 ? void 0 : user.fullName), React.createElement("div", null, React.createElement(TheAcademyDropdown, {
|
12018
|
+
homeAcademyUrl: academyListRoute.path,
|
12019
|
+
homeUrl: homeRoute.path,
|
12020
|
+
role: role,
|
12021
|
+
navigate: navigate,
|
12022
|
+
hideAcademyName: !isLargerThanXL && headerTabs.length > 6
|
12023
|
+
})), React.createElement("div", {
|
12024
|
+
className: "me-2"
|
12025
|
+
}, React.createElement(TheLanguageDropdown, null)), React.createElement("div", {
|
12026
|
+
className: styles["userImg"] + " d-none d-md-none d-lg-block",
|
12027
|
+
onClick: onSignOut
|
12028
|
+
}, React.createElement("p", {
|
12029
|
+
className: "text-nowrap mb-0"
|
12030
|
+
}, t("logout"))), React.createElement("div", {
|
12031
|
+
className: styles["userImg"] + " d-block d-md-block d-lg-none",
|
12032
|
+
onClick: onSignOut
|
12033
|
+
}, React.createElement(IoIosLogOut, {
|
12034
|
+
size: 24,
|
12035
|
+
color: "#959595"
|
12036
|
+
}))));
|
12037
|
+
};
|
12038
|
+
|
12039
|
+
export { ACADEMY_DOMAIN, ACCESS_TOKEN, AcademyHeaders, AnswerCountSelector, ArticleCategorySelector, ArticleGroupView, BASE_URL, ChatContainer, ChatItemType, types as ChatTypes, CommonDialog, ConfirmDialog, index$1 as CoreHooks, CustomAsyncSelect, CustomCreatable, CustomPagination, CustomSelect, CustomSelectOption, DATE_MIN_VALUE, DATE_TIME_MIN_VALUE, EXAM_CHANNEL, EXAM_STUDENT_CHANNEL, index as Enums, ExamDetailView, ExamEvent, ExamResultV2, Header, InputText, LANGUAGES, LayoutContext, Loading, Login, NotFound, PUSHER_CONFIG, QuestionCountSelector, Role, SUPER_ADMIN_BASE_URL, ScoreSelector, SubjectSelector, index$2 as Textbook, TextbookViewDetail as TextbookDetail, TextbookList, TheAcademyDropdown, TheLanguageDropdown, index$3 as Types, api, apiUpload, canAccess as canAccessRoute, diffFromNow, formatTime, getAcademyDomain, getAccessToken$1 as getAccessToken, i18n, minutesToTimeSpan, setAlert, setLanguage, setLoading, setReFetchUserAcademies, setReadyRegisterPusher, setUser, store, times as timeUtils, toISOString, useAutoAcademyDomain, useCategorySelect, useChatContainer, useGoogleSignOut, useLanguage, useLogin, usePusherConversation, useSubjectSelect, useSwitchAcademy, utcToLocalTime };
|
11368
12040
|
//# sourceMappingURL=index.modern.js.map
|