|
|
@@ -1,29 +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';
|
|
|
-
|
|
|
-
|
|
|
-import MoonIcon from '../Icons/MoonIcon';
|
|
|
-import SidebarDockIcon from '../Icons/SidebarDockIcon';
|
|
|
-import SidebarDrawerIcon from '../Icons/SidebarDrawerIcon';
|
|
|
-import SunIcon from '../Icons/SunIcon';
|
|
|
-
|
|
|
|
|
|
const PersonalDropdown = () => {
|
|
|
const { t } = useTranslation();
|
|
|
@@ -31,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');
|
|
|
@@ -48,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 */}
|
|
|
@@ -128,100 +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>
|
|
|
-
|
|
|
- <div className="dropdown-divider"></div>
|
|
|
-
|
|
|
<button type="button" className="dropdown-item" onClick={logoutHandler}><i className="icon-fw icon-power"></i>{ t('Sign out') }</button>
|
|
|
</div>
|
|
|
|