feat: adding iOS Webapp support

- fix media query about background-color
- Use colors from CSS files instead of fixed values
This commit is contained in:
AprilNEA 2023-03-27 17:04:11 +08:00
parent 785372ad73
commit dd80c4563d
No known key found for this signature in database
GPG Key ID: B93E17BB436B4DE1
2 changed files with 14 additions and 19 deletions

View File

@ -356,33 +356,21 @@ export function Chat(props: { showSideBar?: () => void }) {
function useSwitchTheme() { function useSwitchTheme() {
const config = useChatStore((state) => state.config); const config = useChatStore((state) => state.config);
const screenWidth = window.innerWidth;
useEffect(() => { useEffect(() => {
const metaDescription = document.querySelector('meta[name="theme-color"]');
document.body.classList.remove("light"); document.body.classList.remove("light");
document.body.classList.remove("dark"); document.body.classList.remove("dark");
if (config.theme === "dark") { if (config.theme === "dark") {
document.body.classList.add("dark"); document.body.classList.add("dark");
if (metaDescription) {
if (screenWidth < 600) {
metaDescription.setAttribute('content', "#1a262a");
} else {
metaDescription.setAttribute('content', "#151515");
}
}
} else if (config.theme === "light") { } else if (config.theme === "light") {
document.body.classList.add("light"); document.body.classList.add("light");
if (metaDescription) {
if (screenWidth < 600) {
metaDescription.setAttribute('content', "#e7f8ff");
} else {
metaDescription.setAttribute('content', "#fafafa");
} }
}
} const themeColor = getComputedStyle(document.body).getPropertyValue("--theme-color").trim();
}, [config.theme,screenWidth]); const metaDescription = document.querySelector('meta[name="theme-color"]');
metaDescription?.setAttribute('content', themeColor);
}, [config.theme]);
} }
function exportMessages(messages: Message[], topic: string) { function exportMessages(messages: Message[], topic: string) {

View File

@ -7,6 +7,7 @@
--second: rgb(231, 248, 255); --second: rgb(231, 248, 255);
--hover-color: #f3f3f3; --hover-color: #f3f3f3;
--bar-color: rgba(0, 0, 0, 0.1); --bar-color: rgba(0, 0, 0, 0.1);
--theme-color: var(--gray);
/* shadow */ /* shadow */
--shadow: 50px 50px 100px 10px rgb(0, 0, 0, 0.1); --shadow: 50px 50px 100px 10px rgb(0, 0, 0, 0.1);
@ -28,6 +29,8 @@
--bar-color: rgba(255, 255, 255, 0.1); --bar-color: rgba(255, 255, 255, 0.1);
--border-in-light: 1px solid rgba(255, 255, 255, 0.192); --border-in-light: 1px solid rgba(255, 255, 255, 0.192);
--theme-color: var(--gray);
} }
.light { .light {
@ -85,6 +88,10 @@ body {
user-select: none; user-select: none;
font-family: "Noto Sans SC", "SF Pro SC", "SF Pro Text", "SF Pro Icons", font-family: "Noto Sans SC", "SF Pro SC", "SF Pro Text", "SF Pro Icons",
"PingFang SC", "Helvetica Neue", "Helvetica", "Arial", sans-serif; "PingFang SC", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
@media only screen and (max-width: 600px) {
background-color: var(--second);
}
} }
::-webkit-scrollbar { ::-webkit-scrollbar {