|
|
@@ -1,22 +1,11 @@
|
|
|
-import React, { useState, useCallback } from 'react';
|
|
|
+import React from 'react';
|
|
|
|
|
|
import { UserPicture } from '@growi/ui';
|
|
|
import { useTranslation } from 'react-i18next';
|
|
|
-import { UncontrolledTooltip } from 'reactstrap';
|
|
|
|
|
|
-import { useUserUISettings } from '~/client/services/user-ui-settings';
|
|
|
import { toastError } from '~/client/util/apiNotification';
|
|
|
import { apiv3Post } from '~/client/util/apiv3-client';
|
|
|
-import {
|
|
|
- isUserPreferenceExists,
|
|
|
- isDarkMode as isDarkModeByUtil,
|
|
|
- applyColorScheme,
|
|
|
- removeUserPreference,
|
|
|
- updateUserPreference,
|
|
|
- updateUserPreferenceWithOsSettings,
|
|
|
-} from '~/client/util/color-scheme';
|
|
|
import { useCurrentUser } from '~/stores/context';
|
|
|
-import { usePreferDrawerModeByUser, usePreferDrawerModeOnEditByUser } from '~/stores/ui';
|
|
|
|
|
|
const PersonalDropdown = () => {
|
|
|
const { t } = useTranslation();
|
|
|
@@ -24,13 +13,6 @@ const PersonalDropdown = () => {
|
|
|
|
|
|
const user = currentUser || {};
|
|
|
|
|
|
- // const [useOsSettings, setOsSettings] = useState(!isUserPreferenceExists());
|
|
|
- // const [isDarkMode, setIsDarkMode] = useState(isDarkModeByUtil());
|
|
|
-
|
|
|
- // const { data: isPreferDrawerMode, mutate: mutatePreferDrawerMode } = usePreferDrawerModeByUser();
|
|
|
- // const { data: isPreferDrawerModeOnEdit, mutate: mutatePreferDrawerModeOnEdit } = usePreferDrawerModeOnEditByUser();
|
|
|
- // const { scheduleToPut } = useUserUISettings();
|
|
|
-
|
|
|
const logoutHandler = async() => {
|
|
|
try {
|
|
|
await apiv3Post('/logout');
|
|
|
@@ -41,50 +23,6 @@ const PersonalDropdown = () => {
|
|
|
}
|
|
|
};
|
|
|
|
|
|
- // const preferDrawerModeSwitchModifiedHandler = useCallback((bool) => {
|
|
|
- // mutatePreferDrawerMode(bool);
|
|
|
- // scheduleToPut({ preferDrawerModeByUser: bool });
|
|
|
- // }, [mutatePreferDrawerMode, scheduleToPut]);
|
|
|
-
|
|
|
- // const preferDrawerModeOnEditSwitchModifiedHandler = useCallback((bool) => {
|
|
|
- // mutatePreferDrawerModeOnEdit(bool);
|
|
|
- // scheduleToPut({ preferDrawerModeOnEditByUser: bool });
|
|
|
- // }, [mutatePreferDrawerModeOnEdit, scheduleToPut]);
|
|
|
-
|
|
|
- // const followOsCheckboxModifiedHandler = (bool) => {
|
|
|
- // if (bool) {
|
|
|
- // removeUserPreference();
|
|
|
- // }
|
|
|
- // else {
|
|
|
- // updateUserPreferenceWithOsSettings();
|
|
|
- // }
|
|
|
- // applyColorScheme();
|
|
|
-
|
|
|
- // // update states
|
|
|
- // setOsSettings(bool);
|
|
|
- // setIsDarkMode(isDarkModeByUtil());
|
|
|
- // };
|
|
|
-
|
|
|
- // const userPreferenceSwitchModifiedHandler = (bool) => {
|
|
|
- // updateUserPreference(bool);
|
|
|
- // applyColorScheme();
|
|
|
-
|
|
|
- // // update state
|
|
|
- // setIsDarkMode(isDarkModeByUtil());
|
|
|
- // };
|
|
|
-
|
|
|
-
|
|
|
- // /* eslint-disable react/prop-types */
|
|
|
- // const IconWithTooltip = ({
|
|
|
- // id, label, children, additionalClasses,
|
|
|
- // }) => (
|
|
|
- // <>
|
|
|
- // <div id={id} className={`px-2 grw-icon-container ${additionalClasses != null ? additionalClasses : ''}`}>{children}</div>
|
|
|
- // <UncontrolledTooltip placement="bottom" fade={false} target={id}>{label}</UncontrolledTooltip>
|
|
|
- // </>
|
|
|
- // );
|
|
|
- // /* eslint-enable react/prop-types */
|
|
|
-
|
|
|
return (
|
|
|
<>
|
|
|
{/* Button */}
|
|
|
@@ -121,98 +59,6 @@ const PersonalDropdown = () => {
|
|
|
|
|
|
<div className="dropdown-divider"></div>
|
|
|
|
|
|
- {/* Sidebar Mode */}
|
|
|
- {/* <h6 className="dropdown-header">{t('personal_dropdown.sidebar_mode')}</h6>
|
|
|
- <form className="px-4">
|
|
|
- <div className="form-row justify-content-center">
|
|
|
- <div className="form-group col-auto mb-0 d-flex align-items-center">
|
|
|
- <IconWithTooltip id="iwt-sidebar-drawer" label="Drawer">
|
|
|
- <SidebarDrawerIcon />
|
|
|
- </IconWithTooltip>
|
|
|
- <div className="custom-control custom-switch custom-checkbox-secondary ml-2">
|
|
|
- <input
|
|
|
- id="swSidebarMode"
|
|
|
- className="custom-control-input"
|
|
|
- type="checkbox"
|
|
|
- checked={!isPreferDrawerMode}
|
|
|
- onChange={e => preferDrawerModeSwitchModifiedHandler(!e.target.checked)}
|
|
|
- />
|
|
|
- <label className="custom-control-label" htmlFor="swSidebarMode"></label>
|
|
|
- </div>
|
|
|
- <IconWithTooltip id="iwt-sidebar-dock" label="Dock">
|
|
|
- <SidebarDockIcon />
|
|
|
- </IconWithTooltip>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </form> */}
|
|
|
-
|
|
|
- {/* Sidebar Mode on Editor */}
|
|
|
- {/* <h6 className="dropdown-header">{t('personal_dropdown.sidebar_mode_editor')}</h6>
|
|
|
- <form className="px-4">
|
|
|
- <div className="form-row justify-content-center">
|
|
|
- <div className="form-group col-auto mb-0 d-flex align-items-center">
|
|
|
- <IconWithTooltip id="iwt-sidebar-editor-drawer" label="Drawer">
|
|
|
- <SidebarDrawerIcon />
|
|
|
- </IconWithTooltip>
|
|
|
- <div className="custom-control custom-switch custom-checkbox-secondary ml-2">
|
|
|
- <input
|
|
|
- id="swSidebarModeOnEditor"
|
|
|
- className="custom-control-input"
|
|
|
- type="checkbox"
|
|
|
- checked={!isPreferDrawerModeOnEdit}
|
|
|
- onChange={e => preferDrawerModeOnEditSwitchModifiedHandler(!e.target.checked)}
|
|
|
- />
|
|
|
- <label className="custom-control-label" htmlFor="swSidebarModeOnEditor"></label>
|
|
|
- </div>
|
|
|
- <IconWithTooltip id="iwt-sidebar-editor-dock" label="Dock">
|
|
|
- <SidebarDockIcon />
|
|
|
- </IconWithTooltip>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </form> */}
|
|
|
-
|
|
|
- {/* <div className="dropdown-divider"></div> */}
|
|
|
-
|
|
|
- {/* Color Mode */}
|
|
|
- {/* <h6 className="dropdown-header">{t('personal_dropdown.color_mode')}</h6>
|
|
|
- <form className="px-4">
|
|
|
- <div className="form-row">
|
|
|
- <div className="form-group col-auto">
|
|
|
- <div className="custom-control custom-checkbox">
|
|
|
- <input
|
|
|
- id="cbFollowOs"
|
|
|
- className="custom-control-input"
|
|
|
- type="checkbox"
|
|
|
- checked={useOsSettings}
|
|
|
- onChange={e => followOsCheckboxModifiedHandler(e.target.checked)}
|
|
|
- />
|
|
|
- <label className="custom-control-label text-nowrap" htmlFor="cbFollowOs">{t('personal_dropdown.use_os_settings')}</label>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div className="form-row justify-content-center">
|
|
|
- <div className="form-group col-auto mb-0 d-flex align-items-center">
|
|
|
- <IconWithTooltip id="iwt-light" label="Light" additionalClasses={useOsSettings ? 'grw-icon-container-muted' : ''}>
|
|
|
- <SunIcon />
|
|
|
- </IconWithTooltip>
|
|
|
- <div className="custom-control custom-switch custom-checkbox-secondary ml-2">
|
|
|
- <input
|
|
|
- id="swUserPreference"
|
|
|
- className="custom-control-input"
|
|
|
- type="checkbox"
|
|
|
- checked={isDarkMode}
|
|
|
- disabled={useOsSettings}
|
|
|
- onChange={e => userPreferenceSwitchModifiedHandler(e.target.checked)}
|
|
|
- />
|
|
|
- <label className="custom-control-label" htmlFor="swUserPreference"></label>
|
|
|
- </div>
|
|
|
- <IconWithTooltip id="iwt-dark" label="Dark" additionalClasses={useOsSettings ? 'grw-icon-container-muted' : ''}>
|
|
|
- <MoonIcon />
|
|
|
- </IconWithTooltip>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- </form> */}
|
|
|
-
|
|
|
<button type="button" className="dropdown-item" onClick={logoutHandler}><i className="icon-fw icon-power"></i>{ t('Sign out') }</button>
|
|
|
</div>
|
|
|
|