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:
Withered Flowers 2021-11-22 00:31:42 +07:00 committed by GitHub
parent b92b8ae3ed
commit 1ec3f28b63
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 49 additions and 48 deletions

View file

@ -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

View file

@ -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",

View file

@ -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';

View file

@ -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';

View file

@ -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>

View file

@ -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';

View file

@ -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 };

View file

@ -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 };

View file

@ -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 };