提交 f44b8075 编写于 作者: B baiy 提交者: ninecents

简单实现深色主题

上级 352ee666
{ {
"name": "c-tool", "name": "c-tool",
"version": "1.7.8", "version": "1.7.9",
"private": true, "private": true,
"scripts": { "scripts": {
"serve": "vue-cli-service serve --port 8081", "serve": "vue-cli-service serve --port 8081",
......
public/img/icon_utools.png

14.7 KB | W: | H:

public/img/icon_utools.png

11.1 KB | W: | H:

public/img/icon_utools.png
public/img/icon_utools.png
public/img/icon_utools.png
public/img/icon_utools.png
  • 2-up
  • Swipe
  • Onion skin
...@@ -26,4 +26,10 @@ export const openUrl = (url) => { ...@@ -26,4 +26,10 @@ export const openUrl = (url) => {
return window.open(url); return window.open(url);
}; };
export const version = env('version').trim() export const version = env('version').trim()
\ No newline at end of file
export const setDisplayMode = (mode) => {
mode = ['light', 'dark', 'auto'].includes(mode) ? mode : 'light'
console.log(`set display mode:${mode}`)
document.getElementsByTagName('html')[0].setAttribute('theme-mode', mode);
}
@import '~view-design/src/styles/index.less'; @import '~view-design/src/styles/index.less';
@import './theme_dark.css';
@primary-color: #1abc9c; @primary-color: #1abc9c;
@link-color: #1abc9c; @link-color: #1abc9c;
......
/* 黑暗模式简单实现 */ /* 黑暗模式简单实现 */
html {
background-color: #fff;
}
/* 强制黑暗模 */ /* 强制黑暗模 */
html[theme-mode='dark'] { html[theme-mode='dark'] {
......
...@@ -5,10 +5,14 @@ import router from './tool.router' ...@@ -5,10 +5,14 @@ import router from './tool.router'
import optionBlock from './components/optionBlock' import optionBlock from './components/optionBlock'
import {plugin as modelPlugin} from './tool/model' import {plugin as modelPlugin} from './tool/model'
import cache from './tool/cache' import cache from './tool/cache'
import setting from './tool/setting'
import App from './tool.vue' import App from './tool.vue'
import {isUtools} from './helper' import {isUtools,setDisplayMode} from './helper'
const run = () => { const run = () => {
// 设置显示模式
setDisplayMode(setting.displayMode())
Vue.config.productionTip = false Vue.config.productionTip = false
Vue.use(ViewUI) Vue.use(ViewUI)
......
...@@ -5,7 +5,7 @@ export default { ...@@ -5,7 +5,7 @@ export default {
* @param value * @param value
* @return {boolean} * @return {boolean}
*/ */
autoSaveCopy (value = null) { autoSaveCopy(value = null) {
if (value === null) { if (value === null) {
return config.getSetting('auto_save_copy', true) return config.getSetting('auto_save_copy', true)
} }
...@@ -16,7 +16,7 @@ export default { ...@@ -16,7 +16,7 @@ export default {
* @param value * @param value
* @return {boolean} * @return {boolean}
*/ */
autoReadCopy (value = null) { autoReadCopy(value = null) {
if (value === null) { if (value === null) {
return config.getSetting('auto_read_copy', true) return config.getSetting('auto_read_copy', true)
} }
...@@ -26,10 +26,20 @@ export default { ...@@ -26,10 +26,20 @@ export default {
* @param value * @param value
* @return {boolean} * @return {boolean}
*/ */
autoReadCopyFilter (value = null) { autoReadCopyFilter(value = null) {
if (value === null) { if (value === null) {
return config.getSetting('auto_read_copy_filter', false) return config.getSetting('auto_read_copy_filter', false)
} }
return config.saveSetting('auto_read_copy_filter', value) return config.saveSetting('auto_read_copy_filter', value)
}, },
} /**
\ No newline at end of file * @param value
* @return {boolean}
*/
displayMode(value = null) {
if (value === null) {
return config.getSetting('display_mode', 'light')
}
return config.saveSetting('display_mode', value)
},
}
...@@ -4,6 +4,11 @@ ...@@ -4,6 +4,11 @@
<CellGroup @on-click="open"> <CellGroup @on-click="open">
<Cell title="常用工具设置" name="setting"/> <Cell title="常用工具设置" name="setting"/>
<Cell v-if="is_chromium" title="快捷键设置" name="shortcuts"/> <Cell v-if="is_chromium" title="快捷键设置" name="shortcuts"/>
<Cell title="外观显示">
<Select v-model="display_mode" slot="extra" transfer>
<Option v-for="item in display_mode_list" :value="item.v" :key="item.v">{{ item.n }}</Option>
</Select>
</Cell>
</CellGroup> </CellGroup>
<CellGroup> <CellGroup>
<Cell title="自动复制结果到剪贴板"> <Cell title="自动复制结果到剪贴板">
...@@ -26,6 +31,7 @@ ...@@ -26,6 +31,7 @@
<script> <script>
import {isChromium, isUtools, openUrl} from '../../helper' import {isChromium, isUtools, openUrl} from '../../helper'
import setting from '../../tool/setting' import setting from '../../tool/setting'
import {setDisplayMode} from '../../helper'
import settingBlock from './setting' import settingBlock from './setting'
export default { export default {
...@@ -37,20 +43,33 @@ export default { ...@@ -37,20 +43,33 @@ export default {
settingShow: false, settingShow: false,
auto_save_copy: true, auto_save_copy: true,
auto_read_copy: true, auto_read_copy: true,
display_mode: "light",
auto_read_copy_filter: false, auto_read_copy_filter: false,
is_chromium: isChromium, is_chromium: isChromium,
is_utools: isUtools, is_utools: isUtools,
display_mode_list: [
{n: "浅色", v: "light"},
{n: "深色", v: "dark"},
{n: "自动", v: "auto"},
]
}
},
watch:{
display_mode(value){
setDisplayMode(value)
} }
}, },
created() { created() {
this.auto_save_copy = setting.autoSaveCopy() this.auto_save_copy = setting.autoSaveCopy()
this.auto_read_copy = setting.autoReadCopy() this.auto_read_copy = setting.autoReadCopy()
this.auto_read_copy_filter = setting.autoReadCopyFilter() this.auto_read_copy_filter = setting.autoReadCopyFilter()
this.display_mode = setting.displayMode()
}, },
beforeDestroy() { beforeDestroy() {
setting.autoSaveCopy(this.auto_save_copy) setting.autoSaveCopy(this.auto_save_copy)
setting.autoReadCopy(this.auto_read_copy) setting.autoReadCopy(this.auto_read_copy)
setting.autoReadCopyFilter(this.auto_read_copy_filter) setting.autoReadCopyFilter(this.auto_read_copy_filter)
setting.displayMode(this.display_mode)
}, },
methods: { methods: {
open(name) { open(name) {
...@@ -65,4 +84,4 @@ export default { ...@@ -65,4 +84,4 @@ export default {
} }
}, },
} }
</script> </script>
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册