Compare commits
	
		
			11 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c2b615294e | |||
| c64762831f | |||
| 9b446abc1f | |||
| 5d974e562e | |||
| a030f6b738 | |||
| 1249248a9d | |||
| 0bd6d543bf | |||
| 92d7bfd594 | |||
| 917cb6be34 | |||
| d159cb59be | |||
| 9812d79d4d | 
							
								
								
									
										26
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -2,9 +2,35 @@ | |||||||
|  |  | ||||||
| All notable changes to this project will be documented in this file. Dates are displayed in UTC. | All notable changes to this project will be documented in this file. Dates are displayed in UTC. | ||||||
|  |  | ||||||
|  | #### [0.7.7](https://git.odit.services/lfk/selfservice/compare/0.7.6...0.7.7) | ||||||
|  |  | ||||||
|  | - fix: registration w/o phone [`c647628`](https://git.odit.services/lfk/selfservice/commit/c64762831f1e6dffc9cbc3f531e23435b455a5a9) | ||||||
|  |  | ||||||
|  | #### [0.7.6](https://git.odit.services/lfk/selfservice/compare/0.7.5...0.7.6) | ||||||
|  |  | ||||||
|  | > 31 January 2023 | ||||||
|  |  | ||||||
|  | - update texts of pdf generation status toasts [`#44`](https://git.odit.services/lfk/selfservice/issues/44) | ||||||
|  | - 🚀Bumped version to v0.7.6 [`9b446ab`](https://git.odit.services/lfk/selfservice/commit/9b446abc1fa231bb1f5a78c545400c617eaa4af5) | ||||||
|  | - update release script [`5d974e5`](https://git.odit.services/lfk/selfservice/commit/5d974e562ed1ed5aeac579afe000c2dca945ff71) | ||||||
|  |  | ||||||
|  | #### [0.7.5](https://git.odit.services/lfk/selfservice/compare/0.7.4...0.7.5) | ||||||
|  |  | ||||||
|  | > 30 January 2023 | ||||||
|  |  | ||||||
|  | - fix: relativ links [`917cb6b`](https://git.odit.services/lfk/selfservice/commit/917cb6be340844bcc2318bf73cec37c3c831fd5d) | ||||||
|  | - 🚀Bumped version to v0.7.5 [`1249248`](https://git.odit.services/lfk/selfservice/commit/1249248a9d3e0d72665bca6871a651f2491a4039) | ||||||
|  | - 2023 [`9812d79`](https://git.odit.services/lfk/selfservice/commit/9812d79d4de820ce791f69634c5861f4f04ad7f1) | ||||||
|  | - update nginx base [`0bd6d54`](https://git.odit.services/lfk/selfservice/commit/0bd6d543bf60b7a333b96d5d319269d4bf50db96) | ||||||
|  | - updated base node image [`92d7bfd`](https://git.odit.services/lfk/selfservice/commit/92d7bfd59407273f86809b53ffc9f67fb8ba0ec7) | ||||||
|  | - AGB link [`d159cb5`](https://git.odit.services/lfk/selfservice/commit/d159cb59be35f963abc89c42732ba6110d27830c) | ||||||
|  |  | ||||||
| #### [0.7.4](https://git.odit.services/lfk/selfservice/compare/0.7.3...0.7.4) | #### [0.7.4](https://git.odit.services/lfk/selfservice/compare/0.7.3...0.7.4) | ||||||
|  |  | ||||||
|  | > 21 April 2021 | ||||||
|  |  | ||||||
| - Updated dronefile [`9c9ceaa`](https://git.odit.services/lfk/selfservice/commit/9c9ceaa6664f6ea21a536a12f04e552156e81da4) | - Updated dronefile [`9c9ceaa`](https://git.odit.services/lfk/selfservice/commit/9c9ceaa6664f6ea21a536a12f04e552156e81da4) | ||||||
|  | - 🚀Bumped version to v0.7.4 [`4663214`](https://git.odit.services/lfk/selfservice/commit/4663214ede3880386b5389885e32c953571290e6) | ||||||
|  |  | ||||||
| #### [0.7.3](https://git.odit.services/lfk/selfservice/compare/0.7.2...0.7.3) | #### [0.7.3](https://git.odit.services/lfk/selfservice/compare/0.7.2...0.7.3) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| FROM node:15.9.0-alpine3.13 | FROM registry.odit.services/hub/library/node:15.9.0-alpine3.13 | ||||||
| WORKDIR /app | WORKDIR /app | ||||||
| COPY . . | COPY . . | ||||||
| RUN yarn | RUN yarn | ||||||
| RUN yarn build | RUN yarn build | ||||||
| RUN yarn postbuild | RUN yarn postbuild | ||||||
| # final image | # final image | ||||||
| FROM fholzer/nginx-brotli:v1.19.1 | FROM registry.odit.services/library/nginx-brotli:3.15 | ||||||
| COPY --from=0 /app/dist /usr/share/nginx/html | COPY --from=0 /app/dist /usr/share/nginx/html | ||||||
| COPY ./nginx.conf /etc/nginx/nginx.conf | COPY ./nginx.conf /etc/nginx/nginx.conf | ||||||
| @@ -1,10 +1,10 @@ | |||||||
| { | { | ||||||
| 	"name": "@odit/lfk-selfservice", | 	"name": "@odit/lfk-selfservice", | ||||||
| 	"version": "0.7.4", | 	"version": "0.7.7", | ||||||
| 	"scripts": { | 	"scripts": { | ||||||
| 		"dev": "vite", | 		"dev": "vite", | ||||||
| 		"build": "vite build", | 		"build": "vite build", | ||||||
| 		"release": "release-it --only-version", | 		"release": "release-it", | ||||||
| 		"postbuild": "node env_fix.js" | 		"postbuild": "node env_fix.js" | ||||||
| 	}, | 	}, | ||||||
| 	"dependencies": { | 	"dependencies": { | ||||||
| @@ -36,7 +36,7 @@ | |||||||
| 			"requireCleanWorkingDir": false, | 			"requireCleanWorkingDir": false, | ||||||
| 			"commitMessage": "🚀Bumped version to v${version}", | 			"commitMessage": "🚀Bumped version to v${version}", | ||||||
| 			"requireBranch": "dev", | 			"requireBranch": "dev", | ||||||
| 			"push": false, | 			"push": true, | ||||||
| 			"tag": true, | 			"tag": true, | ||||||
| 			"tagName": null, | 			"tagName": null, | ||||||
| 			"tagAnnotation": "v${version}" | 			"tagAnnotation": "v${version}" | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
|   <footer class="text-gray-400 bg-gray-900 body-font"> |   <footer class="text-gray-400 bg-gray-900 body-font"> | ||||||
|     <div class="container px-5 py-8 mx-auto flex items-center sm:flex-row flex-col"> |     <div class="container px-5 py-8 mx-auto flex items-center sm:flex-row flex-col"> | ||||||
|       <p class="text-sm text-gray-400 sm:ml-4 sm:pl-4 sm:py-2 sm:mt-0 mt-4"> |       <p class="text-sm text-gray-400 sm:ml-4 sm:pl-4 sm:py-2 sm:mt-0 mt-4"> | ||||||
|         Lauf für Kaya! Selfservice - Copyright © 2021 + proudly powered by |         Lauf für Kaya! Selfservice - Copyright © 2023 + proudly powered by | ||||||
|         <a |         <a | ||||||
|           class="underline" |           class="underline" | ||||||
|           target="_blank" |           target="_blank" | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ | |||||||
|               placeholder="Passwort" |               placeholder="Passwort" | ||||||
|             /> |             /> | ||||||
|             <div class="absolute inset-y-0 right-0 pr-3 flex items-center text-sm"> |             <div class="absolute inset-y-0 right-0 pr-3 flex items-center text-sm"> | ||||||
|               <a href="./reset" class="text-gray-900 underline">Passwort vergessen?</a> |               <a href="/selfservice/reset" class="text-gray-900 underline">Passwort vergessen?</a> | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| @@ -80,7 +80,7 @@ | |||||||
|         </div> |         </div> | ||||||
|         <div class="mt-6"> |         <div class="mt-6"> | ||||||
|           <a |           <a | ||||||
|             href="./register" |             href="/selfservice/register" | ||||||
|             class="block w-full text-center py-2 px-3 border border-gray-300 rounded-md font-medium hover:border-gray-400 focus:outline-none focus:border-gray-400 sm:text-sm" |             class="block w-full text-center py-2 px-3 border border-gray-300 rounded-md font-medium hover:border-gray-400 focus:outline-none focus:border-gray-400 sm:text-sm" | ||||||
|           >Account erstellen</a> |           >Account erstellen</a> | ||||||
|         </div> |         </div> | ||||||
| @@ -101,7 +101,7 @@ function login() { | |||||||
|   axios.get("").then((res) => { |   axios.get("").then((res) => { | ||||||
|     loading.value = false; |     loading.value = false; | ||||||
|     Toastify({ |     Toastify({ | ||||||
|       text: "This is a toast", |       text: "Login läuft...", | ||||||
|       duration: 3000, |       duration: 3000, | ||||||
|     }).showToast(); |     }).showToast(); | ||||||
|   }); |   }); | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ | |||||||
|               placeholder="Passwort" |               placeholder="Passwort" | ||||||
|             /> |             /> | ||||||
|             <div class="absolute inset-y-0 right-0 pr-3 flex items-center text-sm"> |             <div class="absolute inset-y-0 right-0 pr-3 flex items-center text-sm"> | ||||||
|               <a href="./reset" class="text-gray-900 underline">Passwort vergessen?</a> |               <a href="/selfservice/reset" class="text-gray-900 underline">Passwort vergessen?</a> | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| @@ -80,7 +80,7 @@ | |||||||
|         </div> |         </div> | ||||||
|         <div class="mt-6"> |         <div class="mt-6"> | ||||||
|           <a |           <a | ||||||
|             href="./register" |             href="/selfservice/register" | ||||||
|             class="block w-full text-center py-2 px-3 border border-gray-300 rounded-md font-medium hover:border-gray-400 focus:outline-none focus:border-gray-400 sm:text-sm" |             class="block w-full text-center py-2 px-3 border border-gray-300 rounded-md font-medium hover:border-gray-400 focus:outline-none focus:border-gray-400 sm:text-sm" | ||||||
|           >Account erstellen</a> |           >Account erstellen</a> | ||||||
|         </div> |         </div> | ||||||
| @@ -101,7 +101,7 @@ function login() { | |||||||
|   axios.get("").then((res) => { |   axios.get("").then((res) => { | ||||||
|     loading.value = false; |     loading.value = false; | ||||||
|     Toastify({ |     Toastify({ | ||||||
|       text: "This is a toast", |       text: "Login läuft...", | ||||||
|       duration: 3000, |       duration: 3000, | ||||||
|     }).showToast(); |     }).showToast(); | ||||||
|   }); |   }); | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ | |||||||
|     "profile": "Profil", |     "profile": "Profil", | ||||||
|     "provide_address": "Adresse angeben?", |     "provide_address": "Adresse angeben?", | ||||||
|     "register": { |     "register": { | ||||||
|         "register_now": "Jetzt für den Lauf für Kaya! 2021 registrieren." |         "register_now": "Jetzt für den Lauf für Kaya! 2023 registrieren." | ||||||
|     }, |     }, | ||||||
|     "register_now": "Jetzt registrieren!", |     "register_now": "Jetzt registrieren!", | ||||||
|     "register_now_small": "Jetzt registrieren", |     "register_now_small": "Jetzt registrieren", | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ | |||||||
|     "profile": "Profile", |     "profile": "Profile", | ||||||
|     "provide_address": "Provide a postal address?", |     "provide_address": "Provide a postal address?", | ||||||
|     "register": { |     "register": { | ||||||
|         "register_now": "Register now for Lauf für Kaya! 2021." |         "register_now": "Register now for Lauf für Kaya! 2023." | ||||||
|     }, |     }, | ||||||
|     "register_now": "Register now!", |     "register_now": "Register now!", | ||||||
|     "register_now_small": "Register now", |     "register_now_small": "Register now", | ||||||
|   | |||||||
| @@ -11,10 +11,10 @@ | |||||||
|         <div class="mt-6 sm:flex place-content-center"> |         <div class="mt-6 sm:flex place-content-center"> | ||||||
|           <a |           <a | ||||||
|             class="w-full sm:w-auto inline-flex px-6 py-3 border border-transparent text-base font-semibold rounded-md text-gray-900 bg-white shadow-sm hover:text-gray-600 focus:outline-none focus:text-gray-600 transition ease-in-out duration-150 xl:text-lg xl:py-4" |             class="w-full sm:w-auto inline-flex px-6 py-3 border border-transparent text-base font-semibold rounded-md text-gray-900 bg-white shadow-sm hover:text-gray-600 focus:outline-none focus:text-gray-600 transition ease-in-out duration-150 xl:text-lg xl:py-4" | ||||||
|             href="./register/" |             href="/selfservice/register/" | ||||||
|           >{{ $t('register_now') }}</a> |           >{{ $t('register_now') }}</a> | ||||||
|           <a |           <a | ||||||
|             href="./profile/" |             href="/selfservice/profile/" | ||||||
|             class="mt-4 sm:ml-4 sm:mt-0 w-full sm:w-auto inline-flex px-6 py-3 border border-transparent text-base font-semibold rounded-md text-white bg-gray-800 shadow-sm hover:bg-gray-700 focus:outline-none focus:bg-gray-700 transition ease-in-out duration-150 xl:text-lg xl:py-4" |             class="mt-4 sm:ml-4 sm:mt-0 w-full sm:w-auto inline-flex px-6 py-3 border border-transparent text-base font-semibold rounded-md text-white bg-gray-800 shadow-sm hover:bg-gray-700 focus:outline-none focus:bg-gray-700 transition ease-in-out duration-150 xl:text-lg xl:py-4" | ||||||
|           >{{ $t('view_my_data') }}</a> |           >{{ $t('view_my_data') }}</a> | ||||||
|         </div> |         </div> | ||||||
|   | |||||||
| @@ -359,7 +359,7 @@ axios.get(`${config.baseurl}api/runners/me/${accesstoken}`) | |||||||
|     state.sponsorings = data.distanceDonations; |     state.sponsorings = data.distanceDonations; | ||||||
|     state.fullobject = data; |     state.fullobject = data; | ||||||
|   }).catch((error) => { |   }).catch((error) => { | ||||||
|     toast.error("An error occured while loading your profile data"); |     toast.error("Profil konnte nicht geladen werden..."); | ||||||
|   }) |   }) | ||||||
| axios.get(`${config.baseurl}api/runners/me/${accesstoken}/scans`) | axios.get(`${config.baseurl}api/runners/me/${accesstoken}/scans`) | ||||||
|   .then(({ data }) => { |   .then(({ data }) => { | ||||||
| @@ -371,22 +371,22 @@ axios.get(`${config.baseurl}api/runners/me/${accesstoken}/scans`) | |||||||
|     data.filter(s => s.valid === true); |     data.filter(s => s.valid === true); | ||||||
|     state.scans = data; |     state.scans = data; | ||||||
|   }).catch((error) => { |   }).catch((error) => { | ||||||
|     toast.error("An error occured while loading your profile data"); |     toast.error("Profil konnte nicht geladen werden..."); | ||||||
|   }) |   }) | ||||||
| function delete_me() { | function delete_me() { | ||||||
|   toast("Deletion in progress..."); |   toast("Profil wird gelöscht..."); | ||||||
|   let url = `${config.baseurl}api/runners/me/${accesstoken}?force=true` |   let url = `${config.baseurl}api/runners/me/${accesstoken}?force=true` | ||||||
|   axios.delete(url) |   axios.delete(url) | ||||||
|     .then(() => { |     .then(() => { | ||||||
|       toast("All Data deleted!"); |       toast("Alle Daten gelöscht!"); | ||||||
|       location.replace(`${config.baseurl_selfservice}`); |       location.replace(`${config.baseurl_selfservice}`); | ||||||
|     }) |     }) | ||||||
|     .catch((error) => { |     .catch((error) => { | ||||||
|       toast.error("An error occured while deleting your profile data"); |       toast.error("Profil konnte nicht gelöscht werden..."); | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| function get_certificate() { | function get_certificate() { | ||||||
|   toast("Generation in progress..."); |   toast("Urkunde wird generiert..."); | ||||||
|   const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2); |   const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2); | ||||||
|   let url = `${config.baseurl_documentserver}certificates?locale=${browserlocale}&download=true&key=${config.documentserver_key}`; |   let url = `${config.baseurl_documentserver}certificates?locale=${browserlocale}&download=true&key=${config.documentserver_key}`; | ||||||
|   let postdata = Object.assign({}, state.fullobject); |   let postdata = Object.assign({}, state.fullobject); | ||||||
| @@ -400,7 +400,7 @@ function get_certificate() { | |||||||
|     .then((response) => { |     .then((response) => { | ||||||
|       console.log(response) |       console.log(response) | ||||||
|       if (response.status != "200") { |       if (response.status != "200") { | ||||||
|         toast.error("An error occured while generateing your certificate!"); |         toast.error("Urkunde konnte nicht generiert werden..."); | ||||||
|       } else { |       } else { | ||||||
|         var fileURL = window.URL.createObjectURL(new Blob([response.data], { type: 'application/pdf' })); |         var fileURL = window.URL.createObjectURL(new Blob([response.data], { type: 'application/pdf' })); | ||||||
|         var fileLink = document.createElement('a'); |         var fileLink = document.createElement('a'); | ||||||
| @@ -411,7 +411,7 @@ function get_certificate() { | |||||||
|  |  | ||||||
|         fileLink.click(); |         fileLink.click(); | ||||||
|         fileLink.remove(); |         fileLink.remove(); | ||||||
|         toast("Document generated!"); |         toast("Urkunde generiert!"); | ||||||
|       } |       } | ||||||
|     }) |     }) | ||||||
|     .catch((err) => { |     .catch((err) => { | ||||||
|   | |||||||
| @@ -61,7 +61,7 @@ | |||||||
|                 </div> |                 </div> | ||||||
|                 <div class="mt-2"> |                 <div class="mt-2"> | ||||||
|                     <a |                     <a | ||||||
|                         href="../register/" |                         href="/selfservice/register/" | ||||||
|                         class="text-white block w-full text-center py-2 px-3 border-2 border-gray-300 rounded-md p-1 bg-blue-800 font-medium hover:border-gray-400 focus:outline-none focus:border-gray-400 sm:text-sm" |                         class="text-white block w-full text-center py-2 px-3 border-2 border-gray-300 rounded-md p-1 bg-blue-800 font-medium hover:border-gray-400 focus:outline-none focus:border-gray-400 sm:text-sm" | ||||||
|                     >{{ $t('register_now_small') }}</a> |                     >{{ $t('register_now_small') }}</a> | ||||||
|                 </div> |                 </div> | ||||||
| @@ -88,16 +88,16 @@ const state = reactive({ | |||||||
| const toast = useToast(); | const toast = useToast(); | ||||||
| function resendMail() { | function resendMail() { | ||||||
|     if (isEmail(user_email.value)) { |     if (isEmail(user_email.value)) { | ||||||
|         toast("sending password reset mail..."); |         toast("Login-Link wird angefordert..."); | ||||||
|         const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2); |         const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2); | ||||||
|         axios.post(`${config.baseurl}api/runners/forgot?mail=${user_email.value}&locale=${browserlocale}`) |         axios.post(`${config.baseurl}api/runners/forgot?mail=${user_email.value}&locale=${browserlocale}`) | ||||||
|             .then(({ data }) => { |             .then(({ data }) => { | ||||||
|                 console.log(data); |                 console.log(data); | ||||||
|                 toast("sent password reset mail to " + user_email.value + "!"); |                 toast("Login-Link gesendet an " + user_email.value + "!"); | ||||||
|             }) |             }) | ||||||
|             .catch((error) => { |             .catch((error) => { | ||||||
|                 console.log(error); |                 console.log(error); | ||||||
|                 toast("user does not exist..."); |                 toast("Fehler beim Anfordern des Login-Links..."); | ||||||
|             }); |             }); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -200,7 +200,7 @@ | |||||||
|               <a |               <a | ||||||
|                 target="_blank" |                 target="_blank" | ||||||
|                 rel="noreferrer,noopener" |                 rel="noreferrer,noopener" | ||||||
|                 href |                 href="https://lauf-fuer-kaya.de/datenschutz/" | ||||||
|                 class="underline" |                 class="underline" | ||||||
|               >{{ $t('tos') }}</a> |               >{{ $t('tos') }}</a> | ||||||
|               {{ $t('i_accept_end') }} |               {{ $t('i_accept_end') }} | ||||||
| @@ -277,7 +277,7 @@ const state = reactive({ | |||||||
| const toast = useToast(); | const toast = useToast(); | ||||||
| function login() { | function login() { | ||||||
|   userdetails = userdetails.value; |   userdetails = userdetails.value; | ||||||
|   if (userdetails.phone === "" || isMobilePhone(userdetails.phone)) { |   if (userdetails?.phone === "" || isMobilePhone(userdetails.phone)) { | ||||||
|     if (isEmail(userdetails.mail)) { |     if (isEmail(userdetails.mail)) { | ||||||
|       let postdata = { |       let postdata = { | ||||||
|         "email": userdetails.mail, |         "email": userdetails.mail, | ||||||
| @@ -301,7 +301,7 @@ function login() { | |||||||
|       if (state.org_name !== '' && state.org_teams.length > 0) { |       if (state.org_name !== '' && state.org_teams.length > 0) { | ||||||
|         postdata.team = org_team.value; |         postdata.team = org_team.value; | ||||||
|       } |       } | ||||||
|       toast("registration in progress..."); |       toast("Registrierung läuft..."); | ||||||
|       const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2); |       const browserlocale = ((navigator.languages && navigator.languages[0]) || '').substr(0, 2); | ||||||
|       let url = `${config.baseurl}api/runners/register/?locale=${browserlocale}`; |       let url = `${config.baseurl}api/runners/register/?locale=${browserlocale}`; | ||||||
|       if (props.token) { |       if (props.token) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user