aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-03-19 22:46:57 +0100
committerArmand Philippot <git@armandphilippot.com>2022-03-19 22:46:57 +0100
commit3038cdeb6287720a42b905fc9cc09eda658f12cf (patch)
tree06f9ddff916ee5b6207d05f6135e82baf3157f37
parentca734febb23133e2b405cdc69e58d9cf6011298f (diff)
feat: add vue small apps
-rw-r--r--.gitmodules3
-rwxr-xr-xconfig/build.sh39
m---------public/projects/vue-small-apps0
-rw-r--r--src/js/config/projects.js20
4 files changed, 59 insertions, 3 deletions
diff --git a/.gitmodules b/.gitmodules
index a7f2070..7578b82 100644
--- a/.gitmodules
+++ b/.gitmodules
@@ -7,3 +7,6 @@ url = git@github.com:ArmandPhilippot/react-small-apps.git
[submodule "public/projects/angular-small-apps"]
path = public/projects/angular-small-apps
url = git@github.com:ArmandPhilippot/angular-small-apps.git
+[submodule "public/projects/vue-small-apps"]
+ path = public/projects/vue-small-apps
+ url = git@github.com:ArmandPhilippot/vue-small-apps.git
diff --git a/config/build.sh b/config/build.sh
index 60f4ccb..9bf8230 100755
--- a/config/build.sh
+++ b/config/build.sh
@@ -1,13 +1,14 @@
#!/usr/bin/env bash
#
# Build
-# Build all Angular & React projects.
+# Build all Angular, React & Vue projects.
###############################################################################
# 1.0. Config
###############################################################################
_ANGULAR_PROJECTS="projects/angular-small-apps"
_REACT_PROJECTS="projects/react-small-apps"
+_VUE_PROJECTS="projects/vue-small-apps"
###############################################################################
# 2.0. Helpers
@@ -115,7 +116,38 @@ setup_react_projects() {
}
###############################################################################
-# 5.0. Main
+# 5.0. Vue
+###############################################################################
+
+install_vue_dependencies() {
+ if [ ! -d "./public/${_VUE_PROJECTS}" ]; then
+ error "Vue projects are missing."
+ printf "Exit.\n"
+ exit 1
+ fi
+
+ cd "./public/${_VUE_PROJECTS}" || exit
+ yarn
+ cd "$OLDPWD" || exit
+}
+
+build_vue_app() {
+ [ $# -ne 1 ] && error_unexpected
+
+ cd "./public/${_VUE_PROJECTS}" || exit
+ PUBLIC_URL="/${_VUE_PROJECTS}/apps/${1}/dist/" yarn --cwd "apps/${1}" run build
+ info "${1} built."
+ cd "$OLDPWD" || exit
+}
+
+setup_vue_projects() {
+ install_vue_dependencies
+ build_vue_app "typing"
+ success "Vue apps are ready."
+}
+
+###############################################################################
+# 6.0. Main
###############################################################################
# Check if Yarn is installed.
@@ -130,11 +162,12 @@ is_yarn_installed() {
fi
}
-# Build Angular & React projects.
+# Build Angular, React & Vue projects.
build_all_projects() {
is_yarn_installed
setup_angular_projects
setup_react_projects
+ setup_vue_projects
success "All projects have been built."
}
diff --git a/public/projects/vue-small-apps b/public/projects/vue-small-apps
new file mode 160000
+Subproject 5e60ef7741b2e2b0163dcd1dd85df936705157c
diff --git a/src/js/config/projects.js b/src/js/config/projects.js
index 5125c18..5c6bbf8 100644
--- a/src/js/config/projects.js
+++ b/src/js/config/projects.js
@@ -220,6 +220,26 @@ const projects = [
technologies: ['React', 'React router', 'Redux'],
},
{
+ id: 'typing',
+ name: 'Typing',
+ description: {
+ en: 'You can practice to type as quickly and accurately as possible a random list of words. Three dictionaries are available.\n\nLogin: demo\nPassword: demo',
+ fr: 'Vous pouvez vous entrainer à taper le plus rapidement une liste de mots générées alétatoirement. Trois dictionnaires sont disponibles.\n\nLogin : demo\nMot de passe : demo',
+ },
+ path: './projects/vue-small-apps/apps/typing/dist/',
+ repo: [
+ {
+ name: 'Github',
+ url: 'https://github.com/ArmandPhilippot/vue-small-apps/tree/main/apps/typing',
+ },
+ {
+ name: 'Gitlab',
+ url: 'https://gitlab.com/ArmandPhilippot/vue-small-apps/-/tree/main/apps/typing',
+ },
+ ],
+ technologies: ['Vue', 'Vue router'],
+ },
+ {
id: 'users-list',
name: 'Users list',
description: {