You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
54 lines
1.3 KiB
54 lines
1.3 KiB
const defaultSetting = {
|
|
collapse: false,
|
|
silderTheme: 'dark',
|
|
themeColor: '#1890FF',
|
|
layout: 'sidemenu',
|
|
grid: 'Fluid',
|
|
fixedHeader: false,
|
|
autoHideHeader: false,
|
|
fixSiderbar: false,
|
|
colorWeak: 'close',
|
|
};
|
|
export default {
|
|
namespace: 'setting',
|
|
|
|
state: defaultSetting,
|
|
reducers: {
|
|
getSetting(state) {
|
|
const setting = { ...state };
|
|
const urlParams = new URL(window.location.href);
|
|
Object.keys(state).forEach(key => {
|
|
if (urlParams.searchParams.has(key)) {
|
|
const value = urlParams.searchParams.get(key);
|
|
setting[key] = value;
|
|
}
|
|
});
|
|
return setting;
|
|
},
|
|
changeSetting(state, { payload }) {
|
|
const urlParams = new URL(window.location.href);
|
|
Object.keys(defaultSetting).forEach(key => {
|
|
if (urlParams.searchParams.has(key)) {
|
|
urlParams.searchParams.delete(key);
|
|
}
|
|
});
|
|
Object.keys(payload).forEach(key => {
|
|
if (key === 'collapse') {
|
|
return;
|
|
}
|
|
let value = payload[key];
|
|
if (value === true) {
|
|
value = 1;
|
|
}
|
|
if (defaultSetting[key] !== value) {
|
|
urlParams.searchParams.set(key, value);
|
|
}
|
|
});
|
|
window.history.replaceState(null, 'setting', urlParams.href);
|
|
return {
|
|
...state,
|
|
...payload,
|
|
};
|
|
},
|
|
},
|
|
};
|
|
|