export const COUNTER_COMPONENTS = { preact: { filename: `src/components/PreactCounter.jsx`, content: `import { useState } from 'preact/hooks'; export default function PreactCounter() { const [count, setCount] = useState(0); const add = () => setCount((i) => i + 1); const subtract = () => setCount((i) => i - 1); return (
{count}
); } `, }, react: { filename: `src/components/ReactCounter.jsx`, content: `import { useState } from 'react'; export default function ReactCounter() { const [count, setCount] = useState(0); const add = () => setCount((i) => i + 1); const subtract = () => setCount((i) => i - 1); return (
{count}
); } `, }, solid: { filename: `src/components/SolidCounter.jsx`, content: `import { createSignal } from "solid-js"; export default function SolidCounter() { const [count, setCount] = createSignal(0); const add = () => setCount(count() + 1); const subtract = () => setCount(count() - 1); return (
{count()}
); } `, }, svelte: { filename: `src/components/SvelteCounter.svelte`, content: `
{ count }
`, }, vue: { filename: `src/components/VueCounter.vue`, content: ` `, }, }; export const FRAMEWORKS = [ { title: 'preact', value: '@astrojs/preact', }, { title: 'react', value: 'react', }, { title: 'solid', value: 'solid', }, { title: 'svelte', value: 'svelte', }, { title: 'vue', value: 'vue', }, ];