touchstudy-core 0.1.14 → 0.1.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/dist/assets/iconChatBubble.d.ts +3 -0
  2. package/dist/assets/iconChecked.d.ts +3 -0
  3. package/dist/assets/iconPersonActive.d.ts +3 -0
  4. package/dist/assets/iconPersonNoActive.d.ts +3 -0
  5. package/dist/assets/iconSendMessenger.d.ts +4 -0
  6. package/dist/components/Chats/ChatContainer.d.ts +0 -1
  7. package/dist/components/Chats/ChatHeader.d.ts +9 -6
  8. package/dist/components/Chats/ChatItem.d.ts +6 -21
  9. package/dist/components/Chats/ChatList.d.ts +1 -2
  10. package/dist/components/Chats/ChatRightItem.d.ts +1 -5
  11. package/dist/components/Chats/InputChat.d.ts +6 -3
  12. package/dist/components/Chats/apiClient/conversationService.d.ts +2 -0
  13. package/dist/components/Chats/configs/constants.d.ts +5 -0
  14. package/dist/components/Chats/configs/types.d.ts +79 -15
  15. package/dist/components/Chats/hooks/useChatContainer.d.ts +20 -25
  16. package/dist/components/Chats/hooks/useDialog.d.ts +6 -0
  17. package/dist/components/Chats/hooks/useMessageList.d.ts +3 -5
  18. package/dist/containers/Login/apiClient/index.d.ts +0 -1
  19. package/dist/containers/Login/views/Login.d.ts +3 -0
  20. package/dist/containers/Login/views/block/BlockLogin.d.ts +3 -0
  21. package/dist/index.css +349 -0
  22. package/dist/index.d.ts +12 -8
  23. package/dist/index.js +1614 -1225
  24. package/dist/index.js.map +1 -1
  25. package/dist/index.modern.js +1593 -1214
  26. package/dist/index.modern.js.map +1 -1
  27. package/dist/layouts/TheAcademyDropdown.d.ts +10 -0
  28. package/dist/redux/commons/action.d.ts +1 -0
  29. package/dist/services/academyService.d.ts +3 -0
  30. package/dist/services/accountService.d.ts +5 -0
  31. package/dist/utils/constants.d.ts +11 -7
  32. package/dist/utils/hooks/index.d.ts +3 -0
  33. package/dist/utils/hooks/useAutoAcademyDomain.d.ts +2 -0
  34. package/dist/utils/{useGoogleSignOut.d.ts → hooks/useGoogleSignOut.d.ts} +1 -1
  35. package/dist/utils/{useLanguage.d.ts → hooks/useLanguage.d.ts} +1 -1
  36. package/dist/utils/hooks/useLogin.d.ts +7 -0
  37. package/dist/utils/hooks/useSwitchAcademy.d.ts +10 -0
  38. package/dist/utils/types/academy.d.ts +6 -0
  39. package/dist/utils/types/login.d.ts +33 -0
  40. package/package.json +2 -1
  41. package/dist/components/Chats/hooks/useConversationList.d.ts +0 -20
  42. package/dist/components/Chats/hooks/useExamList.d.ts +0 -6
@@ -0,0 +1,10 @@
1
+ import { FC } from "react";
2
+ import { Role } from "../containers/Login/configs/constants";
3
+ interface ITheAcademyDropdownProps {
4
+ role?: Role;
5
+ navigate: (pathname: string) => void;
6
+ homeAcademyUrl: string;
7
+ homeUrl: string;
8
+ }
9
+ declare const TheAcademyDropdown: FC<ITheAcademyDropdownProps>;
10
+ export default TheAcademyDropdown;
@@ -3,3 +3,4 @@ export declare const setAlert: import("@reduxjs/toolkit").ActionCreatorWithPaylo
3
3
  export declare const setUser: import("@reduxjs/toolkit").ActionCreatorWithPayload<any, string>;
4
4
  export declare const setLanguage: import("@reduxjs/toolkit").ActionCreatorWithPayload<string, string>;
5
5
  export declare const reset: import("@reduxjs/toolkit").ActionCreatorWithOptionalPayload<undefined, string>;
6
+ export declare const setReFetchUserAcademies: import("@reduxjs/toolkit").ActionCreatorWithPayload<boolean, string>;
@@ -0,0 +1,3 @@
1
+ export declare const getAcademyList: (role?: string | undefined) => Promise<import("axios").AxiosResponse<any, any>>;
2
+ export declare const getUserAcademies: (role?: string | undefined) => Promise<import("axios").AxiosResponse<any, any>>;
3
+ export declare const switchAcademy: (academyId: number) => Promise<import("axios").AxiosResponse<any, any>>;
@@ -1 +1,6 @@
1
+ import { LoginAccessTokenRequest, LoginRequest } from "../utils/types/login";
1
2
  export declare const getInfo: () => Promise<import("axios").AxiosResponse<any, any>>;
3
+ export declare const getSuperAdminInfoFromWeb: () => Promise<import("axios").AxiosResponse<any, any>>;
4
+ export declare const apiLoginGoogle: (body: LoginRequest) => Promise<import("axios").AxiosResponse<any, any>>;
5
+ export declare const apiLoginGoogleSuperAdmin: (body: LoginRequest) => Promise<import("axios").AxiosResponse<any, any>>;
6
+ export declare const apiLoginWithAccessToken: (body: LoginAccessTokenRequest, domain?: string | undefined) => Promise<import("axios").AxiosResponse<any, any>>;
@@ -1,16 +1,20 @@
1
- export declare const GOOGLE_RECAPTCHA_KEY = "6LfNtLUaAAAAAL24lbBV11jS-gBtt1mhtxb4NXs0";
2
- export declare const GOOGLE_CLIENT_ID = "64118819726-0qlur4qjrs9jbuu6rnoa0u91g680lmpg.apps.googleusercontent.com";
3
- export declare const GOOGLE_RECAPTCHA_ID = "6LfNtLUaAAAAAL24lbBV11jS-gBtt1mhtxb4NXs0";
4
- export declare const GOOGLE_RECAPTCHA_SECRET = "6LfNtLUaAAAAAC7zhleGzO61FgFwGF0H5FAsKYux";
5
- export declare const ACCESS_TOKEN = "ACCESS_TOKEN";
6
- export declare const DATE_MIN_VALUE = "0001-01-01T00:00:00+00:00";
7
- export declare const DATE_TIME_MIN_VALUE = "0001-01-01T00:00:00";
1
+ export declare const GOOGLE_RECAPTCHA_KEY: string;
2
+ export declare const GOOGLE_CLIENT_ID: string;
3
+ export declare const GOOGLE_RECAPTCHA_ID: string;
4
+ export declare const GOOGLE_RECAPTCHA_SECRET: string;
8
5
  export declare const BASE_URL: string;
6
+ export declare const SUPER_ADMIN_BASE_URL: string;
9
7
  export declare const PUSHER_CONFIG: {
10
8
  cluster: string;
11
9
  key: string;
12
10
  };
11
+ export declare const ACCESS_TOKEN = "ACCESS_TOKEN";
12
+ export declare const ACADEMY_DOMAIN = "ACADEMY_DOMAIN";
13
+ export declare const AcademyHeaders = "Academy-Headers";
14
+ export declare const DATE_MIN_VALUE = "0001-01-01T00:00:00+00:00";
15
+ export declare const DATE_TIME_MIN_VALUE = "0001-01-01T00:00:00";
13
16
  export declare const EXAM_CHANNEL = "presence-exam-channel";
14
17
  export declare const EXAM_STUDENT_CHANNEL = "EXAM-CHANNEL-{examCode}-STUDENT-{studentId}";
15
18
  export declare const getAccessToken: () => string | null;
19
+ export declare const getAcademyDomain: () => string | null;
16
20
  export declare const encodeParams: (params: any) => string;
@@ -0,0 +1,3 @@
1
+ import useAutoAcademyDomain from "./useAutoAcademyDomain";
2
+ import useLogin from "./useLogin";
3
+ export { useLogin, useAutoAcademyDomain };
@@ -0,0 +1,2 @@
1
+ declare const useAutoAcademyDomain: (logout: Function, history: any, superUrls: string[], homeUrl: string, homeAcademyUrl: string) => void;
2
+ export default useAutoAcademyDomain;
@@ -4,7 +4,7 @@ interface Props {
4
4
  onNavigate: Function;
5
5
  }
6
6
  declare const useGoogleSignOut: (props: Props) => {
7
- handleSignOut: () => void;
7
+ handleSignOut: (isRemoveDomainStorage?: boolean) => void;
8
8
  loaded: boolean;
9
9
  };
10
10
  export default useGoogleSignOut;
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { Language } from "../configs/constants";
2
+ import { Language } from "../../configs/constants";
3
3
  import "moment/locale/ko.js";
4
4
  import "moment/locale/en-au.js";
5
5
  declare const useLanguage: () => {
@@ -0,0 +1,7 @@
1
+ import { LoginAccessTokenRequest, LoginRequest } from "../types/login";
2
+ declare const useLogin: (onNavigate: (pathname: string) => void, homeAcademyUrl: string, homeUrl: string, registerUrl?: string | undefined) => {
3
+ handleLoginGoogle: (data: LoginRequest, isLogout?: boolean) => Promise<void>;
4
+ handleLoginAccessToken: (data: LoginAccessTokenRequest, isLogout?: boolean, domain?: string | undefined) => Promise<void>;
5
+ redirectLoginUser: (data: any, token: string, redirectUrl?: string | undefined) => void;
6
+ };
7
+ export default useLogin;
@@ -0,0 +1,10 @@
1
+ import { AcademyResponse } from "../types/academy";
2
+ import { Role } from "../../containers/Login/configs/constants";
3
+ declare const useSwitchAcademy: (role: Role | undefined, navigate: (pathname: string) => void, homeAcademyUrl: string, homeUrl: string) => {
4
+ selectedAcademy: AcademyResponse | undefined;
5
+ dropdownOpen: boolean;
6
+ academyList: AcademyResponse[];
7
+ toggleDropdown: () => void;
8
+ handleSwitchAcademy: (selectedAcademy?: AcademyResponse | undefined, isLoading?: boolean) => Promise<void>;
9
+ };
10
+ export default useSwitchAcademy;
@@ -0,0 +1,6 @@
1
+ export declare type AcademyResponse = {
2
+ id: number;
3
+ name: string;
4
+ image: string;
5
+ domain: string;
6
+ };
@@ -0,0 +1,33 @@
1
+ export declare type LoginRequest = {
2
+ imageUrl: string;
3
+ fullName: string;
4
+ email: string;
5
+ token: string;
6
+ googleId: string;
7
+ role: string;
8
+ };
9
+ export declare type LoginAccessTokenRequest = {
10
+ accessToken: string;
11
+ email: string;
12
+ academyId?: number;
13
+ role: string;
14
+ };
15
+ export declare type LoginResponse = {
16
+ token: string;
17
+ isFirstLogin: boolean;
18
+ user: UserResponse;
19
+ };
20
+ export declare type UserResponse = {
21
+ id: number;
22
+ phoneNumber?: string;
23
+ email: string;
24
+ avatar: string;
25
+ fulName: string;
26
+ className: string;
27
+ parentPhoneNumber: string;
28
+ parentName: string;
29
+ major: string;
30
+ schoolName: string;
31
+ academyDomain?: string;
32
+ roles: string[];
33
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "touchstudy-core",
3
- "version": "0.1.14",
3
+ "version": "0.1.16",
4
4
  "description": "Contains core components && functions for TouchStudy project",
5
5
  "author": "brss",
6
6
  "license": "MIT",
@@ -13,6 +13,7 @@
13
13
  },
14
14
  "dependencies": {
15
15
  "@leecheuk/react-google-login": "^5.4.1",
16
+ "@mui/material": "^5.14.12",
16
17
  "@reduxjs/toolkit": "^2.0.1",
17
18
  "axios": "^1.6.2",
18
19
  "formik": "^2.4.5",
@@ -1,20 +0,0 @@
1
- import { ChangeEvent } from "react";
2
- import { ConversationFilter, ConversationResponse, MessageResponse } from "../configs/types";
3
- declare const useConversationList: () => {
4
- isStudent: any;
5
- conversationFilter: ConversationFilter;
6
- selectedConversation: ConversationResponse | undefined;
7
- conversations: ConversationResponse[];
8
- handleUpdateTotalUnreadMessage: () => void;
9
- handleChangeFilter: (filter: ConversationFilter) => void;
10
- handleChangeSelectedConversation: (val: ConversationResponse) => void;
11
- handleChangeTextSearch: (e: ChangeEvent<HTMLInputElement>) => void;
12
- setSelectedConversation: import("react").Dispatch<import("react").SetStateAction<ConversationResponse | undefined>>;
13
- handleUpdateLastMessage: (lastMessage: MessageResponse) => void;
14
- getConversationList: () => Promise<void>;
15
- formatConversationLastMessageContent: (conversation: ConversationResponse) => string;
16
- handleNewMessageConversation: (val: ConversationResponse) => void;
17
- handleCreateConversationSuccess: (id: number) => Promise<void>;
18
- handleMessageReadConversation: (id: number, totalUnread: number) => void;
19
- };
20
- export default useConversationList;
@@ -1,6 +0,0 @@
1
- import { ExamResponse } from "../configs/types";
2
- declare const useExamList: (isStudent?: boolean) => {
3
- getListExam: (userId?: number | undefined) => Promise<void>;
4
- exams: ExamResponse[] | undefined;
5
- };
6
- export default useExamList;