| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193 |
- import React, {
- FC, useState, useCallback,
- } from 'react';
- import { useTranslation } from 'react-i18next';
- import UserGroupForm from '../UserGroup/UserGroupForm';
- import UserGroupTable from '../UserGroup/UserGroupTable';
- import UserGroupDropdown from '../UserGroup/UserGroupDropdown';
- import UserGroupUserTable from './UserGroupUserTable';
- import UserGroupUserModal from './UserGroupUserModal';
- import UserGroupPageList from './UserGroupPageList';
- import { withUnstatedContainers } from '../../UnstatedUtils';
- import AppContainer from '~/client/services/AppContainer';
- import {
- apiv3Get, apiv3Put, apiv3Delete, apiv3Post,
- } from '~/client/util/apiv3-client';
- import { toastSuccess, toastError } from '~/client/util/apiNotification';
- import { IPageHasId } from '~/interfaces/page';
- import {
- IUserGroup, IUserGroupHasId, IUserGroupRelation,
- } from '~/interfaces/user';
- import {
- useSWRxUserGroupPages, useSWRxUserGroupRelations, useSWRxChildUserGroupList, useSWRxSelectableUserGroups,
- } from '~/stores/user-group';
- type Props = {
- appContainer: AppContainer,
- };
- const UserGroupDetailPage: FC<Props> = (props: Props) => {
- const rootElem = document.getElementById('admin-user-group-detail');
- const { t } = useTranslation();
- /*
- * State (from AdminUserGroupDetailContainer)
- */
- const [userGroup, setUserGroup] = useState<IUserGroupHasId>(JSON.parse(rootElem?.getAttribute('data-user-group') || 'null'));
- const [grandChildUserGroups, setGrandChildUserGroups] = useState<IUserGroupHasId[]>([]); // TODO 85062: fetch data on init (findChildGroupsByParentIds) For child group list
- const [childUserGroupRelations, setChildUserGroupRelations] = useState<IUserGroupRelation[]>([]); // TODO 85062: fetch data on init (findRelationsByGroupIds) For child group list
- const [relatedPages, setRelatedPages] = useState<IPageHasId[]>([]); // For page list
- const [isUserGroupUserModalOpen, setUserGroupUserModalOpen] = useState<boolean>(false);
- const [searchType, setSearchType] = useState<string>('partial');
- const [isAlsoMailSearched, setAlsoMailSearched] = useState<boolean>(false);
- const [isAlsoNameSearched, setAlsoNameSearched] = useState<boolean>(false);
- /*
- * Fetch
- */
- const { data: userGroupPages } = useSWRxUserGroupPages(userGroup._id, 10, 0);
- const { data: userGroupRelations, mutate: mutateUserGroupRelations } = useSWRxUserGroupRelations(userGroup._id);
- const { data: childUserGroups, mutate: mutateChildUserGroups } = useSWRxChildUserGroupList([userGroup._id], false);
- const { data: selectableUserGroups, mutate: mutateSelectableUserGroups } = useSWRxSelectableUserGroups(userGroup._id);
- /*
- * Function
- */
- // TODO 85062: old name: switchIsAlsoMailSearched
- const toggleIsAlsoMailSearched = useCallback(() => {
- setAlsoMailSearched(prev => !prev);
- }, []);
- // TODO 85062: old name: switchIsAlsoNameSearched
- const toggleAlsoNameSearched = useCallback(() => {
- setAlsoNameSearched(prev => !prev);
- }, []);
- const switchSearchType = useCallback((searchType) => {
- setSearchType(searchType);
- }, []);
- const updateUserGroup = useCallback(async(param: Partial<IUserGroup>) => {
- const res = await apiv3Put<{ userGroup: IUserGroupHasId }>(`/user-groups/${userGroup._id}`, param);
- const { userGroup: newUserGroup } = res.data;
- setUserGroup(newUserGroup);
- return newUserGroup;
- }, [userGroup]);
- const openUserGroupUserModal = useCallback(() => {
- setUserGroupUserModalOpen(true);
- }, []);
- const closeUserGroupUserModal = useCallback(() => {
- setUserGroupUserModalOpen(false);
- }, []);
- const fetchApplicableUsers = useCallback(async(searchWord) => {
- const res = await apiv3Get(`/user-groups/${userGroup._id}/unrelated-users`, {
- searchWord,
- searchType,
- isAlsoMailSearched,
- isAlsoNameSearched,
- });
- const { users } = res.data;
- return users;
- }, [searchType, isAlsoMailSearched, isAlsoNameSearched]);
- // TODO 85062: will be used in UserGroupUserFormByInput
- const addUserByUsername = useCallback(async(username: string) => {
- await apiv3Post(`/user-groups/${userGroup._id}/users/${username}`);
- mutateUserGroupRelations();
- }, [userGroup, mutateUserGroupRelations]);
- const removeUserByUsername = useCallback(async(username: string) => {
- await apiv3Delete(`/user-groups/${userGroup._id}/users/${username}`);
- mutateUserGroupRelations();
- }, [userGroup, mutateUserGroupRelations]);
- const onClickAddChildButtonHandler = async(selectedUserGroup: IUserGroupHasId) => {
- try {
- await apiv3Put(`/user-groups/${selectedUserGroup._id}`, {
- name: selectedUserGroup.name,
- description: selectedUserGroup.description,
- parentId: userGroup._id,
- forceUpdateParents: true, // TODO 87748: Make forceUpdateParents optionally selectable
- });
- mutateSelectableUserGroups();
- mutateChildUserGroups();
- toastSuccess(t('toaster.update_successed', { target: t('UserGroup') }));
- }
- catch (err) {
- toastError(err);
- }
- };
- // TODO 87614: UserGroup New creation form can be displayed in modal
- const onClickCreateChildGroupButtonHandler = () => {
- console.log('button clicked!');
- };
- /*
- * Dependencies
- */
- if (userGroup == null) {
- return <></>;
- }
- return (
- <div>
- <a href="/admin/user-groups" className="btn btn-outline-secondary">
- <i className="icon-fw ti-arrow-left" aria-hidden="true"></i>
- {t('admin:user_group_management.back_to_list')}
- </a>
- {/* TODO 85062: Link to the ancestors group */}
- <div className="mt-4 form-box">
- <UserGroupForm
- userGroup={userGroup}
- successedMessage={t('toaster.update_successed', { target: t('UserGroup') })}
- failedMessage={t('toaster.update_failed', { target: t('UserGroup') })}
- submitButtonLabel={t('Update')}
- onSubmit={updateUserGroup}
- />
- </div>
- <h2 className="admin-setting-header mt-4">{t('admin:user_group_management.user_list')}</h2>
- <UserGroupUserTable />
- <UserGroupUserModal />
- <h2 className="admin-setting-header mt-4">{t('admin:user_group_management.child_group_list')}</h2>
- <UserGroupDropdown
- selectableUserGroups={selectableUserGroups}
- onClickAddExistingUserGroupButtonHandler={onClickAddChildButtonHandler}
- onClickCreateUserGroupButtonHandler={() => onClickCreateChildGroupButtonHandler()}
- />
- {/* <UserGroupTable
- appContainer={props.appContainer}
- userGroups={userGroups}
- childUserGroups={childUserGroups}
- isAclEnabled={isAclEnabled}
- onDelete={showDeleteModal}
- userGroupRelations={userGroupRelations}
- /> */}
- <h2 className="admin-setting-header mt-4">{t('Page')}</h2>
- <div className="page-list">
- <UserGroupPageList />
- </div>
- </div>
- );
- };
- /**
- * Wrapper component for using unstated
- */
- const UserGroupDetailPageWrapper = withUnstatedContainers(UserGroupDetailPage, [AppContainer]);
- export default UserGroupDetailPageWrapper;
|