diff options
Diffstat (limited to 'examples/framework-multiple')
| -rw-r--r-- | examples/framework-multiple/.gitignore | 18 | ||||
| -rw-r--r-- | examples/framework-multiple/.npmrc | 2 | ||||
| -rw-r--r-- | examples/framework-multiple/README.md | 7 | ||||
| -rw-r--r-- | examples/framework-multiple/package.json | 15 | ||||
| -rw-r--r-- | examples/framework-multiple/src/components/A.astro | 3 | ||||
| -rw-r--r-- | examples/framework-multiple/src/components/B.astro | 3 | ||||
| -rw-r--r-- | examples/framework-multiple/src/components/PreactCounter.tsx | 20 | ||||
| -rw-r--r-- | examples/framework-multiple/src/components/ReactCounter.jsx | 19 | ||||
| -rw-r--r-- | examples/framework-multiple/src/components/SvelteCounter.svelte | 22 | ||||
| -rw-r--r-- | examples/framework-multiple/src/components/VueCounter.vue | 27 | ||||
| -rw-r--r-- | examples/framework-multiple/src/components/index.ts | 2 | ||||
| -rw-r--r-- | examples/framework-multiple/src/pages/index.astro | 58 | 
12 files changed, 196 insertions, 0 deletions
| diff --git a/examples/framework-multiple/.gitignore b/examples/framework-multiple/.gitignore new file mode 100644 index 000000000..d436c6dad --- /dev/null +++ b/examples/framework-multiple/.gitignore @@ -0,0 +1,18 @@ +# build output +dist + +# dependencies +node_modules/ +.snowpack/ + +# logs +npm-debug.log* +yarn-debug.log* +yarn-error.log* + +# environment variables +.env +.env.production + +# macOS-specific files +.DS_Store diff --git a/examples/framework-multiple/.npmrc b/examples/framework-multiple/.npmrc new file mode 100644 index 000000000..0cc653b2c --- /dev/null +++ b/examples/framework-multiple/.npmrc @@ -0,0 +1,2 @@ +## force pnpm to hoist  +shamefully-hoist = true
\ No newline at end of file diff --git a/examples/framework-multiple/README.md b/examples/framework-multiple/README.md new file mode 100644 index 000000000..42f8e2b1f --- /dev/null +++ b/examples/framework-multiple/README.md @@ -0,0 +1,7 @@ +# Using Preact with Astro + +This example showcases Astro's built-in support for multiple frameworks ([React](https://reactjs.org), [Preact](https://preactjs.com), [Svelte](https://svelte.dev), and [Vue (`v3.x`)](https://v3.vuejs.org/)). + +No configuration is needed to enable these frameworks—just start writing components in `src/components`. + +> **Note**: If used, components _must_ include a JSX factory (ex. `import React from "react"`, `import { h } from "preact"`). Astro is unable to determine which framework is used without having the [JSX factory](https://mariusschulz.com/blog/per-file-jsx-factories-in-typescript#what-is-a-jsx-factory) in scope. diff --git a/examples/framework-multiple/package.json b/examples/framework-multiple/package.json new file mode 100644 index 000000000..e0845d1ca --- /dev/null +++ b/examples/framework-multiple/package.json @@ -0,0 +1,15 @@ +{ +  "name": "@astrojs/example-framework-multiple", +  "private": true, +  "version": "0.0.1", +  "scripts": { +    "start": "astro dev", +    "build": "astro build" +  }, +  "devDependencies": { +    "astro": "^0.15.1" +  }, +  "snowpack": { +    "workspaceRoot": "../.." +  } +} diff --git a/examples/framework-multiple/src/components/A.astro b/examples/framework-multiple/src/components/A.astro new file mode 100644 index 000000000..702a4be35 --- /dev/null +++ b/examples/framework-multiple/src/components/A.astro @@ -0,0 +1,3 @@ +<div class="children"> +  <h1>Hello Astro (A)</h1> +</div> diff --git a/examples/framework-multiple/src/components/B.astro b/examples/framework-multiple/src/components/B.astro new file mode 100644 index 000000000..9022cb372 --- /dev/null +++ b/examples/framework-multiple/src/components/B.astro @@ -0,0 +1,3 @@ +<div class="children"> +  <h1>Hello Astro (B)</h1> +</div> diff --git a/examples/framework-multiple/src/components/PreactCounter.tsx b/examples/framework-multiple/src/components/PreactCounter.tsx new file mode 100644 index 000000000..be4ddb6ce --- /dev/null +++ b/examples/framework-multiple/src/components/PreactCounter.tsx @@ -0,0 +1,20 @@ +import { h, Fragment } from 'preact'; +import { useState } from 'preact/hooks'; + +/** a counter written in Preact */ +export function PreactCounter({ children }) { +  const [count, setCount] = useState(0); +  const add = () => setCount((i) => i + 1); +  const subtract = () => setCount((i) => i - 1); + +  return ( +    <> +      <div className="counter"> +        <button onClick={subtract}>-</button> +        <pre>{count}</pre> +        <button onClick={add}>+</button> +      </div> +      <div className="children">{children}</div> +    </> +  ); +} diff --git a/examples/framework-multiple/src/components/ReactCounter.jsx b/examples/framework-multiple/src/components/ReactCounter.jsx new file mode 100644 index 000000000..06d8f2513 --- /dev/null +++ b/examples/framework-multiple/src/components/ReactCounter.jsx @@ -0,0 +1,19 @@ +import React, { useState } from 'react'; + +/** a counter written in React */ +export function Counter({ children }) { +  const [count, setCount] = useState(0); +  const add = () => setCount((i) => i + 1); +  const subtract = () => setCount((i) => i - 1); + +  return ( +    <> +      <div className="counter"> +        <button onClick={subtract}>-</button> +        <pre>{count}</pre> +        <button onClick={add}>+</button> +      </div> +      <div className="children">{children}</div> +    </> +  ); +} diff --git a/examples/framework-multiple/src/components/SvelteCounter.svelte b/examples/framework-multiple/src/components/SvelteCounter.svelte new file mode 100644 index 000000000..8d6b3f5e1 --- /dev/null +++ b/examples/framework-multiple/src/components/SvelteCounter.svelte @@ -0,0 +1,22 @@ + +<script> +  let children; +  let count = 0; + +  function add() { +		count += 1; +	} + +  function subtract() { +		count -= 1; +	} +</script> + +<div class="counter"> +    <button on:click={subtract}>-</button> +    <pre>{ count }</pre> +    <button on:click={add}>+</button> +</div> +<div class="children"> +    <slot /> +</div> diff --git a/examples/framework-multiple/src/components/VueCounter.vue b/examples/framework-multiple/src/components/VueCounter.vue new file mode 100644 index 000000000..8179fb1d9 --- /dev/null +++ b/examples/framework-multiple/src/components/VueCounter.vue @@ -0,0 +1,27 @@ +<template> +  <div class="counter"> +      <button @click="subtract()">-</button> +      <pre>{{ count }}</pre> +      <button @click="add()">+</button> +  </div> +  <div class="children"> +      <slot /> +  </div> +</template> + +<script> +import { ref } from 'vue'; +export default { +  setup() { +    const count = ref(0) +    const add = () => count.value = count.value + 1; +    const subtract = () => count.value = count.value - 1; + +    return { +      count, +      add, +      subtract +    } +  } +} +</script> diff --git a/examples/framework-multiple/src/components/index.ts b/examples/framework-multiple/src/components/index.ts new file mode 100644 index 000000000..4077dcacd --- /dev/null +++ b/examples/framework-multiple/src/components/index.ts @@ -0,0 +1,2 @@ +export { default as A } from './A.astro'; +export { default as B } from './B.astro'; diff --git a/examples/framework-multiple/src/pages/index.astro b/examples/framework-multiple/src/pages/index.astro new file mode 100644 index 000000000..3fbef72e0 --- /dev/null +++ b/examples/framework-multiple/src/pages/index.astro @@ -0,0 +1,58 @@ +--- +import { A, B as Renamed } from '../components'; +import * as react from '../components/ReactCounter.jsx'; +import { PreactCounter } from '../components/PreactCounter.tsx'; +import VueCounter from '../components/VueCounter.vue'; +import SvelteCounter from '../components/SvelteCounter.svelte'; +--- + +<html> +  <head> +    <meta charset="utf-8" /> +    <meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover" /> +    <style> +        :global(:root) { +            font-family: system-ui; +            padding: 2em 0; +        } +        :global(.counter) { +            display: grid; +            grid-template-columns: repeat(3, minmax(0, 1fr)); +            place-items: center; +            font-size: 2em; +            margin-top: 2em; +        } +        :global(.children) { +            display: grid; +            place-items: center; +            margin-bottom: 2em; +        } +    </style> +  </head> +  <body> +      <main> + +        <react.Counter:visible> +            <h1>Hello React!</h1> +            <p>What's up?</p> +        </react.Counter:visible> + +        <PreactCounter:visible> +          <h1>Hello Preact!</h1> +        </PreactCounter:visible> + +        <VueCounter:visible> +            <h1>Hello Vue!</h1> +        </VueCounter:visible> + +        <SvelteCounter:visible> +            <h1>Hello Svelte!</h1> +        </SvelteCounter:visible> + +        <A /> +         +        <Renamed /> + +      </main> +  </body> +</html> | 
