8
0
Fork 0
mirror of https://gitlab2.federez.net/re2o/re2o synced 2024-09-12 01:03:09 +00:00

Add base VueJS configuration

This commit is contained in:
Alexandre Iooss 2020-04-22 10:54:35 +02:00
parent 17fbaab502
commit 0dc3329f7a
No known key found for this signature in database
GPG key ID: 6C79278F3FCDCC02
5 changed files with 127 additions and 6 deletions

19
.gitignore vendored
View file

@ -27,20 +27,27 @@ venv/
ENV/
env.bak/
venv.bak/
node_modules
# Spyder project settings
# Editor directories and files
.ropeproject
.spyderproject
.spyproject
.idea
.vscode
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?
# Rope project settings
.ropeproject
# PyCharm project settings
.idea/
# Do not pin versions
yarn.lock
# Django statics
static_files/
static/logo/
static/bundles/
# re2o specific
settings_local.py

50
package.json Normal file
View file

@ -0,0 +1,50 @@
{
"name": "re2o",
"private": true,
"repository": "git@gitlab.federez.net:re2o/re2o.git",
"license": "GPL-3.0+",
"scripts": {
"build": "vue-cli-service build --inline-vue --target wc-async 'static/components/*.vue'",
"lint": "vue-cli-service lint"
},
"dependencies": {
"core-js": "^3.6.4",
"vue": "^2.6.11"
},
"devDependencies": {
"@vue/cli-plugin-babel": "~4.3.0",
"@vue/cli-plugin-eslint": "~4.3.0",
"@vue/cli-service": "~4.3.0",
"babel-eslint": "^10.1.0",
"eslint": "^6.7.2",
"eslint-plugin-vue": "^6.2.2",
"sass": "^1.26.3",
"sass-loader": "^8.0.2",
"vue-template-compiler": "^2.6.11",
"webpack-bundle-tracker": "^1.0.0-alpha.1"
},
"babel": {
"presets": [
"@vue/cli-plugin-babel/preset"
]
},
"eslintConfig": {
"root": true,
"env": {
"node": true
},
"extends": [
"plugin:vue/essential",
"eslint:recommended"
],
"parserOptions": {
"parser": "babel-eslint"
},
"rules": {}
},
"browserslist": [
"> 1%",
"last 2 versions",
"not dead"
]
}

View file

@ -0,0 +1,20 @@
<template>
<div class="hello">
<h3>
Hello World from Re2o VueJS
</h3>
</div>
</template>
<script>
export default {
name: "HelloWorld"
};
</script>
<!-- Add "scoped" attribute to limit SCSS to this component only -->
<style scoped lang="scss">
h3 {
margin: 40px 0 0;
}
</style>

View file

@ -0,0 +1,21 @@
<template>
<div class="hello">
<h3>
One Hello World wasn't enough :p
</h3>
</div>
</template>
<script>
export default {
name: "HelloWorld"
};
</script>
<!-- Add "scoped" attribute to limit SCSS to this component only -->
<style scoped lang="scss">
h3 {
margin: 40px 0 0;
background-color: #ff0000;
}
</style>

23
vue.config.js Normal file
View file

@ -0,0 +1,23 @@
/**
* Re2o VueJS configuration
*
* Each VueJS components in static/components are compiled into asynchronous
* chunks in static/bundles.
* Then you can use for exemple <re2o-hello-world></re2o-hello-world> to call
* the HelloWorld component.
*/
const BundleTracker = require("webpack-bundle-tracker");
module.exports = {
// Output to Django statics
outputDir: './static/bundles/',
// Customize Webpack
chainWebpack: config => {
// Create file for django-webpack-loader
config
.plugin('BundleTracker')
.use(BundleTracker, [{ filename: './webpack-stats.json' }])
}
};