Patch: Example Nanostores Update (#1955)
* Mention astro.new in docs (#1935) * Fix - Deprecated nanostores functions createStore and getValue is deprecated in nanostores, changed it to atom and atom.get() * fix: change code to nanostores non-deprecated functions Co-authored-by: Jonathan Neal <jonathantneal@hotmail.com>
This commit is contained in:
parent
b92b8ae3ed
commit
1ec3f28b63
9 changed files with 49 additions and 48 deletions
|
@ -30,7 +30,9 @@ npm init astro -- --template [GITHUB_USER]/[REPO_NAME]/path/to/example
|
||||||
|
|
||||||
### Online Playgrounds
|
### Online Playgrounds
|
||||||
|
|
||||||
If you're interested in playing around with Astro in the browser, you can use an online code editor like Stackblitz, CodeSandbox, Gitpod, or GitHub Codespaces. Click the "Open in Stackblitz" link in any of the examples in our [examples library](https://github.com/snowpackjs/astro/tree/main/examples). Or, [click here](https://stackblitz.com/fork/astro) to start a new project in [Stackblitz](https://stackblitz.com/fork/astro).
|
If you're interested in playing around with Astro in the browser, you can instantly spin up a new Astro project with our UI at [astro.new](https://astro.new/).
|
||||||
|
|
||||||
|
You can try Astro in online code editors like Stackblitz, CodeSandbox, Gitpod, and GitHub Codespaces. Click the "Open in Stackblitz" link in any of the examples in our [examples library](https://github.com/snowpackjs/astro/tree/main/examples). Or, [click here](https://stackblitz.com/fork/astro) to start a new project in [Stackblitz](https://stackblitz.com/fork/astro).
|
||||||
|
|
||||||
## Learn Astro
|
## Learn Astro
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,10 @@
|
||||||
"preview": "astro preview"
|
"preview": "astro preview"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"nanostores": "^0.3.3"
|
"@nanostores/preact": "^0.1.2",
|
||||||
|
"@nanostores/react": "^0.1.2",
|
||||||
|
"@nanostores/vue": "^0.4.1",
|
||||||
|
"nanostores": "^0.5.6"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@astrojs/renderer-solid": "^0.2.0",
|
"@astrojs/renderer-solid": "^0.2.0",
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { h, Fragment } from 'preact';
|
import { h, Fragment } from 'preact';
|
||||||
import { useStore } from 'nanostores/preact';
|
import { useStore } from '@nanostores/preact';
|
||||||
|
|
||||||
import { admins } from '../store/admins.js';
|
import { admins } from '../store/admins.js';
|
||||||
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { useStore } from 'nanostores/react';
|
import { useStore } from '@nanostores/react';
|
||||||
|
|
||||||
import { admins } from '../store/admins.js';
|
import { admins } from '../store/admins.js';
|
||||||
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
<script>
|
<script>
|
||||||
import { getValue } from 'nanostores'
|
|
||||||
|
|
||||||
import { users } from '../store/users.js';
|
import { users } from '../store/users.js';
|
||||||
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
||||||
|
|
||||||
const list = getValue(users).filter(user => user.isAdmin);
|
const list = users.get().filter((user) => user.isAdmin);
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<h1>Svelte</h1>
|
<h1>Svelte</h1>
|
||||||
|
|
|
@ -1,21 +1,23 @@
|
||||||
<template>
|
<template>
|
||||||
<h1>Vue</h1>
|
|
||||||
<ul>
|
|
||||||
<li v-for="user in list" :key="user.name">
|
|
||||||
{{ JSON.stringify(user, null, 2) }}
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<div>
|
<div>
|
||||||
<h3>Counter</h3>
|
<h1>Vue</h1>
|
||||||
<p>{{ count }}</p>
|
<ul>
|
||||||
<button @click="decreaseCounter">-1</button>
|
<li v-for="user in list" :key="user.name">
|
||||||
<button @click="increaseCounter">+1</button>
|
{{ JSON.stringify(user, null, 2) }}
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<div>
|
||||||
|
<h3>Counter</h3>
|
||||||
|
<p>{{ count }}</p>
|
||||||
|
<button @click="decreaseCounter">-1</button>
|
||||||
|
<button @click="increaseCounter">+1</button>
|
||||||
|
</div>
|
||||||
|
<br />
|
||||||
</div>
|
</div>
|
||||||
<br />
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { useStore } from 'nanostores/vue';
|
import { useStore } from '@nanostores/vue';
|
||||||
|
|
||||||
import { admins } from '../store/admins.js';
|
import { admins } from '../store/admins.js';
|
||||||
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
import { counter, increaseCounter, decreaseCounter } from '../store/counter.js';
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import { createDerived } from 'nanostores';
|
import { computed } from 'nanostores';
|
||||||
|
|
||||||
import { users } from './users.js';
|
import { users } from './users.js';
|
||||||
|
|
||||||
const admins = createDerived(users, (list) => list.filter((user) => user.isAdmin));
|
const admins = computed(users, (list) => list.filter((user) => user.isAdmin));
|
||||||
|
|
||||||
export { admins };
|
export { admins };
|
||||||
|
|
|
@ -1,15 +1,13 @@
|
||||||
import { createStore, getValue } from 'nanostores';
|
import { atom } from 'nanostores';
|
||||||
|
|
||||||
const counter = createStore(() => {
|
const counter = atom(0);
|
||||||
counter.set(0);
|
|
||||||
});
|
|
||||||
|
|
||||||
function increaseCounter() {
|
function increaseCounter() {
|
||||||
counter.set(getValue(counter) + 1);
|
counter.set(counter.get() + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
function decreaseCounter() {
|
function decreaseCounter() {
|
||||||
counter.set(getValue(counter) - 1);
|
counter.set(counter.get() - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
export { counter, increaseCounter, decreaseCounter };
|
export { counter, increaseCounter, decreaseCounter };
|
||||||
|
|
|
@ -1,27 +1,25 @@
|
||||||
import { createStore, getValue } from 'nanostores';
|
import { atom } from 'nanostores';
|
||||||
|
|
||||||
const users = createStore(() => {
|
const users = atom([
|
||||||
users.set([
|
{
|
||||||
{
|
name: 'Imanadmin',
|
||||||
name: 'Imanadmin',
|
age: 2,
|
||||||
age: 2,
|
isAdmin: true,
|
||||||
isAdmin: true,
|
},
|
||||||
},
|
{
|
||||||
{
|
name: 'Imnotadmin',
|
||||||
name: 'Imnotadmin',
|
age: 35,
|
||||||
age: 35,
|
isAdmin: false,
|
||||||
isAdmin: false,
|
},
|
||||||
},
|
{
|
||||||
{
|
name: 'Wowsomuchadmin',
|
||||||
name: 'Wowsomuchadmin',
|
age: 3634,
|
||||||
age: 3634,
|
isAdmin: true,
|
||||||
isAdmin: true,
|
},
|
||||||
},
|
]);
|
||||||
]);
|
|
||||||
});
|
|
||||||
|
|
||||||
const addUser = function addUser(user) {
|
const addUser = function addUser(user) {
|
||||||
users.set([...getValue(users), user]);
|
users.set([...users.get(), user]);
|
||||||
};
|
};
|
||||||
|
|
||||||
export { users, addUser };
|
export { users, addUser };
|
||||||
|
|
Loading…
Reference in a new issue