Skip to content

Commit

Permalink
Merge pull request #551 from terwer/dev
Browse files Browse the repository at this point in the history
fix: #385 dark mode is back again
  • Loading branch information
terwer authored Dec 19, 2024
2 parents d2fd906 + 0781d6f commit 25460d3
Show file tree
Hide file tree
Showing 9 changed files with 145 additions and 34 deletions.
3 changes: 2 additions & 1 deletion app.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,8 @@ export default defineAppConfig<AppConfig>({
customCss: [
{
name: "custom.css",
content: "body { background-color: #f5f5f5; }",
// content: "body { background-color: #f5f5f5; }",
content: "",
},
],

Expand Down
2 changes: 1 addition & 1 deletion common/Constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@

// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
export const isDev = process.dev
export const isDev = typeof process === "undefined" ? false : process?.dev
// export const isDev = import.meta.dev
// https://github.com/nuxt/nuxt/discussions/18779#discussioncomment-5082909
// typeof process === "undefined" ? false : process?.env?.DEV_MODE === "true"
72 changes: 70 additions & 2 deletions components/static/Footer.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@
import { useStaticSettingStore } from "~/stores/useStaticSettingStore"
import { useI18n } from "vue-i18n"
const { locale } = useI18n()
const { locale, t } = useI18n()
const { getStaticSetting } = useStaticSettingStore()
const setting = await getStaticSetting()
await useStaticThemeMode()
const { colorMode, toggleDark } = await useStaticThemeMode()
const VNode = () =>
h("div", {
Expand All @@ -25,5 +25,73 @@ onBeforeMount(() => {
<template>
<div class="footer">
<VNode />
<div class="theme-toggle" @click="toggleDark()">
<div class="theme-option" :class="{ active: !colorMode }">
{{ t("theme.mode.light") }}
</div>
<div class="theme-option" :class="{ active: colorMode }">
{{ t("theme.mode.dark") }}
</div>
</div>
</div>
</template>

<style>
:root {
--footer-only-background-color: #ffffff;
--footer-only-hover-background-color: #f0f0f0;
--footer-only-active-background-color: #007bff;
--footer-only-border-color: #ccc;
--footer-only-text-color: #333;
--footer-only-active-text-color: #ffffff;
}
html[data-theme-mode="dark"] {
--footer-only-background-color: #444444; /* 深色背景 */
--footer-only-hover-background-color: #555555; /* 悬浮背景 */
--footer-only-active-background-color: #ffa500; /* 激活项背景 */
--footer-only-border-color: #666666; /* 边框深色 */
--footer-only-text-color: #f0f0f0; /* 默认文字浅色 */
--footer-only-active-text-color: #333333; /* 激活项文字深色 */
}
</style>
<style scoped>
.footer {
font-size: 12px;
color: #bbb;
text-align: center;
padding-bottom: 8px;
}
.theme-toggle {
position: fixed;
bottom: 20px;
right: 20px;
display: flex;
flex-direction: column;
background-color: var(--footer-only-background-color, #ffffff);
border: 1px solid var(--footer-only-border-color, #ccc);
border-radius: 8px;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
overflow: hidden;
}
.theme-option {
padding: 10px 20px;
text-align: center;
cursor: pointer;
transition: background-color 0.3s, color 0.3s;
font-size: 14px;
font-weight: bold;
color: var(--footer-only-text-color, #333);
}
.theme-option:hover {
background-color: var(--footer-only-hover-background-color, #f0f0f0);
}
.theme-option.active {
background-color: var(--footer-only-active-background-color, #007bff);
color: var(--footer-only-active-text-color, #ffffff);
}
</style>
4 changes: 2 additions & 2 deletions composables/useSiyuanDevice.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ export const useSiyuanDevice = () => {
const isInSiyuanWidget = () => {
const deviceType = DeviceDetection.getDevice()
const isSiyuanOrSiyuanNewWin = deviceType === DeviceTypeEnum.DeviceType_Siyuan_Widget
logger.debug("deviceType=>", deviceType)
logger.info("deviceType=>", deviceType)
logger.debug("isSiyuanOrSiyuanNewWin=>", String(isSiyuanOrSiyuanNewWin))
return isSiyuanOrSiyuanNewWin
}
Expand All @@ -52,7 +52,7 @@ export const useSiyuanDevice = () => {
const deviceType = DeviceDetection.getDevice()
const isSiyuanOrSiyuanNewWin =
deviceType === DeviceTypeEnum.DeviceType_Siyuan_MainWin ||
deviceType === DeviceTypeEnum.DeviceType_Siyuan_NewWin ||
deviceType === DeviceTypeEnum.DeviceType_Siyuan_RendererWin ||
deviceType === DeviceTypeEnum.DeviceType_Siyuan_Widget
logger.debug("deviceType=>", deviceType)
logger.debug("isSiyuanOrSiyuanNewWin=>", String(isSiyuanOrSiyuanNewWin))
Expand Down
32 changes: 22 additions & 10 deletions composables/useStaticThemeMode.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,10 @@
* questions.
*/

import { BrowserUtil } from "zhi-device"
import { BrowserUtil, SiyuanDevice } from "zhi-device"
import { createAppLogger } from "~/common/appLogger"
import { CONSTANTS } from "~/utils/constants"
import { useRoute } from "vue-router"
import { useProviderMode } from "~/composables/useProviderMode"
import { useStaticSettingStore } from "~/stores/useStaticSettingStore"

// 创建日志记录器
Expand All @@ -40,12 +39,18 @@ export const useStaticThemeMode = async () => {
// 获取颜色模式和运行时配置
const color = useColorMode()
const { query } = useRoute()
const { providerMode } = useProviderMode()
const appBase = process.env.APP_BASE
const { getStaticSetting } = useStaticSettingStore()

// 在 mounted 生命周期中处理加载后逻辑
onMounted(() => {})
onMounted(() => {
// 检测浏览器不是暗黑模式,根据媒介查询
const win = SiyuanDevice.siyuanWindow()
const isDarkMode = !BrowserUtil.hasNodeEnv() && win.matchMedia("(prefers-color-scheme: dark)").matches
if (isDarkMode) {
setThemeMode(true)
}
})

// computes
// 获取颜色模式并暴露 computed 属性
Expand Down Expand Up @@ -125,28 +130,35 @@ export const useStaticThemeMode = async () => {

// 设置主题模式
const setThemeMode = (isDarkMode: boolean) => {
if (isDarkMode) {
document.body.style.backgroundColor = "unset"
} else {
document.body.style.backgroundColor = "#f5f5f5"
}
if (BrowserUtil.isInBrowser) {
setCssAndThemeMode(isDarkMode)
// 记录日志
logger.debug(isDarkMode ? "Browser Dark Mode" : "Browser Light Mode")
logger.info(`Auto set mode, isDark => ${isDarkMode}`)
}

color.preference = isDarkMode ? "dark" : "light"
}

// 根据浏览器模式设置 CSS 和主题模式
const setCssAndThemeMode = (isDarkMode: boolean) => {
// 默认主题适配
const themeDefaultStyle = document.querySelector("#themeDefaultStyle") as any
themeDefaultStyle.href =
appBase + `resources/appearance/themes/${isDarkMode ? "midnight" : "daylight"}/theme.css?v=${siyuanV}`
if (themeDefaultStyle) {
themeDefaultStyle.href =
appBase + `resources/appearance/themes/${isDarkMode ? "midnight" : "daylight"}/theme.css?v=${siyuanV}`
}

// 代码块适配
const protyleHljsStyle = document.querySelector("#protyleHljsStyle") as any
protyleHljsStyle.href =
appBase + `resources/stage/protyle/js/highlight.js/styles/vs${isDarkMode ? "2015" : ""}.min.css?v=${hljsV}`

if (protyleHljsStyle) {
protyleHljsStyle.href =
appBase + `resources/stage/protyle/js/highlight.js/styles/vs${isDarkMode ? "2015" : ""}.min.css?v=${hljsV}`
}
// 颜色模式属性
document.documentElement.dataset.themeMode = isDarkMode ? "dark" : "light"

Expand Down
52 changes: 36 additions & 16 deletions nuxt.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ const generateDynamicV = () => {
}

const isDev = process.env.NODE_ENV === "development"
const appBase = "/"
const appBase = "/plugins/siyuan-blog/"
const staticV = generateDynamicV()

// https://nuxt.com/docs/api/configuration/nuxt-config
Expand All @@ -24,7 +24,14 @@ export default defineNuxtConfig({
},

// build modules
modules: ["@vueuse/nuxt", "@nuxtjs/i18n", "@element-plus/nuxt", "@nuxtjs/color-mode", "@pinia/nuxt", "@nuxt/image"],
modules: [
"@vueuse/nuxt",
"@nuxtjs/i18n-edge",
"@element-plus/nuxt",
"@nuxtjs/color-mode",
"@pinia/nuxt",
"@nuxt/image",
],

// vueuse
vueuse: {
Expand All @@ -47,7 +54,7 @@ export default defineNuxtConfig({
define: {
"process.env.DEV_MODE": `"${isDev}"`,
"process.env.APP_BASE": `"${appBase}"`,
"process.env.SSR": `"true"`,
"process.env.SSR": `"false"`,
},
plugins: [],
css: {
Expand All @@ -66,6 +73,14 @@ export default defineNuxtConfig({
themes: ["dark"],
},

// https://nuxt.com/docs/guide/going-further/custom-routing#hash-mode-spa
ssr: false,
router: {
options: {
hashMode: true,
},
},

css: ["~/assets/siyuan/style.styl", "~/assets/siyuan/index.styl"],

app: {
Expand Down Expand Up @@ -94,12 +109,12 @@ export default defineNuxtConfig({
// https://nuxt.com/docs/api/configuration/nuxt-config#head
script: isDev
? [
// {
// src: appBase + "libs/eruda/eruda.js",
// },
// {
// children: "eruda.init();console.log('eruda inited');",
// },
{
src: appBase + "libs/eruda/eruda.js",
},
{
children: "eruda.init();console.log('eruda inited');",
},
{
defer: true,
src: appBase + "libs/katex/0.16.10/katex.min.js",
Expand All @@ -116,14 +131,19 @@ export default defineNuxtConfig({

// 环境变量
runtimeConfig: {
siyuanAuthToken: process.env.NUXT_SIYUAN_AUTH_TOKEN,
siyuanCookie: process.env.NUXT_SIYUAN_COOKIE,
// siyuanAuthToken: process.env.NUXT_SIYUAN_AUTH_TOKEN,
siyuanAuthToken: "",
// siyuanCookie: process.env.NUXT_SIYUAN_COOKIE,
siyuanCookie: "",
public: {
defaultType: process.env.NUXT_PUBLIC_DEFAULT_TYPE ?? "siyuan",
siyuanApiUrl: process.env.NUXT_PUBLIC_SIYUAN_API_URL ?? "http://127.0.0.1:6806",
waitTime: process.env.NUXT_PUBLIC_WAIT_TIME,
providerMode: process.env.NUXT_PUBLIC_PROVIDER_MODE ?? "false",
providerUrl: process.env.NUXT_PUBLIC_PROVIDER_URL ?? "http://127.0.0.1:8000",
// defaultType: process.env.NUXT_PUBLIC_DEFAULT_TYPE,
defaultType: "siyuan",
// siyuanApiUrl: process.env.NUXT_PUBLIC_SIYUAN_API_URL,
siyuanApiUrl: "",
// waitTime: process.env.NUXT_PUBLIC_WAIT_TIME,
waitTime: "0",
providerMode: "false",
providerUrl: "http://127.0.0.1:8000",
},
},

Expand Down
11 changes: 10 additions & 1 deletion pages/share.vue
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ import { sendMessageToParent } from "~/utils/innerIframeEvent"
import { getAllIps } from "~/utils/urlUtil"
import { useStaticShare } from "~/composables/useStaticShare"
import { useShareType } from "~/composables/useShareType"
import { useStaticThemeMode } from "~/composables/useStaticThemeMode"

definePageMeta({
layout: "default",
Expand All @@ -53,6 +54,7 @@ const { blogApi, kernelApi } = useSiyuanApi()
const { getShareType, isPrivateShare } = useShareType()
const { updateShareType } = useCommonShareType()
const { openStaticShare, closeStaticShare, updateStaticShare } = useStaticShare()
const { colorMode, toggleDark } = await useStaticThemeMode()

const id = useRouteQuery("id", "")
const origin = useRouteQuery("origin", "")
Expand Down Expand Up @@ -103,7 +105,7 @@ const formData = reactive({
const { optionState, optionToggle } = useShareOptionToggle(formData.optionEnabled)

const goHelp = async () => {
window.open("https://blog.terwer.space/s/20230621001422-xsimx5v")
window.open("https://siyuan.wiki/s/20230621001422-xsimx5v")
}

const copyWebLink = () => {
Expand Down Expand Up @@ -350,6 +352,13 @@ const goSetting = () => {
</el-icon>
{{ t("share.setting") }}
</el-text>

<el-text @click="toggleDark">
<el-icon>
<el-icon-coffee />
</el-icon>
{{ colorMode ? t("theme.mode.light") : t("theme.mode.dark") }}
</el-text>
</el-space>
</div>
</div>
Expand Down
2 changes: 2 additions & 0 deletions plugins/renderer/useStaticClientAssets.ts
Original file line number Diff line number Diff line change
Expand Up @@ -61,12 +61,14 @@ export const useStaticClientAssets = () => {
const imgUrl = [baseUrl, pubicAssetsFolder, src].join("/")

img.setAttribute("src", imgUrl)
img.setAttribute("data-src", imgUrl)
}
}
// 兼容旧图片域名
if (src.indexOf("https://api.siyuannote.site") > -1) {
const imgUrl = src.replace("https://api.siyuannote.site", "https://img1.siyuan.wiki")
img.setAttribute("src", imgUrl)
img.setAttribute("data-src", imgUrl)
}
})
logger.info("The local image has been processed and the picture display has been repaired.")
Expand Down
1 change: 0 additions & 1 deletion public/.well-known/pki-validation/fileauth.txt

This file was deleted.

0 comments on commit 25460d3

Please sign in to comment.