forked from mirror/codesnap.nvim
[Feat] finished theme changer on preview page
This commit is contained in:
parent
7a27b2a899
commit
2af46371e2
8 changed files with 32732 additions and 40 deletions
496
snap-client/public/themes.json
Normal file
496
snap-client/public/themes.json
Normal 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" ]
|
|
@ -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
|
||||
|
|
|
@ -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>
|
||||
);
|
||||
|
|
|
@ -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;
|
||||
|
|
@ -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;
|
||||
|
|
@ -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
32152
snap-client/src/themes.css
Normal file
File diff suppressed because it is too large
Load diff
|
@ -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"))
|
||||
})
|
||||
|
|
Loading…
Reference in a new issue