1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-26 10:03:37 +03:00

F #3951: Add system schema option (#836)

This commit is contained in:
Sergio Betanzos 2021-02-18 15:48:04 +01:00 committed by GitHub
parent c17f67ba53
commit d0ec9b5d74
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 55 additions and 30 deletions

View File

@ -1,5 +1,7 @@
const { Setting: { SCHEMES } } = require('client/constants')
const CHANGE_ZONE = 'CHANGE_ZONE'
const CHANGE_THEME_TYPE = 'CHANGE_THEME_TYPE'
const CHANGE_SCHEME = 'CHANGE_SCHEME'
const CHANGE_LOADING = 'CHANGE_LOADING'
const TOGGLE_MENU = 'TOGGLE_MENU'
const FIX_MENU = 'FIX_MENU'
@ -10,7 +12,7 @@ const REMOVE_SNACKBAR = 'REMOVE_SNACKBAR'
const Actions = {
CHANGE_ZONE,
CHANGE_THEME_TYPE,
CHANGE_SCHEME,
CHANGE_LOADING,
TOGGLE_MENU,
FIX_MENU,
@ -25,13 +27,13 @@ module.exports = {
type: CHANGE_ZONE,
payload: { zone }
}),
updateTheme: (dispatch, getState) => {
updateScheme: (dispatch, getState) => {
const current = getState()
const currentTheme = current.Authenticated?.theme
const userTheme = current.Authenticated?.user?.TEMPLATE?.FIREEDGE?.THEME ?? 'dark'
const userScheme = current.Authenticated?.user?.TEMPLATE?.FIREEDGE?.SCHEME
if (['dark', 'light'].includes(userTheme) && currentTheme !== userTheme) {
dispatch(({ type: CHANGE_THEME_TYPE, payload: { theme: userTheme } }))
if (Object.values(SCHEMES).includes(userScheme) && currentTheme !== userScheme) {
dispatch(({ type: CHANGE_SCHEME, payload: { scheme: userScheme } }))
}
},
changeLoading: isLoading => ({

View File

@ -82,7 +82,7 @@ const translate = (str = '', values) => {
key = context.hash[key]
}
if (Array.isArray(values)) {
if (key && Array.isArray(values)) {
key = sprintf(key, ...values)
}

View File

@ -69,6 +69,7 @@ export const DEBUG_LEVEL = {
}
export * as T from 'client/constants/translates'
export * as Setting from 'client/constants/setting'
export * from 'client/constants/flow'
export * from 'client/constants/states'
export * from 'client/constants/provision'

View File

@ -0,0 +1,5 @@
export const SCHEMES = {
SYSTEM: 'system',
DARK: 'dark',
LIGHT: 'light'
}

View File

@ -62,9 +62,10 @@ module.exports = {
/* sections */
Dashboard: 'Dashboard',
Settings: 'Settings',
/* sections - settgins */
/* sections - settings */
Dark: 'Dark',
Light: 'Light',
System: 'System',
/* sections - system */
User: 'User',
Users: 'Users',

View File

@ -25,7 +25,7 @@ import {
import { useAuth, useGeneral } from 'client/hooks'
import { Tr, TranslateContext } from 'client/components/HOC'
import { T } from 'client/constants'
import { T, Setting } from 'client/constants'
import SubmitButton from 'client/components/FormControl/SubmitButton'
const useStyles = makeStyles(theme => ({
@ -56,11 +56,11 @@ const Settings = () => {
const context = React.useContext(TranslateContext)
// const langAvailables = Array.isArray(window?.langs) ? window?.langs : []
const { theme: currentTheme } = useGeneral()
const { scheme: currentScheme } = useGeneral()
const { updateUser } = useAuth()
const [{ theme, lang }, setSettings] = React.useState({
theme: currentTheme,
const [settings, setSettings] = React.useState({
scheme: currentScheme,
lang: context.lang
})
@ -77,8 +77,13 @@ const Settings = () => {
const handleSubmit = evt => {
evt.preventDefault()
const values = Object.entries(settings)
.map(([key, value]) => `\n ${String(key).toUpperCase()} = "${value}"`)
console.log({values})
updateUser({
template: `FIREEDGE = [\n THEME = "${theme}",\n LANG = "${lang}" ]\n`
template: `FIREEDGE = [\n SCHEME = "${scheme}",\n LANG = "${lang}" ]\n`
}).then(() => context.changeLang(lang))
}
@ -97,21 +102,22 @@ const Settings = () => {
{`${Tr(T.Configuration)} UI`}
</Typography>
<TextField
id='select-theme-type'
id='select-scheme-type'
select
fullWidth
name='theme'
name='scheme'
color='secondary'
label='Theme'
value={theme}
label='Scheme'
value={settings.scheme}
onChange={handleChange}
SelectProps={{
native: true
}}
variant='outlined'
>
<option value='light'>{T.Light}</option>
<option value='dark'>{T.Dark}</option>
<option value={Setting.SCHEMES.LIGHT}>{T.Light}</option>
<option value={Setting.SCHEMES.DARK}>{T.Dark}</option>
<option value={Setting.SCHEMES.SYSTEM}>{T.System}</option>
</TextField>
{/* is not operative yet */}

View File

@ -15,7 +15,7 @@ import {
logout as logoutRequest
} from 'client/actions/user'
import { setGroups } from 'client/actions/pool'
import { updateTheme, enqueueError, enqueueSuccess } from 'client/actions/general'
import { updateScheme, enqueueError, enqueueSuccess } from 'client/actions/general'
const useAuth = () => {
const {
@ -80,7 +80,7 @@ const useAuth = () => {
.then(user => dispatch(successAuth({ user })))
.then(serviceOne.getGroups)
.then(groups => dispatch(setGroups(groups)))
.then(() => dispatch(updateTheme))
.then(() => dispatch(updateScheme))
.catch(err => dispatch(failureAuth({ error: err })))
}, [dispatch, JWT_NAME, authUser])

View File

@ -9,7 +9,7 @@ export default function useGeneral () {
isLoading,
isOpenMenu,
isFixMenu,
theme
scheme
} = useSelector(state => state?.General, shallowEqual)
const dispatch = useDispatch()
@ -41,7 +41,7 @@ export default function useGeneral () {
)
return {
theme,
scheme,
isFixMenu,
isLoading,
isOpenMenu,

View File

@ -12,7 +12,7 @@ const Logo = memo(({ width, height, spinner, withText, viewBox, ...props }) => {
child5: { from: '#bfe6f2', to: '#ffffff' }
}
const textColor = {
top: theme.palette.primary.contrastText,
top: theme.palette.text.primary,
bottom: '#0098c3'
}
return (

View File

@ -1,14 +1,23 @@
import * as React from 'react'
import PropTypes from 'prop-types'
import { CssBaseline, ThemeProvider, StylesProvider } from '@material-ui/core'
import { CssBaseline, ThemeProvider, StylesProvider, useMediaQuery } from '@material-ui/core'
import { createTheme, generateClassName } from 'client/theme'
import { useGeneral } from 'client/hooks'
import { Setting } from 'client/constants'
const { SCHEMES: { DARK, LIGHT, SYSTEM } } = Setting
const MuiProvider = ({ theme: appTheme, children }) => {
const { theme } = useGeneral()
const { scheme } = useGeneral()
const prefersDarkMode = useMediaQuery('(prefers-color-scheme: dark)')
const changeThemeType = () => createTheme(appTheme(theme))
const changeThemeType = () => {
const prefersScheme = prefersDarkMode ? DARK : LIGHT
const userScheme = scheme === SYSTEM ? prefersScheme : scheme
return createTheme(appTheme(userScheme))
}
const [muitheme, setTheme] = React.useState(changeThemeType)
@ -19,7 +28,7 @@ const MuiProvider = ({ theme: appTheme, children }) => {
}
}, [])
React.useEffect(() => { setTheme(changeThemeType) }, [theme])
React.useEffect(() => setTheme(changeThemeType), [scheme, prefersDarkMode])
return (
<ThemeProvider theme={muitheme}>

View File

@ -16,6 +16,7 @@
const { Actions: PoolActions } = require('../actions/pool')
const { Actions: UserActions } = require('../actions/user')
const { Actions: GeneralActions } = require('../actions/general')
const { Setting: { SCHEMES } } = require('client/constants')
const initial = {
zone: 0,
@ -23,7 +24,7 @@ const initial = {
isLoading: false,
isOpenMenu: false,
isFixMenu: false,
theme: 'dark'
scheme: SCHEMES.DARK
}
const General = (state = initial, action) => {
@ -58,7 +59,7 @@ const General = (state = initial, action) => {
notification => notification.key !== action.key
)
}
case GeneralActions.CHANGE_THEME_TYPE:
case GeneralActions.CHANGE_SCHEME:
return { ...state, ...action.payload }
case GeneralActions.CHANGE_LOADING:
return { ...state, ...action.payload }