Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/svelte-brasil/svelte-routify-dotenv-sass-prettier-test
https://github.com/svelte-brasil/svelte-routify-dotenv-sass-prettier-test
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/svelte-brasil/svelte-routify-dotenv-sass-prettier-test
- Owner: svelte-brasil
- Created: 2020-05-17T18:06:56.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-03-04T18:44:19.000Z (almost 2 years ago)
- Last Synced: 2024-08-02T19:34:25.969Z (6 months ago)
- Language: Svelte
- Size: 2.55 MB
- Stars: 3
- Watchers: 8
- Forks: 0
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-svelte - svelte-routify-dotenv-sass-prettier-test - Template svelte configurado com Routify, Sass, Dotenv, prettier, jest e rollup. (Svelte Básico / Comunidade Global)
README
# about this template
# svelte app
This is a project template for [Svelte](https://svelte.dev) apps. It lives at https://github.com/sveltejs/template.
To create a new project based on this template using [degit](https://github.com/Rich-Harris/degit):
```bash
npx degit svelte-brasil/svelte-routfy-dotenv-sass-prettier-test svelte-app
cd svelte-app
```_Note that you will need to have [Node.js](https://nodejs.org) installed._
## sass
Sass was configurated with svelte-preprocess, it has a global variable.scss that we can use into any component
```js
//rollup.config.js
preprocess: autoPreprocess({
scss: {
data: `@import './src/styles/variables.scss';`,
},
})
```And to VSCode recognize the sass in svelte components, was created the svelte.config.js
```js
//svelte.config.js
const sass = require('node-sass')module.exports = {
preprocess: {
style: async ({ content, attributes }) => {
if (
!['text/sass', 'text/scss'].some(attributes.type) &&
!['sass', 'scss'].some(attributes.lang)
)
returnreturn new Promise((resolve, reject) => {
sass.render(
{
data: content,
sourceMap: true,
outFile: 'x', // this is necessary, but is ignored
},
(err, result) => {
if (err) return reject(err)resolve({
code: result.css.toString(),
map: result.map.toString(),
})
}
)
})
},
},
}
```## dotenv
To enviroments was made a configuration with dotenv, rollup-plugin-replace, fs and path.
```js
//rollup.config.jsconst mode = process.env.NODE_ENV || 'development'
dotenv.config()
const ENV_VARS = dotenv.parse(
fs.readFileSync(path.resolve(__dirname, `.env.${mode}`))
)const valuesEnvToReplace = () => {
return Object.entries(ENV_VARS).reduce((acc, [key, val]) => {
acc[`process.env.${key}`] = JSON.stringify(val)
return acc
}, {})
}export default {
//...others conf
plugins: [
//...others conf
replace({
//spread variables to replace
...valuesEnvToReplace(),
}),
],
}
```And
```env
//.env.development
APP_ENV=development
``````svelte
//.src/pages/index.svelteWe are in {process.env.APP_ENV} enviroment
```## prettier
```js
//prettier.config.js
module.exports = {
tabWidth: 2,
semi: false,
singleQuote: true,
trailingComma: 'es5',
plugins: ['svelte'],
}
```# routify-starter
Starter template for [Routify](https://github.com/sveltech/routify)
### Get started
To use this starter run `npx @sveltech/routify init` in an empty folder.
Alternatively, you can clone this repo.
### Npm scripts
| Syntax | Description |
| ------------- | ------------------------------------------------------------------------- |
| `dev` | Development (port 5000) |
| `dev-dynamic` | Development with dynamic imports |
| `build` | Build a bundled app with SSR + prerendering and dynamic imports |
| `serve` | Run after a build to preview. Serves SPA on 5000 and SSR on 5005 |
| `deploy:*` | Deploy to netlify or now |
| `export` | Create static pages from content in dist folder (used by `npm run build`) |### SSR and pre-rendering
SSR and pre-rendering are included in the default build process.
`npm run deploy:(now|netlify)` will deploy the app with SSR and prerendering included.
To render async data, call the `$ready()` helper whenever your data is ready.
If \$ready() is present, rendering will be delayed till the function has been called.
Otherwise it will be rendered instantly.
See [src/pages/example/api/[showId].svelte](https://github.com/sveltech/routify-starter/blob/master/src/pages/example/api/%5BshowId%5D.svelte) for an example.
### Production
- For SPA or SSR apps please make sure that url rewrite is enabled on the server.
- For SPA redirect to `__dynamic.html`.
- For SSR redirect to the lambda function or express server.### Issues?
File on Github! See https://github.com/sveltech/routify/issues .