Compare commits
	
		
			94 Commits
		
	
	
		
			892a04f289
			...
			0.15.6
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 9fc4ad63c4 | |||
| 97054a71c1 | |||
| 2391668a25 | |||
| 717d33547c | |||
| 997be32679 | |||
| 134f00c40e | |||
| 47c898bdfd | |||
| e752ee12d1 | |||
| cc4515ff66 | |||
| f190292171 | |||
| b246f2b349 | |||
| 76b69d851a | |||
| 224f586368 | |||
| 9add6c8ff1 | |||
| 7a63d4eed1 | |||
| e54a4807f7 | |||
| cee04c1d6f | |||
| cbec78589d | |||
| a85db7cb3f | |||
| 2bd3779839 | |||
| 303e33cafb | |||
| b4e689dddf | |||
| 98a0b036c5 | |||
| fb3f30fb10 | |||
| 6213952007 | |||
| 07ac041d69 | |||
| 5c02028841 | |||
| c561b53670 | |||
| dcd0d5a362 | |||
| 18acac83bc | |||
| d7d44470bb | |||
| 0f0aae7ba4 | |||
| 4c0886a5d9 | |||
| 04a3038369 | |||
| bdcf5d3fc0 | |||
| c7a858eed7 | |||
| de5aa9237d | |||
| d015f97395 | |||
| 57618156b4 | |||
| 865254d646 | |||
| 1dbab03fe7 | |||
| a943aaf5fc | |||
| 6e6e8b2617 | |||
| 4c2c24af2c | |||
| 3d3a10aafb | |||
| 000fc97beb | |||
| 5645eeaafa | |||
| 961477d522 | |||
| a5f71015a6 | |||
| e42ea943b7 | |||
| 9c5fc6b61c | |||
| 302caf015f | |||
| e11296071a | |||
| 112eb29f93 | |||
| c6c97516b3 | |||
| 03676b2894 | |||
| 9ca57fac2e | |||
| 18f151c1fb | |||
| e90e56d8b2 | |||
| d241ca5698 | |||
| b512cf8667 | |||
| a24d2923c6 | |||
| 467808abef | |||
| 861f1f2216 | |||
| 509b22bea0 | |||
| 7447b2f4c1 | |||
| fef14b6e4f | |||
| 01d2a7e6aa | |||
| ac586fec5a | |||
| 5476808683 | |||
| 331d737796 | |||
| ef81b8adf9 | |||
| 8a7d635cef | |||
| 4c259c1eef | |||
| 5b4ede5e2f | |||
| d0ab3dda78 | |||
| d9cf51b4bb | |||
| aa17f24220 | |||
| cf60edf7d4 | |||
| ffbc243194 | |||
| b6b07cf30c | |||
| 495a6b22bd | |||
| 0acaffbdfa | |||
| 6043bc4517 | |||
| e6ed066e3f | |||
| ee4e8655b8 | |||
| 37970d2be6 | |||
| 1376788016 | |||
| 4cad86cf85 | |||
| 6304116edb | |||
| 834ff8fa63 | |||
| 1f428a535e | |||
| 0c40966970 | |||
| 9da071fe9b | 
| @@ -27,7 +27,7 @@ name: build:dev | |||||||
| steps: | steps: | ||||||
|   - name: run full license export |   - name: run full license export | ||||||
|     depends_on: ["clone"] |     depends_on: ["clone"] | ||||||
|     image: node:alpine |     image: registry.odit.services/hub/library/node:alpine | ||||||
|     commands: |     commands: | ||||||
|       - yarn |       - yarn | ||||||
|       - yarn licenses:export |       - yarn licenses:export | ||||||
|   | |||||||
							
								
								
									
										165
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										165
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -2,9 +2,174 @@ | |||||||
|  |  | ||||||
| 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.15.6](https://git.odit.services/lfk/frontend/compare/0.15.5...0.15.6) | ||||||
|  |  | ||||||
|  | - Fixed donations getting reduced to the first one on certificates [`2391668`](https://git.odit.services/lfk/frontend/commit/2391668a25a1e11a1409df572d77ad1635070fbc) | ||||||
|  | - new license file version [CI SKIP] [`97054a7`](https://git.odit.services/lfk/frontend/commit/97054a71c1ab8a045762a55148124965c6994373) | ||||||
|  |  | ||||||
|  | #### [0.15.5](https://git.odit.services/lfk/frontend/compare/0.15.4...0.15.5) | ||||||
|  |  | ||||||
|  | > 5 July 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.15.5 [`717d335`](https://git.odit.services/lfk/frontend/commit/717d33547c3378424dd720005da9952f8a753f1a) | ||||||
|  | - Merge pull request 'Fixed kilometer conversion' (#142) from bugfix/141-runner_kilometers into dev [`997be32`](https://git.odit.services/lfk/frontend/commit/997be32679dc38c9fb0e92b6ce011057b854d99d) | ||||||
|  | - Fixed kilometer conversion [`134f00c`](https://git.odit.services/lfk/frontend/commit/134f00c40e0c8252e7604a73151e8d6685b2c61d) | ||||||
|  | - new license file version [CI SKIP] [`e752ee1`](https://git.odit.services/lfk/frontend/commit/e752ee12d17a4423f4364f7766eafbe7d4cef2d1) | ||||||
|  |  | ||||||
|  | #### [0.15.4](https://git.odit.services/lfk/frontend/compare/0.15.3...0.15.4) | ||||||
|  |  | ||||||
|  | > 5 July 2021 | ||||||
|  |  | ||||||
|  | - Merge pull request 'fix total donation sum in dashboard' (#140) from bugfix/139-total-donation-sum-is-wrong into dev [`#139`](https://git.odit.services/lfk/frontend/issues/139) | ||||||
|  | - 🚀RELEASE v0.15.4 [`cc4515f`](https://git.odit.services/lfk/frontend/commit/cc4515ff66b1c1de3747d0ee6cc465574accedb7) | ||||||
|  | - divide by 100 + toFixes(2) [`b246f2b`](https://git.odit.services/lfk/frontend/commit/b246f2b349b06d1adea318dfad58f97fb1a249bb) | ||||||
|  |  | ||||||
|  | #### [0.15.3](https://git.odit.services/lfk/frontend/compare/0.15.2...0.15.3) | ||||||
|  |  | ||||||
|  | > 16 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.15.3 [`76b69d8`](https://git.odit.services/lfk/frontend/commit/76b69d851aa590ecf8caac135b72962a72e83635) | ||||||
|  | - Small bugfix (null got displayed) 🛠 [`224f586`](https://git.odit.services/lfk/frontend/commit/224f5863683ae2543a4a435510ed2c558dc5d307) | ||||||
|  |  | ||||||
|  | #### [0.15.2](https://git.odit.services/lfk/frontend/compare/0.15.1...0.15.2) | ||||||
|  |  | ||||||
|  | > 16 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.15.2 [`9add6c8`](https://git.odit.services/lfk/frontend/commit/9add6c8ff1fbeed91fe97a7cf262921b716f4e3c) | ||||||
|  | - Footer - noopener link [`cee04c1`](https://git.odit.services/lfk/frontend/commit/cee04c1d6fb6005cefe77fb95855ab6fe2cc448f) | ||||||
|  | - Hotfix: Team change recognition 🐞 [`cbec785`](https://git.odit.services/lfk/frontend/commit/cbec78589d2fa21f12ce87e71bff2b49c3a7d345) | ||||||
|  | - NGINX cache assets [`e54a480`](https://git.odit.services/lfk/frontend/commit/e54a4807f70bc333396885f81d3dcc7ae6c115d9) | ||||||
|  |  | ||||||
|  | #### [0.15.1](https://git.odit.services/lfk/frontend/compare/0.15.0...0.15.1) | ||||||
|  |  | ||||||
|  | > 16 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.15.1 [`a85db7c`](https://git.odit.services/lfk/frontend/commit/a85db7cb3f89881794e37a66ecd822f8ad5873f1) | ||||||
|  | - Merge pull request '🐞🐳 fix Dockerfile' (#138) from bugfix/136-opacity_reactivity into dev [`2bd3779`](https://git.odit.services/lfk/frontend/commit/2bd3779839de16a89b91a3da93033e2a2b742ab7) | ||||||
|  | - 🚚 move to tailwind [`07ac041`](https://git.odit.services/lfk/frontend/commit/07ac041d69b3b1810e5db538b53fe62084490f7a) | ||||||
|  | - 🐞🐳 fix Dockerfile [`303e33c`](https://git.odit.services/lfk/frontend/commit/303e33cafb4a1be01e4c4b43f46ff0c651cb4620) | ||||||
|  | - Dockerfile now uses selfhosted registry [`b4e689d`](https://git.odit.services/lfk/frontend/commit/b4e689dddf0b93a2794aa30ea83e8c6505d6bbfd) | ||||||
|  | - new license file version [CI SKIP] [`98a0b03`](https://git.odit.services/lfk/frontend/commit/98a0b036c5490b4bc4992e83f3bca02be39927fa) | ||||||
|  | - Merge pull request 'Opacity import fix bugfix/136-opacity_reactivity' (#137) from bugfix/136-opacity_reactivity into dev [`fb3f30f`](https://git.odit.services/lfk/frontend/commit/fb3f30fb1024de61ce1c541dae90374454f6ef96) | ||||||
|  | - Added bs import fix [`6213952`](https://git.odit.services/lfk/frontend/commit/621395200751c2d42b9ad44c77e84bda03b62e83) | ||||||
|  |  | ||||||
|  | #### [0.15.0](https://git.odit.services/lfk/frontend/compare/0.14.0...0.15.0) | ||||||
|  |  | ||||||
|  | > 15 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.15.0 [`5c02028`](https://git.odit.services/lfk/frontend/commit/5c02028841c68d9a284bf6971eec2b6bc2fdf1f3) | ||||||
|  | - Merge pull request 'Mark donations as payed feature/133-donation_payments' (#135) from feature/133-donation_payments into dev [`c561b53`](https://git.odit.services/lfk/frontend/commit/c561b536705a68215d9c0a6b320587d1647bf57f) | ||||||
|  | - Sorted translations [`c7a858e`](https://git.odit.services/lfk/frontend/commit/c7a858eed7962294bc9df3c92ce2e46b0a354796) | ||||||
|  | - Added total donation amount to donor overview [`e42ea94`](https://git.odit.services/lfk/frontend/commit/e42ea943b7821d433fe21599edbd9f76c3128ef2) | ||||||
|  | - Added Add Payment button to donor overview [`6e6e8b2`](https://git.odit.services/lfk/frontend/commit/6e6e8b26171f16542c101520800b4b6ea7c023d3) | ||||||
|  | - You can now open a modal to add a payment to a donation from the donation overview [`a943aaf`](https://git.odit.services/lfk/frontend/commit/a943aaf5fce8f113dd967d3842e2b0d7d50604e9) | ||||||
|  | - You can now add payments from the donation overview [`1dbab03`](https://git.odit.services/lfk/frontend/commit/1dbab03fe73b5e0fc011f9b0af7199bd71bc79c5) | ||||||
|  | - Added payment updating via detail [`bdcf5d3`](https://git.odit.services/lfk/frontend/commit/bdcf5d3fc08d250377226a253642d79b2e82d624) | ||||||
|  | - Added **all** missing toast translations [`de5aa92`](https://git.odit.services/lfk/frontend/commit/de5aa9237d261b5d47a8def35afa7f8e0089aea6) | ||||||
|  | - You can now mark fixed donations as already paid on creation [`3d3a10a`](https://git.odit.services/lfk/frontend/commit/3d3a10aafb16d371be9471eb5172f9251fb2583f) | ||||||
|  | - Added translations 🌎 [`d015f97`](https://git.odit.services/lfk/frontend/commit/d015f9739570c44a7a2fe6ba248c9a45c3047c62) | ||||||
|  | - Changed top info style for donation overview [`4c2c24a`](https://git.odit.services/lfk/frontend/commit/4c2c24af2ca5c2874a583b0fd93bee147a17f449) | ||||||
|  | - Added paid donation amount and status to donation detail [`5645eea`](https://git.odit.services/lfk/frontend/commit/5645eeaafaa4254edf1a81bc597ce0c7a9b03ff0) | ||||||
|  | - Added total donation amount to donation overview [`961477d`](https://git.odit.services/lfk/frontend/commit/961477d5224bc44b552d2fc2851d8514116f4e20) | ||||||
|  | - Fixed chante recognition bug for fixed donation [`0f0aae7`](https://git.odit.services/lfk/frontend/commit/0f0aae7ba4cf5dfab15d56ce48edbdbc7cb7e403) | ||||||
|  | - Added total donation amount to donor detail [`a5f7101`](https://git.odit.services/lfk/frontend/commit/a5f71015a6557d664e9d3f505613352792fc38cb) | ||||||
|  | - Added msiisng runner id conversion [`5761815`](https://git.odit.services/lfk/frontend/commit/57618156b49b2b0f0274f2126fef36a017d90022) | ||||||
|  | - AddDonationModal - vertical alignment for paid status [`18acac8`](https://git.odit.services/lfk/frontend/commit/18acac83bc6532e14d36b3399d867e026d0c88ac) | ||||||
|  | - Added missing updated comparison [`04a3038`](https://git.odit.services/lfk/frontend/commit/04a3038369f2717c43459318b7b5754ebbaa9e45) | ||||||
|  | - DonationsOverview contrast on action [`d7d4447`](https://git.odit.services/lfk/frontend/commit/d7d44470bb08ac06594bc400608c17eeacb0434b) | ||||||
|  | - Fixed typo [`4c0886a`](https://git.odit.services/lfk/frontend/commit/4c0886a5d9b91439967bc8f66b09a57177f967d0) | ||||||
|  | - Fixed styling [`865254d`](https://git.odit.services/lfk/frontend/commit/865254d646b5f7de15720551c67ae649601cbcd2) | ||||||
|  | - Changed top info style for donation detail [`000fc97`](https://git.odit.services/lfk/frontend/commit/000fc97beb14427f69d421ff2c96975dbbdc7a3a) | ||||||
|  |  | ||||||
|  | #### [0.14.0](https://git.odit.services/lfk/frontend/compare/0.13.1...0.14.0) | ||||||
|  |  | ||||||
|  | > 14 April 2021 | ||||||
|  |  | ||||||
|  | - Merge pull request 'added donor receipt list download to DonorsOverview' (#134) from feature/132-export-donors-receipt-list into dev [`#132`](https://git.odit.services/lfk/frontend/issues/132) | ||||||
|  | - Sorted translations 🌎 [`c6c9751`](https://git.odit.services/lfk/frontend/commit/c6c97516b3981ef580d620c0c8a6fcc42f26facd) | ||||||
|  | - Fixed typos in translations [`03676b2`](https://git.odit.services/lfk/frontend/commit/03676b2894892c3559118b93e969c063b53b081e) | ||||||
|  | - added donor receipt list download to DonorsOverview [`d241ca5`](https://git.odit.services/lfk/frontend/commit/d241ca569838abbe9581fbd319f7f3b563cb7dcc) | ||||||
|  | - 🚀RELEASE v0.14.0 [`9c5fc6b`](https://git.odit.services/lfk/frontend/commit/9c5fc6b61c0bb2a6d831d4a23ef8679c6e68c6a1) | ||||||
|  | - ⏫ general version bump [`18f151c`](https://git.odit.services/lfk/frontend/commit/18f151c1fb878a74c3d1a2c2a2debf7913739417) | ||||||
|  | - new license file version [CI SKIP] [`302caf0`](https://git.odit.services/lfk/frontend/commit/302caf015f88f77e2b2ae2b67680e79f987ad81e) | ||||||
|  | - Switched to selfhosted images [`112eb29`](https://git.odit.services/lfk/frontend/commit/112eb29f932cd936f1d6c2308dcaeaf8cb642490) | ||||||
|  | - ⏫ bump @odit/lfk-client-js@0.11.0 [`9ca57fa`](https://git.odit.services/lfk/frontend/commit/9ca57fac2eeabbf25142a507fb9c0fa3c90b4e74) | ||||||
|  | - replace donationAmount with paidDonationAmount [`e90e56d`](https://git.odit.services/lfk/frontend/commit/e90e56d8b26aef23aba2bbb0c3942ba4d7feb224) | ||||||
|  |  | ||||||
|  | #### [0.13.1](https://git.odit.services/lfk/frontend/compare/0.13.0...0.13.1) | ||||||
|  |  | ||||||
|  | > 11 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.13.1 [`b512cf8`](https://git.odit.services/lfk/frontend/commit/b512cf86674f1c60b5ac790985ededdfd6554185) | ||||||
|  | - For await fix [`a24d292`](https://git.odit.services/lfk/frontend/commit/a24d2923c6e6da90d610c05183d29d47eaf2ed30) | ||||||
|  |  | ||||||
|  | #### [0.13.0](https://git.odit.services/lfk/frontend/compare/0.12.5...0.13.0) | ||||||
|  |  | ||||||
|  | > 11 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.13.0 [`467808a`](https://git.odit.services/lfk/frontend/commit/467808abefe127dac66a2837fcce3197dddb140f) | ||||||
|  | - Merge pull request 'Better org pdf generation feature/130-org_doc_splitting' (#131) from feature/130-org_doc_splitting into dev [`861f1f2`](https://git.odit.services/lfk/frontend/commit/861f1f221653283e7586aa2c67b205337fd44398) | ||||||
|  | - Org card generation now runs in sequence [`fef14b6`](https://git.odit.services/lfk/frontend/commit/fef14b6e4fb47ad92da61de91fedce96aea26b2c) | ||||||
|  | - Org certificate generation now runs in sequence [`509b22b`](https://git.odit.services/lfk/frontend/commit/509b22bea0dd3e4446e6ecc37d27644e9bf2ad50) | ||||||
|  | - Org contract generation now runs in sequence [`01d2a7e`](https://git.odit.services/lfk/frontend/commit/01d2a7e6aa709b3f2d71575f705fc962e97e2742) | ||||||
|  | - Emergency document server url change [`5476808`](https://git.odit.services/lfk/frontend/commit/5476808683a919bc34dbaea1f1ed276d49750096) | ||||||
|  | - Fixed const -> let [`7447b2f`](https://git.odit.services/lfk/frontend/commit/7447b2f4c134a585905db6733093eab13e6f7c47) | ||||||
|  | - Hotfix: Org * generation🐞 [`ac586fe`](https://git.odit.services/lfk/frontend/commit/ac586fec5abd324d590ba99cdfe8ddddefbf95e6) | ||||||
|  |  | ||||||
|  | #### [0.12.5](https://git.odit.services/lfk/frontend/compare/0.12.4...0.12.5) | ||||||
|  |  | ||||||
|  | > 8 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.12.5 [`331d737`](https://git.odit.services/lfk/frontend/commit/331d737796c82454b1c19fa1840ccc20e36d2626) | ||||||
|  | - Merge pull request 'Added runner team's parentorg name to runenr overciew' (#129) from feature/128-runner_orgs into dev [`ef81b8a`](https://git.odit.services/lfk/frontend/commit/ef81b8adf9bef685a55936d7544bf645c0d6ecbe) | ||||||
|  | - Switched to html entity [`8a7d635`](https://git.odit.services/lfk/frontend/commit/8a7d635cef2d465e70c84e1f7a7b90b98a8dbab1) | ||||||
|  | - Added runner team's parentorg name to runenr overciew [`4c259c1`](https://git.odit.services/lfk/frontend/commit/4c259c1eef2b0166ce6a8493d0c9e9d5ede11146) | ||||||
|  |  | ||||||
|  | #### [0.12.4](https://git.odit.services/lfk/frontend/compare/0.12.3...0.12.4) | ||||||
|  |  | ||||||
|  | > 8 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.12.4 [`5b4ede5`](https://git.odit.services/lfk/frontend/commit/5b4ede5e2f6a26b475a7a4b430a4146d21fb9671) | ||||||
|  | - 🚑 [HOTFIX] - drop "svelte-infinite-loading" [`d0ab3dd`](https://git.odit.services/lfk/frontend/commit/d0ab3dda78bbad2cea18a2491056530897d56607) | ||||||
|  |  | ||||||
|  | #### [0.12.3](https://git.odit.services/lfk/frontend/compare/0.12.2...0.12.3) | ||||||
|  |  | ||||||
|  | > 8 April 2021 | ||||||
|  |  | ||||||
|  | - Merge pull request 'fix' (#126) from bugfix/125-mobile into dev [`#125`](https://git.odit.services/lfk/frontend/issues/125) | ||||||
|  | - almost fixed... [`495a6b2`](https://git.odit.services/lfk/frontend/commit/495a6b22bd8036593f390bdb862d325524cefbcc) | ||||||
|  | - 🐞 bugfix for svelte x tailwind class names [`b6b07cf`](https://git.odit.services/lfk/frontend/commit/b6b07cf30cc6533bd5dbfec1f813c16fde85634d) | ||||||
|  | - fix [`0acaffb`](https://git.odit.services/lfk/frontend/commit/0acaffbdfa359e52654a5afe2788aa59fe6f9036) | ||||||
|  | - 🚀RELEASE v0.12.3 [`d9cf51b`](https://git.odit.services/lfk/frontend/commit/d9cf51b4bbc2136594a03c5d0eeb8cb3f3440b2a) | ||||||
|  | - custom css fix for collapsed_navigation [`ffbc243`](https://git.odit.services/lfk/frontend/commit/ffbc243194c7faeb4fe61c12711a1c441c3994ef) | ||||||
|  | - new license file version [CI SKIP] [`aa17f24`](https://git.odit.services/lfk/frontend/commit/aa17f242209f7e7cecff774ace7a35b581adec1f) | ||||||
|  |  | ||||||
|  | #### [0.12.2](https://git.odit.services/lfk/frontend/compare/0.12.1...0.12.2) | ||||||
|  |  | ||||||
|  | > 7 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.12.2 [`6043bc4`](https://git.odit.services/lfk/frontend/commit/6043bc45174d51ab110b0ed10a8679d96127ab87) | ||||||
|  | - Merge pull request 'feature/110-virtual_list' (#124) from feature/110-virtual_list into dev [`e6ed066`](https://git.odit.services/lfk/frontend/commit/e6ed066e3ffabba6519f94d801d21a27819d0492) | ||||||
|  | - wip on virtuallist [`6304116`](https://git.odit.services/lfk/frontend/commit/6304116edb7f5e3c7b67c15e0b1740d34c513155) | ||||||
|  | - fixed height table [`4cad86c`](https://git.odit.services/lfk/frontend/commit/4cad86cf852468428d77103d052c6974b17c34c3) | ||||||
|  | - pre-merge fixes [`37970d2`](https://git.odit.services/lfk/frontend/commit/37970d2be6b6502701914e41e5bfe2c418438480) | ||||||
|  | - updated virtual scroll list [`1376788`](https://git.odit.services/lfk/frontend/commit/1376788016e767f006661f8c9e6747781f2dce55) | ||||||
|  |  | ||||||
|  | #### [0.12.1](https://git.odit.services/lfk/frontend/compare/0.12.0...0.12.1) | ||||||
|  |  | ||||||
|  | > 6 April 2021 | ||||||
|  |  | ||||||
|  | - 🚀RELEASE v0.12.1 [`834ff8f`](https://git.odit.services/lfk/frontend/commit/834ff8fa63178f36dcacf931c128ba67a3e7bd1b) | ||||||
|  | - Merge pull request 'ImportRunnerModal Cancel Button feature/122-import_cancel' (#123) from feature/112-import_cancel into dev [`1f428a5`](https://git.odit.services/lfk/frontend/commit/1f428a535e3ae619cbf8db51d04255aac8dd8614) | ||||||
|  | - Added cancel button for the first stage of runner import [`0c40966`](https://git.odit.services/lfk/frontend/commit/0c409669700d3a8096cc04716154b0fdca458fe5) | ||||||
|  | - Escape now triggers foll modal close (including reset) instead of just hiding th modal [`9da071f`](https://git.odit.services/lfk/frontend/commit/9da071fe9ba067160334682bf00163e3630fe919) | ||||||
|  |  | ||||||
| #### [0.12.0](https://git.odit.services/lfk/frontend/compare/0.11.0...0.12.0) | #### [0.12.0](https://git.odit.services/lfk/frontend/compare/0.11.0...0.12.0) | ||||||
|  |  | ||||||
|  | > 5 April 2021 | ||||||
|  |  | ||||||
| - Merge pull request 'feature/108_vite_migration' (#118) from feature/108_vite_migration into dev [`#108`](https://git.odit.services/lfk/frontend/issues/108) | - Merge pull request 'feature/108_vite_migration' (#118) from feature/108_vite_migration into dev [`#108`](https://git.odit.services/lfk/frontend/issues/108) | ||||||
|  | - 🚀RELEASE v0.12.0 [`892a04f`](https://git.odit.services/lfk/frontend/commit/892a04f28930481715eb486b1ef4efeb98a6e999) | ||||||
| - Fixed package version [`27cc972`](https://git.odit.services/lfk/frontend/commit/27cc9727f1d02d186c3ccadb06e5b4b1b1d6202d) | - Fixed package version [`27cc972`](https://git.odit.services/lfk/frontend/commit/27cc9727f1d02d186c3ccadb06e5b4b1b1d6202d) | ||||||
| - Merge pull request 'Implmented certificate generation feature/119-Certificate_generation' (#120) from feature/119-Certificate_generation into dev [`f0738d4`](https://git.odit.services/lfk/frontend/commit/f0738d451b02e4a298b5f9cb8ab0be16aed10a38) | - Merge pull request 'Implmented certificate generation feature/119-Certificate_generation' (#120) from feature/119-Certificate_generation into dev [`f0738d4`](https://git.odit.services/lfk/frontend/commit/f0738d451b02e4a298b5f9cb8ab0be16aed10a38) | ||||||
| - The PFS Prefixes now get translated via i18n [`bfacfec`](https://git.odit.services/lfk/frontend/commit/bfacfec76511cae3015f52698fdcbd80a7a15981) | - The PFS Prefixes now get translated via i18n [`bfacfec`](https://git.odit.services/lfk/frontend/commit/bfacfec76511cae3015f52698fdcbd80a7a15981) | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -1,14 +1,12 @@ | |||||||
| FROM node:15.5.1-alpine3.12 | FROM registry.odit.services/hub/library/node:15.14.0-alpine3.13 | ||||||
| WORKDIR /app | WORKDIR /app | ||||||
| COPY package.json ./ | COPY package.json ./ | ||||||
| RUN yarn | RUN yarn | ||||||
| COPY package.json *.config.js index.html ./ | COPY package.json *.config.js postcss.config.cjs index.html ./ | ||||||
| COPY src ./src | COPY src ./src | ||||||
| COPY public ./public | COPY public ./public | ||||||
| RUN yarn build | RUN yarn build | ||||||
| # final image | # final image | ||||||
| FROM alpine | FROM registry.odit.services/hub/fholzer/nginx-brotli:v1.19.1 | ||||||
| COPY --from=0 /app/dist /app | COPY --from=0 /app/dist /usr/share/nginx/html | ||||||
| FROM fholzer/nginx-brotli:v1.19.1 |  | ||||||
| COPY --from=1 /app /usr/share/nginx/html |  | ||||||
| COPY ./nginx.conf /etc/nginx/nginx.conf | COPY ./nginx.conf /etc/nginx/nginx.conf | ||||||
| @@ -13,7 +13,7 @@ | |||||||
| </head> | </head> | ||||||
|  |  | ||||||
| <body> | <body> | ||||||
|   <span style="display: none;visibility: hidden;" id="buildinfo">RELEASE_INFO-0.12.0-RELEASE_INFO</span> |   <span style="display: none;visibility: hidden;" id="buildinfo">RELEASE_INFO-0.15.6-RELEASE_INFO</span> | ||||||
|   <noscript>You need to enable JavaScript to run this app.</noscript> |   <noscript>You need to enable JavaScript to run this app.</noscript> | ||||||
|   <script src="/env.js"></script> |   <script src="/env.js"></script> | ||||||
|   <script type="module" src="/src/main.js"></script> |   <script type="module" src="/src/main.js"></script> | ||||||
|   | |||||||
| @@ -6,6 +6,11 @@ http { | |||||||
|     server { |     server { | ||||||
|         error_page 404 /index.html; |         error_page 404 /index.html; | ||||||
|         root /usr/share/nginx/html; |         root /usr/share/nginx/html; | ||||||
|  |         location /assets { | ||||||
|  |             expires 1y; | ||||||
|  |             log_not_found off; | ||||||
|  |             access_log off; | ||||||
|  |         } | ||||||
|         location = /index.html { |         location = /index.html { | ||||||
|             add_header Cache-Control 'no-store'; |             add_header Cache-Control 'no-store'; | ||||||
|         } |         } | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
| 	"name": "@odit/lfk-frontend", | 	"name": "@odit/lfk-frontend", | ||||||
| 	"version": "0.12.0", | 	"version": "0.15.6", | ||||||
| 	"scripts": { | 	"scripts": { | ||||||
| 		"i18n-order": "node order.js", | 		"i18n-order": "node order.js", | ||||||
| 		"dev": "vite", | 		"dev": "vite", | ||||||
| @@ -10,30 +10,30 @@ | |||||||
| 	}, | 	}, | ||||||
| 	"license": "CC-BY-NC-SA-4.0", | 	"license": "CC-BY-NC-SA-4.0", | ||||||
| 	"devDependencies": { | 	"devDependencies": { | ||||||
| 		"check-password-strength": "2.0.2", | 		"@odit/lfk-client-js": "0.11.0", | ||||||
| 		"@odit/lfk-client-js": "0.10.1", |  | ||||||
| 		"@odit/license-exporter": "0.0.11", | 		"@odit/license-exporter": "0.0.11", | ||||||
| 		"@sveltejs/vite-plugin-svelte": "1.0.0-next.5", | 		"@sveltejs/vite-plugin-svelte": "1.0.0-next.6", | ||||||
| 		"@types/html-minifier": "4.0.0", | 		"@types/html-minifier": "4.0.0", | ||||||
| 		"auto-changelog": "2.2.1", | 		"auto-changelog": "2.2.1", | ||||||
| 		"autoprefixer": "10.2.5", | 		"autoprefixer": "^10.2.5", | ||||||
|  | 		"check-password-strength": "2.0.2", | ||||||
| 		"csvtojson": "2.0.10", | 		"csvtojson": "2.0.10", | ||||||
| 		"gridjs": "3.4.0", | 		"gridjs": "3.4.0", | ||||||
| 		"html-minifier": "4.0.0", | 		"html-minifier": "4.0.0", | ||||||
| 		"localforage": "1.9.0", | 		"localforage": "1.9.0", | ||||||
| 		"marked": "2.0.1", | 		"marked": "2.0.3", | ||||||
| 		"release-it": "14.5.1", | 		"postcss": "^8.2.10", | ||||||
|  | 		"release-it": "14.6.1", | ||||||
| 		"svelte": "3.37.0", | 		"svelte": "3.37.0", | ||||||
| 		"svelte-focus-trap": "1.2.0", | 		"svelte-focus-trap": "1.2.0", | ||||||
| 		"svelte-i18n": "3.3.9", | 		"svelte-i18n": "3.3.9", | ||||||
| 		"svelte-preprocess": "4.7.0", | 		"svelte-preprocess": "^4.7.0", | ||||||
| 		"svelte-select": "3.17.0", | 		"svelte-select": "3.17.0", | ||||||
| 		"tailwindcss": "2.0.4", | 		"tailwindcss": "^2.1.1", | ||||||
| 		"tinro": "0.6.1", | 		"tinro": "0.6.1", | ||||||
| 		"toastify-js": "1.10.0", | 		"toastify-js": "1.10.0", | ||||||
| 		"validator": "13.5.2", | 		"validator": "13.5.2", | ||||||
| 		"vite": "2.1.5", | 		"vite": "2.1.5", | ||||||
| 		"vite-plugin-windicss": "0.12.2", |  | ||||||
| 		"xlsx": "0.16.9" | 		"xlsx": "0.16.9" | ||||||
| 	}, | 	}, | ||||||
| 	"release-it": { | 	"release-it": { | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								postcss.config.cjs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								postcss.config.cjs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | module.exports = { | ||||||
|  | 	plugins: { | ||||||
|  | 		tailwindcss: {}, | ||||||
|  | 		autoprefixer: {} | ||||||
|  | 	} | ||||||
|  | }; | ||||||
| @@ -1,5 +1,6 @@ | |||||||
| const config = { | const config = { | ||||||
| 	baseurl: 'http://localhost:4010', | 	baseurl: 'http://localhost:4010', | ||||||
|  | 	baseurl_documentserver: 'http://localhost:4010/documents', | ||||||
| 	documentserver_key: 'NqZSYTy5AFQ7MppbLW5moqpTk7u7YrNUHKYhKYuThnnya2WpCOIU694hIZT1FzYe', | 	documentserver_key: 'NqZSYTy5AFQ7MppbLW5moqpTk7u7YrNUHKYhKYuThnnya2WpCOIU694hIZT1FzYe', | ||||||
| 	// optional | 	// optional | ||||||
| 	default_username: 'demo', | 	default_username: 'demo', | ||||||
|   | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -76,7 +76,7 @@ | |||||||
|       // last login was not processed yet |       // last login was not processed yet | ||||||
|     } else { |     } else { | ||||||
|       Toastify({ |       Toastify({ | ||||||
|         text: "chill...", |         text: $_('please-wait-a-moment-your-login-is-still-being-processed'), | ||||||
|         duration: 1500, |         duration: 1500, | ||||||
|         backgroundColor: |         backgroundColor: | ||||||
|           "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", |           "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								src/components/base/importfixes.svelte
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								src/components/base/importfixes.svelte
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | <!-- | ||||||
|  |     Temporary tailwind import fixes for classes that wouldn't be directly used otherwise.  | ||||||
|  |     Or as others may call it: Real big bullshit time. | ||||||
|  |     Issue: https://git.odit.services/lfk/frontend/issues/136 | ||||||
|  |  --> | ||||||
|  | <div class="opacity-50"></div> | ||||||
| @@ -77,7 +77,7 @@ | |||||||
|             duration: -1, |             duration: -1, | ||||||
|           }).showToast(); |           }).showToast(); | ||||||
|           fetch( |           fetch( | ||||||
|             `${config.baseurl}/documents/cards?&download=true&key=${config.documentserver_key}`, |             `${config.baseurl_documentserver}/cards?&download=true&key=${config.documentserver_key}`, | ||||||
|             { |             { | ||||||
|               method: "POST", |               method: "POST", | ||||||
|               headers: { |               headers: { | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| <script> | <script> | ||||||
|   import { getLocaleFromNavigator, json, _ } from "svelte-i18n"; |   import { _ } from "svelte-i18n"; | ||||||
|   import { RunnerCardService } from "@odit/lfk-client-js"; |   import { RunnerCardService } from "@odit/lfk-client-js"; | ||||||
|   import store from "../../store"; |   import store from "../../store"; | ||||||
|   import Toastify from "toastify-js"; |   import Toastify from "toastify-js"; | ||||||
| @@ -11,11 +11,21 @@ | |||||||
|   export let editable = {}; |   export let editable = {}; | ||||||
|   export let original_data = {}; |   export let original_data = {}; | ||||||
|   export let current_cards = []; |   export let current_cards = []; | ||||||
|  |   $: filtered_cards = current_cards.filter(function (c) { | ||||||
|  |     if ( | ||||||
|  |       c.code.toLowerCase().includes(searchvalue_lowercase) || | ||||||
|  |       c.runner?.firstname.toLowerCase().includes(searchvalue_lowercase) || | ||||||
|  |       c.runner?.middlename.toLowerCase().includes(searchvalue_lowercase) || | ||||||
|  |       c.runner?.lastname.toLowerCase().includes(searchvalue_lowercase) || | ||||||
|  |       should_display_based_on_id(c.id) | ||||||
|  |     ) { | ||||||
|  |       return true; | ||||||
|  |     } | ||||||
|  |   }); | ||||||
|   $: searchvalue = ""; |   $: searchvalue = ""; | ||||||
|  |   $: searchvalue_lowercase = searchvalue.toLowerCase(); | ||||||
|   $: active_deletes = []; |   $: active_deletes = []; | ||||||
|   $: cards_show = current_cards.some( |   $: cards_show = current_cards.some((r) => r.is_selected === true); | ||||||
|     (r) => r.is_selected === true |  | ||||||
|   ); |  | ||||||
|   $: generate_cards = current_cards.filter((r) => r.is_selected === true); |   $: generate_cards = current_cards.filter((r) => r.is_selected === true); | ||||||
|   const cards_promise = RunnerCardService.runnerCardControllerGetAll().then( |   const cards_promise = RunnerCardService.runnerCardControllerGetAll().then( | ||||||
|     (val) => { |     (val) => { | ||||||
| @@ -46,8 +56,38 @@ | |||||||
|     original_data = Object.assign(original_data, card); |     original_data = Object.assign(original_data, card); | ||||||
|     edit_modal_open = true; |     edit_modal_open = true; | ||||||
|   } |   } | ||||||
|  | // ----------------- | ||||||
|  |   let scrollTop = 0; | ||||||
|  |   $: rendered = filtered_cards; | ||||||
|  |   let innerHeight = 0; | ||||||
|  |   let ele; | ||||||
|  |   $: updateSlice(scrollTop); | ||||||
|  |   $: innerHeight = `${filtered_cards.length * 25}px`; | ||||||
|  |   $: if (ele) updateSlice(); | ||||||
|  |   function updateSlice() { | ||||||
|  |     const height = ele ? parseInt(ele.clientHeight) : 100; | ||||||
|  |     const init = scrollTop / 25; | ||||||
|  |     const end = Math.ceil((scrollTop + height) / 25); | ||||||
|  |     rendered = filtered_cards.slice(init, end + 15); | ||||||
|  |   } | ||||||
|  |   function updateScroll($event) { | ||||||
|  |     scrollTop = $event.target.scrollTop; | ||||||
|  |   } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  | <style> | ||||||
|  |   table tbody { | ||||||
|  |   display: block; | ||||||
|  |   overflow-y: scroll; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | table thead, table tbody tr { | ||||||
|  |   display: table; | ||||||
|  |   width: 100%; | ||||||
|  |   table-layout: fixed; | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  |  | ||||||
| {#if store.state.jwtinfo.userdetails.permissions.includes('CARD:UPDATE')} | {#if store.state.jwtinfo.userdetails.permissions.includes('CARD:UPDATE')} | ||||||
|   <CardDetailModal |   <CardDetailModal | ||||||
|     bind:current_cards |     bind:current_cards | ||||||
| @@ -121,107 +161,111 @@ | |||||||
|               </th> |               </th> | ||||||
|             </tr> |             </tr> | ||||||
|           </thead> |           </thead> | ||||||
|           <tbody class="divide-y divide-gray-200"> |           <tbody class="divide-y divide-gray-200 virtual-wrapper" | ||||||
|             {#each current_cards as card} |   on:scroll={updateScroll} | ||||||
|               {#if card.code |   style="height: 70vh; width:100%" | ||||||
|                 .toLowerCase() |   bind:this={ele} | ||||||
|                 .includes( |           > | ||||||
|                   searchvalue.toLowerCase() |     {#each filtered_cards as card, index} | ||||||
|                 ) || card.runner?.firstname |     {#if card.code | ||||||
|                   .toLowerCase() |       .toLowerCase() | ||||||
|                   .includes( |       .includes( | ||||||
|                     searchvalue.toLowerCase() |         searchvalue.toLowerCase() | ||||||
|                   ) || card.runner?.middlename |       ) || card.runner?.firstname | ||||||
|                   .toLowerCase() |         .toLowerCase() | ||||||
|                   .includes( |         .includes( | ||||||
|                     searchvalue.toLowerCase() |           searchvalue.toLowerCase() | ||||||
|                   ) || card.runner?.lastname |         ) || card.runner?.middlename | ||||||
|                   .toLowerCase() |         .toLowerCase() | ||||||
|                   .includes( |         .includes( | ||||||
|                     searchvalue.toLowerCase() |           searchvalue.toLowerCase() | ||||||
|                   ) || should_display_based_on_id(card.id)} |         ) || card.runner?.lastname | ||||||
|                 <tr data-rowid="card_{card.id}"> |         .toLowerCase() | ||||||
|                   <td class="px-6 py-4 whitespace-nowrap"> |         .includes( | ||||||
|                     <input |           searchvalue.toLowerCase() | ||||||
|                       bind:checked={card.is_selected} |         ) || should_display_based_on_id(card.id)} | ||||||
|                       type="checkbox" |       <tr data-rowid="card_{card.id}"> | ||||||
|                       class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" /> |         <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|                   </td> |           <input | ||||||
|                   <td class="px-6 py-4 whitespace-nowrap"> |             bind:checked={card.is_selected} | ||||||
|                     <div class="flex items-center">{card.code}</div> |             type="checkbox" | ||||||
|                   </td> |             class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" /> | ||||||
|                   <td class="px-6 py-4 whitespace-nowrap"> |         </td> | ||||||
|                     <div class="flex items-center"> |         <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|                       {#if card.runner} |           <div class="flex items-center">{card.code}</div> | ||||||
|                         <a |         </td> | ||||||
|                           href="../runners/{card.runner.id}" |         <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|                           class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{card.runner.firstname} |           <div class="flex items-center"> | ||||||
|                           {card.runner.middlename || ''} |             {#if card.runner} | ||||||
|                           {card.runner.lastname}</a> |               <a | ||||||
|                       {:else}{$_('non-blanko')}{/if} |                 href="../runners/{card.runner.id}" | ||||||
|                     </div> |                 class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{card.runner.firstname} | ||||||
|                   </td> |                 {card.runner.middlename || ''} | ||||||
|                   <td class="px-6 py-4 whitespace-nowrap"> |                 {card.runner.lastname}</a> | ||||||
|                     <div class="flex items-center"> |             {:else}{$_('non-blanko')}{/if} | ||||||
|                       {#if card.enabled} |           </div> | ||||||
|                         <span |         </td> | ||||||
|                           class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-green-100 text-green-800">{$_('enabled')}</span> |         <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|                       {:else} |           <div class="flex items-center"> | ||||||
|                         <span |             {#if card.enabled} | ||||||
|                           class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-red-100 text-red-800">{$_('disabled')}</span> |               <span | ||||||
|                       {/if} |                 class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-green-100 text-green-800">{$_('enabled')}</span> | ||||||
|                     </div> |             {:else} | ||||||
|                   </td> |               <span | ||||||
|  |                 class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-red-100 text-red-800">{$_('disabled')}</span> | ||||||
|  |             {/if} | ||||||
|  |           </div> | ||||||
|  |         </td> | ||||||
|  |  | ||||||
|                   {#if active_deletes[card.id] === true} |         {#if active_deletes[card.id] === true} | ||||||
|                     <td |           <td | ||||||
|                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> |             class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> | ||||||
|                       <button |             <button | ||||||
|                         on:click={() => { |               on:click={() => { | ||||||
|                           active_deletes[card.id] = false; |                 active_deletes[card.id] = false; | ||||||
|                         }} |               }} | ||||||
|                         tabindex="0" |               tabindex="0" | ||||||
|                         class="ml-4 text-indigo-600 hover:text-indigo-900 cursor-pointer">{$_('cancel-delete')}</button> |               class="ml-4 text-indigo-600 hover:text-indigo-900 cursor-pointer">{$_('cancel-delete')}</button> | ||||||
|                       <button |             <button | ||||||
|                         on:click={() => { |               on:click={() => { | ||||||
|                           RunnerCardService.runnerCardControllerRemove(card.id, false).then( |                 RunnerCardService.runnerCardControllerRemove(card.id, false).then( | ||||||
|                             (resp) => { |                   (resp) => { | ||||||
|                               current_cards = current_cards.filter( |                     current_cards = current_cards.filter( | ||||||
|                                 (obj) => obj.id !== card.id |                       (obj) => obj.id !== card.id | ||||||
|                               ); |                     ); | ||||||
|                               Toastify({ |                     Toastify({ | ||||||
|                                 text: $_('card-deleted'), |                       text: $_('card-deleted'), | ||||||
|                                 duration: 500, |                       duration: 500, | ||||||
|                                 backgroundColor: |                       backgroundColor: | ||||||
|                                   'linear-gradient(to right, #00b09b, #96c93d)', |                         'linear-gradient(to right, #00b09b, #96c93d)', | ||||||
|                               }).showToast(); |                     }).showToast(); | ||||||
|                             } |                   } | ||||||
|                           ); |                 ); | ||||||
|                         }} |               }} | ||||||
|                         tabindex="0" |               tabindex="0" | ||||||
|                         class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('confirm-delete')}</button> |               class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('confirm-delete')}</button> | ||||||
|                     </td> |           </td> | ||||||
|                   {:else} |         {:else} | ||||||
|                     <td |           <td | ||||||
|                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> |             class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> | ||||||
|                       <button |             <button | ||||||
|                         on:click={() => { |               on:click={() => { | ||||||
|                           open_edit_modal(card); |                 open_edit_modal(card); | ||||||
|                         }} |               }} | ||||||
|                         class="text-indigo-600 hover:text-indigo-900">{$_('details')}</button> |               class="text-indigo-600 hover:text-indigo-900">{$_('details')}</button> | ||||||
|                       {#if store.state.jwtinfo.userdetails.permissions.includes('CARD:DELETE')} |             {#if store.state.jwtinfo.userdetails.permissions.includes('CARD:DELETE')} | ||||||
|                         <button |               <button | ||||||
|                           on:click={() => { |                 on:click={() => { | ||||||
|                             active_deletes[card.id] = true; |                   active_deletes[card.id] = true; | ||||||
|                           }} |                 }} | ||||||
|                           tabindex="0" |                 tabindex="0" | ||||||
|                           class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('delete')}</button> |                 class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('delete')}</button> | ||||||
|                       {/if} |             {/if} | ||||||
|                     </td> |           </td> | ||||||
|                   {/if} |         {/if} | ||||||
|                 </tr> |       </tr> | ||||||
|               {/if} |     {/if} | ||||||
|             {/each} |     {/each} | ||||||
|           </tbody> |           </tbody> | ||||||
|         </table> |         </table> | ||||||
|       </div> |       </div> | ||||||
|   | |||||||
| @@ -86,7 +86,7 @@ | |||||||
|     if (processed_last_submit === true) { |     if (processed_last_submit === true) { | ||||||
|       processed_last_submit = false; |       processed_last_submit = false; | ||||||
|       const toast = Toastify({ |       const toast = Toastify({ | ||||||
|         text: "Contact is being added...", |         text: $_('contact-is-being-added'), | ||||||
|         duration: -1, |         duration: -1, | ||||||
|       }).showToast(); |       }).showToast(); | ||||||
|       let address = {}; |       let address = {}; | ||||||
| @@ -123,7 +123,7 @@ | |||||||
|           modal_open = false; |           modal_open = false; | ||||||
|           // |           // | ||||||
|           Toastify({ |           Toastify({ | ||||||
|             text: "Contact added", |             text: $_('contact-added'), | ||||||
|             duration: 500, |             duration: 500, | ||||||
|             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|           }).showToast(); |           }).showToast(); | ||||||
|   | |||||||
| @@ -12,11 +12,21 @@ | |||||||
|   } |   } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  | <style> | ||||||
|  |   .collapsed_navigation { | ||||||
|  |     transform: translateX(-100%); | ||||||
|  |   } | ||||||
|  |   @media (min-width: 768px) { | ||||||
|  |     .collapsed_navigation { | ||||||
|  |       transform: translateX(0px); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | </style> | ||||||
|  |  | ||||||
| <section class="min-h-screen bg-gray-50"> | <section class="min-h-screen bg-gray-50"> | ||||||
|   <nav |   <div | ||||||
|     class:-translate-x-full={!navOpen} |     class:collapsed_navigation={!navOpen} | ||||||
|     class:translate-x-0={navOpen} |     class="select-none fixed top-0 left-0 z-20 h-full pb-10 overflow-x-hidden overflow-y-auto transition origin-left transform border-r w-60 bg-gray-50"> | ||||||
|     class="select-none fixed top-0 left-0 z-20 h-full pb-10 overflow-x-hidden overflow-y-auto transition origin-left transform border-r w-60 md:translate-x-0 bg-gray-50"> |  | ||||||
|     <a href="/" class="flex items-center px-4 py-5"> |     <a href="/" class="flex items-center px-4 py-5"> | ||||||
|       <img src="/lfk-logo.png" alt="Logo" class="h-10" /> |       <img src="/lfk-logo.png" alt="Logo" class="h-10" /> | ||||||
|       <h3 class="text-lg">Lauf für Kaya! Admin</h3> |       <h3 class="text-lg">Lauf für Kaya! Admin</h3> | ||||||
| @@ -297,14 +307,15 @@ | |||||||
|         <span>{$_('logout')}</span> |         <span>{$_('logout')}</span> | ||||||
|       </span> |       </span> | ||||||
|     </nav> |     </nav> | ||||||
|   </nav> |   </div> | ||||||
|   <div class="ml-0 transition md:ml-60"> |   <div class="ml-0 transition md:ml-60"> | ||||||
|     <header |     <header | ||||||
|       on:click={() => { |  | ||||||
|         navOpen = true; |  | ||||||
|       }} |  | ||||||
|       class="flex items-center justify-between w-full px-4 bg-white border-b h-14 md:hidden"> |       class="flex items-center justify-between w-full px-4 bg-white border-b h-14 md:hidden"> | ||||||
|       <button class="block btn btn-light md:hidden"> |       <button | ||||||
|  |         on:click={() => { | ||||||
|  |           navOpen = true; | ||||||
|  |         }} | ||||||
|  |         class="block btn btn-light md:hidden"> | ||||||
|         <span class="sr-only">Menu</span><svg |         <span class="sr-only">Menu</span><svg | ||||||
|           class="w-4 h-4" |           class="w-4 h-4" | ||||||
|           xmlns="http://www.w3.org/2000/svg" |           xmlns="http://www.w3.org/2000/svg" | ||||||
| @@ -318,10 +329,13 @@ | |||||||
|       <NoComponentLoaded /> |       <NoComponentLoaded /> | ||||||
|     </slot> |     </slot> | ||||||
|   </div> |   </div> | ||||||
|   <div |   {#if navOpen === true} | ||||||
|     on:click={() => { |     <div | ||||||
|       navOpen = false; |       on:click={() => { | ||||||
|     }} |         navOpen = false; | ||||||
|     class:hidden={!navOpen} |         console.log({ navOpen }); | ||||||
|     class="fixed inset-0 z-10 w-screen h-screen bg-black bg-opacity-25 md:hidden" /> |       }} | ||||||
|  |       class:hidden={!navOpen} | ||||||
|  |       class="fixed inset-0 z-10 w-screen h-screen bg-black bg-opacity-25 md:hidden" /> | ||||||
|  |   {/if} | ||||||
| </section> | </section> | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ | |||||||
|             <div class="text-xs uppercase font-light text-grey-500"> |             <div class="text-xs uppercase font-light text-grey-500"> | ||||||
|               {$_('total-donations')} |               {$_('total-donations')} | ||||||
|             </div> |             </div> | ||||||
|             <div class="text-xl font-bold">{stats.total_donation} €</div> |             <div class="text-xl font-bold">{(stats.total_donation/100).toFixed(2)} €</div> | ||||||
|           </div><svg |           </div><svg | ||||||
|             xmlns="http://www.w3.org/2000/svg" |             xmlns="http://www.w3.org/2000/svg" | ||||||
|             height="24" |             height="24" | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ | |||||||
|   } from "@odit/lfk-client-js"; |   } from "@odit/lfk-client-js"; | ||||||
|   import Select from "svelte-select"; |   import Select from "svelte-select"; | ||||||
|   import Toastify from "toastify-js"; |   import Toastify from "toastify-js"; | ||||||
|  | import { is_promise } from "svelte/internal"; | ||||||
|   export let modal_open; |   export let modal_open; | ||||||
|   export let current_donations; |   export let current_donations; | ||||||
|   const getDonorLabel = (option) => |   const getDonorLabel = (option) => | ||||||
| @@ -24,6 +25,7 @@ | |||||||
|   $: donors = []; |   $: donors = []; | ||||||
|   $: runners = []; |   $: runners = []; | ||||||
|   $: is_fixed = false; |   $: is_fixed = false; | ||||||
|  |   $: is_paid = false; | ||||||
|   DonorService.donorControllerGetAll().then((val) => { |   DonorService.donorControllerGetAll().then((val) => { | ||||||
|     donors = val.map((r) => { |     donors = val.map((r) => { | ||||||
|       return { label: getDonorLabel(r), value: r }; |       return { label: getDonorLabel(r), value: r }; | ||||||
| @@ -57,14 +59,18 @@ | |||||||
|       let amount_cent = Math.floor(amount_input * 100); |       let amount_cent = Math.floor(amount_input * 100); | ||||||
|       processed_last_submit = false; |       processed_last_submit = false; | ||||||
|       const toast = Toastify({ |       const toast = Toastify({ | ||||||
|         text: "adding donation", |         text: $_('adding-donation'), | ||||||
|         duration: -1, |         duration: -1, | ||||||
|       }).showToast(); |       }).showToast(); | ||||||
|       if (is_fixed) { |       if (is_fixed) { | ||||||
|         let postdata = { |         let postdata = { | ||||||
|           donor, |           donor, | ||||||
|           amount: amount_cent, |           amount: amount_cent, | ||||||
|  |           paidAmount: 0 | ||||||
|         }; |         }; | ||||||
|  |         if(is_paid){ | ||||||
|  |           postdata.paidAmount = amount_cent; | ||||||
|  |         } | ||||||
|         DonationService.donationControllerPostFixed(postdata) |         DonationService.donationControllerPostFixed(postdata) | ||||||
|           .then((result) => { |           .then((result) => { | ||||||
|             donor = donors[0].id || 0; |             donor = donors[0].id || 0; | ||||||
| @@ -73,7 +79,7 @@ | |||||||
|             modal_open = false; |             modal_open = false; | ||||||
|             // |             // | ||||||
|             Toastify({ |             Toastify({ | ||||||
|               text: "donation_added", |               text: $_('donation_added'), | ||||||
|               duration: 500, |               duration: 500, | ||||||
|               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|             }).showToast(); |             }).showToast(); | ||||||
| @@ -102,7 +108,7 @@ | |||||||
|             modal_open = false; |             modal_open = false; | ||||||
|             // |             // | ||||||
|             Toastify({ |             Toastify({ | ||||||
|               text: "donation_added", |               text: $_('donation_added'), | ||||||
|               duration: 500, |               duration: 500, | ||||||
|               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|             }).showToast(); |             }).showToast(); | ||||||
| @@ -123,7 +129,7 @@ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style> | <style> | ||||||
|   input:before { |   .toggle:before { | ||||||
|     content: ""; |     content: ""; | ||||||
|     position: absolute; |     position: absolute; | ||||||
|     width: 1.25rem; |     width: 1.25rem; | ||||||
| @@ -137,12 +143,12 @@ | |||||||
|     transition: 0.2s ease-in-out; |     transition: 0.2s ease-in-out; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   input:checked { |   .toggle:checked { | ||||||
|     /* @apply: bg-indigo-400; */ |     /* @apply: bg-indigo-400; */ | ||||||
|     background-color: #7f9cf5; |     background-color: #7f9cf5; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   input:checked:before { |   .toggle:checked:before { | ||||||
|     left: 1.25rem; |     left: 1.25rem; | ||||||
|   } |   } | ||||||
| </style> | </style> | ||||||
| @@ -195,7 +201,7 @@ | |||||||
|                   class="ml-2 text-base" |                   class="ml-2 text-base" | ||||||
|                   class:text-gray-300={is_fixed}>{$_('distance-donation')}</span> |                   class:text-gray-300={is_fixed}>{$_('distance-donation')}</span> | ||||||
|                 <input |                 <input | ||||||
|                   class="relative w-10 h-5 transition-all duration-200 ease-in-out bg-gray-400 rounded-full shadow-inner outline-none appearance-none align-middle" |                   class="toggle relative w-10 h-5 transition-all duration-200 ease-in-out bg-gray-400 rounded-full shadow-inner outline-none appearance-none align-middle" | ||||||
|                   type="checkbox" |                   type="checkbox" | ||||||
|                   bind:checked={is_fixed} /> |                   bind:checked={is_fixed} /> | ||||||
|                 <span |                 <span | ||||||
| @@ -267,6 +273,29 @@ | |||||||
|                     </span> |                     </span> | ||||||
|                   {/if} |                   {/if} | ||||||
|                 </div> |                 </div> | ||||||
|  |                 {#if is_fixed} | ||||||
|  |                 <div class="col-span-6"> | ||||||
|  |                   <label | ||||||
|  |                     for="paid" | ||||||
|  |                     class="block text-sm font-medium text-gray-700">{$_('already-paid')}</label> | ||||||
|  |                     <p class="text-gray-500"> | ||||||
|  |                       <input | ||||||
|  |                         id="paid" | ||||||
|  |                         bind:checked={is_paid} | ||||||
|  |                         name="paid" | ||||||
|  |                         type="checkbox" | ||||||
|  |                         class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" > | ||||||
|  |                         <span class="align-text-bottom"> | ||||||
|  |  | ||||||
|  |                       {#if is_paid} | ||||||
|  |                       {$_('paid')} | ||||||
|  |                       {:else} | ||||||
|  |                       {$_('open')} | ||||||
|  |                       {/if} | ||||||
|  |                         </span> | ||||||
|  |                     </p> | ||||||
|  |                 </div> | ||||||
|  |                 {/if} | ||||||
|               </div> |               </div> | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|   | |||||||
							
								
								
									
										202
									
								
								src/components/donations/AddDonationPaymentModal.svelte
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										202
									
								
								src/components/donations/AddDonationPaymentModal.svelte
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,202 @@ | |||||||
|  | <script> | ||||||
|  |   import { _ } from "svelte-i18n"; | ||||||
|  |   import { clickOutside } from "../base/outsideclick"; | ||||||
|  |   import { focusTrap } from "svelte-focus-trap"; | ||||||
|  |   import { DonationService } from "@odit/lfk-client-js"; | ||||||
|  |   import Toastify from "toastify-js"; | ||||||
|  |   export let payment_modal_open = false; | ||||||
|  |   export let current_donations = []; | ||||||
|  |   export let editable = {}; | ||||||
|  |   export let original_data = {}; | ||||||
|  |   export let paid_amount_input = 0; | ||||||
|  |   $:processed_last_submit=true; | ||||||
|  |   function focus(el) { | ||||||
|  |     el.focus(); | ||||||
|  |   } | ||||||
|  |   $: createbtnenabled = is_paid_amount_valid && !(paid_amount_input*100 == original_data.paidAmount) | ||||||
|  |   $: is_paid_amount_valid = paid_amount_input > 0; | ||||||
|  |   (() => { | ||||||
|  |     document.onkeydown = (e) => { | ||||||
|  |       e = e || window.event; | ||||||
|  |       if (e.key === "Escape") { | ||||||
|  |         payment_modal_open = false; | ||||||
|  |       } | ||||||
|  |       if (e.keyCode === 13) { | ||||||
|  |         if (createbtnenabled === true) { | ||||||
|  |           createbtnenabled = false; | ||||||
|  |           submit(); | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     }; | ||||||
|  |   })(); | ||||||
|  |   function submit() { | ||||||
|  |     if (processed_last_submit === true) { | ||||||
|  |       processed_last_submit = false; | ||||||
|  |       const toast = Toastify({ | ||||||
|  |         text: $_('updating-donation'), | ||||||
|  |         duration: -1, | ||||||
|  |       }).showToast(); | ||||||
|  |       editable.donor = editable.donor.id; | ||||||
|  |       editable.paidAmount = paid_amount_input*100; | ||||||
|  |       if(editable.responseType == "DISTANCEDONATION" || editable.runner){ | ||||||
|  |         editable.runner = editable.runner.id; | ||||||
|  |         DonationService.donationControllerPutDistance(original_data.id, editable) | ||||||
|  |         .then((result) => { | ||||||
|  |           let id = original_data.id; | ||||||
|  |           editable = {}; | ||||||
|  |           original_data = {}; | ||||||
|  |           payment_modal_open = false; | ||||||
|  |           // | ||||||
|  |           Toastify({ | ||||||
|  |             text: $_('donation-updated'), | ||||||
|  |             duration: 500, | ||||||
|  |             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|  |           }).showToast(); | ||||||
|  |           current_donations[current_donations.findIndex((c) => c.id === id)] = result; | ||||||
|  |           current_donations = current_donations; | ||||||
|  |         }) | ||||||
|  |         .catch((err) => { | ||||||
|  |           // | ||||||
|  |         }) | ||||||
|  |         .finally(() => { | ||||||
|  |           processed_last_submit = true; | ||||||
|  |           // | ||||||
|  |           toast.hideToast(); | ||||||
|  |         }); | ||||||
|  |       } | ||||||
|  |       else{ | ||||||
|  |           DonationService.donationControllerPutFixed(original_data.id, editable) | ||||||
|  |         .then((result) => { | ||||||
|  |           let id = original_data.id; | ||||||
|  |           editable = {}; | ||||||
|  |           original_data = {}; | ||||||
|  |           payment_modal_open = false; | ||||||
|  |           // | ||||||
|  |           Toastify({ | ||||||
|  |             text: $_('donation-updated'), | ||||||
|  |             duration: 500, | ||||||
|  |             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|  |           }).showToast(); | ||||||
|  |           current_donations[current_donations.findIndex((c) => c.id === id)] = result; | ||||||
|  |           current_donations = current_donations; | ||||||
|  |         }) | ||||||
|  |         .catch((err) => { | ||||||
|  |           // | ||||||
|  |         }) | ||||||
|  |         .finally(() => { | ||||||
|  |           processed_last_submit = true; | ||||||
|  |           // | ||||||
|  |           toast.hideToast(); | ||||||
|  |         }); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | {#if payment_modal_open} | ||||||
|  |   <div | ||||||
|  |     class="fixed z-10 inset-0 overflow-y-auto" | ||||||
|  |     use:focusTrap | ||||||
|  |     use:clickOutside | ||||||
|  |     on:click_outside={() => { | ||||||
|  |       payment_modal_open = false; | ||||||
|  |     }}> | ||||||
|  |     <div | ||||||
|  |       class="flex items-end justify-center min-h-screen pt-4 px-4 pb-20 text-center sm:block sm:p-0"> | ||||||
|  |       <div class="fixed inset-0 transition-opacity" aria-hidden="true"> | ||||||
|  |         <div | ||||||
|  |           class="absolute inset-0 bg-gray-500 opacity-75" | ||||||
|  |           data-id="modal_backdrop" /> | ||||||
|  |       </div> | ||||||
|  |       <span | ||||||
|  |         class="hidden sm:inline-block sm:align-middle sm:h-screen" | ||||||
|  |         aria-hidden="true">​</span> | ||||||
|  |       <div | ||||||
|  |         class="inline-block align-bottom bg-white rounded-lg text-left shadow-xl transform transition-all sm:my-8 sm:align-middle sm:max-w-lg sm:w-full" | ||||||
|  |         role="dialog" | ||||||
|  |         aria-modal="true" | ||||||
|  |         aria-labelledby="modal-headline"> | ||||||
|  |         <div class="bg-white px-4 pt-5 pb-4 sm:p-6 sm:pb-4"> | ||||||
|  |           <div class="sm:flex sm:items-start"> | ||||||
|  |             <div | ||||||
|  |               class="mx-auto flex-shrink-0 flex items-center justify-center h-12 w-12 rounded-full bg-blue-100 sm:mx-0 sm:h-10 sm:w-10"> | ||||||
|  |               <svg | ||||||
|  |                 class="h-6 w-6 text-blue-600" | ||||||
|  |                 fill="currentColor" | ||||||
|  |                 xmlns="http://www.w3.org/2000/svg" | ||||||
|  |                 viewBox="0 0 24 24" | ||||||
|  |                 width="24" | ||||||
|  |                 height="24"><path fill="none" d="M0 0h24v24H0z" /> | ||||||
|  |                 <path | ||||||
|  |                   fill="currentColor" | ||||||
|  |                   d="M22 10v10a1 1 0 01-1 1H3a1 1 0 01-1-1V10h20zm0-2H2V4a1 1 0 011-1h18a1 1 0 011 1v4zm-7 8v2h4v-2h-4z" /></svg> | ||||||
|  |             </div> | ||||||
|  |             <div class="mt-3 text-center sm:mt-0 sm:ml-4 sm:text-left"> | ||||||
|  |               <h3 class="text-lg leading-6 font-medium text-gray-900"> | ||||||
|  |                 {$_('enter-payment')} | ||||||
|  |               </h3> | ||||||
|  |               <div class="mt-2 mb-6"> | ||||||
|  |                 <p class="text-sm text-gray-500"> | ||||||
|  |                   {$_('you-can-enter-the-donations-paid-amount-manually-or-use-the-max-button-to-use-the-donations-exact-amount')} | ||||||
|  |                 </p> | ||||||
|  |               </div> | ||||||
|  |               <div class="grid grid-cols gap-6"> | ||||||
|  |                 <div class="w-full"> | ||||||
|  |                   <label | ||||||
|  |                   for="token" | ||||||
|  |                   class="block text-sm font-medium text-gray-700">{$_('paid-amount')}</label> | ||||||
|  |                 <div class="inline-flex border-gray-300 border rounded-l-md rounded-r-md bg-gray-50 text-gray-500 w-full"> | ||||||
|  |                   <input | ||||||
|  |                       autocomplete="off" | ||||||
|  |                       class:border-red-500={!is_paid_amount_valid} | ||||||
|  |                       class:focus:border-red-500={!is_paid_amount_valid} | ||||||
|  |                       class:focus:ring-red-500={!is_paid_amount_valid} | ||||||
|  |                       bind:value={paid_amount_input} | ||||||
|  |                       type="number" | ||||||
|  |                       step="0.01" | ||||||
|  |                       name="donation_amount_eur" | ||||||
|  |                       class="focus:ring-indigo-500 focus:border-indigo-500 flex-1 block w-full rounded-none rounded-l-md sm:text-sm p-2" | ||||||
|  |                       placeholder="2.00" /> | ||||||
|  |                     <button | ||||||
|  |                       on:click={ | ||||||
|  |                         ()=>{ | ||||||
|  |                           paid_amount_input=paid_amount_input = (original_data.amount/100).toFixed(2); | ||||||
|  |                         } | ||||||
|  |                       } | ||||||
|  |                       class="inline-flex items-center p-r-2 text-indigo-300 hover:text-indigo-700 text-sm">MAX</button> | ||||||
|  |                     <span | ||||||
|  |                       class="inline-flex items-center px-3 rounded-r-md border border-gray-300 bg-gray-50 text-gray-500 text-sm">€</span> | ||||||
|  |                   </div> | ||||||
|  |                   {#if !is_paid_amount_valid} | ||||||
|  |                     <span | ||||||
|  |                       class="flex items-center font-medium tracking-wide text-red-500 text-xs mt-1 ml-1"> | ||||||
|  |                       {$_('payment-amount-must-be-greater-than-0-00eur')} | ||||||
|  |                     </span> | ||||||
|  |                   {/if} | ||||||
|  |                 </div> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |           <div class="bg-gray-50 px-4 py-3 sm:px-6 sm:flex sm:flex-row-reverse"> | ||||||
|  |             <button | ||||||
|  |               disabled={!createbtnenabled} | ||||||
|  |               class:opacity-50={!createbtnenabled} | ||||||
|  |               on:click={submit} | ||||||
|  |               type="button" | ||||||
|  |               class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-600 text-base font-medium text-white hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm"> | ||||||
|  |               {$_('save-changes')} | ||||||
|  |             </button> | ||||||
|  |             <button | ||||||
|  |               on:click={() => { | ||||||
|  |                 payment_modal_open = false; | ||||||
|  |               }} | ||||||
|  |               type="button" | ||||||
|  |               class="mt-3 w-full inline-flex justify-center rounded-md border border-gray-300 shadow-sm px-4 py-2 bg-white text-base font-medium text-gray-700 hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-indigo-500 sm:mt-0 sm:ml-3 sm:w-auto sm:text-sm"> | ||||||
|  |               {$_('cancel')} | ||||||
|  |             </button> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  | {/if} | ||||||
| @@ -20,6 +20,8 @@ | |||||||
|   $: current_runners = []; |   $: current_runners = []; | ||||||
|   $: amount_input = 0; |   $: amount_input = 0; | ||||||
|   $: is_amount_valid = amount_input > 0; |   $: is_amount_valid = amount_input > 0; | ||||||
|  |   $: paid_amount_input = 0; | ||||||
|  |   $: is_paid_amount_valid = paid_amount_input > 0; | ||||||
|   $: is_everything_set = |   $: is_everything_set = | ||||||
|     editable.donor != null && |     editable.donor != null && | ||||||
|     ((original_data.responseType == "DISTANCEDONATION" && |     ((original_data.responseType == "DISTANCEDONATION" && | ||||||
| @@ -30,15 +32,17 @@ | |||||||
|     (original_data.responseType == "DISTANCEDONATION" && |     (original_data.responseType == "DISTANCEDONATION" && | ||||||
|       !(Math.floor(amount_input * 100) === original_data.amountPerDistance)) || |       !(Math.floor(amount_input * 100) === original_data.amountPerDistance)) || | ||||||
|     (original_data.responseType !== "DISTANCEDONATION" && |     (original_data.responseType !== "DISTANCEDONATION" && | ||||||
|       !(Math.floor(amount_input * 100) === original_data.amount)); |       !(Math.floor(amount_input * 100) === original_data.amount)) || | ||||||
|  |       !(Math.floor(paid_amount_input * 100) === original_data.paidAmount); | ||||||
|   $: save_enabled = changes_performed && is_amount_valid && is_everything_set; |   $: save_enabled = changes_performed && is_amount_valid && is_everything_set; | ||||||
|  |  | ||||||
|   const promise = DonationService.donationControllerGetOne( |   const promise = DonationService.donationControllerGetOne( | ||||||
|     params.donationid |     params.donationid | ||||||
|   ).then((data) => { |   ).then((data) => { | ||||||
|     data_loaded = true; |     data_loaded = true; | ||||||
|     original_data = Object.assign(original_data, data); |     original_data = Object.assign({}, data); | ||||||
|     editable = Object.assign(editable, original_data); |     editable = Object.assign({}, original_data); | ||||||
|  |     paid_amount_input = data.paidAmount / 100; | ||||||
|     if (data.responseType == "DISTANCEDONATION") { |     if (data.responseType == "DISTANCEDONATION") { | ||||||
|       amount_input = data.amountPerDistance / 100; |       amount_input = data.amountPerDistance / 100; | ||||||
|       RunnerService.runnerControllerGetAll().then((val) => { |       RunnerService.runnerControllerGetAll().then((val) => { | ||||||
| @@ -66,10 +70,11 @@ | |||||||
|   function submit() { |   function submit() { | ||||||
|     if (data_loaded === true && save_enabled) { |     if (data_loaded === true && save_enabled) { | ||||||
|       Toastify({ |       Toastify({ | ||||||
|         text: "Donation is being updated", |         text: $_('updating-donation'), | ||||||
|         duration: 2500, |         duration: 2500, | ||||||
|       }).showToast(); |       }).showToast(); | ||||||
|       let postdata = {}; |       let postdata = {}; | ||||||
|  |       editable.paidAmount = paid_amount_input*100; | ||||||
|       if (original_data.responseType === "DISTANCEDONATION") { |       if (original_data.responseType === "DISTANCEDONATION") { | ||||||
|         editable.amountPerDistance = Math.floor(amount_input * 100); |         editable.amountPerDistance = Math.floor(amount_input * 100); | ||||||
|         postdata = Object.assign(postdata, editable); |         postdata = Object.assign(postdata, editable); | ||||||
| @@ -83,7 +88,7 @@ | |||||||
|             Object.assign(original_data, editable); |             Object.assign(original_data, editable); | ||||||
|             original_data = original_data; |             original_data = original_data; | ||||||
|             Toastify({ |             Toastify({ | ||||||
|               text: "updated donation", |               text: $_('donation-updated'), | ||||||
|               duration: 2500, |               duration: 2500, | ||||||
|               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|             }).showToast(); |             }).showToast(); | ||||||
| @@ -98,7 +103,7 @@ | |||||||
|             Object.assign(original_data, editable); |             Object.assign(original_data, editable); | ||||||
|             original_data = original_data; |             original_data = original_data; | ||||||
|             Toastify({ |             Toastify({ | ||||||
|               text: "updated donation", |               text: $_('donation-updated'), | ||||||
|               duration: 2500, |               duration: 2500, | ||||||
|               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|             }).showToast(); |             }).showToast(); | ||||||
| @@ -112,7 +117,7 @@ | |||||||
|     DonationService.donationControllerRemove(original_data.id, false) |     DonationService.donationControllerRemove(original_data.id, false) | ||||||
|       .then((resp) => { |       .then((resp) => { | ||||||
|         Toastify({ |         Toastify({ | ||||||
|           text: "Donation delete", |           text: $_('donation-deleted'), | ||||||
|           duration: 500, |           duration: 500, | ||||||
|           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
| @@ -219,7 +224,24 @@ | |||||||
|       <span>{(editable.amount / 100) |       <span>{(editable.amount / 100) | ||||||
|           .toFixed(2) |           .toFixed(2) | ||||||
|           .toLocaleString('de-DE', { valute: 'EUR' })}€</span> |           .toLocaleString('de-DE', { valute: 'EUR' })}€</span> | ||||||
|  |       | | ||||||
|  |       <span | ||||||
|  |         class="font-medium text-gray-700">{$_('paid-amount')}:</span> | ||||||
|  |       <span>{(editable.paidAmount / 100) | ||||||
|  |           .toFixed(2) | ||||||
|  |           .toLocaleString('de-DE', { valute: 'EUR' })}€</span> | ||||||
|  |       | | ||||||
|  |       <span | ||||||
|  |         class="font-medium text-gray-700">{$_('status')}:</span> | ||||||
|  |         {#if editable.status =="PAID"} | ||||||
|  |           <span | ||||||
|  |             class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-green-100 text-green-800">{$_('paid')}</span> | ||||||
|  |         {:else} | ||||||
|  |           <span | ||||||
|  |             class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-red-100 text-red-800">{$_('open')}</span> | ||||||
|  |         {/if} | ||||||
|     </div> |     </div> | ||||||
|  |     <br> | ||||||
|     <div class=" w-full"> |     <div class=" w-full"> | ||||||
|       <label |       <label | ||||||
|         for="donor" |         for="donor" | ||||||
| @@ -232,7 +254,7 @@ | |||||||
|         placeholder={$_('search-for-donor-name-or-id')} |         placeholder={$_('search-for-donor-name-or-id')} | ||||||
|         noOptionsMessage={$_('no-donors-found')} |         noOptionsMessage={$_('no-donors-found')} | ||||||
|         bind:selectedValue={donor} |         bind:selectedValue={donor} | ||||||
|         on:select={(selectedValue) => (editable.donor = selectedValue.detail.value)} |         on:select={(selectedValue) => {editable.donor = selectedValue.detail.value; editable.donor.donationAmount=original_data.donor.donationAmount; editable.donor.paidDonationAmount =original_data.donor.paidDonationAmount}} | ||||||
|         on:clear={() => (editable.donor = null)} /> |         on:clear={() => (editable.donor = null)} /> | ||||||
|     </div> |     </div> | ||||||
|     {#if original_data.responseType == 'DISTANCEDONATION'} |     {#if original_data.responseType == 'DISTANCEDONATION'} | ||||||
| @@ -280,6 +302,39 @@ | |||||||
|         </span> |         </span> | ||||||
|       {/if} |       {/if} | ||||||
|     </div> |     </div> | ||||||
|  |     <div class="w-full"> | ||||||
|  |       <label | ||||||
|  |         for="token" | ||||||
|  |         class="block text-sm font-medium text-gray-700">{$_('paid-amount')}</label> | ||||||
|  |       <div class="inline-flex border-gray-300 border rounded-l-md rounded-r-md bg-gray-50 text-gray-500 w-full"> | ||||||
|  |         <input | ||||||
|  |             autocomplete="off" | ||||||
|  |             class:border-red-500={!is_amount_valid} | ||||||
|  |             class:focus:border-red-500={!is_amount_valid} | ||||||
|  |             class:focus:ring-red-500={!is_amount_valid} | ||||||
|  |             bind:value={paid_amount_input} | ||||||
|  |             type="number" | ||||||
|  |             step="0.01" | ||||||
|  |             name="donation_amount_eur" | ||||||
|  |             class="focus:ring-indigo-500 focus:border-indigo-500 flex-1 block w-full rounded-none rounded-l-md sm:text-sm p-2" | ||||||
|  |             placeholder="2.00" /> | ||||||
|  |           <button | ||||||
|  |             on:click={ | ||||||
|  |               ()=>{ | ||||||
|  |                 paid_amount_input=paid_amount_input = (original_data.amount/100).toFixed(2); | ||||||
|  |               } | ||||||
|  |             } | ||||||
|  |             class="inline-flex items-center p-r-2 text-indigo-300 hover:text-indigo-700 text-sm">MAX</button> | ||||||
|  |           <span | ||||||
|  |             class="inline-flex items-center px-3 rounded-r-md border border-gray-300 bg-gray-50 text-gray-500 text-sm">€</span> | ||||||
|  |         </div> | ||||||
|  |         {#if !is_paid_amount_valid} | ||||||
|  |           <span | ||||||
|  |             class="flex items-center font-medium tracking-wide text-red-500 text-xs mt-1 ml-1"> | ||||||
|  |             {$_('payment-amount-must-be-greater-than-0-00eur')} | ||||||
|  |           </span> | ||||||
|  |         {/if} | ||||||
|  |     </div> | ||||||
|   </section> |   </section> | ||||||
| {:catch error} | {:catch error} | ||||||
|   <PromiseError {error} /> |   <PromiseError {error} /> | ||||||
|   | |||||||
| @@ -4,9 +4,14 @@ | |||||||
|   import store from "../../store"; |   import store from "../../store"; | ||||||
|   import Toastify from "toastify-js"; |   import Toastify from "toastify-js"; | ||||||
|   import DonationsEmptyState from "./DonationsEmptyState.svelte"; |   import DonationsEmptyState from "./DonationsEmptyState.svelte"; | ||||||
|  |   import AddDonationPaymentModal from "./AddDonationPaymentModal.svelte"; | ||||||
|   $: searchvalue = ""; |   $: searchvalue = ""; | ||||||
|   $: active_deletes = []; |   $: active_deletes = []; | ||||||
|   export let current_donations = []; |   export let current_donations = []; | ||||||
|  |   export let payment_modal_open = false; | ||||||
|  |   export let editable = {}; | ||||||
|  |   export let original_data = {}; | ||||||
|  |   export let paid_amount_input = 0; | ||||||
|   const donations_promise = DonationService.donationControllerGetAll().then( |   const donations_promise = DonationService.donationControllerGetAll().then( | ||||||
|     (val) => { |     (val) => { | ||||||
|       current_donations = val; |       current_donations = val; | ||||||
| @@ -18,8 +23,15 @@ | |||||||
|     } |     } | ||||||
|     return id.toString() === searchvalue; |     return id.toString() === searchvalue; | ||||||
|   } |   } | ||||||
|  |   function open_payment_modal(donation) { | ||||||
|  |     editable = Object.assign({}, donation); | ||||||
|  |     original_data = Object.assign({}, donation); | ||||||
|  |     paid_amount_input = (donation.paidAmount/100).toFixed(2); | ||||||
|  |     payment_modal_open = true; | ||||||
|  |   } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  | <AddDonationPaymentModal bind:current_donations bind:original_data bind:editable bind:paid_amount_input bind:payment_modal_open /> | ||||||
| {#if store.state.jwtinfo.userdetails.permissions.includes('DONATION:GET')} | {#if store.state.jwtinfo.userdetails.permissions.includes('DONATION:GET')} | ||||||
|   {#await donations_promise} |   {#await donations_promise} | ||||||
|     <div |     <div | ||||||
| @@ -63,6 +75,16 @@ | |||||||
|                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider"> |                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider"> | ||||||
|                 {$_('donation-amount')} |                 {$_('donation-amount')} | ||||||
|               </th> |               </th> | ||||||
|  |               <th | ||||||
|  |                 scope="col" | ||||||
|  |                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider"> | ||||||
|  |                 {$_('paid-amount')} | ||||||
|  |               </th> | ||||||
|  |               <th | ||||||
|  |                 scope="col" | ||||||
|  |                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider"> | ||||||
|  |                 {$_('status')} | ||||||
|  |               </th> | ||||||
|               <th scope="col" class="relative px-6 py-3"> |               <th scope="col" class="relative px-6 py-3"> | ||||||
|                 <span class="sr-only">{$_('action')}</span> |                 <span class="sr-only">{$_('action')}</span> | ||||||
|               </th> |               </th> | ||||||
| @@ -132,6 +154,22 @@ | |||||||
|                         .toLocaleString('de-DE', { valute: 'EUR' })}€ |                         .toLocaleString('de-DE', { valute: 'EUR' })}€ | ||||||
|                     </div> |                     </div> | ||||||
|                   </td> |                   </td> | ||||||
|  |                   <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|  |                     <div class="text-sm font-medium text-gray-900"> | ||||||
|  |                       {(donation.paidAmount / 100) | ||||||
|  |                         .toFixed(2) | ||||||
|  |                         .toLocaleString('de-DE', { valute: 'EUR' })}€ | ||||||
|  |                     </div> | ||||||
|  |                   </td> | ||||||
|  |                   <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|  |                     {#if donation.status =="PAID"} | ||||||
|  |                       <span | ||||||
|  |                         class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-green-100 text-green-800">{$_('paid')}</span> | ||||||
|  |                     {:else} | ||||||
|  |                       <span | ||||||
|  |                         class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-red-100 text-red-800">{$_('open')}</span> | ||||||
|  |                     {/if} | ||||||
|  |                   </td> | ||||||
|                   {#if active_deletes[donation.id] === true} |                   {#if active_deletes[donation.id] === true} | ||||||
|                     <td |                     <td | ||||||
|                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> |                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> | ||||||
| @@ -149,7 +187,7 @@ | |||||||
|                                 (obj) => obj.id !== donation.id |                                 (obj) => obj.id !== donation.id | ||||||
|                               ); |                               ); | ||||||
|                               Toastify({ |                               Toastify({ | ||||||
|                                 text: 'Donation deleted', |                                 text: $_('donation-deleted'), | ||||||
|                                 duration: 500, |                                 duration: 500, | ||||||
|                                 backgroundColor: |                                 backgroundColor: | ||||||
|                                   'linear-gradient(to right, #00b09b, #96c93d)', |                                   'linear-gradient(to right, #00b09b, #96c93d)', | ||||||
| @@ -163,6 +201,9 @@ | |||||||
|                   {:else} |                   {:else} | ||||||
|                     <td |                     <td | ||||||
|                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> |                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> | ||||||
|  |                       <button | ||||||
|  |                         on:click={() => {open_payment_modal(donation);}} | ||||||
|  |                         class="text-[#025a21] hover:text-green-900 mr-4">{$_('enter-payment')}</button> | ||||||
|                       <a |                       <a | ||||||
|                         href="./{donation.id}" |                         href="./{donation.id}" | ||||||
|                         class="text-indigo-600 hover:text-indigo-900">{$_('details')}</a> |                         class="text-indigo-600 hover:text-indigo-900">{$_('details')}</a> | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ | |||||||
|     ) |     ) | ||||||
|       .then((resp) => { |       .then((resp) => { | ||||||
|         Toastify({ |         Toastify({ | ||||||
|           text: "Donor deleted", |           text: $_('donor-deleted'), | ||||||
|           duration: 500, |           duration: 500, | ||||||
|           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|   | |||||||
| @@ -193,6 +193,12 @@ | |||||||
|       <span>{(editable.donationAmount / 100) |       <span>{(editable.donationAmount / 100) | ||||||
|           .toFixed(2) |           .toFixed(2) | ||||||
|           .toLocaleString('de-DE', { valute: 'EUR' })}€</span> |           .toLocaleString('de-DE', { valute: 'EUR' })}€</span> | ||||||
|  |       | | ||||||
|  |       <span | ||||||
|  |         class="font-medium text-gray-700">{$_('total-paid-amount')}:</span> | ||||||
|  |       <span>{(editable.paidDonationAmount / 100) | ||||||
|  |           .toFixed(2) | ||||||
|  |           .toLocaleString('de-DE', { valute: 'EUR' })}€</span> | ||||||
|       <br /> |       <br /> | ||||||
|       <span class="font-medium text-gray-700">{$_('donations')}:</span> |       <span class="font-medium text-gray-700">{$_('donations')}:</span> | ||||||
|       {#if current_donations.filter((d) => d.donor.id == editable.id).length > 0} |       {#if current_donations.filter((d) => d.donor.id == editable.id).length > 0} | ||||||
|   | |||||||
| @@ -20,6 +20,31 @@ | |||||||
|         {$_('add-donor')} |         {$_('add-donor')} | ||||||
|       </button> |       </button> | ||||||
|     {/if} |     {/if} | ||||||
|  |     {#if store.state.jwtinfo.userdetails.permissions.includes('DONOR:GET')} | ||||||
|  |       <button | ||||||
|  |         on:click={() => { | ||||||
|  |           const data = (current_donors.filter(d=>d.receiptNeeded===true)).map(function (d) { | ||||||
|  |             d.address.address2=d.address.address2===""?"":" "+d.address.address2; | ||||||
|  |             const address=`${d.address.address1}${d.address.address2}, ${d.address.postalcode} ${d.address.city}, ${d.address.country}`; | ||||||
|  |             return [d.firstname,d.middlename,d.lastname,d.paidDonationAmount,address]; | ||||||
|  |           }) | ||||||
|  |           let csv = `${$_('csv_import__firstname')};${$_('csv_import__middlename')};${$_('csv_import__lastname')};${$_('total_donation_amount_in_eur')};${$_('address')}\n`; | ||||||
|  |     data.forEach(function(row) { | ||||||
|  |             csv += row.join(';'); | ||||||
|  |             csv += "\n"; | ||||||
|  |     }); | ||||||
|  |     let hiddenElement = document.createElement('a'); | ||||||
|  |     hiddenElement.href = 'data:text/csv;charset=utf-8,' + encodeURI(csv); | ||||||
|  |     hiddenElement.target = '_blank'; | ||||||
|  |     hiddenElement.download = `${$_('filename_sponsoringquittungsliste')}.csv`; | ||||||
|  |     hiddenElement.click(); | ||||||
|  |     hiddenElement.remove(); | ||||||
|  |         }} | ||||||
|  |         type="button" | ||||||
|  |         class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-600 text-base font-medium text-white hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm"> | ||||||
|  |         {$_('sponsoring-quittungs-liste_herunterladen')} | ||||||
|  |       </button> | ||||||
|  |     {/if} | ||||||
|   </span> |   </span> | ||||||
|   <DonorsOverview bind:current_donors /> |   <DonorsOverview bind:current_donors /> | ||||||
| </section> | </section> | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| <script> | <script> | ||||||
|   import { getLocaleFromNavigator, _ } from "svelte-i18n"; |   import { _ } from "svelte-i18n"; | ||||||
|   import { DonationService, DonorService } from "@odit/lfk-client-js"; |   import { DonationService, DonorService } from "@odit/lfk-client-js"; | ||||||
|   import store from "../../store"; |   import store from "../../store"; | ||||||
|   import DonorsEmptyState from "./DonorsEmptyState.svelte"; |   import DonorsEmptyState from "./DonorsEmptyState.svelte"; | ||||||
| @@ -77,6 +77,11 @@ | |||||||
|                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider"> |                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider"> | ||||||
|                 {$_('total-donation-amount')} |                 {$_('total-donation-amount')} | ||||||
|               </th> |               </th> | ||||||
|  |               <th | ||||||
|  |                 scope="col" | ||||||
|  |                 class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider"> | ||||||
|  |                 {$_('total-paid-amount')} | ||||||
|  |               </th> | ||||||
|               <th scope="col" class="relative px-6 py-3"> |               <th scope="col" class="relative px-6 py-3"> | ||||||
|                 <span class="sr-only">{$_('action')}</span> |                 <span class="sr-only">{$_('action')}</span> | ||||||
|               </th> |               </th> | ||||||
| @@ -127,7 +132,7 @@ | |||||||
|                           <a |                           <a | ||||||
|                             href="../donations/{d.id}" |                             href="../donations/{d.id}" | ||||||
|                             class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-blue-600 text-white mr-1">{d.runner.firstname} |                             class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-blue-600 text-white mr-1">{d.runner.firstname} | ||||||
|                             {d.runner.middlename} |                             {d.runner.middlename || ''} | ||||||
|                             {d.runner.lastname}</a> |                             {d.runner.lastname}</a> | ||||||
|                         {:else} |                         {:else} | ||||||
|                           <a |                           <a | ||||||
| @@ -145,6 +150,11 @@ | |||||||
|                       .toFixed(2) |                       .toFixed(2) | ||||||
|                       .toLocaleString('de-DE', { valute: 'EUR' })}€ |                       .toLocaleString('de-DE', { valute: 'EUR' })}€ | ||||||
|                   </td> |                   </td> | ||||||
|  |                   <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|  |                     {(donor.paidDonationAmount / 100) | ||||||
|  |                       .toFixed(2) | ||||||
|  |                       .toLocaleString('de-DE', { valute: 'EUR' })}€ | ||||||
|  |                   </td> | ||||||
|                   {#if active_deletes[donor.id] === true} |                   {#if active_deletes[donor.id] === true} | ||||||
|                     <td |                     <td | ||||||
|                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> |                       class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium"> | ||||||
|   | |||||||
| @@ -32,8 +32,12 @@ | |||||||
|       target="_blank" |       target="_blank" | ||||||
|       rel="noopener, noreferrer" |       rel="noopener, noreferrer" | ||||||
|       href="https://git.odit.services/lfk/frontend/src/tag/{releaseinfo}">{releaseinfo}</a> |       href="https://git.odit.services/lfk/frontend/src/tag/{releaseinfo}">{releaseinfo}</a> | ||||||
|       - |     - | ||||||
|     <a class="underline" href="https://docs.lauf-fuer-kaya.de" target="_blank">{$_('documentation')}</a> |     <a | ||||||
|  |       rel="noopener, noreferrer" | ||||||
|  |       class="underline" | ||||||
|  |       href="https://docs.lauf-fuer-kaya.de" | ||||||
|  |       target="_blank">{$_('documentation')}</a> | ||||||
|     - |     - | ||||||
|     <a class="underline" href="/privacy">{$_('privacy')}</a> |     <a class="underline" href="/privacy">{$_('privacy')}</a> | ||||||
|     - |     - | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ | |||||||
|     ) |     ) | ||||||
|       .then((resp) => { |       .then((resp) => { | ||||||
|         Toastify({ |         Toastify({ | ||||||
|           text: "Organization deleted", |           text: $_('organization-deleted'), | ||||||
|           duration: 500, |           duration: 500, | ||||||
|           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ | |||||||
|   $: active_deletes = []; |   $: active_deletes = []; | ||||||
|   $: sponsoring_contracts_show = current_organizations.some((r) => r.is_selected === true); |   $: sponsoring_contracts_show = current_organizations.some((r) => r.is_selected === true); | ||||||
|   $: cards_show = current_organizations.some((r) => r.is_selected === true); |   $: cards_show = current_organizations.some((r) => r.is_selected === true); | ||||||
|   $: generate_orgs = current_organizations.some((r) => r.is_selected === true); |   $: generate_orgs = current_organizations.filter((r) => r.is_selected === true); | ||||||
|   $: certificates_show = current_organizations.some( |   $: certificates_show = current_organizations.some( | ||||||
|     (r) => r.is_selected === true |     (r) => r.is_selected === true | ||||||
|   ); |   ); | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ | |||||||
|             duration: -1, |             duration: -1, | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|         fetch( |         fetch( | ||||||
|             `${config.baseurl}/documents/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, |             `${config.baseurl_documentserver}/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|             { |             { | ||||||
|                 method: "POST", |                 method: "POST", | ||||||
|                 headers: { |                 headers: { | ||||||
| @@ -101,7 +101,7 @@ | |||||||
|             cards.push(card); |             cards.push(card); | ||||||
|         } |         } | ||||||
|         fetch( |         fetch( | ||||||
|             `${config.baseurl}/documents/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, |             `${config.baseurl_documentserver}/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|             { |             { | ||||||
|                 method: "POST", |                 method: "POST", | ||||||
|                 headers: { |                 headers: { | ||||||
| @@ -169,7 +169,7 @@ | |||||||
|                 cards.push(card); |                 cards.push(card); | ||||||
|             } |             } | ||||||
|             fetch( |             fetch( | ||||||
|                 `${config.baseurl}/documents/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, |                 `${config.baseurl_documentserver}/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|                 { |                 { | ||||||
|                     method: "POST", |                     method: "POST", | ||||||
|                     headers: { |                     headers: { | ||||||
| @@ -216,15 +216,16 @@ | |||||||
|  |  | ||||||
|     async function generateOrgCards(locale) { |     async function generateOrgCards(locale) { | ||||||
|         const toast = Toastify({ |         const toast = Toastify({ | ||||||
|             text: $_("generating-pdf"), |             text: $_("generating-pdfs"), | ||||||
|             duration: -1, |             duration: -1, | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|         let count = 0; |  | ||||||
|         const current_cards = await RunnerCardService.runnerCardControllerGetAll(); |         const current_cards = await RunnerCardService.runnerCardControllerGetAll(); | ||||||
|  |         let count = 0; | ||||||
|  |         let count_orgs =0; | ||||||
|         for (const o of generate_orgs) { |         for (const o of generate_orgs) { | ||||||
|             const runners = await RunnerOrganizationService.runnerOrganizationControllerGetRunners( |             count_orgs++; | ||||||
|                 o.id |             let count = 0; | ||||||
|             ); |             let runners = await RunnerOrganizationService.runnerOrganizationControllerGetRunners(o.id, true) | ||||||
|             let cards = []; |             let cards = []; | ||||||
|             for (let runner of runners) { |             for (let runner of runners) { | ||||||
|                 let card = current_cards.find((c) => c.runner?.id == runner.id); |                 let card = current_cards.find((c) => c.runner?.id == runner.id); | ||||||
| @@ -235,8 +236,8 @@ | |||||||
|                 } |                 } | ||||||
|                 cards.push(card); |                 cards.push(card); | ||||||
|             } |             } | ||||||
|             fetch( |             await fetch( | ||||||
|                 `${config.baseurl}/documents/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, |                 `${config.baseurl_documentserver}/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|                 { |                 { | ||||||
|                     method: "POST", |                     method: "POST", | ||||||
|                     headers: { |                     headers: { | ||||||
| @@ -245,39 +246,97 @@ | |||||||
|                     body: JSON.stringify(cards), |                     body: JSON.stringify(cards), | ||||||
|                 } |                 } | ||||||
|             ) |             ) | ||||||
|                 .then((response) => { |             .then((response) => { | ||||||
|                     if (response.status != "200") { |                 if (response.status != "200") { | ||||||
|                         toast.hideToast(); |                     toast.hideToast(); | ||||||
|                         Toastify({ |                     Toastify({ | ||||||
|                             text: $_("pdf-generation-failed"), |                         text: $_("pdf-generation-failed"), | ||||||
|                             duration: 3500, |                         duration: 3500, | ||||||
|                             backgroundColor: |                         backgroundColor: | ||||||
|                                 "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", |                             "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", | ||||||
|                         }).showToast(); |                     }).showToast(); | ||||||
|                     } else { |                 } else { | ||||||
|                         return response.blob(); |                     return response.blob(); | ||||||
|                     } |                 } | ||||||
|                 }) |             }) | ||||||
|                 .then((blob) => { |             .then((blob) => { | ||||||
|                     count++; |                 const url = window.URL.createObjectURL(blob); | ||||||
|                     const url = window.URL.createObjectURL(blob); |                 let a = document.createElement("a"); | ||||||
|                     let a = document.createElement("a"); |                 a.href = url; | ||||||
|                     a.href = url; |                 a.download = `${$_('runnercards')}_${o.name}_direct-${locale}.pdf`; | ||||||
|                     a.download = `${$_('runnercards')}_${o.name}-${locale}.pdf`; |                 document.body.appendChild(a); | ||||||
|                     document.body.appendChild(a); |                 a.click(); | ||||||
|                     a.click(); |                 a.remove(); | ||||||
|                     a.remove(); |                 if (count === o.teams.length && count_orgs === generate_orgs.length) { | ||||||
|                     if (count === generate_orgs.length) { |                     toast.hideToast(); | ||||||
|                         toast.hideToast(); |                     console.log("here") | ||||||
|                         Toastify({ |                     Toastify({ | ||||||
|                             text: $_("pdfs-successfully-generated"), |                         text: $_("pdfs-successfully-generated"), | ||||||
|                             duration: 3500, |                         duration: 3500, | ||||||
|                             backgroundColor: |                         backgroundColor: | ||||||
|                                 "linear-gradient(to right, #00b09b, #96c93d)", |                         "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|                         }).showToast(); |                     }).showToast(); | ||||||
|                     } |                 } | ||||||
|                 }) |             }) | ||||||
|                 .catch((err) => {}); |             .catch((err) => {}); | ||||||
|  |             for (const t of o.teams) { | ||||||
|  |                 count++; | ||||||
|  |                 let runners = await RunnerTeamService.runnerTeamControllerGetRunners( | ||||||
|  |                     t.id | ||||||
|  |                 ); | ||||||
|  |             let cards = []; | ||||||
|  |             for (let runner of runners) { | ||||||
|  |                 let card = current_cards.find((c) => c.runner?.id == runner.id); | ||||||
|  |                 if (!card) { | ||||||
|  |                     card = await RunnerCardService.runnerCardControllerPost({ | ||||||
|  |                         runner: runner.id, | ||||||
|  |                     }); | ||||||
|  |                 } | ||||||
|  |                 cards.push(card); | ||||||
|  |             } | ||||||
|  |             await fetch( | ||||||
|  |                 `${config.baseurl_documentserver}/cards?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|  |                 { | ||||||
|  |                     method: "POST", | ||||||
|  |                     headers: { | ||||||
|  |                         "Content-Type": "application/json", | ||||||
|  |                     }, | ||||||
|  |                     body: JSON.stringify(cards), | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |             .then((response) => { | ||||||
|  |                 if (response.status != "200") { | ||||||
|  |                     toast.hideToast(); | ||||||
|  |                     Toastify({ | ||||||
|  |                         text: $_("pdf-generation-failed"), | ||||||
|  |                         duration: 3500, | ||||||
|  |                         backgroundColor: | ||||||
|  |                             "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", | ||||||
|  |                     }).showToast(); | ||||||
|  |                 } else { | ||||||
|  |                     return response.blob(); | ||||||
|  |                 } | ||||||
|  |             }) | ||||||
|  |             .then((blob) => { | ||||||
|  |                 const url = window.URL.createObjectURL(blob); | ||||||
|  |                 let a = document.createElement("a"); | ||||||
|  |                 a.href = url; | ||||||
|  |                 a.download = `${$_('runnercards')}_${o.name}_${t.name}-${locale}.pdf`; | ||||||
|  |                 document.body.appendChild(a); | ||||||
|  |                 a.click(); | ||||||
|  |                 a.remove(); | ||||||
|  |                 if (count === o.teams.length && count_orgs === generate_orgs.length) { | ||||||
|  |                     toast.hideToast(); | ||||||
|  |                     Toastify({ | ||||||
|  |                         text: $_("pdfs-successfully-generated"), | ||||||
|  |                         duration: 3500, | ||||||
|  |                         backgroundColor: | ||||||
|  |                             "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|  |                     }).showToast(); | ||||||
|  |                 } | ||||||
|  |             }) | ||||||
|  |             .catch((err) => {}); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| </script> | </script> | ||||||
|   | |||||||
| @@ -37,14 +37,15 @@ | |||||||
|             text: $_("generating-pdf"), |             text: $_("generating-pdf"), | ||||||
|             duration: -1, |             duration: -1, | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|         const current_donations = await DonationService.donationControllerGetAll(); |         const current_donations = (await DonationService.donationControllerGetAll()) || []; | ||||||
|         let certificateRunners = []; |         let certificateRunners = []; | ||||||
|         for (let runner of generate_runners) { |         for (let runner of generate_runners) { | ||||||
|             runner.distanceDonations = current_donations.find((d) => d.runner?.id == runner.id) || []; |             runner.distanceDonations = current_donations.filter((d) => d.runner?.id == runner.id) || []; | ||||||
|  |             console.log(runner.distanceDonations) | ||||||
|             certificateRunners.push(runner); |             certificateRunners.push(runner); | ||||||
|         } |         } | ||||||
|         fetch( |         fetch( | ||||||
|             `${config.baseurl}/documents/certificates?locale=${locale}&download=true&key=${config.documentserver_key}`, |             `${config.baseurl_documentserver}/certificates?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|             { |             { | ||||||
|                 method: "POST", |                 method: "POST", | ||||||
|                 headers: { |                 headers: { | ||||||
| @@ -96,18 +97,18 @@ | |||||||
|             duration: -1, |             duration: -1, | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|         let count = 0; |         let count = 0; | ||||||
|         const current_donations = await DonationService.donationControllerGetAll(); |         const current_donations = (await DonationService.donationControllerGetAll()) || []; | ||||||
|         for (const t of generate_teams) { |         for (const t of generate_teams) { | ||||||
|             const runners = await RunnerTeamService.runnerTeamControllerGetRunners( |             const runners = await RunnerTeamService.runnerTeamControllerGetRunners( | ||||||
|                 t.id |                 t.id | ||||||
|                 ); |                 ); | ||||||
|             let certificateRunners = []; |             let certificateRunners = []; | ||||||
|             for (let runner of runners) { |             for (let runner of runners) { | ||||||
|                 runner.distanceDonations = current_donations.find((d) => d.runner?.id == runner.id) || []; |                 runner.distanceDonations = current_donations.filter((d) => d.runner?.id == runner.id) || []; | ||||||
|                 certificateRunners.push(runner); |                 certificateRunners.push(runner); | ||||||
|             } |             } | ||||||
|             fetch( |             fetch( | ||||||
|                 `${config.baseurl}/documents/certificates?locale=${locale}&download=true&key=${config.documentserver_key}`, |                 `${config.baseurl_documentserver}/certificates?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|                 { |                 { | ||||||
|                     method: "POST", |                     method: "POST", | ||||||
|                     headers: { |                     headers: { | ||||||
| @@ -154,22 +155,23 @@ | |||||||
|  |  | ||||||
|     async function generateOrgCertificates(locale) { |     async function generateOrgCertificates(locale) { | ||||||
|         const toast = Toastify({ |         const toast = Toastify({ | ||||||
|             text: $_("generating-pdf"), |             text: $_("generating-pdfs"), | ||||||
|             duration: -1, |             duration: -1, | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|  |         const current_donations = (await DonationService.donationControllerGetAll()) || []; | ||||||
|         let count = 0; |         let count = 0; | ||||||
|         const current_donations = await DonationService.donationControllerGetAll(); |         let count_orgs =0; | ||||||
|         for (const o of generate_orgs) { |         for (const o of generate_orgs) { | ||||||
|             const runners = await RunnerOrganizationService.runnerOrganizationControllerGetRunners( |             count_orgs++; | ||||||
|                 o.id |             let count = 0; | ||||||
|             ); |             let runners = await RunnerOrganizationService.runnerOrganizationControllerGetRunners(o.id, true) | ||||||
|             let certificateRunners = []; |             let certificateRunners = []; | ||||||
|             for (let runner of runners) { |             for (let runner of runners) { | ||||||
|                 runner.distanceDonations = current_donations.find((d) => d.runner?.id == runner.id) || []; |                 runner.distanceDonations = current_donations.filter((d) => d.runner?.id == runner.id) || []; | ||||||
|                 certificateRunners.push(runner); |                 certificateRunners.push(runner); | ||||||
|             } |             } | ||||||
|             fetch( |             await fetch( | ||||||
|                 `${config.baseurl}/documents/certificates?locale=${locale}&download=true&key=${config.documentserver_key}`, |                 `${config.baseurl_documentserver}/certificates?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|                 { |                 { | ||||||
|                     method: "POST", |                     method: "POST", | ||||||
|                     headers: { |                     headers: { | ||||||
| @@ -178,39 +180,92 @@ | |||||||
|                     body: JSON.stringify(certificateRunners), |                     body: JSON.stringify(certificateRunners), | ||||||
|                 } |                 } | ||||||
|             ) |             ) | ||||||
|                 .then((response) => { |             .then((response) => { | ||||||
|                     if (response.status != "200") { |                 if (response.status != "200") { | ||||||
|                         toast.hideToast(); |                     toast.hideToast(); | ||||||
|                         Toastify({ |                     Toastify({ | ||||||
|                             text: $_("pdf-generation-failed"), |                         text: $_("pdf-generation-failed"), | ||||||
|                             duration: 3500, |                         duration: 3500, | ||||||
|                             backgroundColor: |                         backgroundColor: | ||||||
|                                 "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", |                             "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", | ||||||
|                         }).showToast(); |                     }).showToast(); | ||||||
|                     } else { |                 } else { | ||||||
|                         return response.blob(); |                     return response.blob(); | ||||||
|                     } |                 } | ||||||
|                 }) |             }) | ||||||
|                 .then((blob) => { |             .then((blob) => { | ||||||
|                     count++; |                 const url = window.URL.createObjectURL(blob); | ||||||
|                     const url = window.URL.createObjectURL(blob); |                 let a = document.createElement("a"); | ||||||
|                     let a = document.createElement("a"); |                 a.href = url; | ||||||
|                     a.href = url; |                 a.download = `${$_('certificates')}_${o.name}_direct-${locale}.pdf`; | ||||||
|                     a.download = `${$_('certificates')}_${o.name}-${locale}.pdf`; |                 document.body.appendChild(a); | ||||||
|                     document.body.appendChild(a); |                 a.click(); | ||||||
|                     a.click(); |                 a.remove(); | ||||||
|                     a.remove(); |                 if (count === o.teams.length && count_orgs === generate_orgs.length) { | ||||||
|                     if (count === generate_orgs.length) { |                     toast.hideToast(); | ||||||
|                         toast.hideToast(); |                     console.log("here") | ||||||
|                         Toastify({ |                     Toastify({ | ||||||
|                             text: $_("pdfs-successfully-generated"), |                         text: $_("pdfs-successfully-generated"), | ||||||
|                             duration: 3500, |                         duration: 3500, | ||||||
|                             backgroundColor: |                         backgroundColor: | ||||||
|                                 "linear-gradient(to right, #00b09b, #96c93d)", |                         "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|                         }).showToast(); |                     }).showToast(); | ||||||
|                     } |                 } | ||||||
|                 }) |             }) | ||||||
|                 .catch((err) => {}); |             .catch((err) => {}); | ||||||
|  |             for (const t of o.teams) { | ||||||
|  |                 count++; | ||||||
|  |                 let runners = await RunnerTeamService.runnerTeamControllerGetRunners( | ||||||
|  |                     t.id | ||||||
|  |                 ); | ||||||
|  |                 let certificateRunners = []; | ||||||
|  |             for (let runner of runners) { | ||||||
|  |                 runner.distanceDonations = current_donations.filter((d) => d.runner?.id == runner.id) || []; | ||||||
|  |                 certificateRunners.push(runner); | ||||||
|  |             } | ||||||
|  |             await fetch( | ||||||
|  |                 `${config.baseurl_documentserver}/certificates?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|  |                 { | ||||||
|  |                     method: "POST", | ||||||
|  |                     headers: { | ||||||
|  |                         "Content-Type": "application/json", | ||||||
|  |                     }, | ||||||
|  |                     body: JSON.stringify(certificateRunners), | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |             .then((response) => { | ||||||
|  |                 if (response.status != "200") { | ||||||
|  |                     toast.hideToast(); | ||||||
|  |                     Toastify({ | ||||||
|  |                         text: $_("pdf-generation-failed"), | ||||||
|  |                         duration: 3500, | ||||||
|  |                         backgroundColor: | ||||||
|  |                             "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", | ||||||
|  |                     }).showToast(); | ||||||
|  |                 } else { | ||||||
|  |                     return response.blob(); | ||||||
|  |                 } | ||||||
|  |             }) | ||||||
|  |             .then((blob) => { | ||||||
|  |                 const url = window.URL.createObjectURL(blob); | ||||||
|  |                 let a = document.createElement("a"); | ||||||
|  |                 a.href = url; | ||||||
|  |                 a.download = `${$_('certificates')}_${o.name}_${t.name}-${locale}.pdf`; | ||||||
|  |                 document.body.appendChild(a); | ||||||
|  |                 a.click(); | ||||||
|  |                 a.remove(); | ||||||
|  |                 if (count === o.teams.length && count_orgs === generate_orgs.length) { | ||||||
|  |                     toast.hideToast(); | ||||||
|  |                     Toastify({ | ||||||
|  |                         text: $_("pdfs-successfully-generated"), | ||||||
|  |                         duration: 3500, | ||||||
|  |                         backgroundColor: | ||||||
|  |                             "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|  |                     }).showToast(); | ||||||
|  |                 } | ||||||
|  |             }) | ||||||
|  |             .catch((err) => {}); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| </script> | </script> | ||||||
|   | |||||||
| @@ -43,7 +43,7 @@ | |||||||
|                 t.id |                 t.id | ||||||
|             ); |             ); | ||||||
|             fetch( |             fetch( | ||||||
|                 `${config.baseurl}/documents/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`, |                 `${config.baseurl_documentserver}/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|                 { |                 { | ||||||
|                     method: "POST", |                     method: "POST", | ||||||
|                     headers: { |                     headers: { | ||||||
| @@ -92,12 +92,13 @@ | |||||||
|             text: $_("generating-pdf"), |             text: $_("generating-pdf"), | ||||||
|             duration: -1, |             duration: -1, | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|  |         let count_orgs =0; | ||||||
|         for (const o of generate_orgs) { |         for (const o of generate_orgs) { | ||||||
|             const runners = await RunnerOrganizationService.runnerOrganizationControllerGetRunners( |             count_orgs++; | ||||||
|                 o.id |             let count = 0; | ||||||
|             ); |             let runners = await RunnerOrganizationService.runnerOrganizationControllerGetRunners(o.id, true) | ||||||
|             fetch( |             await fetch( | ||||||
|                 `${config.baseurl}/documents/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`, |                 `${config.baseurl_documentserver}/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|                 { |                 { | ||||||
|                     method: "POST", |                     method: "POST", | ||||||
|                     headers: { |                     headers: { | ||||||
| @@ -106,39 +107,87 @@ | |||||||
|                     body: JSON.stringify(runners), |                     body: JSON.stringify(runners), | ||||||
|                 } |                 } | ||||||
|             ) |             ) | ||||||
|                 .then((response) => { |             .then((response) => { | ||||||
|                     if (response.status != "200") { |                 if (response.status != "200") { | ||||||
|                         toast.hideToast(); |                     toast.hideToast(); | ||||||
|                         Toastify({ |                     Toastify({ | ||||||
|                             text: $_("pdf-generation-failed"), |                         text: $_("pdf-generation-failed"), | ||||||
|                             duration: 3500, |                         duration: 3500, | ||||||
|                             backgroundColor: |                         backgroundColor: | ||||||
|                                 "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", |                             "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", | ||||||
|                         }).showToast(); |                     }).showToast(); | ||||||
|                     } else { |                 } else { | ||||||
|                         return response.blob(); |                     return response.blob(); | ||||||
|                     } |                 } | ||||||
|                 }) |             }) | ||||||
|                 .then((blob) => { |             .then((blob) => { | ||||||
|                     count++; |                 const url = window.URL.createObjectURL(blob); | ||||||
|                     const url = window.URL.createObjectURL(blob); |                 let a = document.createElement("a"); | ||||||
|                     let a = document.createElement("a"); |                 a.href = url; | ||||||
|                     a.href = url; |                 a.download = `${$_('sponsorings')}_${o.name}_direct-${locale}.pdf`; | ||||||
|                     a.download = `${$_('sponsorings')}_${o.name}-${locale}.pdf`; |                 document.body.appendChild(a); | ||||||
|                     document.body.appendChild(a); |                 a.click(); | ||||||
|                     a.click(); |                 a.remove(); | ||||||
|                     a.remove(); |                 if (count === o.teams.length && count_orgs === generate_orgs.length) { | ||||||
|                     if (count === generate_orgs.length) { |                     toast.hideToast(); | ||||||
|                         toast.hideToast(); |                     console.log("here") | ||||||
|                         Toastify({ |                     Toastify({ | ||||||
|                             text: $_("pdfs-successfully-generated"), |                         text: $_("pdfs-successfully-generated"), | ||||||
|                             duration: 3500, |                         duration: 3500, | ||||||
|                             backgroundColor: |                         backgroundColor: | ||||||
|                                 "linear-gradient(to right, #00b09b, #96c93d)", |                         "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|                         }).showToast(); |                     }).showToast(); | ||||||
|                     } |                 } | ||||||
|                 }) |             }) | ||||||
|                 .catch((err) => {}); |             .catch((err) => {}); | ||||||
|  |             for (const t of o.teams) { | ||||||
|  |                 count++; | ||||||
|  |                 let runners = await RunnerTeamService.runnerTeamControllerGetRunners( | ||||||
|  |                     t.id | ||||||
|  |                 ); | ||||||
|  |             await fetch( | ||||||
|  |                 `${config.baseurl_documentserver}/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|  |                 { | ||||||
|  |                     method: "POST", | ||||||
|  |                     headers: { | ||||||
|  |                         "Content-Type": "application/json", | ||||||
|  |                     }, | ||||||
|  |                     body: JSON.stringify(runners), | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |             .then((response) => { | ||||||
|  |                 if (response.status != "200") { | ||||||
|  |                     toast.hideToast(); | ||||||
|  |                     Toastify({ | ||||||
|  |                         text: $_("pdf-generation-failed"), | ||||||
|  |                         duration: 3500, | ||||||
|  |                         backgroundColor: | ||||||
|  |                             "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)", | ||||||
|  |                     }).showToast(); | ||||||
|  |                 } else { | ||||||
|  |                     return response.blob(); | ||||||
|  |                 } | ||||||
|  |             }) | ||||||
|  |             .then((blob) => { | ||||||
|  |                 const url = window.URL.createObjectURL(blob); | ||||||
|  |                 let a = document.createElement("a"); | ||||||
|  |                 a.href = url; | ||||||
|  |                 a.download = `${$_('sponsorings')}_${o.name}_${t.name}-${locale}.pdf`; | ||||||
|  |                 document.body.appendChild(a); | ||||||
|  |                 a.click(); | ||||||
|  |                 a.remove(); | ||||||
|  |                 if (count === o.teams.length && count_orgs === generate_orgs.length) { | ||||||
|  |                     toast.hideToast(); | ||||||
|  |                     Toastify({ | ||||||
|  |                         text: $_("pdfs-successfully-generated"), | ||||||
|  |                         duration: 3500, | ||||||
|  |                         backgroundColor: | ||||||
|  |                             "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|  |                     }).showToast(); | ||||||
|  |                 } | ||||||
|  |             }) | ||||||
|  |             .catch((err) => {}); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -148,7 +197,7 @@ | |||||||
|             duration: -1, |             duration: -1, | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|         fetch( |         fetch( | ||||||
|             `${config.baseurl}/documents/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`, |             `${config.baseurl_documentserver}/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`, | ||||||
|             { |             { | ||||||
|                 method: "POST", |                 method: "POST", | ||||||
|                 headers: { |                 headers: { | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ | |||||||
|     document.onkeydown = (e) => { |     document.onkeydown = (e) => { | ||||||
|       e = e || window.event; |       e = e || window.event; | ||||||
|       if (e.key === "Escape") { |       if (e.key === "Escape") { | ||||||
|         import_modal_open = false; |         cancelModal(); | ||||||
|       } |       } | ||||||
|       if (e.keyCode === 13) { |       if (e.keyCode === 13) { | ||||||
|         // |         // | ||||||
| @@ -202,7 +202,7 @@ | |||||||
|               toast.hideToast(); |               toast.hideToast(); | ||||||
|               recent_processed = true; |               recent_processed = true; | ||||||
|               Toastify({ |               Toastify({ | ||||||
|                 text: "Import finished", |                 text: $_('import-finished'), | ||||||
|                 duration: 500, |                 duration: 500, | ||||||
|                 backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |                 backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|               }).showToast(); |               }).showToast(); | ||||||
| @@ -281,6 +281,16 @@ | |||||||
|                   bind:files |                   bind:files | ||||||
|                   type="file" /> |                   type="file" /> | ||||||
|               </div> |               </div> | ||||||
|  |               <div class="overflow-hidden relative mt-4 mb-4"> | ||||||
|  |                 <button | ||||||
|  |                   on:click={() => { | ||||||
|  |                     cancelModal(); | ||||||
|  |                   }} | ||||||
|  |                   type="button" | ||||||
|  |                   class="w-full rounded-md border border-transparent shadow-sm px-4 py-2 bg-red-600 text-base font-medium text-white hover:bg-red-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-red-500 md:ml-40 mr-0 sm:ml-0 sm:w-auto sm:text-sm"> | ||||||
|  |                   {$_('cancel')} | ||||||
|  |                 </button> | ||||||
|  |               </div> | ||||||
|             {/if} |             {/if} | ||||||
|             {#if json_output.length > 0} |             {#if json_output.length > 0} | ||||||
|               {#if opened_from === 'OrgOverview'} |               {#if opened_from === 'OrgOverview'} | ||||||
|   | |||||||
| @@ -294,7 +294,7 @@ | |||||||
|     <div class="text-sm w-full"> |     <div class="text-sm w-full"> | ||||||
|       <span class="font-medium text-gray-700">{$_('distance')}</span> |       <span class="font-medium text-gray-700">{$_('distance')}</span> | ||||||
|       <br /> |       <br /> | ||||||
|       <span class="text-gray-700">{original_data.distance} km</span> |       <span class="text-gray-700">{original_data.distance /1000 } km</span> | ||||||
|     </div> |     </div> | ||||||
|   </section> |   </section> | ||||||
| {:catch error} | {:catch error} | ||||||
|   | |||||||
| @@ -197,7 +197,7 @@ | |||||||
|                       {#if runner.group.responseType === 'RUNNERTEAM'} |                       {#if runner.group.responseType === 'RUNNERTEAM'} | ||||||
|                         <a |                         <a | ||||||
|                           href="../teams/{runner.group.id}" |                           href="../teams/{runner.group.id}" | ||||||
|                           class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{runner.group.name}</a> |                           class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{runner.group.parentGroup.name} > {runner.group.name}</a> | ||||||
|                       {/if} |                       {/if} | ||||||
|                       {#if runner.group.responseType === 'RUNNERORGANIZATION'} |                       {#if runner.group.responseType === 'RUNNERORGANIZATION'} | ||||||
|                         <a |                         <a | ||||||
| @@ -206,7 +206,7 @@ | |||||||
|                       {/if} |                       {/if} | ||||||
|                     </td> |                     </td> | ||||||
|                     <td class="px-6 py-4 whitespace-nowrap"> |                     <td class="px-6 py-4 whitespace-nowrap"> | ||||||
|                       {runner.distance} |                       {runner.distance /1000 } km | ||||||
|                     </td> |                     </td> | ||||||
|                     {#if active_deletes[runner.id] === true} |                     {#if active_deletes[runner.id] === true} | ||||||
|                       <td |                       <td | ||||||
|   | |||||||
| @@ -17,7 +17,7 @@ | |||||||
|     MeService.meControllerRemove(true) |     MeService.meControllerRemove(true) | ||||||
|       .then((resp) => { |       .then((resp) => { | ||||||
|         Toastify({ |         Toastify({ | ||||||
|           text: "Profile deleted!", |           text: $_('profile-deleted'), | ||||||
|           duration: 500, |           duration: 500, | ||||||
|           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|   | |||||||
| @@ -43,7 +43,7 @@ | |||||||
|     if (processed_last_submit === true) { |     if (processed_last_submit === true) { | ||||||
|       processed_last_submit = false; |       processed_last_submit = false; | ||||||
|       const toast = Toastify({ |       const toast = Toastify({ | ||||||
|         text: "Team is being added...", |         text: $_('team-is-being-added'), | ||||||
|         duration: -1, |         duration: -1, | ||||||
|       }).showToast(); |       }).showToast(); | ||||||
|       RunnerTeamService.runnerTeamControllerPost({ |       RunnerTeamService.runnerTeamControllerPost({ | ||||||
| @@ -55,7 +55,7 @@ | |||||||
|           modal_open = false; |           modal_open = false; | ||||||
|           // |           // | ||||||
|           Toastify({ |           Toastify({ | ||||||
|             text: "Team added", |             text: $_('team-added'), | ||||||
|             duration: 500, |             duration: 500, | ||||||
|             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|           }).showToast(); |           }).showToast(); | ||||||
|   | |||||||
| @@ -16,7 +16,7 @@ | |||||||
|     RunnerTeamService.runnerTeamControllerRemove(delete_team.id, true) |     RunnerTeamService.runnerTeamControllerRemove(delete_team.id, true) | ||||||
|       .then((resp) => { |       .then((resp) => { | ||||||
|         Toastify({ |         Toastify({ | ||||||
|           text: "Team deleted", |           text: $_('team-deleted'), | ||||||
|           duration: 500, |           duration: 500, | ||||||
|           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
|   | |||||||
| @@ -26,9 +26,9 @@ | |||||||
|   export let params; |   export let params; | ||||||
|   export let import_modal_open = false; |   export let import_modal_open = false; | ||||||
|   $: delete_triggered = false; |   $: delete_triggered = false; | ||||||
|   $: save_enabled = !data_changed && teamdata.parentGroup != null; |   $: save_enabled = data_changed && teamdata.parentGroup != null; | ||||||
|   $: data_loaded = false; |   $: data_loaded = false; | ||||||
|   $: data_changed = JSON.stringify(teamdata) === JSON.stringify(original); |   $: data_changed = !(JSON.stringify(teamdata) === JSON.stringify(original)); | ||||||
|   $: sponsoring_contracts_show = true; |   $: sponsoring_contracts_show = true; | ||||||
|   $: cards_show = true; |   $: cards_show = true; | ||||||
|   $: certificates_show = true; |   $: certificates_show = true; | ||||||
| @@ -47,6 +47,8 @@ | |||||||
|     RunnerOrganizationService.runnerOrganizationControllerGetAll().then( |     RunnerOrganizationService.runnerOrganizationControllerGetAll().then( | ||||||
|       (val) => { |       (val) => { | ||||||
|         orgs = val.map((r) => { |         orgs = val.map((r) => { | ||||||
|  |           delete r.contact; | ||||||
|  |           r.teams = []; | ||||||
|           return { label: r.name, value: r }; |           return { label: r.name, value: r }; | ||||||
|         }); |         }); | ||||||
|         group = orgs.find((g) => g.value.id == teamdata.parentGroup.id); |         group = orgs.find((g) => g.value.id == teamdata.parentGroup.id); | ||||||
| @@ -67,7 +69,7 @@ | |||||||
|     RunnerTeamService.runnerTeamControllerRemove(original.id, false) |     RunnerTeamService.runnerTeamControllerRemove(original.id, false) | ||||||
|       .then((resp) => { |       .then((resp) => { | ||||||
|         Toastify({ |         Toastify({ | ||||||
|           text: "Organization deleted", |           text: $_('team-deleted'), | ||||||
|           duration: 500, |           duration: 500, | ||||||
|           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |           backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|         }).showToast(); |         }).showToast(); | ||||||
| @@ -81,7 +83,7 @@ | |||||||
|   function submit() { |   function submit() { | ||||||
|     if (data_loaded === true && save_enabled) { |     if (data_loaded === true && save_enabled) { | ||||||
|       Toastify({ |       Toastify({ | ||||||
|         text: "updating team", |         text: $_('updating-team'), | ||||||
|         duration: 2500, |         duration: 2500, | ||||||
|       }).showToast(); |       }).showToast(); | ||||||
|       let postdata = teamdata; |       let postdata = teamdata; | ||||||
| @@ -92,7 +94,7 @@ | |||||||
|           Object.assign(original, teamdata); |           Object.assign(original, teamdata); | ||||||
|           original = original; |           original = original; | ||||||
|           Toastify({ |           Toastify({ | ||||||
|             text: "updated team", |             text: $_('updated-team'), | ||||||
|             duration: 2500, |             duration: 2500, | ||||||
|             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|           }).showToast(); |           }).showToast(); | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ | |||||||
|         `[data-id="triggered_table_actions_${trackid}"]` |         `[data-id="triggered_table_actions_${trackid}"]` | ||||||
|       ).parentNode.parentNode.parentNode; |       ).parentNode.parentNode.parentNode; | ||||||
|       Toastify({ |       Toastify({ | ||||||
|         text: "Track is being updated...", |         text: $_('track-is-being-updated'), | ||||||
|         duration: 500, |         duration: 500, | ||||||
|       }).showToast(); |       }).showToast(); | ||||||
|       TrackService.trackControllerPut(trackid, { |       TrackService.trackControllerPut(trackid, { | ||||||
| @@ -45,7 +45,7 @@ | |||||||
|       }) |       }) | ||||||
|         .then((r) => { |         .then((r) => { | ||||||
|           Toastify({ |           Toastify({ | ||||||
|             text: "Track was updated!", |             text: $_('track-was-updated'), | ||||||
|             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", |             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||||
|             duration: 1000, |             duration: 1000, | ||||||
|           }).showToast(); |           }).showToast(); | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ | |||||||
|   }); |   }); | ||||||
|   function submit() { |   function submit() { | ||||||
|     Toastify({ |     Toastify({ | ||||||
|       text: "updating permissions...", |       text: $_('updating-permissions'), | ||||||
|       duration: 2500, |       duration: 2500, | ||||||
|     }).showToast(); |     }).showToast(); | ||||||
|     to_delete.forEach((d) => { |     to_delete.forEach((d) => { | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ | |||||||
|     "add-your-fist-donation": "Erstelle dein erstes Sponsoring", |     "add-your-fist-donation": "Erstelle dein erstes Sponsoring", | ||||||
|     "add-your-fist-scan": "Füge deinen ersten Scan hinzu", |     "add-your-fist-scan": "Füge deinen ersten Scan hinzu", | ||||||
|     "adding-card": "Karte wird erstellt", |     "adding-card": "Karte wird erstellt", | ||||||
|  |     "adding-donation": "Sponsoring wird erstellt...", | ||||||
|     "adding-scan": "Scan wird hinzugefügt", |     "adding-scan": "Scan wird hinzugefügt", | ||||||
|     "address": "Adresse", |     "address": "Adresse", | ||||||
|     "address-is-required": "Du musst eine Adresse angeben", |     "address-is-required": "Du musst eine Adresse angeben", | ||||||
| @@ -30,6 +31,7 @@ | |||||||
|     "all-associated-donations-will-get-deleted-as-well": "Alle Sponsorings dieser Sponsor:in werden ebenfalls gelöscht", |     "all-associated-donations-will-get-deleted-as-well": "Alle Sponsorings dieser Sponsor:in werden ebenfalls gelöscht", | ||||||
|     "all-associated-runners-will-be-deleted-too": "Alle zugehörigen Läufer:innen werden auch gelöscht!", |     "all-associated-runners-will-be-deleted-too": "Alle zugehörigen Läufer:innen werden auch gelöscht!", | ||||||
|     "all-associated-teams-and-runners-will-be-deleted-too": "Alle assoziierten Teams und Läufer:innen werden auch gelöscht!", |     "all-associated-teams-and-runners-will-be-deleted-too": "Alle assoziierten Teams und Läufer:innen werden auch gelöscht!", | ||||||
|  |     "already-paid": "Bereits bezahlt", | ||||||
|     "amount": "Anzahl", |     "amount": "Anzahl", | ||||||
|     "amount-per-kilometer": "Betrag pro Kilometer", |     "amount-per-kilometer": "Betrag pro Kilometer", | ||||||
|     "apartment-suite-etc": "Apartment, Wohnung, etc.", |     "apartment-suite-etc": "Apartment, Wohnung, etc.", | ||||||
| @@ -68,8 +70,10 @@ | |||||||
|     "confirm-deletion": "Löschung Bestätigen", |     "confirm-deletion": "Löschung Bestätigen", | ||||||
|     "confirm-the-new-password": "Neues Passwort bestätigen", |     "confirm-the-new-password": "Neues Passwort bestätigen", | ||||||
|     "contact": "Kontakt", |     "contact": "Kontakt", | ||||||
|  |     "contact-added": "Kontakt wurde hinzugefügt", | ||||||
|     "contact-deleted": "Kontakt gelöscht", |     "contact-deleted": "Kontakt gelöscht", | ||||||
|     "contact-information": "Kontaktinformation", |     "contact-information": "Kontaktinformation", | ||||||
|  |     "contact-is-being-added": "Kontakt wird erstellt...", | ||||||
|     "contact-is-being-updated": "Kontakt wird aktualisiert ...", |     "contact-is-being-updated": "Kontakt wird aktualisiert ...", | ||||||
|     "contact-is-not-a-member-in-any-group": "Kontakt gehört zu keiner Gruppe", |     "contact-is-not-a-member-in-any-group": "Kontakt gehört zu keiner Gruppe", | ||||||
|     "contacts": "Kontakte", |     "contacts": "Kontakte", | ||||||
| @@ -129,7 +133,7 @@ | |||||||
|     }, |     }, | ||||||
|     "delete": "Löschen", |     "delete": "Löschen", | ||||||
|     "delete-contact": "Kontakt löschen", |     "delete-contact": "Kontakt löschen", | ||||||
|     "delete-donation": "Sponsporing löschen", |     "delete-donation": "Sponsoring löschen", | ||||||
|     "delete-donor": "Sponsor:in löschen", |     "delete-donor": "Sponsor:in löschen", | ||||||
|     "delete-group": "Gruppe löschen", |     "delete-group": "Gruppe löschen", | ||||||
|     "delete-organization": "Organisation löschen", |     "delete-organization": "Organisation löschen", | ||||||
| @@ -157,6 +161,9 @@ | |||||||
|     "documentation": "Dokumentation", |     "documentation": "Dokumentation", | ||||||
|     "donation-amount": "Sponsoringbetrag", |     "donation-amount": "Sponsoringbetrag", | ||||||
|     "donation-amount-must-be-greater-that-0-00eur": "Der Sponsoringbetrag muss größer als 0.00€ sein.", |     "donation-amount-must-be-greater-that-0-00eur": "Der Sponsoringbetrag muss größer als 0.00€ sein.", | ||||||
|  |     "donation-deleted": "Sponsoring gelöscht", | ||||||
|  |     "donation-updated": "Sponsoring wurde aktualisiert", | ||||||
|  |     "donation_added": "Sponsoring hinzugefügt", | ||||||
|     "donations": "Sponsorings", |     "donations": "Sponsorings", | ||||||
|     "donor": "Sponsor:in", |     "donor": "Sponsor:in", | ||||||
|     "donor-added": "Sponsor:in hinzugefügt", |     "donor-added": "Sponsor:in hinzugefügt", | ||||||
| @@ -176,6 +183,7 @@ | |||||||
|     "enabled": "aktiviert", |     "enabled": "aktiviert", | ||||||
|     "enabled_large": "Aktiviert", |     "enabled_large": "Aktiviert", | ||||||
|     "english": "Englisch", |     "english": "Englisch", | ||||||
|  |     "enter-payment": "Zahlung eingeben", | ||||||
|     "error-during-import": "Fehler beim Importieren", |     "error-during-import": "Fehler beim Importieren", | ||||||
|     "error-whyile-copying-to-clipboard": "Fehler beim Kopieren in die Zwischenablage", |     "error-whyile-copying-to-clipboard": "Fehler beim Kopieren in die Zwischenablage", | ||||||
|     "error_on_login": "😢Fehler beim Login", |     "error_on_login": "😢Fehler beim Login", | ||||||
| @@ -183,6 +191,7 @@ | |||||||
|     "everything-concerning-your-profile": "Alles zu deinem Profil", |     "everything-concerning-your-profile": "Alles zu deinem Profil", | ||||||
|     "everything-is-more-fun-together": "Im Team macht's mehr Spaß 🏃♂️🏃♀️🏃♂️", |     "everything-is-more-fun-together": "Im Team macht's mehr Spaß 🏃♂️🏃♀️🏃♂️", | ||||||
|     "faq": "FAQ", |     "faq": "FAQ", | ||||||
|  |     "filename_sponsoringquittungsliste": "SponsoringQuittungsListe", | ||||||
|     "filter-by-organization-team": "Filtern nach Organisation / Team", |     "filter-by-organization-team": "Filtern nach Organisation / Team", | ||||||
|     "first-name": "Vorname", |     "first-name": "Vorname", | ||||||
|     "first-name-is-required": "Vorname muss angegeben werden", |     "first-name-is-required": "Vorname muss angegeben werden", | ||||||
| @@ -268,6 +277,7 @@ | |||||||
|     "no-runners-found": "Keine Läufer:innen gefunden", |     "no-runners-found": "Keine Läufer:innen gefunden", | ||||||
|     "no-tracks-added-yet": "Es wurden noch keine Tracks erstellt.", |     "no-tracks-added-yet": "Es wurden noch keine Tracks erstellt.", | ||||||
|     "non-blanko": "Keine/Blankokarte", |     "non-blanko": "Keine/Blankokarte", | ||||||
|  |     "open": "OFFEN", | ||||||
|     "organization": "Organisation", |     "organization": "Organisation", | ||||||
|     "organization-added": "Organisation hinzugefügt", |     "organization-added": "Organisation hinzugefügt", | ||||||
|     "organization-deleted": "Organisation gelöscht", |     "organization-deleted": "Organisation gelöscht", | ||||||
| @@ -278,6 +288,8 @@ | |||||||
|     "organizations-are-being-loaded": "Organisationen werden geladen ...", |     "organizations-are-being-loaded": "Organisationen werden geladen ...", | ||||||
|     "orgs": "Organisationen", |     "orgs": "Organisationen", | ||||||
|     "oss_credit_description": "Wir verwenden eine Menge Open Source-Software bei diesen Projekten und möchten uns bei den folgenden Projekten und Mitwirkenden bedanken, die dazu beitragen, Open Source großartig zu machen!", |     "oss_credit_description": "Wir verwenden eine Menge Open Source-Software bei diesen Projekten und möchten uns bei den folgenden Projekten und Mitwirkenden bedanken, die dazu beitragen, Open Source großartig zu machen!", | ||||||
|  |     "paid": "BEZAHLT", | ||||||
|  |     "paid-amount": "Gezahlter Betrag", | ||||||
|     "password": "Passwort", |     "password": "Passwort", | ||||||
|     "password-changed": "Passwort wurde aktualisiert!", |     "password-changed": "Passwort wurde aktualisiert!", | ||||||
|     "password-is-required": "Passwort muss angegeben werden", |     "password-is-required": "Passwort muss angegeben werden", | ||||||
| @@ -286,6 +298,7 @@ | |||||||
|     "password-reset-mail-sent": "Passwort-Reset Mail wurde an \"{usersEmail}\" geschickt.", |     "password-reset-mail-sent": "Passwort-Reset Mail wurde an \"{usersEmail}\" geschickt.", | ||||||
|     "password-reset-successful": "Passwort erfolgreich zurückgesetzt!", |     "password-reset-successful": "Passwort erfolgreich zurückgesetzt!", | ||||||
|     "passwords-dont-match": "Die Passwörter stimmen nicht überein!", |     "passwords-dont-match": "Die Passwörter stimmen nicht überein!", | ||||||
|  |     "payment-amount-must-be-greater-than-0-00eur": "Der Zahlungsbetrag muss größer als 0.00€ sein!", | ||||||
|     "pdf-generation-failed": "PDF Generierung fehlgeschlagen!", |     "pdf-generation-failed": "PDF Generierung fehlgeschlagen!", | ||||||
|     "pdf-successfully-generated": "PDF wurde erfolgreich generiert!", |     "pdf-successfully-generated": "PDF wurde erfolgreich generiert!", | ||||||
|     "pdfs-successfully-generated": "Alle PDFs wurden generiert!", |     "pdfs-successfully-generated": "Alle PDFs wurden generiert!", | ||||||
| @@ -308,9 +321,11 @@ | |||||||
|     "please-provide-the-required-information-to-add-a-new-user": "Bitte gebe alle nötigen Informationen an, im die neue Benutzer:in zu erstellen.", |     "please-provide-the-required-information-to-add-a-new-user": "Bitte gebe alle nötigen Informationen an, im die neue Benutzer:in zu erstellen.", | ||||||
|     "please-provide-the-required-information-to-create-a-new-scanstation": "Bitte gebe alle für eine Scannerstation notwendigen Informationen an", |     "please-provide-the-required-information-to-create-a-new-scanstation": "Bitte gebe alle für eine Scannerstation notwendigen Informationen an", | ||||||
|     "please-request-a-new-reset-mail": "Bitte eine neue Passwortreset-Mail anfordern...", |     "please-request-a-new-reset-mail": "Bitte eine neue Passwortreset-Mail anfordern...", | ||||||
|  |     "please-wait-a-moment-your-login-is-still-being-processed": "Bitte warte einen Moment, deine Anmeldung wird verarbeitet", | ||||||
|     "privacy": "Datenschutz", |     "privacy": "Datenschutz", | ||||||
|     "privacy-loading": "Datenschutzerklärung lädt...", |     "privacy-loading": "Datenschutzerklärung lädt...", | ||||||
|     "profile": "Profil", |     "profile": "Profil", | ||||||
|  |     "profile-deleted": "Profil gelöscht!", | ||||||
|     "profile-picture": "Profilbild", |     "profile-picture": "Profilbild", | ||||||
|     "profile-updated": "Profil wurde aktualisiert!", |     "profile-updated": "Profil wurde aktualisiert!", | ||||||
|     "read-license": "Lizenz-Text lesen", |     "read-license": "Lizenz-Text lesen", | ||||||
| @@ -354,13 +369,17 @@ | |||||||
|     "settings": "Einstellungen", |     "settings": "Einstellungen", | ||||||
|     "settings-for-your-profile": "Die Einstellungen deines Accounts", |     "settings-for-your-profile": "Die Einstellungen deines Accounts", | ||||||
|     "something-about-the-group": "Infos zur Gruppe", |     "something-about-the-group": "Infos zur Gruppe", | ||||||
|  |     "sponsoring-quittungs-liste_herunterladen": "Sponsoring-Quittungs-Liste herunterladen", | ||||||
|     "sponsorings": "Sponsoringerklaerungen", |     "sponsorings": "Sponsoringerklaerungen", | ||||||
|     "stats-are-being-loaded": "Die Statistiken werden geladen...", |     "stats-are-being-loaded": "Die Statistiken werden geladen...", | ||||||
|     "status": "Status", |     "status": "Status", | ||||||
|     "stuff-that-could-harm-your-profile": "Einstellungen, die deinem Profil nachhaltig schaden können", |     "stuff-that-could-harm-your-profile": "Einstellungen, die deinem Profil nachhaltig schaden können", | ||||||
|     "successful-password-reset": "Passwort erfolgreich zurückgesetzt!", |     "successful-password-reset": "Passwort erfolgreich zurückgesetzt!", | ||||||
|     "team": "Team", |     "team": "Team", | ||||||
|  |     "team-added": "Team wurde hinzugefügt", | ||||||
|  |     "team-deleted": "Team gelöscht", | ||||||
|     "team-detail-is-being-loaded": "Team wird geladen...", |     "team-detail-is-being-loaded": "Team wird geladen...", | ||||||
|  |     "team-is-being-added": "Team wird erstellt...", | ||||||
|     "team-name": "Teamname", |     "team-name": "Teamname", | ||||||
|     "team-name-is-required": "Teamname ist erforderlich", |     "team-name-is-required": "Teamname ist erforderlich", | ||||||
|     "teams": "Teams", |     "teams": "Teams", | ||||||
| @@ -385,26 +404,35 @@ | |||||||
|     "total-distance": "gelaufene Strecke", |     "total-distance": "gelaufene Strecke", | ||||||
|     "total-donation-amount": "Gesamtbetrag", |     "total-donation-amount": "Gesamtbetrag", | ||||||
|     "total-donations": "Spendensumme", |     "total-donations": "Spendensumme", | ||||||
|  |     "total-paid-amount": "Gezahlter Gesamtbetrag", | ||||||
|     "total-scans": "gesamte Scans", |     "total-scans": "gesamte Scans", | ||||||
|  |     "total_donation_amount_in_eur": "Gesamtbetrag in €", | ||||||
|     "track": "Track", |     "track": "Track", | ||||||
|     "track-added": "Track hinzugefügt", |     "track-added": "Track hinzugefügt", | ||||||
|     "track-data-is-being-loaded": "Trackdaten werden geladen", |     "track-data-is-being-loaded": "Trackdaten werden geladen", | ||||||
|     "track-is-being-added": "Track wird hinzugefügt...", |     "track-is-being-added": "Track wird hinzugefügt...", | ||||||
|  |     "track-is-being-updated": "Track wird aktualisiert...", | ||||||
|     "track-length-in-m": "Tracklänge (in Metern)", |     "track-length-in-m": "Tracklänge (in Metern)", | ||||||
|     "track-length-must-be-greater-than-0": "Die Länge muss größer als 0 (Meter) sein", |     "track-length-must-be-greater-than-0": "Die Länge muss größer als 0 (Meter) sein", | ||||||
|     "track-name": "Trackname", |     "track-name": "Trackname", | ||||||
|     "track-name-must-not-be-empty": "Der Name muss angegeben werden", |     "track-name-must-not-be-empty": "Der Name muss angegeben werden", | ||||||
|  |     "track-was-updated": "Track wurde aktualisiert", | ||||||
|     "tracks": "Tracks", |     "tracks": "Tracks", | ||||||
|  |     "unpaid": "Offen", | ||||||
|  |     "update-card": "Karte aktualisieren", | ||||||
|     "update-password": "Passwort ändern", |     "update-password": "Passwort ändern", | ||||||
|     "updated-contact": "Kontakt aktualisiert!", |     "updated-contact": "Kontakt aktualisiert!", | ||||||
|     "updated-donor": "Sponsor:in wurde aktualisiert", |     "updated-donor": "Sponsor:in wurde aktualisiert", | ||||||
|     "updated-organization": "Organisation wurde aktualisiert", |     "updated-organization": "Organisation wurde aktualisiert", | ||||||
|     "updated-scan": "Scan wurde aktualisiert", |     "updated-scan": "Scan wurde aktualisiert", | ||||||
|  |     "updated-team": "Team wurde aktualisiert", | ||||||
|     "updateing-group": "Gruppe wird aktualisiert...", |     "updateing-group": "Gruppe wird aktualisiert...", | ||||||
|     "updating-card": "Karte wird aktualisiert", |     "updating-card": "Karte wird aktualisiert", | ||||||
|  |     "updating-donation": "Sponsoring wird aktualisiert", | ||||||
|     "updating-organization": "Organisation wird aktualisiert", |     "updating-organization": "Organisation wird aktualisiert", | ||||||
|     "updating-permissions": "Berechtigungen werden aktualisiert...", |     "updating-permissions": "Berechtigungen werden aktualisiert...", | ||||||
|     "updating-runner": "Läufer:in wird aktualisiert.", |     "updating-runner": "Läufer:in wird aktualisiert.", | ||||||
|  |     "updating-team": "Team wird aktualisiert", | ||||||
|     "updating-user": "Benutzer:in wird aktualisiert...", |     "updating-user": "Benutzer:in wird aktualisiert...", | ||||||
|     "updating-your-profile": "Profil wird aktualisiert...", |     "updating-your-profile": "Profil wird aktualisiert...", | ||||||
|     "user-added": "Benutzer hinzugefügt", |     "user-added": "Benutzer hinzugefügt", | ||||||
| @@ -422,6 +450,7 @@ | |||||||
|     "welcome_wavinghand": "Willkommen 👋", |     "welcome_wavinghand": "Willkommen 👋", | ||||||
|     "yes-i-copied-the-token": "Ja, ich habe den Token kopiert", |     "yes-i-copied-the-token": "Ja, ich habe den Token kopiert", | ||||||
|     "you-are-going-to-loose-all-permissions-and-access-to-the-runner-system": "Du wirst all deine Berechtigungen und den Zugriff aufs Läufersystem verlieren!", |     "you-are-going-to-loose-all-permissions-and-access-to-the-runner-system": "Du wirst all deine Berechtigungen und den Zugriff aufs Läufersystem verlieren!", | ||||||
|  |     "you-can-enter-the-donations-paid-amount-manually-or-use-the-max-button-to-use-the-donations-exact-amount": "Du kannst den Betrag der Zahlung entweder manuell eingeben oder über den MAX Button auf den Spendenbetrag setzen", | ||||||
|     "you-can-now-use-your-new-password-to-log-in-to-your-account": "Du kannst dich jetzt mit deinem neuen Passwort anmelden! 🎉", |     "you-can-now-use-your-new-password-to-log-in-to-your-account": "Du kannst dich jetzt mit deinem neuen Passwort anmelden! 🎉", | ||||||
|     "you-can-provide-a-runner-but-you-dont-have-to": "Du kannst eine Läufer:in angeben, musst aber nicht.", |     "you-can-provide-a-runner-but-you-dont-have-to": "Du kannst eine Läufer:in angeben, musst aber nicht.", | ||||||
|     "you-dont-have-any-scanstations-yet": "Es gibt noch keine Scannerstationen", |     "you-dont-have-any-scanstations-yet": "Es gibt noch keine Scannerstationen", | ||||||
|   | |||||||
| @@ -6,7 +6,8 @@ | |||||||
|     "active": "Active", |     "active": "Active", | ||||||
|     "add-card": "Add Card", |     "add-card": "Add Card", | ||||||
|     "add-donation": "Add donation", |     "add-donation": "Add donation", | ||||||
|     "add-donor": "add donor", |     "add-donor": "Add donor", | ||||||
|  |     "add-or-update-a-payment": "Add or update a payment", | ||||||
|     "add-scan": "Add scan", |     "add-scan": "Add scan", | ||||||
|     "add-the-first-scanstation": "Add your first scanstation.", |     "add-the-first-scanstation": "Add your first scanstation.", | ||||||
|     "add-user-group": "Add User Group", |     "add-user-group": "Add User Group", | ||||||
| @@ -22,6 +23,7 @@ | |||||||
|     "add-your-fist-donation": "Add your fist donation", |     "add-your-fist-donation": "Add your fist donation", | ||||||
|     "add-your-fist-scan": "Add your fist scan", |     "add-your-fist-scan": "Add your fist scan", | ||||||
|     "adding-card": "Adding Card", |     "adding-card": "Adding Card", | ||||||
|  |     "adding-donation": "Adding donation...", | ||||||
|     "adding-scan": "Adding Scan", |     "adding-scan": "Adding Scan", | ||||||
|     "address": "Address", |     "address": "Address", | ||||||
|     "address-is-required": "Address is required", |     "address-is-required": "Address is required", | ||||||
| @@ -30,6 +32,7 @@ | |||||||
|     "all-associated-donations-will-get-deleted-as-well": "All associated donations will get deleted as well", |     "all-associated-donations-will-get-deleted-as-well": "All associated donations will get deleted as well", | ||||||
|     "all-associated-runners-will-be-deleted-too": "All associated runners will be deleted too!", |     "all-associated-runners-will-be-deleted-too": "All associated runners will be deleted too!", | ||||||
|     "all-associated-teams-and-runners-will-be-deleted-too": "All associated teams and runners will be deleted too!", |     "all-associated-teams-and-runners-will-be-deleted-too": "All associated teams and runners will be deleted too!", | ||||||
|  |     "already-paid": "Already paid", | ||||||
|     "amount": "Amount", |     "amount": "Amount", | ||||||
|     "amount-per-kilometer": "Amount per kilometer", |     "amount-per-kilometer": "Amount per kilometer", | ||||||
|     "apartment-suite-etc": "Apartment, suite, etc.", |     "apartment-suite-etc": "Apartment, suite, etc.", | ||||||
| @@ -68,8 +71,10 @@ | |||||||
|     "confirm-deletion": "Confirm Deletion", |     "confirm-deletion": "Confirm Deletion", | ||||||
|     "confirm-the-new-password": "Confirm the new password", |     "confirm-the-new-password": "Confirm the new password", | ||||||
|     "contact": "Contact", |     "contact": "Contact", | ||||||
|  |     "contact-added": "Contact added", | ||||||
|     "contact-deleted": "Contact deleted", |     "contact-deleted": "Contact deleted", | ||||||
|     "contact-information": "Contact Information", |     "contact-information": "Contact Information", | ||||||
|  |     "contact-is-being-added": "Contact is being added...", | ||||||
|     "contact-is-being-updated": "Contact is being updated...", |     "contact-is-being-updated": "Contact is being updated...", | ||||||
|     "contact-is-not-a-member-in-any-group": "Contact is not a member in any group", |     "contact-is-not-a-member-in-any-group": "Contact is not a member in any group", | ||||||
|     "contacts": "Contacts", |     "contacts": "Contacts", | ||||||
| @@ -157,6 +162,9 @@ | |||||||
|     "documentation": "Documentation", |     "documentation": "Documentation", | ||||||
|     "donation-amount": "Donation amount", |     "donation-amount": "Donation amount", | ||||||
|     "donation-amount-must-be-greater-that-0-00eur": "Donation amount must be greater that 0.00€", |     "donation-amount-must-be-greater-that-0-00eur": "Donation amount must be greater that 0.00€", | ||||||
|  |     "donation-deleted": "Donation deleted", | ||||||
|  |     "donation-updated": "Donation updated", | ||||||
|  |     "donation_added": "Donation_added", | ||||||
|     "donations": "Donations", |     "donations": "Donations", | ||||||
|     "donor": "Donor", |     "donor": "Donor", | ||||||
|     "donor-added": "Donor added", |     "donor-added": "Donor added", | ||||||
| @@ -176,6 +184,7 @@ | |||||||
|     "enabled": "enabled", |     "enabled": "enabled", | ||||||
|     "enabled_large": "Enabled", |     "enabled_large": "Enabled", | ||||||
|     "english": "English", |     "english": "English", | ||||||
|  |     "enter-payment": "Enter payment", | ||||||
|     "error-during-import": "Error during import", |     "error-during-import": "Error during import", | ||||||
|     "error-whyile-copying-to-clipboard": "Error while copying to clipboard", |     "error-whyile-copying-to-clipboard": "Error while copying to clipboard", | ||||||
|     "error_on_login": "Error on login", |     "error_on_login": "Error on login", | ||||||
| @@ -183,6 +192,7 @@ | |||||||
|     "everything-concerning-your-profile": "Everything concerning your profile", |     "everything-concerning-your-profile": "Everything concerning your profile", | ||||||
|     "everything-is-more-fun-together": "everything is more fun together 🏃♂️🏃♀️🏃♂️", |     "everything-is-more-fun-together": "everything is more fun together 🏃♂️🏃♀️🏃♂️", | ||||||
|     "faq": "FAQ", |     "faq": "FAQ", | ||||||
|  |     "filename_sponsoringquittungsliste": "DonorReceiptList", | ||||||
|     "filter-by-organization-team": "Filter by Organization/ Team", |     "filter-by-organization-team": "Filter by Organization/ Team", | ||||||
|     "first-name": "First name", |     "first-name": "First name", | ||||||
|     "first-name-is-required": "First Name is required", |     "first-name-is-required": "First Name is required", | ||||||
| @@ -268,6 +278,7 @@ | |||||||
|     "no-runners-found": "No runners found", |     "no-runners-found": "No runners found", | ||||||
|     "no-tracks-added-yet": "there are no tracks added yet.", |     "no-tracks-added-yet": "there are no tracks added yet.", | ||||||
|     "non-blanko": "Non/Blanko", |     "non-blanko": "Non/Blanko", | ||||||
|  |     "open": "OPEN", | ||||||
|     "organization": "Organization", |     "organization": "Organization", | ||||||
|     "organization-added": "Organization added", |     "organization-added": "Organization added", | ||||||
|     "organization-deleted": "Organization deleted", |     "organization-deleted": "Organization deleted", | ||||||
| @@ -278,6 +289,8 @@ | |||||||
|     "organizations-are-being-loaded": "organizations are being loaded...", |     "organizations-are-being-loaded": "organizations are being loaded...", | ||||||
|     "orgs": "Organizations", |     "orgs": "Organizations", | ||||||
|     "oss_credit_description": "We use a lot of open source software on these projects, and would like to thank the following projects and contributors who help make open source great!", |     "oss_credit_description": "We use a lot of open source software on these projects, and would like to thank the following projects and contributors who help make open source great!", | ||||||
|  |     "paid": "PAID", | ||||||
|  |     "paid-amount": "Paid amount", | ||||||
|     "password": "Password", |     "password": "Password", | ||||||
|     "password-changed": "Password changed!", |     "password-changed": "Password changed!", | ||||||
|     "password-is-required": "Password is required", |     "password-is-required": "Password is required", | ||||||
| @@ -286,6 +299,7 @@ | |||||||
|     "password-reset-mail-sent": "Password reset mail was sent to \"{usersEmail}\".", |     "password-reset-mail-sent": "Password reset mail was sent to \"{usersEmail}\".", | ||||||
|     "password-reset-successful": "Password Reset successful!", |     "password-reset-successful": "Password Reset successful!", | ||||||
|     "passwords-dont-match": "Passwords don't match!", |     "passwords-dont-match": "Passwords don't match!", | ||||||
|  |     "payment-amount-must-be-greater-than-0-00eur": "Payment amount must be greater than 0.00€!", | ||||||
|     "pdf-generation-failed": "PDF generation failed!", |     "pdf-generation-failed": "PDF generation failed!", | ||||||
|     "pdf-successfully-generated": "PDF successfully generated!", |     "pdf-successfully-generated": "PDF successfully generated!", | ||||||
|     "pdfs-successfully-generated": "PDFs successfully generated!", |     "pdfs-successfully-generated": "PDFs successfully generated!", | ||||||
| @@ -308,9 +322,11 @@ | |||||||
|     "please-provide-the-required-information-to-add-a-new-user": "Please provide the required information to add a new user.", |     "please-provide-the-required-information-to-add-a-new-user": "Please provide the required information to add a new user.", | ||||||
|     "please-provide-the-required-information-to-create-a-new-scanstation": "Please provide the required information to create a new scanstation", |     "please-provide-the-required-information-to-create-a-new-scanstation": "Please provide the required information to create a new scanstation", | ||||||
|     "please-request-a-new-reset-mail": "Please request a new reset mail...", |     "please-request-a-new-reset-mail": "Please request a new reset mail...", | ||||||
|  |     "please-wait-a-moment-your-login-is-still-being-processed": "Please wait a moment, your login is still being processed", | ||||||
|     "privacy": "Privacy", |     "privacy": "Privacy", | ||||||
|     "privacy-loading": "Privacy loading...", |     "privacy-loading": "Privacy loading...", | ||||||
|     "profile": "Profile", |     "profile": "Profile", | ||||||
|  |     "profile-deleted": "Profile deleted!", | ||||||
|     "profile-picture": "Profile Picture", |     "profile-picture": "Profile Picture", | ||||||
|     "profile-updated": "Profile updated!", |     "profile-updated": "Profile updated!", | ||||||
|     "read-license": "Read License", |     "read-license": "Read License", | ||||||
| @@ -354,13 +370,17 @@ | |||||||
|     "settings": "Settings", |     "settings": "Settings", | ||||||
|     "settings-for-your-profile": "Settings for your profile", |     "settings-for-your-profile": "Settings for your profile", | ||||||
|     "something-about-the-group": "Something about the group...", |     "something-about-the-group": "Something about the group...", | ||||||
|  |     "sponsoring-quittungs-liste_herunterladen": "Download donor receipt list", | ||||||
|     "sponsorings": "Sponsorings", |     "sponsorings": "Sponsorings", | ||||||
|     "stats-are-being-loaded": "stats are being loaded...", |     "stats-are-being-loaded": "stats are being loaded...", | ||||||
|     "status": "Status", |     "status": "Status", | ||||||
|     "stuff-that-could-harm-your-profile": "Stuff that could harm your profile", |     "stuff-that-could-harm-your-profile": "Stuff that could harm your profile", | ||||||
|     "successful-password-reset": "Successful password reset!", |     "successful-password-reset": "Successful password reset!", | ||||||
|     "team": "Team", |     "team": "Team", | ||||||
|  |     "team-added": "Team added", | ||||||
|  |     "team-deleted": "Team deleted", | ||||||
|     "team-detail-is-being-loaded": "team detail is being loaded...", |     "team-detail-is-being-loaded": "team detail is being loaded...", | ||||||
|  |     "team-is-being-added": "Team is being added...", | ||||||
|     "team-name": "Team name", |     "team-name": "Team name", | ||||||
|     "team-name-is-required": "team name is required", |     "team-name-is-required": "team name is required", | ||||||
|     "teams": "Teams", |     "teams": "Teams", | ||||||
| @@ -385,27 +405,35 @@ | |||||||
|     "total-distance": "total distance", |     "total-distance": "total distance", | ||||||
|     "total-donation-amount": "total donation amount", |     "total-donation-amount": "total donation amount", | ||||||
|     "total-donations": "total donations", |     "total-donations": "total donations", | ||||||
|  |     "total-paid-amount": "Total paid amount", | ||||||
|     "total-scans": "total scans", |     "total-scans": "total scans", | ||||||
|  |     "total_donation_amount_in_eur": "Total donation amount in €", | ||||||
|     "track": "Track", |     "track": "Track", | ||||||
|     "track-added": "Track added", |     "track-added": "Track added", | ||||||
|     "track-data-is-being-loaded": "Track data is being loaded", |     "track-data-is-being-loaded": "Track data is being loaded", | ||||||
|     "track-is-being-added": "Track is being added...", |     "track-is-being-added": "Track is being added...", | ||||||
|  |     "track-is-being-updated": "Track is being updated...", | ||||||
|     "track-length-in-m": "Track Length in m", |     "track-length-in-m": "Track Length in m", | ||||||
|     "track-length-must-be-greater-than-0": "Track length must be greater than 0", |     "track-length-must-be-greater-than-0": "Track length must be greater than 0", | ||||||
|     "track-name": "Track name", |     "track-name": "Track name", | ||||||
|     "track-name-must-not-be-empty": "Track name must not be empty", |     "track-name-must-not-be-empty": "Track name must not be empty", | ||||||
|  |     "track-was-updated": "Track was updated!", | ||||||
|     "tracks": "Tracks", |     "tracks": "Tracks", | ||||||
|  |     "unpaid": "Unpaid", | ||||||
|     "update-card": "Update Card", |     "update-card": "Update Card", | ||||||
|     "update-password": "Update password", |     "update-password": "Update password", | ||||||
|     "updated-contact": "Updated contact!", |     "updated-contact": "Updated contact!", | ||||||
|     "updated-donor": "updated donor", |     "updated-donor": "updated donor", | ||||||
|     "updated-organization": "updated organization", |     "updated-organization": "updated organization", | ||||||
|     "updated-scan": "updated scan", |     "updated-scan": "updated scan", | ||||||
|  |     "updated-team": "Updated team", | ||||||
|     "updateing-group": "updateing group...", |     "updateing-group": "updateing group...", | ||||||
|     "updating-card": "Updating card", |     "updating-card": "Updating card", | ||||||
|  |     "updating-donation": "Updating donation", | ||||||
|     "updating-organization": "updating organization", |     "updating-organization": "updating organization", | ||||||
|     "updating-permissions": "updating permissions...", |     "updating-permissions": "updating permissions...", | ||||||
|     "updating-runner": "Updating runner...", |     "updating-runner": "Updating runner...", | ||||||
|  |     "updating-team": "Updating team", | ||||||
|     "updating-user": "updating user...", |     "updating-user": "updating user...", | ||||||
|     "updating-your-profile": "Updating your profile...", |     "updating-your-profile": "Updating your profile...", | ||||||
|     "user-added": "User added", |     "user-added": "User added", | ||||||
| @@ -423,6 +451,7 @@ | |||||||
|     "welcome_wavinghand": "Welcome 👋", |     "welcome_wavinghand": "Welcome 👋", | ||||||
|     "yes-i-copied-the-token": "Yes, I copied the token", |     "yes-i-copied-the-token": "Yes, I copied the token", | ||||||
|     "you-are-going-to-loose-all-permissions-and-access-to-the-runner-system": "You are going to loose all permissions and access to the runner system!", |     "you-are-going-to-loose-all-permissions-and-access-to-the-runner-system": "You are going to loose all permissions and access to the runner system!", | ||||||
|  |     "you-can-enter-the-donations-paid-amount-manually-or-use-the-max-button-to-use-the-donations-exact-amount": "You can enter the donation's paid amount manually or use the MAX button to use the donation's exact amount.", | ||||||
|     "you-can-now-use-your-new-password-to-log-in-to-your-account": "You can now use your new password to log in to your account! 🎉", |     "you-can-now-use-your-new-password-to-log-in-to-your-account": "You can now use your new password to log in to your account! 🎉", | ||||||
|     "you-can-provide-a-runner-but-you-dont-have-to": "You can provide a runner, but you don't have to.", |     "you-can-provide-a-runner-but-you-dont-have-to": "You can provide a runner, but you don't have to.", | ||||||
|     "you-dont-have-any-scanstations-yet": "You don't have any scanstations yet", |     "you-dont-have-any-scanstations-yet": "You don't have any scanstations yet", | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| import 'windi.css'; | import './style.css'; | ||||||
| import "toastify-js/src/toastify.css"; | import "toastify-js/src/toastify.css"; | ||||||
| import "gridjs/dist/theme/mermaid.css"; | import "gridjs/dist/theme/mermaid.css"; | ||||||
| import App from './App.svelte'; | import App from './App.svelte'; | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								src/style.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								src/style.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | @tailwind base; | ||||||
|  | @tailwind components; | ||||||
|  | @tailwind utilities; | ||||||
| @@ -1,4 +1,6 @@ | |||||||
| module.exports = { | module.exports = { | ||||||
|  | 	mode: 'jit', | ||||||
|  | 	purge: [ './src/**/*.svelte' ], | ||||||
| 	theme: { | 	theme: { | ||||||
| 		extend: { | 		extend: { | ||||||
| 			colors: { | 			colors: { | ||||||
|   | |||||||
| @@ -1,5 +1,4 @@ | |||||||
| import svelte from '@sveltejs/vite-plugin-svelte'; | import svelte from '@sveltejs/vite-plugin-svelte'; | ||||||
| import windiCSS from 'vite-plugin-windicss'; |  | ||||||
| import { minify } from 'html-minifier'; | import { minify } from 'html-minifier'; | ||||||
| import { defineConfig } from 'vite'; | import { defineConfig } from 'vite'; | ||||||
| // | // | ||||||
| @@ -24,17 +23,6 @@ export default defineConfig(({ command, mode }) => { | |||||||
| 			minify: isProduction | 			minify: isProduction | ||||||
| 		}, | 		}, | ||||||
| 		plugins: [ | 		plugins: [ | ||||||
| 			windiCSS({ |  | ||||||
| 				//@ts-ignore |  | ||||||
| 				verbose: true, |  | ||||||
| 				silent: false, |  | ||||||
| 				debug: true, |  | ||||||
| 				config: 'tailwind.config.js', // tailwind config file path (optional) |  | ||||||
| 				compile: false, // false: interpretation mode; true: compilation mode |  | ||||||
| 				prefix: 'windi-', // set compilation mode style prefix |  | ||||||
| 				globalPreflight: true, // set preflight style is global or scoped |  | ||||||
| 				globalUtility: true // set utility style is global or scoped |  | ||||||
| 			}), |  | ||||||
| 			svelte({ | 			svelte({ | ||||||
| 				//@ts-ignore | 				//@ts-ignore | ||||||
| 				hot: !isProduction, | 				hot: !isProduction, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user