[Feat] finished theme changer on preview page

This commit is contained in:
Marco Kutscha 2024-02-24 22:38:19 +01:00
parent 7a27b2a899
commit 2af46371e2
8 changed files with 32732 additions and 40 deletions

View file

@ -0,0 +1,496 @@
[ "a11y-dark" ,
"a11y-dark-min" ,
"a11y-light" ,
"a11y-light-min" ,
"agate" ,
"agate-min" ,
"an-old-hope" ,
"an-old-hope-min" ,
"androidstudio" ,
"androidstudio-min" ,
"arduino-light" ,
"arduino-light-min" ,
"arta" ,
"arta-min" ,
"ascetic" ,
"ascetic-min" ,
"atom-one-dark-reasonable" ,
"atom-one-dark-reasonable-min" ,
"atom-one-dark" ,
"atom-one-dark-min" ,
"atom-one-light" ,
"atom-one-light-min" ,
"base16-3024" ,
"base16-3024-min" ,
"base16-apathy" ,
"base16-apathy-min" ,
"base16-apprentice" ,
"base16-apprentice-min" ,
"base16-ashes" ,
"base16-ashes-min" ,
"base16-atelier-cave-light" ,
"base16-atelier-cave-light-min" ,
"base16-atelier-cave" ,
"base16-atelier-cave-min" ,
"base16-atelier-dune-light" ,
"base16-atelier-dune-light-min" ,
"base16-atelier-dune" ,
"base16-atelier-dune-min" ,
"base16-atelier-estuary-light" ,
"base16-atelier-estuary-light-min" ,
"base16-atelier-estuary" ,
"base16-atelier-estuary-min" ,
"base16-atelier-forest-light" ,
"base16-atelier-forest-light-min" ,
"base16-atelier-forest" ,
"base16-atelier-forest-min" ,
"base16-atelier-heath-light" ,
"base16-atelier-heath-light-min" ,
"base16-atelier-heath" ,
"base16-atelier-heath-min" ,
"base16-atelier-lakeside-light" ,
"base16-atelier-lakeside-light-min" ,
"base16-atelier-lakeside" ,
"base16-atelier-lakeside-min" ,
"base16-atelier-plateau-light" ,
"base16-atelier-plateau-light-min" ,
"base16-atelier-plateau" ,
"base16-atelier-plateau-min" ,
"base16-atelier-savanna-light" ,
"base16-atelier-savanna-light-min" ,
"base16-atelier-savanna" ,
"base16-atelier-savanna-min" ,
"base16-atelier-seaside-light" ,
"base16-atelier-seaside-light-min" ,
"base16-atelier-seaside" ,
"base16-atelier-seaside-min" ,
"base16-atelier-sulphurpool-light" ,
"base16-atelier-sulphurpool-light-min" ,
"base16-atelier-sulphurpool" ,
"base16-atelier-sulphurpool-min" ,
"base16-atlas" ,
"base16-atlas-min" ,
"base16-bespin" ,
"base16-bespin-min" ,
"base16-black-metal-bathory" ,
"base16-black-metal-bathory-min" ,
"base16-black-metal-burzum" ,
"base16-black-metal-burzum-min" ,
"base16-black-metal-dark-funeral" ,
"base16-black-metal-dark-funeral-min" ,
"base16-black-metal-gorgoroth" ,
"base16-black-metal-gorgoroth-min" ,
"base16-black-metal-immortal" ,
"base16-black-metal-immortal-min" ,
"base16-black-metal-khold" ,
"base16-black-metal-khold-min" ,
"base16-black-metal-marduk" ,
"base16-black-metal-marduk-min" ,
"base16-black-metal-mayhem" ,
"base16-black-metal-mayhem-min" ,
"base16-black-metal-nile" ,
"base16-black-metal-nile-min" ,
"base16-black-metal-venom" ,
"base16-black-metal-venom-min" ,
"base16-black-metal" ,
"base16-black-metal-min" ,
"base16-brewer" ,
"base16-brewer-min" ,
"base16-bright" ,
"base16-bright-min" ,
"base16-brogrammer" ,
"base16-brogrammer-min" ,
"base16-brush-trees-dark" ,
"base16-brush-trees-dark-min" ,
"base16-brush-trees" ,
"base16-brush-trees-min" ,
"base16-chalk" ,
"base16-chalk-min" ,
"base16-circus" ,
"base16-circus-min" ,
"base16-classic-dark" ,
"base16-classic-dark-min" ,
"base16-classic-light" ,
"base16-classic-light-min" ,
"base16-codeschool" ,
"base16-codeschool-min" ,
"base16-colors" ,
"base16-colors-min" ,
"base16-cupcake" ,
"base16-cupcake-min" ,
"base16-cupertino" ,
"base16-cupertino-min" ,
"base16-danqing" ,
"base16-danqing-min" ,
"base16-darcula" ,
"base16-darcula-min" ,
"base16-dark-violet" ,
"base16-dark-violet-min" ,
"base16-darkmoss" ,
"base16-darkmoss-min" ,
"base16-darktooth" ,
"base16-darktooth-min" ,
"base16-decaf" ,
"base16-decaf-min" ,
"base16-default-dark" ,
"base16-default-dark-min" ,
"base16-default-light" ,
"base16-default-light-min" ,
"base16-dirtysea" ,
"base16-dirtysea-min" ,
"base16-dracula" ,
"base16-dracula-min" ,
"base16-edge-dark" ,
"base16-edge-dark-min" ,
"base16-edge-light" ,
"base16-edge-light-min" ,
"base16-eighties" ,
"base16-eighties-min" ,
"base16-embers" ,
"base16-embers-min" ,
"base16-equilibrium-dark" ,
"base16-equilibrium-dark-min" ,
"base16-equilibrium-gray-dark" ,
"base16-equilibrium-gray-dark-min" ,
"base16-equilibrium-gray-light" ,
"base16-equilibrium-gray-light-min" ,
"base16-equilibrium-light" ,
"base16-equilibrium-light-min" ,
"base16-espresso" ,
"base16-espresso-min" ,
"base16-eva-dim" ,
"base16-eva-dim-min" ,
"base16-eva" ,
"base16-eva-min" ,
"base16-flat" ,
"base16-flat-min" ,
"base16-framer" ,
"base16-framer-min" ,
"base16-fruit-soda" ,
"base16-fruit-soda-min" ,
"base16-gigavolt" ,
"base16-gigavolt-min" ,
"base16-github" ,
"base16-github-min" ,
"base16-google-dark" ,
"base16-google-dark-min" ,
"base16-google-light" ,
"base16-google-light-min" ,
"base16-grayscale-dark" ,
"base16-grayscale-dark-min" ,
"base16-grayscale-light" ,
"base16-grayscale-light-min" ,
"base16-green-screen" ,
"base16-green-screen-min" ,
"base16-gruvbox-dark-hard" ,
"base16-gruvbox-dark-hard-min" ,
"base16-gruvbox-dark-medium" ,
"base16-gruvbox-dark-medium-min" ,
"base16-gruvbox-dark-pale" ,
"base16-gruvbox-dark-pale-min" ,
"base16-gruvbox-dark-soft" ,
"base16-gruvbox-dark-soft-min" ,
"base16-gruvbox-light-hard" ,
"base16-gruvbox-light-hard-min" ,
"base16-gruvbox-light-medium" ,
"base16-gruvbox-light-medium-min" ,
"base16-gruvbox-light-soft" ,
"base16-gruvbox-light-soft-min" ,
"base16-hardcore" ,
"base16-hardcore-min" ,
"base16-harmonic16-dark" ,
"base16-harmonic16-dark-min" ,
"base16-harmonic16-light" ,
"base16-harmonic16-light-min" ,
"base16-heetch-dark" ,
"base16-heetch-dark-min" ,
"base16-heetch-light" ,
"base16-heetch-light-min" ,
"base16-helios" ,
"base16-helios-min" ,
"base16-hopscotch" ,
"base16-hopscotch-min" ,
"base16-horizon-dark" ,
"base16-horizon-dark-min" ,
"base16-horizon-light" ,
"base16-horizon-light-min" ,
"base16-humanoid-dark" ,
"base16-humanoid-dark-min" ,
"base16-humanoid-light" ,
"base16-humanoid-light-min" ,
"base16-ia-dark" ,
"base16-ia-dark-min" ,
"base16-ia-light" ,
"base16-ia-light-min" ,
"base16-icy-dark" ,
"base16-icy-dark-min" ,
"base16-ir-black" ,
"base16-ir-black-min" ,
"base16-isotope" ,
"base16-isotope-min" ,
"base16-kimber" ,
"base16-kimber-min" ,
"base16-london-tube" ,
"base16-london-tube-min" ,
"base16-macintosh" ,
"base16-macintosh-min" ,
"base16-marrakesh" ,
"base16-marrakesh-min" ,
"base16-materia" ,
"base16-materia-min" ,
"base16-material-darker" ,
"base16-material-darker-min" ,
"base16-material-lighter" ,
"base16-material-lighter-min" ,
"base16-material-palenight" ,
"base16-material-palenight-min" ,
"base16-material-vivid" ,
"base16-material-vivid-min" ,
"base16-material" ,
"base16-material-min" ,
"base16-mellow-purple" ,
"base16-mellow-purple-min" ,
"base16-mexico-light" ,
"base16-mexico-light-min" ,
"base16-mocha" ,
"base16-mocha-min" ,
"base16-monokai" ,
"base16-monokai-min" ,
"base16-nebula" ,
"base16-nebula-min" ,
"base16-nord" ,
"base16-nord-min" ,
"base16-nova" ,
"base16-nova-min" ,
"base16-ocean" ,
"base16-ocean-min" ,
"base16-oceanicnext" ,
"base16-oceanicnext-min" ,
"base16-one-light" ,
"base16-one-light-min" ,
"base16-onedark" ,
"base16-onedark-min" ,
"base16-outrun-dark" ,
"base16-outrun-dark-min" ,
"base16-papercolor-dark" ,
"base16-papercolor-dark-min" ,
"base16-papercolor-light" ,
"base16-papercolor-light-min" ,
"base16-paraiso" ,
"base16-paraiso-min" ,
"base16-pasque" ,
"base16-pasque-min" ,
"base16-phd" ,
"base16-phd-min" ,
"base16-pico" ,
"base16-pico-min" ,
"base16-pop" ,
"base16-pop-min" ,
"base16-porple" ,
"base16-porple-min" ,
"base16-qualia" ,
"base16-qualia-min" ,
"base16-railscasts" ,
"base16-railscasts-min" ,
"base16-rebecca" ,
"base16-rebecca-min" ,
"base16-ros-pine-dawn" ,
"base16-ros-pine-dawn-min" ,
"base16-ros-pine-moon" ,
"base16-ros-pine-moon-min" ,
"base16-ros-pine" ,
"base16-ros-pine-min" ,
"base16-sagelight" ,
"base16-sagelight-min" ,
"base16-sandcastle" ,
"base16-sandcastle-min" ,
"base16-seti-ui" ,
"base16-seti-ui-min" ,
"base16-shapeshifter" ,
"base16-shapeshifter-min" ,
"base16-silk-dark" ,
"base16-silk-dark-min" ,
"base16-silk-light" ,
"base16-silk-light-min" ,
"base16-snazzy" ,
"base16-snazzy-min" ,
"base16-solar-flare-light" ,
"base16-solar-flare-light-min" ,
"base16-solar-flare" ,
"base16-solar-flare-min" ,
"base16-solarized-dark" ,
"base16-solarized-dark-min" ,
"base16-solarized-light" ,
"base16-solarized-light-min" ,
"base16-spacemacs" ,
"base16-spacemacs-min" ,
"base16-summercamp" ,
"base16-summercamp-min" ,
"base16-summerfruit-dark" ,
"base16-summerfruit-dark-min" ,
"base16-summerfruit-light" ,
"base16-summerfruit-light-min" ,
"base16-synth-midnight-terminal-dark" ,
"base16-synth-midnight-terminal-dark-min" ,
"base16-synth-midnight-terminal-light" ,
"base16-synth-midnight-terminal-light-min" ,
"base16-tango" ,
"base16-tango-min" ,
"base16-tender" ,
"base16-tender-min" ,
"base16-tomorrow-night" ,
"base16-tomorrow-night-min" ,
"base16-tomorrow" ,
"base16-tomorrow-min" ,
"base16-twilight" ,
"base16-twilight-min" ,
"base16-unikitty-dark" ,
"base16-unikitty-dark-min" ,
"base16-unikitty-light" ,
"base16-unikitty-light-min" ,
"base16-vulcan" ,
"base16-vulcan-min" ,
"base16-windows-10-light" ,
"base16-windows-10-light-min" ,
"base16-windows-10" ,
"base16-windows-10-min" ,
"base16-windows-95-light" ,
"base16-windows-95-light-min" ,
"base16-windows-95" ,
"base16-windows-95-min" ,
"base16-windows-high-contrast-light" ,
"base16-windows-high-contrast-light-min" ,
"base16-windows-high-contrast" ,
"base16-windows-high-contrast-min" ,
"base16-windows-nt-light" ,
"base16-windows-nt-light-min" ,
"base16-windows-nt" ,
"base16-windows-nt-min" ,
"base16-woodland" ,
"base16-woodland-min" ,
"base16-xcode-dusk" ,
"base16-xcode-dusk-min" ,
"base16-zenburn" ,
"base16-zenburn-min" ,
"brown-paper" ,
"brown-paper-min" ,
"codepen-embed" ,
"codepen-embed-min" ,
"color-brewer" ,
"color-brewer-min" ,
"dark" ,
"dark-min" ,
"default" ,
"default-min" ,
"devibeans" ,
"devibeans-min" ,
"docco" ,
"docco-min" ,
"far" ,
"far-min" ,
"felipec" ,
"felipec-min" ,
"foundation" ,
"foundation-min" ,
"github-dark-dimmed" ,
"github-dark-dimmed-min" ,
"github-dark" ,
"github-dark-min" ,
"github" ,
"github-min" ,
"gml" ,
"gml-min" ,
"googlecode" ,
"googlecode-min" ,
"gradient-dark" ,
"gradient-dark-min" ,
"gradient-light" ,
"gradient-light-min" ,
"grayscale" ,
"grayscale-min" ,
"hybrid" ,
"hybrid-min" ,
"idea" ,
"idea-min" ,
"intellij-light" ,
"intellij-light-min" ,
"ir-black" ,
"ir-black-min" ,
"isbl-editor-dark" ,
"isbl-editor-dark-min" ,
"isbl-editor-light" ,
"isbl-editor-light-min" ,
"kimbie-dark" ,
"kimbie-dark-min" ,
"kimbie-light" ,
"kimbie-light-min" ,
"lightfair" ,
"lightfair-min" ,
"lioshi" ,
"lioshi-min" ,
"magula" ,
"magula-min" ,
"mono-blue" ,
"mono-blue-min" ,
"monokai-sublime" ,
"monokai-sublime-min" ,
"monokai" ,
"monokai-min" ,
"night-owl" ,
"night-owl-min" ,
"nnfx-dark" ,
"nnfx-dark-min" ,
"nnfx-light" ,
"nnfx-light-min" ,
"nord" ,
"nord-min" ,
"obsidian" ,
"obsidian-min" ,
"panda-syntax-dark" ,
"panda-syntax-dark-min" ,
"panda-syntax-light" ,
"panda-syntax-light-min" ,
"paraiso-dark" ,
"paraiso-dark-min" ,
"paraiso-light" ,
"paraiso-light-min" ,
"pojoaque" ,
"pojoaque-min" ,
"purebasic" ,
"purebasic-min" ,
"qtcreator-dark" ,
"qtcreator-dark-min" ,
"qtcreator-light" ,
"qtcreator-light-min" ,
"rainbow" ,
"rainbow-min" ,
"routeros" ,
"routeros-min" ,
"school-book" ,
"school-book-min" ,
"shades-of-purple" ,
"shades-of-purple-min" ,
"srcery" ,
"srcery-min" ,
"stackoverflow-dark" ,
"stackoverflow-dark-min" ,
"stackoverflow-light" ,
"stackoverflow-light-min" ,
"sunburst" ,
"sunburst-min" ,
"tokyo-night-dark" ,
"tokyo-night-dark-min" ,
"tokyo-night-light" ,
"tokyo-night-light-min" ,
"tomorrow-night-blue" ,
"tomorrow-night-blue-min" ,
"tomorrow-night-bright" ,
"tomorrow-night-bright-min" ,
"vs" ,
"vs-min" ,
"vs2015" ,
"vs2015-min" ,
"xcode" ,
"xcode-min" ,
"xt256" ,
"xt256-min" ]

View file

@ -5,10 +5,12 @@ import { useConfig, useEvent } from "./hooks";
import { toPng, toBlob } from "html-to-image";
import download from "downloadjs";
import { getWebsocketHost } from "./utils";
import "./themes.css";
const CODE_EMPTY_PLACEHOLDER = `print "Hello, CodeSnap.nvim!"`;
const WATER_MARK_PLACEHOLDER = "CodeSnap.nvim";
const PREVIEW_TITLE_PLACEHOLDER = "CodeSnap.nvim";
const DEFAULT_THEME = "atom-one-dark";
function App() {
const [socketUrl] = useState(`ws://${getWebsocketHost()}/ws`);
@ -17,6 +19,7 @@ function App() {
const config = useConfig(event?.config_setup);
const frameRef = useRef<HTMLDivElement | null>(null);
const [isCopyButtonDisabled, setIsCopyButtonDisabled] = useState(false);
var theme = DEFAULT_THEME;
const handleCopyButtonClick = useCallback(async () => {
if (!frameRef.current) {
@ -69,6 +72,11 @@ function App() {
document.title = config?.preview_title ?? PREVIEW_TITLE_PLACEHOLDER;
}, [config?.preview_title]);
const changeTheme = (theme: string) => {
var new_theme = "theme-" + theme;
document.body.className = new_theme;
}
return (
<div className="w-full h-full flex flex-col items-center bg-deep-gray">
<p className="rainbow-text text-4xl font-extrabold mt-20">
@ -80,6 +88,7 @@ function App() {
onExportClick={handleExportClick}
onCopyClick={handleCopyButtonClick}
readyState={readyState}
onThemeChangeProp={changeTheme}
/>
<div id="frame" className="rounded-xl overflow-hidden">
<Frame

View file

@ -1,12 +1,13 @@
import { ConnectionStatus } from "./connection-status";
import { ReadyState } from "react-use-websocket";
import ThemeSelector from "./theme-selector";
import ThemeSelector from "./theme-selector/theme-selector";
interface ControlBarProps {
isCopyButtonDisabled: boolean;
onCopyClick(): void;
onExportClick(): void;
readyState: ReadyState;
onThemeChangeProp(theme: string): void;
}
export const ControlBar = ({
@ -14,6 +15,7 @@ export const ControlBar = ({
onExportClick,
isCopyButtonDisabled,
readyState,
onThemeChangeProp,
}: ControlBarProps) => {
return (
<div className="bg-neutral rounded-xl mb-2 p-1 flex flex-row items-center">
@ -60,7 +62,11 @@ export const ControlBar = ({
<path d="M360-240q-33 0-56.5-23.5T280-320v-480q0-33 23.5-56.5T360-880h360q33 0 56.5 23.5T800-800v480q0 33-23.5 56.5T720-240H360Zm0-80h360v-480H360v480ZM200-80q-33 0-56.5-23.5T120-160v-560h80v560h440v80H200Zm160-240v-480 480Z" />
</svg>{" "}
</button>
<ThemeSelector />
<ThemeSelector
onChangeTheme={(theme: string) => {
onThemeChangeProp(theme);
}}
/>
</div>
</div>
);

View file

@ -1,36 +0,0 @@
import React, { useState } from 'react';
const ThemeSelector = () => {
const [theme, setTheme] = useState('theme1');
const handleThemeChange = (event: React.ChangeEvent<HTMLSelectElement>) => {
setTheme(event.target.value);
console.log('Theme Changed:', event.target.value);
// Implement functionality to change theme here
};
return (
<div className="theme-dropdown">
<select
value={theme}
onChange={handleThemeChange}
className="text-white py-2 px-4 rounded-md focus:outline-none mr-1"
style={{
backgroundColor: '#191e24',
margin: '0.25rem',
paddingLeft: '1rem', paddingRight: '1rem',
height: '3rem',
fontFamily: 'inherit',
fontSize: '0.875rem',
fontWeight: '600',
color: 'hsl(220 13% 69%)' }}
>
<option value="theme1">Theme 1</option>
<option value="theme2">Theme 2</option>
</select>
</div>
);
};
export default ThemeSelector;

View file

@ -0,0 +1,59 @@
import React, { useEffect, useState } from 'react';
const ThemeSelector = ({ onChangeTheme }: { onChangeTheme: (theme: string) => void }) => {
const [theme, setTheme] = useState('theme1');
const fetchThemes: () => Promise<string[]> = () => {
const themes = fetch('/themes.json')
.then(response => response.json())
.then(data => {
console.log('Themes:', data);
return data;
});
return themes;
}
const handleThemeChange = (event: React.ChangeEvent<HTMLSelectElement>) => {
const newTheme = event.target.value;
setTheme(newTheme);
onChangeTheme(newTheme);
};
const [themes, setThemes] = useState<string[]>([]);
useEffect(() => {
fetchThemes().then((themes) => {
setThemes(themes);
});
}, []);
return (
<div className="theme-dropdown">
<select
value={theme}
onChange={handleThemeChange}
className="text-white py-2 px-4 rounded-md focus:outline-none mr-1"
style={{
backgroundColor: '#191e24',
margin: '0.25rem',
paddingLeft: '1rem', paddingRight: '1rem',
height: '3rem',
fontFamily: 'inherit',
fontSize: '0.875rem',
fontWeight: '600',
color: 'hsl(220 13% 69%)'
}}
>
{themes.map((theme: string) => (
<option value={theme}>{theme}</option>
))}
</select>
</div>
);
}
export default ThemeSelector;

View file

@ -37,7 +37,8 @@ export const Editor = ({
macStyleTitleBar = true,
}: EditorProps) => (
<div
className={`editor-shadow ${opacity ? "bg-one-dark-base/[.93]" : "bg-one-dark-base"} rounded-2xl p-5 pb-7 border-border-color border-[1px]`}
className={`hljs editor-shadow rounded-2xl p-5 pb-7 border-border-color border-[1px]`}
style = {{ opacity: opacity ? 0.93 : 1 }}
>
{macStyleTitleBar && <MacStyleTitleBar />}
<pre className="mt-4">

32152
snap-client/src/themes.css Normal file

File diff suppressed because it is too large Load diff

View file

@ -31,6 +31,10 @@ async fn root() -> impl Responder {
NamedFile::open_async("./public/index.html").await.unwrap()
}
async fn themes() -> impl Responder {
NamedFile::open_async("./public/themes.json").await.unwrap()
}
#[actix_web::main]
async fn main() -> std::io::Result<()> {
let neovim = Arc::new(Mutex::new(Neovim::new()));
@ -47,7 +51,8 @@ async fn main() -> std::io::Result<()> {
App::new()
.app_data(web::Data::new(server.clone()))
.route("/ws", web::get().to(index))
.service(web::resource("/").to(root))
.route("/", web::get().to(root))
.route("/themes.json", web::get().to(themes))
.service(Files::new("/public", "./public"))
.service(Files::new("/static", "./public/static"))
})