307 Commits

Author SHA1 Message Date
df08591f24 Updated bot email
All checks were successful
Pull Request Pipeline / Lint (pull_request) Successful in 2m47s
Pull Request Pipeline / Test (pull_request) Successful in 2m19s
2026-01-18 14:38:44 +01:00
341de5ea18 Updated workflow name
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m48s
Pull Request Pipeline / Lint (pull_request) Successful in 2m49s
2026-01-18 14:37:58 +01:00
2ba53fc393 Updated progress bar final
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m22s
Pull Request Pipeline / Lint (pull_request) Successful in 2m23s
2026-01-18 14:33:55 +01:00
1a85a17abf Another progress update
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m40s
Pull Request Pipeline / Lint (pull_request) Successful in 2m40s
2026-01-18 14:31:02 +01:00
4c60a149b7 Another progress update
All checks were successful
Pull Request Pipeline / Lint (pull_request) Successful in 2m46s
Pull Request Pipeline / Test (pull_request) Successful in 2m46s
2026-01-18 14:30:15 +01:00
49ce90bc68 Updated progress bar
Some checks failed
Pull Request Pipeline / Test (pull_request) Has been cancelled
Pull Request Pipeline / Lint (pull_request) Has been cancelled
2026-01-18 14:27:58 +01:00
b464c13473 Updated progress bar
Some checks failed
Pull Request Pipeline / Test (pull_request) Has been cancelled
Pull Request Pipeline / Lint (pull_request) Has been cancelled
2026-01-18 14:25:57 +01:00
ee92e72db6 Updated progress bar
Some checks failed
Pull Request Pipeline / Test (pull_request) Has been cancelled
Pull Request Pipeline / Lint (pull_request) Has been cancelled
2026-01-18 14:25:30 +01:00
fe557ffa62 Updated progress bar
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m57s
Pull Request Pipeline / Lint (pull_request) Successful in 3m1s
2026-01-18 14:24:20 +01:00
07e20e9b92 Updated progress bar
All checks were successful
Pull Request Pipeline / Lint (pull_request) Successful in 2m59s
Pull Request Pipeline / Test (pull_request) Successful in 2m58s
2026-01-18 14:23:41 +01:00
70750e076a Redo changes
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m11s
Pull Request Pipeline / Lint (pull_request) Successful in 2m15s
2026-01-18 14:22:00 +01:00
aa8471f891 Tried flutter action instead of wget
Some checks failed
Pull Request Pipeline / Lint (pull_request) Failing after 1m58s
Pull Request Pipeline / Test (pull_request) Successful in 2m18s
2026-01-18 14:17:34 +01:00
b2a9ab14e0 Tried flutter action instead of wget
Some checks failed
Pull Request Pipeline / Lint (pull_request) Failing after 2m23s
Pull Request Pipeline / Test (pull_request) Successful in 2m25s
2026-01-18 14:16:45 +01:00
e6402f294b Condition
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m12s
Pull Request Pipeline / Lint (pull_request) Successful in 2m18s
2026-01-18 14:04:20 +01:00
2cce04029a Changed wget progress
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m10s
Pull Request Pipeline / Lint (pull_request) Successful in 2m13s
2026-01-18 14:01:22 +01:00
d79e082f78 Removed 'false' flags
All checks were successful
Pull Request Pipeline / Test (pull_request) Successful in 2m4s
Pull Request Pipeline / Lint (pull_request) Successful in 2m9s
2026-01-18 13:58:23 +01:00
3a8cab164b Merge branch 'development' into setup/44-workflows-um-format-stage-erweitern
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
2026-01-18 13:57:18 +01:00
2966351b5a Resetted version number 2026-01-18 13:57:16 +01:00
99ea863e80 Finalized workflow
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
2026-01-18 13:52:38 +01:00
Gitea Actions [bot]
85b682da76 Updated version number [skip ci] 2026-01-18 12:51:02 +00:00
1792518747 Merge remote-tracking branch 'origin/setup/44-workflows-um-format-stage-erweitern' into setup/44-workflows-um-format-stage-erweitern
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 13:50:48 +01:00
a2d1f7fe9a Implemented skip ci 2026-01-18 13:49:51 +01:00
Gitea Actions [bot]
467ca8043f Updated version number
Some checks failed
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Has been cancelled
2026-01-18 12:48:05 +00:00
Gitea Actions [bot]
c0cace698b Updated version number
Some checks failed
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Has been cancelled
2026-01-18 12:47:58 +00:00
Gitea Actions [bot]
cf8f996ce4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:47:51 +00:00
Gitea Actions [bot]
8b016c26ca Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:47:43 +00:00
Gitea Actions [bot]
0781dbba19 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:47:36 +00:00
Gitea Actions [bot]
ca96a41f29 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:47:29 +00:00
Gitea Actions [bot]
01d5e56c2c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:47:22 +00:00
Gitea Actions [bot]
3afcddf52e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:47:15 +00:00
Gitea Actions [bot]
5d8c985434 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:47:08 +00:00
Gitea Actions [bot]
799b58bf4d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:47:01 +00:00
Gitea Actions [bot]
471ea1a5a3 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:46:53 +00:00
Gitea Actions [bot]
aa6fce09a1 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:46:47 +00:00
Gitea Actions [bot]
b4e568eb39 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:46:39 +00:00
Gitea Actions [bot]
b7fed29a95 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:46:32 +00:00
Gitea Actions [bot]
0acfb8f05b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:46:25 +00:00
Gitea Actions [bot]
94a38bca83 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:46:18 +00:00
Gitea Actions [bot]
07a6d27a37 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:46:11 +00:00
Gitea Actions [bot]
533e897cf5 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:46:03 +00:00
Gitea Actions [bot]
1d98118558 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:45:56 +00:00
Gitea Actions [bot]
f870ed1825 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:45:49 +00:00
Gitea Actions [bot]
2535ac08b9 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:45:42 +00:00
Gitea Actions [bot]
c01b460a0e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:45:35 +00:00
Gitea Actions [bot]
089515d5c9 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:45:28 +00:00
Gitea Actions [bot]
ce9c379921 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:45:21 +00:00
Gitea Actions [bot]
0ec1be3662 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:45:13 +00:00
Gitea Actions [bot]
77d710d43e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:45:06 +00:00
Gitea Actions [bot]
05fad62842 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:44:59 +00:00
Gitea Actions [bot]
43c1284553 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:44:52 +00:00
c4f6414ac2 Merge remote-tracking branch 'origin/setup/44-workflows-um-format-stage-erweitern' into setup/44-workflows-um-format-stage-erweitern
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 13:44:44 +01:00
99104f9108 Wenn das jetzt funktioniert geh ich crashout 2026-01-18 13:44:37 +01:00
9743781d60 Updated version number
Some checks failed
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Failing after 5s
2026-01-18 12:43:35 +00:00
8fcf4933be Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:43:27 +00:00
44b8aba2bd Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:43:19 +00:00
b97071fbf4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:43:10 +00:00
2763ee99d3 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:43:01 +00:00
82472c8fe4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:42:54 +00:00
8d5d5a83b0 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:42:46 +00:00
c21aba569a Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:42:37 +00:00
0628f10356 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:42:29 +00:00
19045d6ca9 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:42:21 +00:00
354034057b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:42:11 +00:00
8aea58b537 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:42:04 +00:00
f850d2d2af Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:41:55 +00:00
5717c236dc Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:41:47 +00:00
cd48d1984b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:41:39 +00:00
e910d6b907 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:41:30 +00:00
a4d12d5f5c Updated version number
All checks were successful
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:41:20 +00:00
1ae2ee620a Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:41:13 +00:00
9e1afacaa8 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:41:05 +00:00
cc738704f5 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:40:57 +00:00
9198131e8f Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:40:50 +00:00
7f6b02f264 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:40:43 +00:00
27c7fd3208 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:40:35 +00:00
49adc89d06 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:40:26 +00:00
b88b0235ca Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:40:17 +00:00
5ebf9a5b7f Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:40:08 +00:00
bbd9dadd43 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:40:01 +00:00
3474f670aa Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:39:52 +00:00
332e0012de Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:39:43 +00:00
321fd2a4c8 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:39:35 +00:00
1401692800 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:39:27 +00:00
013db92c28 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:39:19 +00:00
d0eb111a75 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:39:10 +00:00
db1e52ea67 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:39:03 +00:00
ed0965b8bd Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:38:56 +00:00
4730a6491a Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:38:47 +00:00
d4f85fa95e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:38:38 +00:00
247fe19fe6 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:38:28 +00:00
ea40e39f3d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:38:21 +00:00
27bc7c1741 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:38:14 +00:00
e47c1c9109 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:38:07 +00:00
b6a9599e49 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:37:58 +00:00
323b095663 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:37:50 +00:00
43c3c1e882 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:37:43 +00:00
dd1804478c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:37:35 +00:00
761543f134 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:37:27 +00:00
77ef88f5ce Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:37:19 +00:00
7ea27a316c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:37:11 +00:00
07b4ec87f4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:37:03 +00:00
86c4de9e2f Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:36:56 +00:00
7ecb8aa1c4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:36:47 +00:00
68d3aaff6e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:36:40 +00:00
6172d85c27 Updated version number
All checks were successful
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:36:31 +00:00
e2388d95b1 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:36:23 +00:00
8d4e936a24 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:36:16 +00:00
ed3df5069d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:36:07 +00:00
dd69e0d868 Updated version number
All checks were successful
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:35:58 +00:00
45a955c26d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:35:49 +00:00
f55d33ef0f Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:35:40 +00:00
2957689312 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:35:33 +00:00
6c66eb3752 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:35:25 +00:00
911595053b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:35:18 +00:00
645f610a11 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:35:09 +00:00
33f4e3ecc1 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:35:00 +00:00
4ad0d92f0e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:34:52 +00:00
4ce9975723 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:34:44 +00:00
83fc0d64ab Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:34:37 +00:00
c3d3208029 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:34:28 +00:00
9135d565f5 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:34:20 +00:00
70bba0bd9b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:34:11 +00:00
d0119e0e63 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:34:04 +00:00
5cf7d1b086 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:33:57 +00:00
727ddc2ea5 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:33:48 +00:00
b1cc74d144 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:33:39 +00:00
5cf833d775 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:33:30 +00:00
a494a3a79d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:33:22 +00:00
da80280769 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:33:13 +00:00
9a7c87a112 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:33:06 +00:00
9eb6ffcbca Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:32:57 +00:00
3bc810afa0 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:32:49 +00:00
bb730cb89e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:32:41 +00:00
cbaf0475dc Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:32:33 +00:00
e1219e3d3b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:32:26 +00:00
83dfdd259e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:32:18 +00:00
cbf667092e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:32:10 +00:00
e9f66a5b1b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:32:01 +00:00
09811ffbb5 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:31:53 +00:00
e88ba78ec6 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:31:45 +00:00
3df38dee44 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:31:37 +00:00
f3b0e9d3c4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:31:30 +00:00
2fc7b76a0e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:31:21 +00:00
c29c09c074 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:31:14 +00:00
8a7ac87d15 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:31:06 +00:00
88b0bed310 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:30:59 +00:00
b8844ccc3c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:30:51 +00:00
4d0f7496f4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 7s
2026-01-18 12:30:43 +00:00
56208eff6c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:30:36 +00:00
8d01b7358a Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:30:27 +00:00
5cf3218292 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:30:19 +00:00
243b474784 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:30:12 +00:00
81dc2a7212 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:30:05 +00:00
42dd20ffc4 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:29:58 +00:00
86bf67606c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:29:50 +00:00
2ea7ea7e67 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:29:43 +00:00
ce140c5f2b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:29:36 +00:00
8661fd81b9 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:29:29 +00:00
158b1f7616 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:29:22 +00:00
ebdacaa426 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:29:14 +00:00
b0f8756e0d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:29:07 +00:00
a55fbbaac1 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:29:00 +00:00
d0f02f4a8f Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:28:53 +00:00
b324f32e7b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 6s
2026-01-18 12:28:45 +00:00
55323526d8 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:28:38 +00:00
b84a5a4ad2 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:28:31 +00:00
52e59f303c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:28:24 +00:00
cb1c7ece01 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:28:17 +00:00
7f81a090e8 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:28:10 +00:00
286777a3f6 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:28:03 +00:00
df8af653dd Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:27:55 +00:00
2ebc311283 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:27:48 +00:00
441526127e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:27:41 +00:00
e3c71e5e90 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:27:34 +00:00
b21c294b7c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:27:27 +00:00
a457f423c0 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:27:19 +00:00
eb8883a502 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:27:12 +00:00
95d908bf1f Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:27:05 +00:00
9ccbc5e378 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:58 +00:00
78607ef972 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:51 +00:00
2e49eaaa42 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:44 +00:00
48d3612813 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:37 +00:00
ebf1f8a320 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:29 +00:00
95724aace2 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:23 +00:00
2453afd0ec Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:15 +00:00
10c2b27daa Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:08 +00:00
7b94d0a016 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:26:01 +00:00
64e61eb1b6 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:25:54 +00:00
444a9a9e0c Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:25:46 +00:00
17dd695975 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:25:39 +00:00
57b5860a96 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:25:32 +00:00
c90c038a38 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:25:25 +00:00
e0ff045aa2 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:25:18 +00:00
690d9d1210 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:25:11 +00:00
3026ba1a83 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:25:04 +00:00
0f1f04a748 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:24:56 +00:00
1e9aae2d38 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:24:49 +00:00
df0c65267e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:24:42 +00:00
ea1d9a15a6 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:24:35 +00:00
7c74ab7df6 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:24:28 +00:00
c0f8c0ba5b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:24:21 +00:00
a7304a904a Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:24:14 +00:00
263c592a39 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:24:06 +00:00
bb7df9b858 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:23:59 +00:00
90bdf4862e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:23:52 +00:00
96039eac18 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:23:45 +00:00
cd651882ba Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:23:38 +00:00
4936f15e34 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:23:30 +00:00
7cf727c8e3 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:23:24 +00:00
f0d1537953 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:23:17 +00:00
43dc326515 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:23:09 +00:00
1c66cbbaa7 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:23:03 +00:00
b9a76c9c76 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:22:55 +00:00
2f8bc1a922 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:22:48 +00:00
a4846bddde Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:22:41 +00:00
f98aa2644e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:22:34 +00:00
1b296c7f99 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:22:26 +00:00
aaa25dd4d9 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:22:19 +00:00
684164961b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:22:12 +00:00
6d9bce740a Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:22:05 +00:00
2d094820e7 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:58 +00:00
60cd8c159e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:50 +00:00
f5750045ab Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:43 +00:00
2b929c53f8 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:36 +00:00
afbbf23587 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:29 +00:00
f4a897f939 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:22 +00:00
a86ac26b57 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:15 +00:00
92879007af Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:21:07 +00:00
a431bbc379 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:21:00 +00:00
d7200c788e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:20:53 +00:00
7f396f320e Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:20:46 +00:00
6b98fc5be0 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:20:39 +00:00
411386c80b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:20:32 +00:00
d386607e37 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:20:24 +00:00
145025790b Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:20:18 +00:00
c4df6c9493 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:20:10 +00:00
33ccd892b8 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:20:03 +00:00
c3d00d541d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:19:56 +00:00
d5ba67545f Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:19:49 +00:00
fa0e0bcaca Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:19:42 +00:00
90eb73d4a9 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:19:34 +00:00
572fedfbd0 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:19:27 +00:00
e1698269c5 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:19:20 +00:00
b4cf6d6ed5 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:19:13 +00:00
c5cf965f32 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:19:06 +00:00
fb59a9c784 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:59 +00:00
33d345d460 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:52 +00:00
fe609d16b8 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:45 +00:00
c45acfa720 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:37 +00:00
41a6f925f1 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:30 +00:00
e09c591917 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:23 +00:00
519403e71d Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:16 +00:00
73aeb29415 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:18:09 +00:00
8bf6b415aa Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 4s
2026-01-18 12:18:02 +00:00
5d49bc68b6 Updated version number
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 12:17:54 +00:00
5924a9e86a Tried PAT
All checks were successful
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Successful in 5s
2026-01-18 13:17:42 +01:00
9b98d3b0ee Tried PAT
Some checks failed
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Failing after 4s
2026-01-18 13:16:13 +01:00
00a9b3f2ca Tried PAT
Some checks failed
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update-Version (pull_request) Failing after 4s
2026-01-18 13:13:16 +01:00
22de4264ed Reset version number
Some checks failed
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update Version (pull_request) Failing after 4s
2026-01-17 21:05:07 +01:00
d1e13ee8aa Updated push workflow accordingly 2026-01-17 21:04:34 +01:00
dbd58907af Updated name
Some checks failed
Pull Request Pipeline / Lint (pull_request) Has been skipped
Pull Request Pipeline / Test (pull_request) Has been skipped
Pull Request Pipeline / Format (pull_request) Has been skipped
Pull Request Pipeline / Update Version (pull_request) Failing after 5s
2026-01-17 20:36:03 +01:00
8e2b3a6381 Updated name
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update version (pull_request) Failing after 5s
2026-01-17 20:35:10 +01:00
7b83e60cb0 test token
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 5s
2026-01-17 20:25:01 +01:00
a390d82d05 test token
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 4s
2026-01-17 20:24:19 +01:00
ed167b00d6 test token
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 4s
2026-01-17 20:23:26 +01:00
9b44141c57 test token
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 5s
2026-01-17 20:21:59 +01:00
2ab07ee795 test token
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 4s
2026-01-17 20:21:25 +01:00
3acd4e8cfe Added secret
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 5s
2026-01-17 20:19:16 +01:00
75f56eaab7 Added secret
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 4s
2026-01-17 20:17:26 +01:00
49e947034e Tested branch protection
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 5s
2026-01-17 20:12:25 +01:00
Gitea Actions [bot]
d8ba6aecf2 Updated version number 2026-01-17 19:11:46 +00:00
3c0f6b6413 Merge remote-tracking branch 'origin/setup/44-workflows-um-format-stage-erweitern' into setup/44-workflows-um-format-stage-erweitern
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Successful in 5s
2026-01-17 20:11:39 +01:00
4fe008af3f Back to patch 2026-01-17 20:11:34 +01:00
Gitea Actions [bot]
8b680f4abe Updated version number 2026-01-17 19:11:01 +00:00
2b52ec3582 Merge remote-tracking branch 'origin/setup/44-workflows-um-format-stage-erweitern' into setup/44-workflows-um-format-stage-erweitern
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Successful in 6s
2026-01-17 20:10:53 +01:00
b79e2af958 Tested minor 2026-01-17 20:10:47 +01:00
Gitea Actions [bot]
b8bd737dc3 Updated version number 2026-01-17 19:10:00 +00:00
a0c0936867 Merge remote-tracking branch 'origin/setup/44-workflows-um-format-stage-erweitern' into setup/44-workflows-um-format-stage-erweitern
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Successful in 4s
2026-01-17 20:09:49 +01:00
b89cfd1f9f Only version number 2026-01-17 20:09:36 +01:00
Gitea Actions [bot]
24bb687317 Updated version number 2026-01-17 19:09:08 +00:00
b315ef3904 Merge remote-tracking branch 'origin/setup/44-workflows-um-format-stage-erweitern' into setup/44-workflows-um-format-stage-erweitern
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Has been cancelled
2026-01-17 20:09:00 +01:00
40e3673a87 Only version number 2026-01-17 20:08:55 +01:00
Gitea Actions [bot]
19f800ff5f Updated version number 2026-01-17 19:08:28 +00:00
5eee9a238d Tried version update
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Successful in 6s
2026-01-17 20:08:19 +01:00
bbf031100f Tried version update
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 5s
2026-01-17 20:07:33 +01:00
5d9e143027 Tried version update
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 5s
2026-01-17 20:06:56 +01:00
10f3aacf99 Tried version update
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Successful in 4s
2026-01-17 20:05:31 +01:00
8045855f91 Tried version update
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
Pull Request Pipeline / update-version (pull_request) Failing after 1s
2026-01-17 20:04:19 +01:00
d4bb0c5698 Tried version update
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been skipped
2026-01-17 20:03:46 +01:00
Gitea Actions [bot]
94c510ce67 Auto-format code 2026-01-17 18:59:41 +00:00
674e1111d2 Try sth
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Successful in 2m15s
2026-01-17 19:57:25 +01:00
ec6105e01d Merge remote-tracking branch 'origin/setup/44-workflows-um-format-stage-erweitern' into setup/44-workflows-um-format-stage-erweitern
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been cancelled
2026-01-17 19:57:05 +01:00
bfb5debbeb Try sth 2026-01-17 19:56:59 +01:00
liquid-actions[bot]
7764b65631 Auto-format code 2026-01-17 18:52:03 +00:00
b5453d9ced Added fetch
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Failing after 2m16s
2026-01-17 19:49:46 +01:00
6a79b7cad9 Added checkout again
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Failing after 2m12s
2026-01-17 19:46:38 +01:00
4bf39e8bba added formatting error
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Failing after 2m17s
2026-01-17 19:43:34 +01:00
fede08b0a8 added formatting error
All checks were successful
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Successful in 2m18s
2026-01-17 19:42:26 +01:00
78aaebcd42 Fixed submodule error
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Failing after 2m12s
2026-01-17 19:39:11 +01:00
c2bf859f85 Removed branch checkout
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Failing after 3m3s
2026-01-17 19:35:54 +01:00
8d50cf4b46 Added branch checkout
Some checks failed
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Failing after 2m9s
2026-01-17 19:32:14 +01:00
b763375748 Updated workflow again 2
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Failing after 3m13s
2026-01-17 19:28:19 +01:00
196b939ca7 Updated workflow again
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been cancelled
2026-01-17 19:26:24 +01:00
c536656dff Added formatting issue
Some checks failed
Pull Request Pipeline / lint (pull_request) Has been skipped
Pull Request Pipeline / test (pull_request) Has been skipped
Pull Request Pipeline / format (pull_request) Has been cancelled
2026-01-17 19:21:21 +01:00
9676ff278d Updated workflow
Some checks are pending
Pull Request Pipeline / lint (pull_request) Has started running
Pull Request Pipeline / test (pull_request) Waiting to run
Pull Request Pipeline / format (pull_request) Successful in 2m6s
2026-01-17 19:18:03 +01:00
b53bb597e1 Updated formatting
Some checks failed
Pull Request Pipeline / lint (pull_request) Waiting to run
Pull Request Pipeline / test (pull_request) Waiting to run
Pull Request Pipeline / format (pull_request) Has been cancelled
2026-01-17 19:12:52 +01:00
929183109c Updated workflow
Some checks failed
Pull Request Pipeline / lint (pull_request) Waiting to run
Pull Request Pipeline / test (pull_request) Waiting to run
Pull Request Pipeline / format (pull_request) Failing after 1m50s
2026-01-17 19:08:40 +01:00
142 changed files with 2649 additions and 9670 deletions

View File

@@ -4,54 +4,49 @@ on:
pull_request: pull_request:
jobs: jobs:
lint: Lint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
# Required for Flutter action - name: Install Flutter (wget)
- name: Install jq
run: | run: |
apt-get update wget --show-progress --progress=bar:force:noscroll:giga https://storage.googleapis.com/flutter_infra_release/releases/stable/linux/flutter_linux_3.38.2-stable.tar.xz
apt-get install -y jq tar xf flutter_linux_3.38.2-stable.tar.xz
# Set Git safe directory for Flutter path
- name: Set up Flutter git config --global --add safe.directory "$(pwd)/flutter"
uses: subosito/flutter-action@v2 # Set Flutter path
with: echo "$(pwd)/flutter/bin" >> $GITEA_PATH
channel: stable
flutter-version: 3.38.6
- name: Get dependencies - name: Get dependencies
run: | run: flutter pub get
git config --global --add safe.directory /opt/hostedtoolcache/flutter/stable-3.38.6-x64
flutter pub get
- name: Analyze Formatting - name: Analyze Formatting
run: flutter analyze lib test run: flutter analyze lib test
test: Test:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
# Required for Flutter action - name: Install dependencies
- name: Install jq
run: | run: |
apt-get update apt-get update
apt-get install -y jq apt-get install -y jq
- name: Set up Flutter - name: Install Flutter (wget)
uses: subosito/flutter-action@v2 run: |
with: wget --show-progress --progress=bar:force:noscroll:giga https://storage.googleapis.com/flutter_infra_release/releases/stable/linux/flutter_linux_3.38.2-stable.tar.xz
channel: stable tar xf flutter_linux_3.38.2-stable.tar.xz
flutter-version: 3.38.6 # Set Git safe directory for Flutter path
git config --global --add safe.directory "$(pwd)/flutter"
# Set Flutter path
echo "$(pwd)/flutter/bin" >> $GITEA_PATH
- name: Get dependencies - name: Get dependencies
run: | run: flutter pub get
git config --global --add safe.directory /opt/hostedtoolcache/flutter/stable-3.38.6-x64
flutter pub get
- name: Run tests - name: Run tests
run: flutter test run: flutter test

View File

@@ -7,166 +7,54 @@ on:
- "main" - "main"
jobs: jobs:
build: Test:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
- name: Setup Java (Temurin 17) - name: Install dependencies
uses: actions/setup-java@v3
with:
distribution: temurin
java-version: '17'
- name: Setup Android SDK
uses: android-actions/setup-android@v3
# Required for Flutter action
- name: Install jq
run: | run: |
apt-get update apt-get update
apt-get install -y jq apt-get install -y jq
- name: Set up Flutter - name: Install Flutter (wget)
uses: subosito/flutter-action@v2 run: |
with: wget --show-progress --progress=bar:force:noscroll:giga https://storage.googleapis.com/flutter_infra_release/releases/stable/linux/flutter_linux_3.38.2-stable.tar.xz
channel: stable tar xf flutter_linux_3.38.2-stable.tar.xz
flutter-version: 3.38.6 # Set Git safe directory for Flutter path
git config --global --add safe.directory "$(pwd)/flutter"
# Set Flutter path
echo "$(pwd)/flutter/bin" >> $GITEA_PATH
- name: Get dependencies - name: Get dependencies
run: | run: flutter pub get
git config --global --add safe.directory /opt/hostedtoolcache/flutter/stable-3.38.6-x64
flutter pub get
- name: Build APK
run: flutter build apk --release
test:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
# Required for Flutter action
- name: Install jq
run: |
apt-get update
apt-get install -y jq
- name: Set up Flutter
uses: subosito/flutter-action@v2
with:
channel: stable
flutter-version: 3.38.6
- name: Get dependencies
run: |
git config --global --add safe.directory /opt/hostedtoolcache/flutter/stable-3.38.6-x64
flutter pub get
- name: Run tests - name: Run tests
run: flutter test run: flutter test
update_version: Format:
runs-on: ubuntu-latest runs-on: ubuntu-latest
if: gitea.ref == 'refs/heads/development'
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ secrets.BOT_TOKEN }}
ref: ${{ gitea.ref_name }}
- name: Increment version number - name: Install dependencies
uses: stikkyapp/update-pubspec-version@v2
with:
strategy: 'patch'
path: './pubspec.yaml'
- name: Commit version update
env:
GITEA_TOKEN: ${{ secrets.BOT_TOKEN }}
run: |
git config --global user.name "Gitea Actions [bot]"
git config --global user.email "actions@yannick-weigert.de"
git config pull.rebase false
git pull origin ${{ gitea.ref_name }}
git add pubspec.yaml
git commit -m "Updated version number [skip ci]"
git push origin HEAD:${{ gitea.ref_name }}
generate_licenses:
runs-on: ubuntu-latest
needs: update_version
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ secrets.BOT_TOKEN }}
ref: ${{ gitea.ref_name }}
# Required for Flutter action
- name: Install jq
run: | run: |
apt-get update apt-get update
apt-get install -y jq apt-get install -y jq
- name: Set up Flutter - name: Install Flutter (wget)
uses: subosito/flutter-action@v2 run: |
with: wget --show-progress --progress=bar:force:noscroll:giga https://storage.googleapis.com/flutter_infra_release/releases/stable/linux/flutter_linux_3.38.2-stable.tar.xz
channel: stable tar xf flutter_linux_3.38.2-stable.tar.xz
flutter-version: 3.38.6 # Set Git safe directory for Flutter path
git config --global --add safe.directory "$(pwd)/flutter"
# Set Flutter path
echo "$(pwd)/flutter/bin" >> $GITEA_PATH
- name: Get dependencies - name: Get dependencies
run: | run: flutter pub get
git config --global --add safe.directory /opt/hostedtoolcache/flutter/stable-3.38.6-x64
flutter pub get
- name: Generate oss_licenses.dart
run: flutter pub run dart_pubspec_licenses:generate -o lib/presentation/views/main_menu/settings_view/licenses/oss_licenses.dart
- name: Commit license update
env:
GITEA_TOKEN: ${{ secrets.BOT_TOKEN }}
run: |
if [ -n "$(git status --porcelain lib test)" ]; then
git config --global user.name "Gitea Actions [bot]"
git config --global user.email "actions@yannick-weigert.de"
git config pull.rebase false
git pull origin ${{ gitea.ref_name }}
git add lib test
git commit -m "Updated licenses [skip ci]"
git push origin HEAD:${{ gitea.ref_name }}
else
echo "No changes to commit"
fi
format:
runs-on: ubuntu-latest
needs: [update_version, generate_licenses]
steps:
- name: Checkout code
uses: actions/checkout@v4
# Required for Flutter action
- name: Install jq
run: |
apt-get update
apt-get install -y jq
- name: Set up Flutter
uses: subosito/flutter-action@v2
with:
channel: stable
flutter-version: 3.38.6
- name: Get dependencies
run: |
git config --global --add safe.directory /opt/hostedtoolcache/flutter/stable-3.38.6-x64
flutter pub get
- name: Check code format - name: Check code format
id: check_format id: check_format
@@ -178,8 +66,8 @@ jobs:
env: env:
GITEA_TOKEN: ${{ secrets.BOT_TOKEN }} GITEA_TOKEN: ${{ secrets.BOT_TOKEN }}
run: | run: |
git fetch origin ${{ gitea.ref_name }} git fetch origin ${{ gitea.head_ref }}
git checkout ${{ gitea.ref_name }} git checkout ${{ gitea.head_ref }}
dart fix --apply lib dart fix --apply lib
dart fix --apply test dart fix --apply test
@@ -187,14 +75,41 @@ jobs:
if [ -n "$(git status --porcelain lib test)" ]; then if [ -n "$(git status --porcelain lib test)" ]; then
git config --global user.name "Gitea Actions [bot]" git config --global user.name "Gitea Actions [bot]"
git config --global user.email "actions@yannick-weigert.de" git config --global user.email "actions@yannick-weigert.de"
git config pull.rebase false
git pull origin ${{ gitea.ref_name }}
git add lib test git add lib test
git commit -m "Auto-format code [skip ci]" git commit -m "Auto-format code [skip ci]"
git push origin HEAD:${{ gitea.ref_name }} git push origin HEAD:${{ gitea.head_ref }}
else else
echo "No changes to commit" echo "No changes to commit"
fi fi
- name: Verify format - name: Verify format
run: flutter analyze lib test run: flutter analyze lib test
Update Version:
runs-on: ubuntu-latest
needs: Format
if: gitea.ref == 'refs/heads/development'
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ secrets.BOT_TOKEN }}
ref: ${{ gitea.head_ref }}
- name: Increment version number
uses: https://github.com/stikkyapp/update-pubspec-version@v2
with:
strategy: 'patch'
path: './pubspec.yaml'
- name: Commit version update
env:
GITEA_TOKEN: ${{ secrets.BOT_TOKEN }}
run: |
git config --global user.name "Gitea Actions [bot]"
git config --global user.email "actions@yannick-weigert.de"
git add pubspec.yaml
git commit -m "Updated version number [skip ci]"
git push origin HEAD:${{ gitea.head_ref }}

View File

@@ -1,13 +0,0 @@
# Contributing
## Code of Conduct
`<insert link to code of conduct here>`
## Code Style
`<insert styling guidelines here>`
## Repository structure
`<insert folder structure and explanation here>`

165
LICENSE
View File

@@ -1,165 +0,0 @@
GNU LESSER GENERAL PUBLIC LICENSE
Version 3, 29 June 2007
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.
This version of the GNU Lesser General Public License incorporates
the terms and conditions of version 3 of the GNU General Public
License, supplemented by the additional permissions listed below.
0. Additional Definitions.
As used herein, "this License" refers to version 3 of the GNU Lesser
General Public License, and the "GNU GPL" refers to version 3 of the GNU
General Public License.
"The Library" refers to a covered work governed by this License,
other than an Application or a Combined Work as defined below.
An "Application" is any work that makes use of an interface provided
by the Library, but which is not otherwise based on the Library.
Defining a subclass of a class defined by the Library is deemed a mode
of using an interface provided by the Library.
A "Combined Work" is a work produced by combining or linking an
Application with the Library. The particular version of the Library
with which the Combined Work was made is also called the "Linked
Version".
The "Minimal Corresponding Source" for a Combined Work means the
Corresponding Source for the Combined Work, excluding any source code
for portions of the Combined Work that, considered in isolation, are
based on the Application, and not on the Linked Version.
The "Corresponding Application Code" for a Combined Work means the
object code and/or source code for the Application, including any data
and utility programs needed for reproducing the Combined Work from the
Application, but excluding the System Libraries of the Combined Work.
1. Exception to Section 3 of the GNU GPL.
You may convey a covered work under sections 3 and 4 of this License
without being bound by section 3 of the GNU GPL.
2. Conveying Modified Versions.
If you modify a copy of the Library, and, in your modifications, a
facility refers to a function or data to be supplied by an Application
that uses the facility (other than as an argument passed when the
facility is invoked), then you may convey a copy of the modified
version:
a) under this License, provided that you make a good faith effort to
ensure that, in the event an Application does not supply the
function or data, the facility still operates, and performs
whatever part of its purpose remains meaningful, or
b) under the GNU GPL, with none of the additional permissions of
this License applicable to that copy.
3. Object Code Incorporating Material from Library Header Files.
The object code form of an Application may incorporate material from
a header file that is part of the Library. You may convey such object
code under terms of your choice, provided that, if the incorporated
material is not limited to numerical parameters, data structure
layouts and accessors, or small macros, inline functions and templates
(ten or fewer lines in length), you do both of the following:
a) Give prominent notice with each copy of the object code that the
Library is used in it and that the Library and its use are
covered by this License.
b) Accompany the object code with a copy of the GNU GPL and this license
document.
4. Combined Works.
You may convey a Combined Work under terms of your choice that,
taken together, effectively do not restrict modification of the
portions of the Library contained in the Combined Work and reverse
engineering for debugging such modifications, if you also do each of
the following:
a) Give prominent notice with each copy of the Combined Work that
the Library is used in it and that the Library and its use are
covered by this License.
b) Accompany the Combined Work with a copy of the GNU GPL and this license
document.
c) For a Combined Work that displays copyright notices during
execution, include the copyright notice for the Library among
these notices, as well as a reference directing the user to the
copies of the GNU GPL and this license document.
d) Do one of the following:
0) Convey the Minimal Corresponding Source under the terms of this
License, and the Corresponding Application Code in a form
suitable for, and under terms that permit, the user to
recombine or relink the Application with a modified version of
the Linked Version to produce a modified Combined Work, in the
manner specified by section 6 of the GNU GPL for conveying
Corresponding Source.
1) Use a suitable shared library mechanism for linking with the
Library. A suitable mechanism is one that (a) uses at run time
a copy of the Library already present on the user's computer
system, and (b) will operate properly with a modified version
of the Library that is interface-compatible with the Linked
Version.
e) Provide Installation Information, but only if you would otherwise
be required to provide such information under section 6 of the
GNU GPL, and only to the extent that such information is
necessary to install and execute a modified version of the
Combined Work produced by recombining or relinking the
Application with a modified version of the Linked Version. (If
you use option 4d0, the Installation Information must accompany
the Minimal Corresponding Source and Corresponding Application
Code. If you use option 4d1, you must provide the Installation
Information in the manner specified by section 6 of the GNU GPL
for conveying Corresponding Source.)
5. Combined Libraries.
You may place library facilities that are a work based on the
Library side by side in a single library together with other library
facilities that are not Applications and are not covered by this
License, and convey such a combined library under terms of your
choice, if you do both of the following:
a) Accompany the combined library with a copy of the same work based
on the Library, uncombined with any other library facilities,
conveyed under the terms of this License.
b) Give prominent notice with the combined library that part of it
is a work based on the Library, and explaining where to find the
accompanying uncombined form of the same work.
6. Revised Versions of the GNU Lesser General Public License.
The Free Software Foundation may publish revised and/or new versions
of the GNU Lesser General Public License from time to time. Such new
versions will be similar in spirit to the present version, but may
differ in detail to address new problems or concerns.
Each version is given a distinguishing version number. If the
Library as you received it specifies that a certain numbered version
of the GNU Lesser General Public License "or any later version"
applies to it, you have the option of following the terms and
conditions either of that published version or of any later version
published by the Free Software Foundation. If the Library as you
received it does not specify a version number of the GNU Lesser
General Public License, you may choose any version of the GNU Lesser
General Public License ever published by the Free Software Foundation.
If the Library as you received it specifies that a proxy can decide
whether future versions of the GNU Lesser General Public License shall
apply, that proxy's public statement of acceptance of any version is
permanent authorization for you to choose that version for the
Library.

View File

@@ -1,63 +1,7 @@
<p align="center"> # Game Tracker
<img alt="Tallee Logo" src="/artefacts/app-logo.png" width="200"/>
<h2 align="center">Tallee</h2>
</p>
<p align="center">
An open-source app to track card- and board games, manage players & groups and get statistics about your played games.
</p>
<p align="center">
<a href="https://apps.apple.com/">
<img src="https://tools.applemediaservices.com/api/badges/download-on-the-app-store/black/en-US"
alt="Download on the App Store"
height="48"
/>
</a>
<a href="https://play.google.com/">
<img alt="Get it on Google Play"
title="Google Play"
src="https://raw.githubusercontent.com/pd4d10/git-touch/main/assets/google-play-badge.png"
height="48"
/>
</a>
</p>
![Version](https://img.shields.io/badge/App--Version-0.0.1_Alpha-orange)
![Flutter](https://img.shields.io/badge/Flutter-3.38.6-027DFD?logo=flutter)
![iOS26](https://img.shields.io/badge/iOS-26-white?logo=apple)
![Android16](https://img.shields.io/badge/Android-16-3DDC84?logo=android)
## Screenshots
<table align="center" cellspacing="8">
<tr>
<td><img src="/artefacts/screenshot-1.png" alt="Screenshot 1" width="240" /></td>
<td><img src="/artefacts/screenshot-2.png" alt="Screenshot 2" width="240" /></td>
<td><img src="/artefacts/screenshot-3.png" alt="Screenshot 3" width="240" /></td>
<td><img src="/artefacts/screenshot-4.png" alt="Screenshot 4" width="240" /></td>
</tr>
</table>
## Contributing
Contributions are welcome! If you find a bug or have a feature request, please open an issue on GitHub. If you'd like to
contribute code, feel free to fork the repository and submit a pull request. For contribution guidelines, please refer
to [CONTRIBUTING.md](CONTRIBUTING.md).
## License
This project is licensed under the GNU LGPLv3 License. See the [LICENSE](LICENSE) file for details.
## Contributors
<a href="https://github.com/liquiddevelopmentde/game-tracker/graphs/contributors">
<img src="https://contrib.rocks/image?repo=liquiddevelopmentde/game-tracker" />
</a>
## Credits
Tallee is developed and maintained by [Liquid Development](https://liquid-dev.de). For more information or support regarding Tallee, contact us through our website or [hello@liquid-dev.de](mailto:hello@liquid-dev.de).
![Created by Liquid Development](https://img.shields.io/badge/Created_by-Liquid_Development-027DFD?logo=data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyBpZD0iRWJlbmVfMSIgZGF0YS1uYW1lPSJFYmVuZSAxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA3MjUuNDggODk3LjMiPgogIDxkZWZzPgogICAgPHN0eWxlPgogICAgICAuY2xzLTEgewogICAgICAgIGZpbGw6ICNmZmY7CiAgICAgIH0KICAgIDwvc3R5bGU+CiAgPC9kZWZzPgogIDxwYXRoIGNsYXNzPSJjbHMtMSIgZD0iTTcwNS4yNiw3MDEuOTJsNi40LDExLjA4Yy0xLjk1LTMuODEtNC4wOS03LjUxLTYuNC0xMS4wOFoiLz4KICA8cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik02MDIuMzksODk3LjI1aC03LjIxYzEuMi4wMywyLjQuMDUsMy42MS4wNXMyLjQxLS4wMiwzLjYxLS4wNVoiLz4KICA8cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik0wLDY5NS4zOGwyLjY4LTQuNjRjLS45MywxLjUyLTEuODIsMy4wNy0yLjY4LDQuNjRaIi8+CiAgPHBhdGggY2xhc3M9ImNscy0xIiBkPSJNNjgyLjU1LDcyMy40NWw2LjA1LDEwLjQ5Yy0xLjc5LTMuNjQtMy44MS03LjE1LTYuMDUtMTAuNDlaIi8+CiAgPHBhdGggY2xhc3M9ImNscy0xIiBkPSJNMzcuNzIsNzMzLjI4bDUuMy05LjE4Yy0xLjk0LDIuOTQtMy43MSw2LjAxLTUuMyw5LjE4WiIvPgogIDxwYXRoIGNsYXNzPSJjbHMtMSIgZD0iTTcxMS42Niw3MTMuMDFsLTYuNC0xMS4wOC0yMjAuNDYtMzgxLjg0aDBWMTAxLjg0YzIwLjY3LTYuOTgsMzUuNTYtMjYuNTIsMzUuNTYtNDkuNTQsMC0yOC44OC0yMy40MS01Mi4zLTUyLjMtNTIuM2gtMjA5LjQ4Yy0yOC44OCwwLTUyLjMsMjMuNDEtNTIuMyw1Mi4zLDAsMjIuNzEsMTQuNDgsNDIuMDMsMzQuNyw0OS4yNXYyMTguNTRsLS4zMy41OEwxOC44OSw3MDQuNzlsLTIuNjgsNC42NGMtOS45OSwxOC4xMi0xNS42OCwzOC45Ni0xNS42OCw2MS4xMiwwLDY5Ljk3LDU2LjY0LDEyNi43LDEyNi41MSwxMjYuN2g0NzUuMzVjNjguMy0xLjkxLDEyMy4wOS01Ny44OCwxMjMuMDktMTI2LjY0LDAtMjAuNzQtNC45OS00MC4zMi0xMy44Mi01Ny42Wk02MDguNTYsODYyLjUzSDExNy40M2MtNDkuMzcsMC04OS4zOS00MC4wMi04OS4zOS04OS4zOSwwLTE0LjM2LDMuMzktMjcuOTMsOS40MS0zOS45Nmw1LjMtOS4xOCwyMzMuMi00MDMuOTJoLS4wOFYxMDQuNTloMTcuODFjOS40NywwLDE3LjE1LTcuNjgsMTcuMTUtMTcuMTVzLTcuNjgtMTcuMTUtMTcuMTUtMTcuMTVoLTM1LjU5di0uMDJjLTkuNzItLjI2LTE3LjUyLTguMi0xNy41Mi0xNy45OHM3LjgtMTcuNzIsMTcuNTItMTcuOTh2LS4wMmgyMDkuMjZjOS45NCwwLDE4LDguMDYsMTgsMThzLTguMDYsMTgtMTgsMThoLTM0LjQ4Yy05LjQ3LDAtMTcuMTUsNy42OC0xNy4xNSwxNy4xNXM3LjY4LDE3LjE1LDE3LjE1LDE3LjE1aDE3LjA0djIxNS40OWguMDdsMjMyLjgyLDQwMy4yNiw2LjA2LDEwLjVjNS44MiwxMS44Niw5LjA5LDI1LjIsOS4wOSwzOS4zLDAsNDkuMzctNDAuMDIsODkuMzktODkuMzksODkuMzlaIi8+CiAgPHBhdGggY2xhc3M9ImNscy0xIiBkPSJNMzgxLjY4LDU0NS4zOGMtMy4wOCwxLjY4LTYuMTgsMy4zLTkuMzIsNC44NiwzLjA3LTEuNjcsNi4xOC0zLjI5LDkuMzItNC44NloiLz4KICA8cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik01ODMuNDIsNTUxLjE5bC0yMC42Ny0zNS44Yy0xMy42OS0xLjg0LTI3LjY3LTIuNzktNDEuODYtMi43OS0xNy45OSwwLTM1LjYyLDEuNTMtNTIuNzgsNC40Ni0zMC41Niw1LjIxLTU5LjYsMTQuODktODYuNDIsMjguMzMtMy4wOCwxLjY4LTYuMTgsMy4zLTkuMzIsNC44Ni00MS44OCwyMC45OS04OS4xNiwzMi43OS0xMzkuMTksMzIuNzktMzQuODUsMC02OC4zNS01Ljc0LTk5LjYzLTE2LjMxLDAsMCwwLC4wMiwwLC4wMmwtMTYuNTIsMjguNjFjMzcuMDEsMTUuNTMsNzcuNjUsMjQuMTIsMTIwLjMsMjQuMTIsMTcuOTgsMCwzNS42MS0xLjUzLDUyLjc2LTQuNDYsMzIuNzctNS41OSw2My43OC0xNi4zMSw5Mi4yLTMxLjI5Ljg3LS40NiwxLjczLS45MiwyLjYtMS40LDQzLjI5LTIyLjgyLDkyLjYyLTM1Ljc0LDE0NC45Ni0zNS43NCwxOC4yOCwwLDM2LjE4LDEuNTksNTMuNTksNC42MWwtLjAyLS4wMloiLz4KICA8Zz4KICAgIDxjaXJjbGUgY2xhc3M9ImNscy0xIiBjeD0iNTg3LjY0IiBjeT0iODAzLjQiIHI9IjE4Ljk2Ii8+CiAgICA8cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik01MTUuNTIsNzg0LjQzSDEwMy41NWMtMTAuOTIsMC0xOS43Niw4LjQ5LTE5Ljc2LDE4Ljk2czguODUsMTguOTYsMTkuNzYsMTguOTZoNDExLjk3YzEwLjkyLDAsMTkuNzYtOC40OSwxOS43Ni0xOC45NnMtOC44NS0xOC45Ni0xOS43Ni0xOC45NloiLz4KICA8L2c+CiAgPGNpcmNsZSBjbGFzcz0iY2xzLTEiIGN4PSIyODMuMzIiIGN5PSI0NjcuNTkiIHI9IjE4Ljk2Ii8+CiAgPGNpcmNsZSBjbGFzcz0iY2xzLTEiIGN4PSIzMjYuMjMiIGN5PSIzNjYuMjUiIHI9IjE4Ljk2Ii8+CiAgPHBhdGggY2xhc3M9ImNscy0xIiBkPSJNNDA2LjU2LDM4NS4yMmMtMjQuMDYsMC00My41NiwxOS41LTQzLjU2LDQzLjU2czE5LjUsNDMuNTYsNDMuNTYsNDMuNTYsNDMuNTYtMTkuNSw0My41Ni00My41Ni0xOS41LTQzLjU2LTQzLjU2LTQzLjU2Wk00MDYuNTYsNDQ3Ljc0Yy0xMC40NywwLTE4Ljk2LTguNDktMTguOTYtMTguOTZzOC40OS0xOC45NiwxOC45Ni0xOC45NiwxOC45Niw4LjQ5LDE4Ljk2LDE4Ljk2LTguNDksMTguOTYtMTguOTYsMTguOTZaIi8+Cjwvc3ZnPg==)
![Version](https://img.shields.io/badge/Version-0.3.0-orange)
![Flutter](https://img.shields.io/badge/Flutter-3.32.1-blue?logo=flutter)
![Dart](https://img.shields.io/badge/Dart-3.8.1-blue?logo=dart)
A all-in-one app to track card- and board games, manage players and groups and get statistics about your played games.

View File

@@ -6,7 +6,7 @@ plugins {
} }
android { android {
namespace = "de.liquid.tallee" namespace = "com.example.game_tracker"
compileSdk = flutter.compileSdkVersion compileSdk = flutter.compileSdkVersion
ndkVersion = flutter.ndkVersion ndkVersion = flutter.ndkVersion
@@ -21,7 +21,7 @@ android {
defaultConfig { defaultConfig {
// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
applicationId = "de.liquid.tallee" applicationId = "com.example.game_tracker"
// You can update the following values to match your application needs. // You can update the following values to match your application needs.
// For more information, see: https://flutter.dev/to/review-gradle-config. // For more information, see: https://flutter.dev/to/review-gradle-config.
minSdk = flutter.minSdkVersion minSdk = flutter.minSdkVersion

View File

@@ -1,7 +1,7 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android"> <manifest xmlns:android="http://schemas.android.com/apk/res/android">
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.INTERNET" />
<application <application
android:label="Tallee" android:label="game_tracker"
android:name="${applicationName}" android:name="${applicationName}"
android:icon="@mipmap/ic_launcher"> android:icon="@mipmap/ic_launcher">
<activity <activity

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

After

Width:  |  Height:  |  Size: 8.0 KiB

View File

@@ -1,4 +1,4 @@
package de.liquid.tallee package com.example.game_tracker
import io.flutter.embedding.android.FlutterActivity import io.flutter.embedding.android.FlutterActivity

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 828 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 884 B

After

Width:  |  Height:  |  Size: 448 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.9 KiB

After

Width:  |  Height:  |  Size: 2.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 938 B

After

Width:  |  Height:  |  Size: 656 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 596 B

After

Width:  |  Height:  |  Size: 348 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 508 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.1 KiB

After

Width:  |  Height:  |  Size: 3.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB

After

Width:  |  Height:  |  Size: 704 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.4 KiB

After

Width:  |  Height:  |  Size: 4.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.4 KiB

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.4 KiB

After

Width:  |  Height:  |  Size: 824 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 9.0 KiB

After

Width:  |  Height:  |  Size: 6.9 KiB

View File

@@ -1,4 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<resources> <resources>
<color name="launch_background">#ef681f</color> <color name="app_icon_background">#E6F1E4</color>
<color name="launch_background">#0B0B0B</color>
</resources> </resources>

View File

@@ -1,4 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<resources> <resources>
<color name="ic_launcher_background">#EF681F</color> <!-- Referenz unbedingt als @color/launch_background (nicht @colors/...) -->
<color name="ic_launcher_background">@color/app_icon_background</color>
</resources> </resources>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 47 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 291 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 279 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 354 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 294 KiB

View File

@@ -15,91 +15,16 @@
}, },
"name": { "name": {
"type": "string" "type": "string"
},
"description": {
"type": "string"
} }
}, },
"required": [ "required": [
"id", "id",
"createdAt", "createdAt",
"name", "name"
"description"
]
}
},
"games": {
"type": "array",
"items": {
"type": "object",
"properties": {
"id": {
"type": "string"
},
"createdAt": {
"type": "string"
},
"name": {
"type": "string"
},
"ruleset": {
"type": "string"
},
"description": {
"type": "string"
},
"color": {
"type": "string"
},
"icon": {
"type": "string"
}
},
"required": [
"id",
"createdAt",
"name",
"ruleset",
"description",
"color",
"icon"
] ]
} }
}, },
"groups": { "groups": {
"type": "array",
"items": {
"type": "object",
"properties": {
"id": {
"type": "string"
},
"name": {
"type": "string"
},
"createdAt": {
"type": "string"
},
"description": {
"type": "string"
},
"memberIds": {
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"id",
"name",
"createdAt",
"description",
"memberIds"
]
}
},
"teams": {
"type": "array", "type": "array",
"items": { "items": {
"type": "object", "type": "object",
@@ -142,14 +67,11 @@
"createdAt": { "createdAt": {
"type": "string" "type": "string"
}, },
"endedAt": {
"type": ["string", "null"]
},
"gameId": {
"type": "string"
},
"groupId": { "groupId": {
"type": ["string", "null"] "anyOf": [
{"type": "string"},
{"type": "null"}
]
}, },
"playerIds": { "playerIds": {
"type": "array", "type": "array",
@@ -157,26 +79,26 @@
"type": "string" "type": "string"
} }
}, },
"notes": { "winnerId": {
"type": "string" "anyOf": [
{"type": "string"},
{"type": "null"}
]
} }
}, },
"required": [ "required": [
"id", "id",
"name", "name",
"createdAt", "createdAt",
"gameId", "groupId",
"playerIds", "playerIds"
"notes"
] ]
} }
} }
}, },
"required": [ "required": [
"players", "players",
"games",
"groups", "groups",
"teams",
"matches" "matches"
] ]
} }

View File

@@ -152,6 +152,7 @@
B68CF4A64F0B5E45B43D6900 /* Pods-RunnerTests.release.xcconfig */, B68CF4A64F0B5E45B43D6900 /* Pods-RunnerTests.release.xcconfig */,
E754D1191B3E54E52B6DCC49 /* Pods-RunnerTests.profile.xcconfig */, E754D1191B3E54E52B6DCC49 /* Pods-RunnerTests.profile.xcconfig */,
); );
name = Pods;
path = Pods; path = Pods;
sourceTree = "<group>"; sourceTree = "<group>";
}; };
@@ -477,7 +478,7 @@
"$(inherited)", "$(inherited)",
"@executable_path/Frameworks", "@executable_path/Frameworks",
); );
PRODUCT_BUNDLE_IDENTIFIER = de.liquid.tallee; PRODUCT_BUNDLE_IDENTIFIER = com.example.gameTracker;
PRODUCT_NAME = "$(TARGET_NAME)"; PRODUCT_NAME = "$(TARGET_NAME)";
SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
SWIFT_VERSION = 5.0; SWIFT_VERSION = 5.0;
@@ -660,7 +661,7 @@
"$(inherited)", "$(inherited)",
"@executable_path/Frameworks", "@executable_path/Frameworks",
); );
PRODUCT_BUNDLE_IDENTIFIER = de.liquid.tallee; PRODUCT_BUNDLE_IDENTIFIER = com.example.gameTracker;
PRODUCT_NAME = "$(TARGET_NAME)"; PRODUCT_NAME = "$(TARGET_NAME)";
SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_OPTIMIZATION_LEVEL = "-Onone";
@@ -683,7 +684,7 @@
"$(inherited)", "$(inherited)",
"@executable_path/Frameworks", "@executable_path/Frameworks",
); );
PRODUCT_BUNDLE_IDENTIFIER = de.liquid.tallee; PRODUCT_BUNDLE_IDENTIFIER = com.example.gameTracker;
PRODUCT_NAME = "$(TARGET_NAME)"; PRODUCT_NAME = "$(TARGET_NAME)";
SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h";
SWIFT_VERSION = 5.0; SWIFT_VERSION = 5.0;

Binary file not shown.

Before

Width:  |  Height:  |  Size: 56 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.4 KiB

View File

@@ -1 +1,14 @@
{"images":[{"size":"60x60","expected-size":"180","filename":"180.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"40x40","expected-size":"80","filename":"80.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"40x40","expected-size":"120","filename":"120.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"60x60","expected-size":"120","filename":"120.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"57x57","expected-size":"57","filename":"57.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"1x"},{"size":"29x29","expected-size":"58","filename":"58.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"29x29","expected-size":"29","filename":"29.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"1x"},{"size":"29x29","expected-size":"87","filename":"87.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"57x57","expected-size":"114","filename":"114.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"20x20","expected-size":"40","filename":"40.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"20x20","expected-size":"60","filename":"60.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"1024x1024","filename":"1024.png","expected-size":"1024","idiom":"ios-marketing","folder":"Assets.xcassets/AppIcon.appiconset/","scale":"1x"}]} {
"images" : [
{
"filename" : "icon_x1024.png",
"idiom" : "universal",
"platform" : "ios",
"size" : "1024x1024"
}
],
"info" : {
"author" : "xcode",
"version" : 1
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.8 KiB

View File

@@ -5,9 +5,9 @@
"color-space" : "srgb", "color-space" : "srgb",
"components" : { "components" : {
"alpha" : "1.000", "alpha" : "1.000",
"blue" : "0.122", "blue" : "0.043",
"green" : "0.408", "green" : "0.043",
"red" : "0.937" "red" : "0.043"
} }
}, },
"idiom" : "universal" "idiom" : "universal"

View File

@@ -1,8 +1,17 @@
{ {
"images" : [ "images" : [
{ {
"filename" : "icon-transparent.png", "filename" : "icon.png",
"idiom" : "universal" "idiom" : "universal",
"scale" : "1x"
},
{
"idiom" : "universal",
"scale" : "2x"
},
{
"idiom" : "universal",
"scale" : "3x"
} }
], ],
"info" : { "info" : {

Binary file not shown.

Before

Width:  |  Height:  |  Size: 21 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.6 KiB

View File

@@ -1,9 +1,9 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="24506" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" colorMatched="YES" initialViewController="01J-lp-oVM"> <document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="24412" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" colorMatched="YES" initialViewController="01J-lp-oVM">
<device id="retina6_12" orientation="portrait" appearance="light"/> <device id="retina6_12" orientation="portrait" appearance="light"/>
<dependencies> <dependencies>
<deployment identifier="iOS"/> <deployment identifier="iOS"/>
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="24504"/> <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="24405"/>
<capability name="Named colors" minToolsVersion="9.0"/> <capability name="Named colors" minToolsVersion="9.0"/>
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/> <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
</dependencies> </dependencies>
@@ -20,19 +20,12 @@
<rect key="frame" x="0.0" y="0.0" width="393" height="852"/> <rect key="frame" x="0.0" y="0.0" width="393" height="852"/>
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/> <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
<subviews> <subviews>
<label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" fixedFrame="YES" text="Tallee" textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="m4u-iU-Cmv">
<rect key="frame" x="153" y="747" width="87" height="37"/>
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
<fontDescription key="fontDescription" name="Futura-Bold" family="Futura" pointSize="28"/>
<color key="textColor" white="1" alpha="1" colorSpace="custom" customColorSpace="genericGamma22GrayColorSpace"/>
<nil key="highlightedColor"/>
</label>
<imageView clipsSubviews="YES" userInteractionEnabled="NO" contentMode="scaleAspectFit" horizontalHuggingPriority="251" verticalHuggingPriority="251" fixedFrame="YES" image="LauncherIcon" translatesAutoresizingMaskIntoConstraints="NO" id="ygV-Op-Bu5"> <imageView clipsSubviews="YES" userInteractionEnabled="NO" contentMode="scaleAspectFit" horizontalHuggingPriority="251" verticalHuggingPriority="251" fixedFrame="YES" image="LauncherIcon" translatesAutoresizingMaskIntoConstraints="NO" id="ygV-Op-Bu5">
<rect key="frame" x="46" y="334" width="301" height="184"/> <rect key="frame" x="46" y="334" width="301" height="184"/>
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/> <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
</imageView> </imageView>
</subviews> </subviews>
<color key="backgroundColor" name="LauncherColor"/> <color key="backgroundColor" name="LauncherBackgroundColor"/>
</view> </view>
</viewController> </viewController>
<placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/> <placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/>
@@ -43,8 +36,8 @@
<color key="tintColor" red="0.90196078431372551" green="0.94509803921568625" blue="0.89411764705882346" alpha="1" colorSpace="custom" customColorSpace="sRGB"/> <color key="tintColor" red="0.90196078431372551" green="0.94509803921568625" blue="0.89411764705882346" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
<resources> <resources>
<image name="LauncherIcon" width="1000" height="1000"/> <image name="LauncherIcon" width="1000" height="1000"/>
<namedColor name="LauncherColor"> <namedColor name="LauncherBackgroundColor">
<color red="0.93699997663497925" green="0.40799999237060547" blue="0.12200000137090683" alpha="1" colorSpace="custom" customColorSpace="sRGB"/> <color red="0.90196078431372551" green="0.94509803921568625" blue="0.89411764705882346" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
</namedColor> </namedColor>
</resources> </resources>
</document> </document>

View File

@@ -2,12 +2,10 @@
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0"> <plist version="1.0">
<dict> <dict>
<key>CADisableMinimumFrameDurationOnPhone</key>
<true/>
<key>CFBundleDevelopmentRegion</key> <key>CFBundleDevelopmentRegion</key>
<string>$(DEVELOPMENT_LANGUAGE)</string> <string>$(DEVELOPMENT_LANGUAGE)</string>
<key>CFBundleDisplayName</key> <key>CFBundleDisplayName</key>
<string>Tallee</string> <string>Game Tracker</string>
<key>CFBundleExecutable</key> <key>CFBundleExecutable</key>
<string>$(EXECUTABLE_NAME)</string> <string>$(EXECUTABLE_NAME)</string>
<key>CFBundleIdentifier</key> <key>CFBundleIdentifier</key>
@@ -15,7 +13,7 @@
<key>CFBundleInfoDictionaryVersion</key> <key>CFBundleInfoDictionaryVersion</key>
<string>6.0</string> <string>6.0</string>
<key>CFBundleName</key> <key>CFBundleName</key>
<string>tallee</string> <string>game_tracker</string>
<key>CFBundlePackageType</key> <key>CFBundlePackageType</key>
<string>APPL</string> <string>APPL</string>
<key>CFBundleShortVersionString</key> <key>CFBundleShortVersionString</key>
@@ -24,15 +22,13 @@
<string>????</string> <string>????</string>
<key>CFBundleVersion</key> <key>CFBundleVersion</key>
<string>$(FLUTTER_BUILD_NUMBER)</string> <string>$(FLUTTER_BUILD_NUMBER)</string>
<key>LSApplicationQueriesSchemes</key>
<array>
<string>https</string>
<string>http</string>
</array>
<key>LSRequiresIPhoneOS</key> <key>LSRequiresIPhoneOS</key>
<true/> <true/>
<key>UIApplicationSupportsIndirectInputEvents</key> <key>LSApplicationQueriesSchemes</key>
<true/> <array>
<string>https</string>
<string>http</string>
</array>
<key>UILaunchStoryboardName</key> <key>UILaunchStoryboardName</key>
<string>LaunchScreen</string> <string>LaunchScreen</string>
<key>UIMainStoryboardFile</key> <key>UIMainStoryboardFile</key>
@@ -48,5 +44,9 @@
<string>UIInterfaceOrientationLandscapeLeft</string> <string>UIInterfaceOrientationLandscapeLeft</string>
<string>UIInterfaceOrientationLandscapeRight</string> <string>UIInterfaceOrientationLandscapeRight</string>
</array> </array>
<key>CADisableMinimumFrameDurationOnPhone</key>
<true/>
<key>UIApplicationSupportsIndirectInputEvents</key>
<true/>
</dict> </dict>
</plist> </plist>

View File

@@ -7,25 +7,25 @@ class CustomTheme {
// ==================== Colors ==================== // ==================== Colors ====================
/// Primary color of the app theme /// Primary color of the app theme
static const Color primaryColor = Color(0xFFef681f); static Color primaryColor = const Color(0xFF7505E4);
/// Secondary color of the app theme /// Secondary color of the app theme
static const Color secondaryColor = Color(0xFFf2a981); static Color secondaryColor = const Color(0xFFAFA2FF);
/// Background color of the app theme /// Background color of the app theme
static const backgroundColor = Color(0xFF0B0B0B); static Color backgroundColor = const Color(0xFF0B0B0B);
/// Default color for boxes and containers /// Default color for boxes and containers
static const Color boxColor = Color(0xFF101010); static Color boxColor = const Color(0xFF101010);
/// Default border color for boxes and containers /// Default border color for boxes and containers
static const Color boxBorder = Color(0xFF272727); static Color boxBorder = const Color(0xFF272727);
/// Color for boxes and containers displayed on boxes /// Color for boxes and containers displayed on boxes
static const Color onBoxColor = Color(0xFF181818); static Color onBoxColor = const Color(0xFF181818);
/// Text color used throughout the app /// Text color used throughout the app
static const Color textColor = Color(0xFFFFFFFF); static const Color textColor = Colors.white;
/// Selected color for the [NavbarItem] /// Selected color for the [NavbarItem]
static Color navBarItemSelectedColor = primaryColor.withGreen(100); static Color navBarItemSelectedColor = primaryColor.withGreen(100);
@@ -63,18 +63,18 @@ class CustomTheme {
); );
// ==================== App Bar Theme ==================== // ==================== App Bar Theme ====================
static const AppBarTheme appBarTheme = AppBarTheme( static AppBarTheme appBarTheme = AppBarTheme(
backgroundColor: backgroundColor, backgroundColor: backgroundColor,
foregroundColor: textColor, foregroundColor: textColor,
elevation: 0, elevation: 0,
scrolledUnderElevation: 0, scrolledUnderElevation: 0,
centerTitle: true, centerTitle: true,
titleTextStyle: TextStyle( titleTextStyle: const TextStyle(
color: textColor, color: textColor,
fontSize: 20, fontSize: 20,
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
overflow: TextOverflow.ellipsis, overflow: TextOverflow.ellipsis,
), ),
iconTheme: IconThemeData(color: textColor), iconTheme: const IconThemeData(color: textColor),
); );
} }

View File

@@ -1,5 +1,5 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:tallee/l10n/generated/app_localizations.dart'; import 'package:game_tracker/l10n/generated/app_localizations.dart';
/// Button types used for styling the [CustomWidthButton] /// Button types used for styling the [CustomWidthButton]
/// - [ButtonType.primary]: Primary button style. /// - [ButtonType.primary]: Primary button style.
@@ -29,38 +29,24 @@ enum ImportResult {
/// - [ExportResult.unknownException]: An exception occurred during export. /// - [ExportResult.unknownException]: An exception occurred during export.
enum ExportResult { success, canceled, unknownException } enum ExportResult { success, canceled, unknownException }
/// Different rulesets available for games /// Different rulesets available for matches
/// - [Ruleset.highestScore]: The player with the highest score wins. /// - [Ruleset.singleWinner]: The match is won by a single player
/// - [Ruleset.lowestScore]: The player with the lowest score wins. /// - [Ruleset.singleLoser]: The match is lost by a single player
/// - [Ruleset.singleWinner]: The match is won by a single player. /// - [Ruleset.mostPoints]: The player with the most points wins.
/// - [Ruleset.singleLoser]: The match has a single loser. /// - [Ruleset.leastPoints]: The player with the fewest points wins.
/// - [Ruleset.multipleWinners]: Multiple players can be winners. enum Ruleset { singleWinner, singleLoser, mostPoints, leastPoints }
enum Ruleset { highestScore, lowestScore, singleWinner, singleLoser, multipleWinners }
/// Different colors available for games
/// - [GameColor.red]: Red color
/// - [GameColor.blue]: Blue color
/// - [GameColor.green]: Green color
/// - [GameColor.yellow]: Yellow color
/// - [GameColor.purple]: Purple color
/// - [GameColor.orange]: Orange color
/// - [GameColor.pink]: Pink color
/// - [GameColor.teal]: Teal color
enum GameColor { red, blue, green, yellow, purple, orange, pink, teal }
/// Translates a [Ruleset] enum value to its corresponding localized string. /// Translates a [Ruleset] enum value to its corresponding localized string.
String translateRulesetToString(Ruleset ruleset, BuildContext context) { String translateRulesetToString(Ruleset ruleset, BuildContext context) {
final loc = AppLocalizations.of(context); final loc = AppLocalizations.of(context);
switch (ruleset) { switch (ruleset) {
case Ruleset.highestScore:
return loc.highest_score;
case Ruleset.lowestScore:
return loc.lowest_score;
case Ruleset.singleWinner: case Ruleset.singleWinner:
return loc.single_winner; return loc.single_winner;
case Ruleset.singleLoser: case Ruleset.singleLoser:
return loc.single_loser; return loc.single_loser;
case Ruleset.multipleWinners: case Ruleset.mostPoints:
return loc.multiple_winners; return loc.most_points;
case Ruleset.leastPoints:
return loc.least_points;
} }
} }

View File

@@ -1,166 +0,0 @@
import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/db/tables/game_table.dart';
import 'package:tallee/data/dto/game.dart';
import 'package:tallee/core/enums.dart';
part 'game_dao.g.dart';
@DriftAccessor(tables: [GameTable])
class GameDao extends DatabaseAccessor<AppDatabase> with _$GameDaoMixin {
GameDao(super.db);
/// Retrieves all games from the database.
Future<List<Game>> getAllGames() async {
final query = select(gameTable);
final result = await query.get();
return result
.map(
(row) => Game(
id: row.id,
name: row.name,
ruleset: Ruleset.values.firstWhere((e) => e.name == row.ruleset),
description: row.description,
color: GameColor.values.firstWhere((e) => e.name == row.color),
icon: row.icon,
createdAt: row.createdAt,
),
)
.toList();
}
/// Retrieves a [Game] by its [gameId].
Future<Game> getGameById({required String gameId}) async {
final query = select(gameTable)..where((g) => g.id.equals(gameId));
final result = await query.getSingle();
return Game(
id: result.id,
name: result.name,
ruleset: Ruleset.values.firstWhere((e) => e.name == result.ruleset),
description: result.description,
color: GameColor.values.firstWhere((e) => e.name == result.color),
icon: result.icon,
createdAt: result.createdAt,
);
}
/// Adds a new [game] to the database.
/// If a game with the same ID already exists, no action is taken.
/// Returns `true` if the game was added, `false` otherwise.
Future<bool> addGame({required Game game}) async {
if (!await gameExists(gameId: game.id)) {
await into(gameTable).insert(
GameTableCompanion.insert(
id: game.id,
name: game.name,
ruleset: game.ruleset.name,
description: game.description,
color: game.color.name,
icon: game.icon,
createdAt: game.createdAt,
),
mode: InsertMode.insertOrReplace,
);
return true;
}
return false;
}
/// Adds multiple [games] to the database in a batch operation.
/// Uses insertOrIgnore to avoid overwriting existing games.
Future<bool> addGamesAsList({required List<Game> games}) async {
if (games.isEmpty) return false;
await db.batch(
(b) => b.insertAll(
gameTable,
games
.map(
(game) => GameTableCompanion.insert(
id: game.id,
name: game.name,
ruleset: game.ruleset.name,
description: game.description,
color: game.color.name,
icon: game.icon,
createdAt: game.createdAt,
),
)
.toList(),
mode: InsertMode.insertOrIgnore,
),
);
return true;
}
/// Deletes the game with the given [gameId] from the database.
/// Returns `true` if the game was deleted, `false` if the game did not exist.
Future<bool> deleteGame({required String gameId}) async {
final query = delete(gameTable)..where((g) => g.id.equals(gameId));
final rowsAffected = await query.go();
return rowsAffected > 0;
}
/// Checks if a game with the given [gameId] exists in the database.
/// Returns `true` if the game exists, `false` otherwise.
Future<bool> gameExists({required String gameId}) async {
final query = select(gameTable)..where((g) => g.id.equals(gameId));
final result = await query.getSingleOrNull();
return result != null;
}
/// Updates the name of the game with the given [gameId] to [newName].
Future<void> updateGameName({required String gameId, required String newName}) async {
await (update(
gameTable,
)..where((g) => g.id.equals(gameId))).write(GameTableCompanion(name: Value(newName)));
}
/// Updates the ruleset of the game with the given [gameId].
Future<void> updateGameRuleset({required String gameId, required Ruleset newRuleset}) async {
await (update(gameTable)..where((g) => g.id.equals(gameId))).write(
GameTableCompanion(ruleset: Value(newRuleset.name)),
);
}
/// Updates the description of the game with the given [gameId].
Future<void> updateGameDescription({
required String gameId,
required String newDescription,
}) async {
await (update(gameTable)..where((g) => g.id.equals(gameId))).write(
GameTableCompanion(description: Value(newDescription)),
);
}
/// Updates the color of the game with the given [gameId].
Future<void> updateGameColor({required String gameId, required GameColor newColor}) async {
await (update(
gameTable,
)..where((g) => g.id.equals(gameId))).write(GameTableCompanion(color: Value(newColor.name)));
}
/// Updates the icon of the game with the given [gameId].
Future<void> updateGameIcon({required String gameId, required String newIcon}) async {
await (update(
gameTable,
)..where((g) => g.id.equals(gameId))).write(GameTableCompanion(icon: Value(newIcon)));
}
/// Retrieves the total count of games in the database.
Future<int> getGameCount() async {
final count = await (selectOnly(
gameTable,
)..addColumns([gameTable.id.count()])).map((row) => row.read(gameTable.id.count())).getSingle();
return count ?? 0;
}
/// Deletes all games from the database.
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> deleteAllGames() async {
final query = delete(gameTable);
final rowsAffected = await query.go();
return rowsAffected > 0;
}
}

View File

@@ -1,8 +0,0 @@
// GENERATED CODE - DO NOT MODIFY BY HAND
part of 'game_dao.dart';
// ignore_for_file: type=lint
mixin _$GameDaoMixin on DatabaseAccessor<AppDatabase> {
$GameTableTable get gameTable => attachedDatabase.gameTable;
}

View File

@@ -1,9 +1,9 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart'; import 'package:game_tracker/data/db/database.dart';
import 'package:tallee/data/db/tables/group_table.dart'; import 'package:game_tracker/data/db/tables/group_table.dart';
import 'package:tallee/data/db/tables/player_group_table.dart'; import 'package:game_tracker/data/db/tables/player_group_table.dart';
import 'package:tallee/data/dto/group.dart'; import 'package:game_tracker/data/dto/group.dart';
import 'package:tallee/data/dto/player.dart'; import 'package:game_tracker/data/dto/player.dart';
part 'group_dao.g.dart'; part 'group_dao.g.dart';
@@ -23,7 +23,6 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
return Group( return Group(
id: groupData.id, id: groupData.id,
name: groupData.name, name: groupData.name,
description: groupData.description,
members: members, members: members,
createdAt: groupData.createdAt, createdAt: groupData.createdAt,
); );
@@ -43,7 +42,6 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
return Group( return Group(
id: result.id, id: result.id,
name: result.name, name: result.name,
description: result.description,
members: members, members: members,
createdAt: result.createdAt, createdAt: result.createdAt,
); );
@@ -58,7 +56,6 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
GroupTableCompanion.insert( GroupTableCompanion.insert(
id: group.id, id: group.id,
name: group.name, name: group.name,
description: group.description,
createdAt: group.createdAt, createdAt: group.createdAt,
), ),
mode: InsertMode.insertOrReplace, mode: InsertMode.insertOrReplace,
@@ -108,7 +105,6 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
(group) => GroupTableCompanion.insert( (group) => GroupTableCompanion.insert(
id: group.id, id: group.id,
name: group.name, name: group.name,
description: group.description,
createdAt: group.createdAt, createdAt: group.createdAt,
), ),
) )
@@ -136,7 +132,6 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
(p) => PlayerTableCompanion.insert( (p) => PlayerTableCompanion.insert(
id: p.id, id: p.id,
name: p.name, name: p.name,
description: p.description,
createdAt: p.createdAt, createdAt: p.createdAt,
), ),
) )
@@ -181,7 +176,7 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
/// Updates the name of the group with the given [id] to [newName]. /// Updates the name of the group with the given [id] to [newName].
/// Returns `true` if more than 0 rows were affected, otherwise `false`. /// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateGroupName({ Future<bool> updateGroupname({
required String groupId, required String groupId,
required String newName, required String newName,
}) async { }) async {
@@ -192,21 +187,6 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
return rowsAffected > 0; return rowsAffected > 0;
} }
/// Updates the description of the group with the given [groupId] to [newDescription].
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateGroupDescription({
required String groupId,
required String newDescription,
}) async {
final rowsAffected =
await (update(groupTable)..where((g) => g.id.equals(groupId))).write(
GroupTableCompanion(description: Value(newDescription)),
);
return rowsAffected > 0;
}
/// Retrieves the number of groups in the database. /// Retrieves the number of groups in the database.
Future<int> getGroupCount() async { Future<int> getGroupCount() async {
final count = final count =
@@ -231,44 +211,4 @@ class GroupDao extends DatabaseAccessor<AppDatabase> with _$GroupDaoMixin {
final rowsAffected = await query.go(); final rowsAffected = await query.go();
return rowsAffected > 0; return rowsAffected > 0;
} }
/// Replaces all players in a group with the provided list of players.
/// Removes all existing players from the group and adds the new players.
/// Also adds any new players to the player table if they don't exist.
Future<void> replaceGroupPlayers({
required String groupId,
required List<Player> newPlayers,
}) async {
await db.transaction(() async {
// Remove all existing players from the group
final deleteQuery = delete(db.playerGroupTable)
..where((p) => p.groupId.equals(groupId));
await deleteQuery.go();
// Add new players to the player table if they don't exist
await Future.wait(
newPlayers.map((player) async {
if (!await db.playerDao.playerExists(playerId: player.id)) {
await db.playerDao.addPlayer(player: player);
}
}),
);
// Add the new players to the group
await db.batch(
(b) => b.insertAll(
db.playerGroupTable,
newPlayers
.map(
(player) => PlayerGroupTableCompanion.insert(
playerId: player.id,
groupId: groupId,
),
)
.toList(),
mode: InsertMode.insertOrReplace,
),
);
});
}
} }

View File

@@ -0,0 +1,98 @@
import 'package:drift/drift.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/db/tables/group_match_table.dart';
import 'package:game_tracker/data/dto/group.dart';
part 'group_match_dao.g.dart';
@DriftAccessor(tables: [GroupMatchTable])
class GroupMatchDao extends DatabaseAccessor<AppDatabase>
with _$GroupMatchDaoMixin {
GroupMatchDao(super.db);
/// Associates a group with a match by inserting a record into the
/// [GroupMatchTable].
Future<void> addGroupToMatch({
required String matchId,
required String groupId,
}) async {
if (await matchHasGroup(matchId: matchId)) {
throw Exception('Match already has a group');
}
await into(groupMatchTable).insert(
GroupMatchTableCompanion.insert(groupId: groupId, matchId: matchId),
mode: InsertMode.insertOrIgnore,
);
}
/// Retrieves the [Group] associated with the given [matchId].
/// Returns `null` if no group is found.
Future<Group?> getGroupOfMatch({required String matchId}) async {
final result = await (select(
groupMatchTable,
)..where((g) => g.matchId.equals(matchId))).getSingleOrNull();
if (result == null) {
return null;
}
final group = await db.groupDao.getGroupById(groupId: result.groupId);
return group;
}
/// Checks if there is a group associated with the given [matchId].
/// Returns `true` if there is a group, otherwise `false`.
Future<bool> matchHasGroup({required String matchId}) async {
final count =
await (selectOnly(groupMatchTable)
..where(groupMatchTable.matchId.equals(matchId))
..addColumns([groupMatchTable.groupId.count()]))
.map((row) => row.read(groupMatchTable.groupId.count()))
.getSingle();
return (count ?? 0) > 0;
}
/// Checks if a specific group is associated with a specific match.
/// Returns `true` if the group is in the match, otherwise `false`.
Future<bool> isGroupInMatch({
required String matchId,
required String groupId,
}) async {
final count =
await (selectOnly(groupMatchTable)
..where(
groupMatchTable.matchId.equals(matchId) &
groupMatchTable.groupId.equals(groupId),
)
..addColumns([groupMatchTable.groupId.count()]))
.map((row) => row.read(groupMatchTable.groupId.count()))
.getSingle();
return (count ?? 0) > 0;
}
/// Removes the association of a group from a match based on [groupId] and
/// [matchId].
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> removeGroupFromMatch({
required String matchId,
required String groupId,
}) async {
final query = delete(groupMatchTable)
..where((g) => g.matchId.equals(matchId) & g.groupId.equals(groupId));
final rowsAffected = await query.go();
return rowsAffected > 0;
}
/// Updates the group associated with a match to [newGroupId] based on
/// [matchId].
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateGroupOfMatch({
required String matchId,
required String newGroupId,
}) async {
final updatedRows =
await (update(groupMatchTable)..where((g) => g.matchId.equals(matchId)))
.write(GroupMatchTableCompanion(groupId: Value(newGroupId)));
return updatedRows > 0;
}
}

View File

@@ -0,0 +1,10 @@
// GENERATED CODE - DO NOT MODIFY BY HAND
part of 'group_match_dao.dart';
// ignore_for_file: type=lint
mixin _$GroupMatchDaoMixin on DatabaseAccessor<AppDatabase> {
$GroupTableTable get groupTable => attachedDatabase.groupTable;
$MatchTableTable get matchTable => attachedDatabase.matchTable;
$GroupMatchTableTable get groupMatchTable => attachedDatabase.groupMatchTable;
}

View File

@@ -1,17 +1,13 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart'; import 'package:game_tracker/data/db/database.dart';
import 'package:tallee/data/db/tables/game_table.dart'; import 'package:game_tracker/data/db/tables/match_table.dart';
import 'package:tallee/data/db/tables/group_table.dart'; import 'package:game_tracker/data/dto/group.dart';
import 'package:tallee/data/db/tables/match_table.dart'; import 'package:game_tracker/data/dto/match.dart';
import 'package:tallee/data/db/tables/player_match_table.dart'; import 'package:game_tracker/data/dto/player.dart';
import 'package:tallee/data/dto/game.dart';
import 'package:tallee/data/dto/group.dart';
import 'package:tallee/data/dto/match.dart';
import 'package:tallee/data/dto/player.dart';
part 'match_dao.g.dart'; part 'match_dao.g.dart';
@DriftAccessor(tables: [MatchTable, GameTable, GroupTable, PlayerMatchTable]) @DriftAccessor(tables: [MatchTable])
class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin { class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
MatchDao(super.db); MatchDao(super.db);
@@ -22,23 +18,20 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
return Future.wait( return Future.wait(
result.map((row) async { result.map((row) async {
final game = await db.gameDao.getGameById(gameId: row.gameId); final group = await db.groupMatchDao.getGroupOfMatch(matchId: row.id);
Group? group;
if (row.groupId != null) {
group = await db.groupDao.getGroupById(groupId: row.groupId!);
}
final players = await db.playerMatchDao.getPlayersOfMatch( final players = await db.playerMatchDao.getPlayersOfMatch(
matchId: row.id, matchId: row.id,
) ?? []; );
final winner = row.winnerId != null
? await db.playerDao.getPlayerById(playerId: row.winnerId!)
: null;
return Match( return Match(
id: row.id, id: row.id,
name: row.name ?? '', name: row.name,
game: game,
group: group, group: group,
players: players, players: players,
notes: row.notes ?? '',
createdAt: row.createdAt, createdAt: row.createdAt,
endedAt: row.endedAt, winner: winner,
); );
}), }),
); );
@@ -49,134 +42,114 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
final query = select(matchTable)..where((g) => g.id.equals(matchId)); final query = select(matchTable)..where((g) => g.id.equals(matchId));
final result = await query.getSingle(); final result = await query.getSingle();
final game = await db.gameDao.getGameById(gameId: result.gameId); List<Player>? players;
if (await db.playerMatchDao.matchHasPlayers(matchId: matchId)) {
Group? group; players = await db.playerMatchDao.getPlayersOfMatch(matchId: matchId);
if (result.groupId != null) { }
group = await db.groupDao.getGroupById(groupId: result.groupId!); Group? group;
if (await db.groupMatchDao.matchHasGroup(matchId: matchId)) {
group = await db.groupMatchDao.getGroupOfMatch(matchId: matchId);
}
Player? winner;
if (result.winnerId != null) {
winner = await db.playerDao.getPlayerById(playerId: result.winnerId!);
} }
final players = await db.playerMatchDao.getPlayersOfMatch(matchId: matchId) ?? [];
return Match( return Match(
id: result.id, id: result.id,
name: result.name ?? '', name: result.name,
game: game,
group: group,
players: players, players: players,
notes: result.notes ?? '', group: group,
winner: winner,
createdAt: result.createdAt, createdAt: result.createdAt,
endedAt: result.endedAt,
); );
} }
/// Adds a new [Match] to the database. Also adds players associations. /// Adds a new [Match] to the database. Also adds players and group
/// This method assumes that the game and group (if any) are already present /// associations. This method assumes that the players and groups added to
/// in the database. /// this match are already present in the database.
Future<void> addMatch({required Match match}) async { Future<void> addMatch({required Match match}) async {
await db.transaction(() async { await db.transaction(() async {
await into(matchTable).insert( await into(matchTable).insert(
MatchTableCompanion.insert( MatchTableCompanion.insert(
id: match.id, id: match.id,
gameId: match.game.id, name: match.name,
groupId: Value(match.group?.id), winnerId: Value(match.winner?.id),
name: Value(match.name),
notes: Value(match.notes),
createdAt: match.createdAt, createdAt: match.createdAt,
endedAt: Value(match.endedAt),
), ),
mode: InsertMode.insertOrReplace, mode: InsertMode.insertOrReplace,
); );
for (final p in match.players) { if (match.players != null) {
await db.playerMatchDao.addPlayerToMatch( for (final p in match.players ?? []) {
await db.playerMatchDao.addPlayerToMatch(
matchId: match.id,
playerId: p.id,
);
}
}
if (match.group != null) {
await db.groupMatchDao.addGroupToMatch(
matchId: match.id, matchId: match.id,
playerId: p.id, groupId: match.group!.id,
); );
} }
}); });
} }
/// Adds multiple [Match]es to the database in a batch operation. /// Adds multiple [Match]s to the database in a batch operation.
/// Also adds associated players and groups if they exist. /// Also adds associated players and groups if they exist.
/// If the [matches] list is empty, the method returns immediately. /// If the [matches] list is empty, the method returns immediately.
/// This method should only be used to import matches from a different device. /// This Method should only be used to import matches from a different device.
Future<void> addMatchAsList({required List<Match> matches}) async { Future<void> addMatchAsList({required List<Match> matches}) async {
if (matches.isEmpty) return; if (matches.isEmpty) return;
await db.transaction(() async { await db.transaction(() async {
// Add all games first (deduplicated)
final uniqueGames = <String, Game>{};
for (final match in matches) {
uniqueGames[match.game.id] = match.game;
}
if (uniqueGames.isNotEmpty) {
await db.batch(
(b) => b.insertAll(
db.gameTable,
uniqueGames.values
.map(
(game) => GameTableCompanion.insert(
id: game.id,
name: game.name,
ruleset: game.ruleset.name,
description: game.description,
color: game.color.name,
icon: game.icon,
createdAt: game.createdAt,
),
)
.toList(),
mode: InsertMode.insertOrIgnore,
),
);
}
// Add all groups of the matches in batch
await db.batch(
(b) => b.insertAll(
db.groupTable,
matches
.where((match) => match.group != null)
.map(
(match) => GroupTableCompanion.insert(
id: match.group!.id,
name: match.group!.name,
description: match.group!.description,
createdAt: match.group!.createdAt,
),
)
.toList(),
mode: InsertMode.insertOrIgnore,
),
);
// Add all matches in batch // Add all matches in batch
await db.batch( await db.batch(
(b) => b.insertAll( (b) => b.insertAll(
matchTable, matchTable,
matches matches
.map( .map(
(match) => MatchTableCompanion.insert( (match) => MatchTableCompanion.insert(
id: match.id, id: match.id,
gameId: match.game.id, name: match.name,
groupId: Value(match.group?.id), createdAt: match.createdAt,
name: Value(match.name), winnerId: Value(match.winner?.id),
notes: Value(match.notes), ),
createdAt: match.createdAt, )
endedAt: Value(match.endedAt),
),
)
.toList(), .toList(),
mode: InsertMode.insertOrReplace, mode: InsertMode.insertOrReplace,
), ),
); );
// Add all groups of the matches in batch
// Using insertOrIgnore to avoid overwriting existing groups (which would
// trigger cascade deletes on player_group associations)
await db.batch(
(b) => b.insertAll(
db.groupTable,
matches
.where((match) => match.group != null)
.map(
(matches) => GroupTableCompanion.insert(
id: matches.group!.id,
name: matches.group!.name,
createdAt: matches.group!.createdAt,
),
)
.toList(),
mode: InsertMode.insertOrIgnore,
),
);
// Add all players of the matches in batch (unique) // Add all players of the matches in batch (unique)
final uniquePlayers = <String, Player>{}; final uniquePlayers = <String, Player>{};
for (final match in matches) { for (final match in matches) {
for (final p in match.players) { if (match.players != null) {
uniquePlayers[p.id] = p; for (final p in match.players!) {
uniquePlayers[p.id] = p;
}
} }
// Also include members of groups // Also include members of groups
if (match.group != null) { if (match.group != null) {
@@ -187,18 +160,19 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
} }
if (uniquePlayers.isNotEmpty) { if (uniquePlayers.isNotEmpty) {
// Using insertOrIgnore to avoid triggering cascade deletes on
// player_group/player_match associations when players already exist
await db.batch( await db.batch(
(b) => b.insertAll( (b) => b.insertAll(
db.playerTable, db.playerTable,
uniquePlayers.values uniquePlayers.values
.map( .map(
(p) => PlayerTableCompanion.insert( (p) => PlayerTableCompanion.insert(
id: p.id, id: p.id,
name: p.name, name: p.name,
description: p.description, createdAt: p.createdAt,
createdAt: p.createdAt, ),
), )
)
.toList(), .toList(),
mode: InsertMode.insertOrIgnore, mode: InsertMode.insertOrIgnore,
), ),
@@ -208,16 +182,17 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
// Add all player-match associations in batch // Add all player-match associations in batch
await db.batch((b) { await db.batch((b) {
for (final match in matches) { for (final match in matches) {
for (final p in match.players) { if (match.players != null) {
b.insert( for (final p in match.players ?? []) {
db.playerMatchTable, b.insert(
PlayerMatchTableCompanion.insert( db.playerMatchTable,
matchId: match.id, PlayerMatchTableCompanion.insert(
playerId: p.id, matchId: match.id,
score: 0, playerId: p.id,
), ),
mode: InsertMode.insertOrIgnore, mode: InsertMode.insertOrIgnore,
); );
}
} }
} }
}); });
@@ -239,6 +214,22 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
} }
} }
}); });
// Add all group-match associations in batch
await db.batch((b) {
for (final match in matches) {
if (match.group != null) {
b.insert(
db.groupMatchTable,
GroupMatchTableCompanion.insert(
matchId: match.id,
groupId: match.group!.id,
),
mode: InsertMode.insertOrIgnore,
);
}
}
});
}); });
} }
@@ -253,9 +244,9 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
/// Retrieves the number of matches in the database. /// Retrieves the number of matches in the database.
Future<int> getMatchCount() async { Future<int> getMatchCount() async {
final count = final count =
await (selectOnly(matchTable)..addColumns([matchTable.id.count()])) await (selectOnly(matchTable)..addColumns([matchTable.id.count()]))
.map((row) => row.read(matchTable.id.count())) .map((row) => row.read(matchTable.id.count()))
.getSingle(); .getSingle();
return count ?? 0; return count ?? 0;
} }
@@ -275,20 +266,52 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
return rowsAffected > 0; return rowsAffected > 0;
} }
/// Updates the notes of the match with the given [matchId]. /// Sets the winner of the match with the given [matchId] to the player with
/// the given [winnerId].
/// Returns `true` if more than 0 rows were affected, otherwise `false`. /// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateMatchNotes({ Future<bool> setWinner({
required String matchId, required String matchId,
required String? notes, required String winnerId,
}) async { }) async {
final query = update(matchTable)..where((g) => g.id.equals(matchId)); final query = update(matchTable)..where((g) => g.id.equals(matchId));
final rowsAffected = await query.write( final rowsAffected = await query.write(
MatchTableCompanion(notes: Value(notes)), MatchTableCompanion(winnerId: Value(winnerId)),
); );
return rowsAffected > 0; return rowsAffected > 0;
} }
/// Changes the name of the match with the given [matchId] to [newName]. /// Retrieves the winner of the match with the given [matchId].
/// Returns the [Player] who won the match, or `null` if no winner is set.
Future<Player?> getWinner({required String matchId}) async {
final query = select(matchTable)..where((g) => g.id.equals(matchId));
final result = await query.getSingleOrNull();
if (result == null || result.winnerId == null) {
return null;
}
final winner = await db.playerDao.getPlayerById(playerId: result.winnerId!);
return winner;
}
/// Removes the winner of the match with the given [matchId].
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> removeWinner({required String matchId}) async {
final query = update(matchTable)..where((g) => g.id.equals(matchId));
final rowsAffected = await query.write(
const MatchTableCompanion(winnerId: Value(null)),
);
return rowsAffected > 0;
}
/// Checks if the match with the given [matchId] has a winner set.
/// Returns `true` if a winner is set, otherwise `false`.
Future<bool> hasWinner({required String matchId}) async {
final query = select(matchTable)
..where((g) => g.id.equals(matchId) & g.winnerId.isNotNull());
final result = await query.getSingleOrNull();
return result != null;
}
/// Changes the title of the match with the given [matchId] to [newName].
/// Returns `true` if more than 0 rows were affected, otherwise `false`. /// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateMatchName({ Future<bool> updateMatchName({
required String matchId, required String matchId,
@@ -300,174 +323,4 @@ class MatchDao extends DatabaseAccessor<AppDatabase> with _$MatchDaoMixin {
); );
return rowsAffected > 0; return rowsAffected > 0;
} }
}
/// Updates the game of the match with the given [matchId].
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateMatchGame({
required String matchId,
required String gameId,
}) async {
final query = update(matchTable)..where((g) => g.id.equals(matchId));
final rowsAffected = await query.write(
MatchTableCompanion(gameId: Value(gameId)),
);
return rowsAffected > 0;
}
/// Updates the group of the match with the given [matchId].
/// Pass null to remove the group association.
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateMatchGroup({
required String matchId,
required String? groupId,
}) async {
final query = update(matchTable)..where((g) => g.id.equals(matchId));
final rowsAffected = await query.write(
MatchTableCompanion(groupId: Value(groupId)),
);
return rowsAffected > 0;
}
/// Updates the createdAt timestamp of the match with the given [matchId].
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateMatchCreatedAt({
required String matchId,
required DateTime createdAt,
}) async {
final query = update(matchTable)..where((g) => g.id.equals(matchId));
final rowsAffected = await query.write(
MatchTableCompanion(createdAt: Value(createdAt)),
);
return rowsAffected > 0;
}
/// Updates the endedAt timestamp of the match with the given [matchId].
/// Pass null to remove the ended time (mark match as ongoing).
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> updateMatchEndedAt({
required String matchId,
required DateTime? endedAt,
}) async {
final query = update(matchTable)..where((g) => g.id.equals(matchId));
final rowsAffected = await query.write(
MatchTableCompanion(endedAt: Value(endedAt)),
);
return rowsAffected > 0;
}
/// Replaces all players in a match with the provided list of players.
/// Removes all existing players from the match and adds the new players.
/// Also adds any new players to the player table if they don't exist.
Future<void> replaceMatchPlayers({
required String matchId,
required List<Player> newPlayers,
}) async {
await db.transaction(() async {
// Remove all existing players from the match
final deleteQuery = delete(db.playerMatchTable)
..where((p) => p.matchId.equals(matchId));
await deleteQuery.go();
// Add new players to the player table if they don't exist
await Future.wait(
newPlayers.map((player) async {
if (!await db.playerDao.playerExists(playerId: player.id)) {
await db.playerDao.addPlayer(player: player);
}
}),
);
// Add the new players to the match
await Future.wait(
newPlayers.map((player) => db.playerMatchDao.addPlayerToMatch(
matchId: matchId,
playerId: player.id,
)),
);
});
}
// ============================================================
// Winner methods - handle winner logic via player scores
// ============================================================
/// Checks if a match has a winner.
/// Returns true if any player in the match has their score set to 1.
Future<bool> hasWinner({required String matchId}) async {
final players = await db.playerMatchDao.getPlayersOfMatch(matchId: matchId) ?? [];
for (final player in players) {
final score = await db.playerMatchDao.getPlayerScore(
matchId: matchId,
playerId: player.id,
);
if (score == 1) {
return true;
}
}
return false;
}
/// Gets the winner of a match.
/// Returns the player with score 1, or null if no winner is set.
Future<Player?> getWinner({required String matchId}) async {
final players = await db.playerMatchDao.getPlayersOfMatch(matchId: matchId) ?? [];
for (final player in players) {
final score = await db.playerMatchDao.getPlayerScore(
matchId: matchId,
playerId: player.id,
);
if (score == 1) {
return player;
}
}
return null;
}
/// Sets the winner of a match.
/// Sets all players' scores to 0, then sets the specified player's score to 1.
/// Returns `true` if the operation was successful, otherwise `false`.
Future<bool> setWinner({
required String matchId,
required String winnerId,
}) async {
await db.transaction(() async {
final players = await db.playerMatchDao.getPlayersOfMatch(matchId: matchId) ?? [];
// Set all players' scores to 0
for (final player in players) {
await db.playerMatchDao.updatePlayerScore(
matchId: matchId,
playerId: player.id,
newScore: 0,
);
}
// Set the winner's score to 1
await db.playerMatchDao.updatePlayerScore(
matchId: matchId,
playerId: winnerId,
newScore: 1,
);
});
return true;
}
/// Removes the winner of a match.
/// Sets the current winner's score to 0 (no winner).
/// Returns `true` if a winner was removed, otherwise `false`.
Future<bool> removeWinner({required String matchId}) async {
final winner = await getWinner(matchId: matchId);
if (winner == null) {
return false;
}
final success = await db.playerMatchDao.updatePlayerScore(
matchId: matchId,
playerId: winner.id,
newScore: 0,
);
return success;
}
}

View File

@@ -4,11 +4,5 @@ part of 'match_dao.dart';
// ignore_for_file: type=lint // ignore_for_file: type=lint
mixin _$MatchDaoMixin on DatabaseAccessor<AppDatabase> { mixin _$MatchDaoMixin on DatabaseAccessor<AppDatabase> {
$GameTableTable get gameTable => attachedDatabase.gameTable;
$GroupTableTable get groupTable => attachedDatabase.groupTable;
$MatchTableTable get matchTable => attachedDatabase.matchTable; $MatchTableTable get matchTable => attachedDatabase.matchTable;
$PlayerTableTable get playerTable => attachedDatabase.playerTable;
$TeamTableTable get teamTable => attachedDatabase.teamTable;
$PlayerMatchTableTable get playerMatchTable =>
attachedDatabase.playerMatchTable;
} }

View File

@@ -1,7 +1,7 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart'; import 'package:game_tracker/data/db/database.dart';
import 'package:tallee/data/db/tables/player_table.dart'; import 'package:game_tracker/data/db/tables/player_table.dart';
import 'package:tallee/data/dto/player.dart'; import 'package:game_tracker/data/dto/player.dart';
part 'player_dao.g.dart'; part 'player_dao.g.dart';
@@ -15,12 +15,7 @@ class PlayerDao extends DatabaseAccessor<AppDatabase> with _$PlayerDaoMixin {
final result = await query.get(); final result = await query.get();
return result return result
.map( .map(
(row) => Player( (row) => Player(id: row.id, name: row.name, createdAt: row.createdAt),
id: row.id,
name: row.name,
description: row.description,
createdAt: row.createdAt,
),
) )
.toList(); .toList();
} }
@@ -32,7 +27,6 @@ class PlayerDao extends DatabaseAccessor<AppDatabase> with _$PlayerDaoMixin {
return Player( return Player(
id: result.id, id: result.id,
name: result.name, name: result.name,
description: result.description,
createdAt: result.createdAt, createdAt: result.createdAt,
); );
} }
@@ -46,7 +40,6 @@ class PlayerDao extends DatabaseAccessor<AppDatabase> with _$PlayerDaoMixin {
PlayerTableCompanion.insert( PlayerTableCompanion.insert(
id: player.id, id: player.id,
name: player.name, name: player.name,
description: player.description,
createdAt: player.createdAt, createdAt: player.createdAt,
), ),
mode: InsertMode.insertOrReplace, mode: InsertMode.insertOrReplace,
@@ -70,7 +63,6 @@ class PlayerDao extends DatabaseAccessor<AppDatabase> with _$PlayerDaoMixin {
(player) => PlayerTableCompanion.insert( (player) => PlayerTableCompanion.insert(
id: player.id, id: player.id,
name: player.name, name: player.name,
description: player.description,
createdAt: player.createdAt, createdAt: player.createdAt,
), ),
) )
@@ -99,7 +91,7 @@ class PlayerDao extends DatabaseAccessor<AppDatabase> with _$PlayerDaoMixin {
} }
/// Updates the name of the player with the given [playerId] to [newName]. /// Updates the name of the player with the given [playerId] to [newName].
Future<void> updatePlayerName({ Future<void> updatePlayername({
required String playerId, required String playerId,
required String newName, required String newName,
}) async { }) async {

View File

@@ -1,8 +1,8 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart'; import 'package:game_tracker/data/db/database.dart';
import 'package:tallee/data/db/tables/player_group_table.dart'; import 'package:game_tracker/data/db/tables/player_group_table.dart';
import 'package:tallee/data/db/tables/player_table.dart'; import 'package:game_tracker/data/db/tables/player_table.dart';
import 'package:tallee/data/dto/player.dart'; import 'package:game_tracker/data/dto/player.dart';
part 'player_group_dao.g.dart'; part 'player_group_dao.g.dart';
@@ -27,7 +27,7 @@ class PlayerGroupDao extends DatabaseAccessor<AppDatabase>
} }
if (!await db.playerDao.playerExists(playerId: player.id)) { if (!await db.playerDao.playerExists(playerId: player.id)) {
await db.playerDao.addPlayer(player: player); db.playerDao.addPlayer(player: player);
} }
await into(playerGroupTable).insert( await into(playerGroupTable).insert(

View File

@@ -1,31 +1,23 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart'; import 'package:game_tracker/data/db/database.dart';
import 'package:tallee/data/db/tables/player_match_table.dart'; import 'package:game_tracker/data/db/tables/player_match_table.dart';
import 'package:tallee/data/db/tables/team_table.dart'; import 'package:game_tracker/data/dto/player.dart';
import 'package:tallee/data/dto/player.dart';
part 'player_match_dao.g.dart'; part 'player_match_dao.g.dart';
@DriftAccessor(tables: [PlayerMatchTable, TeamTable]) @DriftAccessor(tables: [PlayerMatchTable])
class PlayerMatchDao extends DatabaseAccessor<AppDatabase> class PlayerMatchDao extends DatabaseAccessor<AppDatabase>
with _$PlayerMatchDaoMixin { with _$PlayerMatchDaoMixin {
PlayerMatchDao(super.db); PlayerMatchDao(super.db);
/// Associates a player with a match by inserting a record into the /// Associates a player with a match by inserting a record into the
/// [PlayerMatchTable]. Optionally associates with a team and sets initial score. /// [PlayerMatchTable].
Future<void> addPlayerToMatch({ Future<void> addPlayerToMatch({
required String matchId, required String matchId,
required String playerId, required String playerId,
String? teamId,
int score = 0,
}) async { }) async {
await into(playerMatchTable).insert( await into(playerMatchTable).insert(
PlayerMatchTableCompanion.insert( PlayerMatchTableCompanion.insert(playerId: playerId, matchId: matchId),
playerId: playerId,
matchId: matchId,
teamId: Value(teamId),
score: score,
),
mode: InsertMode.insertOrIgnore, mode: InsertMode.insertOrIgnore,
); );
} }
@@ -40,65 +32,21 @@ class PlayerMatchDao extends DatabaseAccessor<AppDatabase>
if (result.isEmpty) return null; if (result.isEmpty) return null;
final futures = result.map( final futures = result.map(
(row) => db.playerDao.getPlayerById(playerId: row.playerId), (row) => db.playerDao.getPlayerById(playerId: row.playerId),
); );
final players = await Future.wait(futures); final players = await Future.wait(futures);
return players; return players;
} }
/// Retrieves a player's score for a specific match.
/// Returns null if the player is not in the match.
Future<int?> getPlayerScore({
required String matchId,
required String playerId,
}) async {
final result = await (select(playerMatchTable)
..where(
(p) => p.matchId.equals(matchId) & p.playerId.equals(playerId),
))
.getSingleOrNull();
return result?.score;
}
/// Updates the score for a player in a match.
/// Returns `true` if the update was successful, otherwise `false`.
Future<bool> updatePlayerScore({
required String matchId,
required String playerId,
required int newScore,
}) async {
final rowsAffected = await (update(playerMatchTable)
..where(
(p) => p.matchId.equals(matchId) & p.playerId.equals(playerId),
))
.write(PlayerMatchTableCompanion(score: Value(newScore)));
return rowsAffected > 0;
}
/// Updates the team for a player in a match.
/// Returns `true` if the update was successful, otherwise `false`.
Future<bool> updatePlayerTeam({
required String matchId,
required String playerId,
required String? teamId,
}) async {
final rowsAffected = await (update(playerMatchTable)
..where(
(p) => p.matchId.equals(matchId) & p.playerId.equals(playerId),
))
.write(PlayerMatchTableCompanion(teamId: Value(teamId)));
return rowsAffected > 0;
}
/// Checks if there are any players associated with the given [matchId]. /// Checks if there are any players associated with the given [matchId].
/// Returns `true` if there are players, otherwise `false`. /// Returns `true` if there are players, otherwise `false`.
Future<bool> matchHasPlayers({required String matchId}) async { Future<bool> matchHasPlayers({required String matchId}) async {
final count = final count =
await (selectOnly(playerMatchTable) await (selectOnly(playerMatchTable)
..where(playerMatchTable.matchId.equals(matchId)) ..where(playerMatchTable.matchId.equals(matchId))
..addColumns([playerMatchTable.playerId.count()])) ..addColumns([playerMatchTable.playerId.count()]))
.map((row) => row.read(playerMatchTable.playerId.count())) .map((row) => row.read(playerMatchTable.playerId.count()))
.getSingle(); .getSingle();
return (count ?? 0) > 0; return (count ?? 0) > 0;
} }
@@ -109,12 +57,12 @@ class PlayerMatchDao extends DatabaseAccessor<AppDatabase>
required String playerId, required String playerId,
}) async { }) async {
final count = final count =
await (selectOnly(playerMatchTable) await (selectOnly(playerMatchTable)
..where(playerMatchTable.matchId.equals(matchId)) ..where(playerMatchTable.matchId.equals(matchId))
..where(playerMatchTable.playerId.equals(playerId)) ..where(playerMatchTable.playerId.equals(playerId))
..addColumns([playerMatchTable.playerId.count()])) ..addColumns([playerMatchTable.playerId.count()]))
.map((row) => row.read(playerMatchTable.playerId.count())) .map((row) => row.read(playerMatchTable.playerId.count()))
.getSingle(); .getSingle();
return (count ?? 0) > 0; return (count ?? 0) > 0;
} }
@@ -148,14 +96,14 @@ class PlayerMatchDao extends DatabaseAccessor<AppDatabase>
final playersToAdd = newPlayerIdsSet.difference(currentPlayerIds); final playersToAdd = newPlayerIdsSet.difference(currentPlayerIds);
final playersToRemove = currentPlayerIds.difference(newPlayerIdsSet); final playersToRemove = currentPlayerIds.difference(newPlayerIdsSet);
await db.transaction(() async { db.transaction(() async {
// Remove old players // Remove old players
if (playersToRemove.isNotEmpty) { if (playersToRemove.isNotEmpty) {
await (delete(playerMatchTable)..where( await (delete(playerMatchTable)..where(
(pg) => (pg) =>
pg.matchId.equals(matchId) & pg.matchId.equals(matchId) &
pg.playerId.isIn(playersToRemove.toList()), pg.playerId.isIn(playersToRemove.toList()),
)) ))
.go(); .go();
} }
@@ -164,15 +112,14 @@ class PlayerMatchDao extends DatabaseAccessor<AppDatabase>
final inserts = playersToAdd final inserts = playersToAdd
.map( .map(
(id) => PlayerMatchTableCompanion.insert( (id) => PlayerMatchTableCompanion.insert(
playerId: id, playerId: id,
matchId: matchId, matchId: matchId,
score: 0, ),
), )
)
.toList(); .toList();
await Future.wait( await Future.wait(
inserts.map( inserts.map(
(c) => into( (c) => into(
playerMatchTable, playerMatchTable,
).insert(c, mode: InsertMode.insertOrIgnore), ).insert(c, mode: InsertMode.insertOrIgnore),
), ),
@@ -180,23 +127,4 @@ class PlayerMatchDao extends DatabaseAccessor<AppDatabase>
} }
}); });
} }
/// Retrieves all players in a specific team for a match.
Future<List<Player>> getPlayersInTeam({
required String matchId,
required String teamId,
}) async {
final result = await (select(playerMatchTable)
..where(
(p) => p.matchId.equals(matchId) & p.teamId.equals(teamId),
))
.get();
if (result.isEmpty) return [];
final futures = result.map(
(row) => db.playerDao.getPlayerById(playerId: row.playerId),
);
return Future.wait(futures);
}
} }

View File

@@ -5,10 +5,7 @@ part of 'player_match_dao.dart';
// ignore_for_file: type=lint // ignore_for_file: type=lint
mixin _$PlayerMatchDaoMixin on DatabaseAccessor<AppDatabase> { mixin _$PlayerMatchDaoMixin on DatabaseAccessor<AppDatabase> {
$PlayerTableTable get playerTable => attachedDatabase.playerTable; $PlayerTableTable get playerTable => attachedDatabase.playerTable;
$GameTableTable get gameTable => attachedDatabase.gameTable;
$GroupTableTable get groupTable => attachedDatabase.groupTable;
$MatchTableTable get matchTable => attachedDatabase.matchTable; $MatchTableTable get matchTable => attachedDatabase.matchTable;
$TeamTableTable get teamTable => attachedDatabase.teamTable;
$PlayerMatchTableTable get playerMatchTable => $PlayerMatchTableTable get playerMatchTable =>
attachedDatabase.playerMatchTable; attachedDatabase.playerMatchTable;
} }

View File

@@ -1,191 +0,0 @@
import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/db/tables/score_table.dart';
part 'score_dao.g.dart';
/// A data class representing a score entry.
class ScoreEntry {
final String playerId;
final String matchId;
final int roundNumber;
final int score;
final int change;
ScoreEntry({
required this.playerId,
required this.matchId,
required this.roundNumber,
required this.score,
required this.change,
});
}
@DriftAccessor(tables: [ScoreTable])
class ScoreDao extends DatabaseAccessor<AppDatabase> with _$ScoreDaoMixin {
ScoreDao(super.db);
/// Adds a score entry to the database.
Future<void> addScore({
required String playerId,
required String matchId,
required int roundNumber,
required int score,
required int change,
}) async {
await into(scoreTable).insert(
ScoreTableCompanion.insert(
playerId: playerId,
matchId: matchId,
roundNumber: roundNumber,
score: score,
change: change,
),
mode: InsertMode.insertOrReplace,
);
}
/// Retrieves all scores for a specific match.
Future<List<ScoreEntry>> getScoresForMatch({required String matchId}) async {
final query = select(scoreTable)..where((s) => s.matchId.equals(matchId));
final result = await query.get();
return result
.map(
(row) => ScoreEntry(
playerId: row.playerId,
matchId: row.matchId,
roundNumber: row.roundNumber,
score: row.score,
change: row.change,
),
)
.toList();
}
/// Retrieves all scores for a specific player in a match.
Future<List<ScoreEntry>> getPlayerScoresInMatch({
required String playerId,
required String matchId,
}) async {
final query = select(scoreTable)
..where(
(s) => s.playerId.equals(playerId) & s.matchId.equals(matchId),
)
..orderBy([(s) => OrderingTerm.asc(s.roundNumber)]);
final result = await query.get();
return result
.map(
(row) => ScoreEntry(
playerId: row.playerId,
matchId: row.matchId,
roundNumber: row.roundNumber,
score: row.score,
change: row.change,
),
)
.toList();
}
/// Retrieves the score for a specific round.
Future<ScoreEntry?> getScoreForRound({
required String playerId,
required String matchId,
required int roundNumber,
}) async {
final query = select(scoreTable)
..where(
(s) =>
s.playerId.equals(playerId) &
s.matchId.equals(matchId) &
s.roundNumber.equals(roundNumber),
);
final result = await query.getSingleOrNull();
if (result == null) return null;
return ScoreEntry(
playerId: result.playerId,
matchId: result.matchId,
roundNumber: result.roundNumber,
score: result.score,
change: result.change,
);
}
/// Updates a score entry.
Future<bool> updateScore({
required String playerId,
required String matchId,
required int roundNumber,
required int newScore,
required int newChange,
}) async {
final rowsAffected = await (update(scoreTable)
..where(
(s) =>
s.playerId.equals(playerId) &
s.matchId.equals(matchId) &
s.roundNumber.equals(roundNumber),
))
.write(
ScoreTableCompanion(
score: Value(newScore),
change: Value(newChange),
),
);
return rowsAffected > 0;
}
/// Deletes a score entry.
Future<bool> deleteScore({
required String playerId,
required String matchId,
required int roundNumber,
}) async {
final query = delete(scoreTable)
..where(
(s) =>
s.playerId.equals(playerId) &
s.matchId.equals(matchId) &
s.roundNumber.equals(roundNumber),
);
final rowsAffected = await query.go();
return rowsAffected > 0;
}
/// Deletes all scores for a specific match.
Future<bool> deleteScoresForMatch({required String matchId}) async {
final query = delete(scoreTable)..where((s) => s.matchId.equals(matchId));
final rowsAffected = await query.go();
return rowsAffected > 0;
}
/// Deletes all scores for a specific player.
Future<bool> deleteScoresForPlayer({required String playerId}) async {
final query = delete(scoreTable)..where((s) => s.playerId.equals(playerId));
final rowsAffected = await query.go();
return rowsAffected > 0;
}
/// Gets the latest round number for a match.
Future<int> getLatestRoundNumber({required String matchId}) async {
final query = selectOnly(scoreTable)
..where(scoreTable.matchId.equals(matchId))
..addColumns([scoreTable.roundNumber.max()]);
final result = await query.getSingle();
return result.read(scoreTable.roundNumber.max()) ?? 0;
}
/// Gets the total score for a player in a match (sum of all changes).
Future<int> getTotalScoreForPlayer({
required String playerId,
required String matchId,
}) async {
final scores = await getPlayerScoresInMatch(
playerId: playerId,
matchId: matchId,
);
if (scores.isEmpty) return 0;
// Return the score from the latest round
return scores.last.score;
}
}

View File

@@ -1,12 +0,0 @@
// GENERATED CODE - DO NOT MODIFY BY HAND
part of 'score_dao.dart';
// ignore_for_file: type=lint
mixin _$ScoreDaoMixin on DatabaseAccessor<AppDatabase> {
$PlayerTableTable get playerTable => attachedDatabase.playerTable;
$GameTableTable get gameTable => attachedDatabase.gameTable;
$GroupTableTable get groupTable => attachedDatabase.groupTable;
$MatchTableTable get matchTable => attachedDatabase.matchTable;
$ScoreTableTable get scoreTable => attachedDatabase.scoreTable;
}

View File

@@ -1,147 +0,0 @@
import 'package:drift/drift.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/db/tables/team_table.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:tallee/data/dto/team.dart';
part 'team_dao.g.dart';
@DriftAccessor(tables: [TeamTable])
class TeamDao extends DatabaseAccessor<AppDatabase> with _$TeamDaoMixin {
TeamDao(super.db);
/// Retrieves all teams from the database.
/// Note: This returns teams without their members. Use getTeamById for full team data.
Future<List<Team>> getAllTeams() async {
final query = select(teamTable);
final result = await query.get();
return Future.wait(
result.map((row) async {
final members = await _getTeamMembers(teamId: row.id);
return Team(
id: row.id,
name: row.name,
createdAt: row.createdAt,
members: members,
);
}),
);
}
/// Retrieves a [Team] by its [teamId], including its members.
Future<Team> getTeamById({required String teamId}) async {
final query = select(teamTable)..where((t) => t.id.equals(teamId));
final result = await query.getSingle();
final members = await _getTeamMembers(teamId: teamId);
return Team(
id: result.id,
name: result.name,
createdAt: result.createdAt,
members: members,
);
}
/// Helper method to get team members from player_match_table.
/// This assumes team members are tracked via the player_match_table.
Future<List<Player>> _getTeamMembers({required String teamId}) async {
// Get all player_match entries with this teamId
final playerMatchQuery = select(db.playerMatchTable)
..where((pm) => pm.teamId.equals(teamId));
final playerMatches = await playerMatchQuery.get();
if (playerMatches.isEmpty) return [];
// Get unique player IDs
final playerIds = playerMatches.map((pm) => pm.playerId).toSet();
// Fetch all players
final players = await Future.wait(
playerIds.map((id) => db.playerDao.getPlayerById(playerId: id)),
);
return players;
}
/// Adds a new [team] to the database.
/// Returns `true` if the team was added, `false` otherwise.
Future<bool> addTeam({required Team team}) async {
if (!await teamExists(teamId: team.id)) {
await into(teamTable).insert(
TeamTableCompanion.insert(
id: team.id,
name: team.name,
createdAt: team.createdAt,
),
mode: InsertMode.insertOrReplace,
);
return true;
}
return false;
}
/// Adds multiple [teams] to the database in a batch operation.
Future<bool> addTeamsAsList({required List<Team> teams}) async {
if (teams.isEmpty) return false;
await db.batch(
(b) => b.insertAll(
teamTable,
teams
.map(
(team) => TeamTableCompanion.insert(
id: team.id,
name: team.name,
createdAt: team.createdAt,
),
)
.toList(),
mode: InsertMode.insertOrIgnore,
),
);
return true;
}
/// Deletes the team with the given [teamId] from the database.
/// Returns `true` if the team was deleted, `false` otherwise.
Future<bool> deleteTeam({required String teamId}) async {
final query = delete(teamTable)..where((t) => t.id.equals(teamId));
final rowsAffected = await query.go();
return rowsAffected > 0;
}
/// Checks if a team with the given [teamId] exists in the database.
/// Returns `true` if the team exists, `false` otherwise.
Future<bool> teamExists({required String teamId}) async {
final query = select(teamTable)..where((t) => t.id.equals(teamId));
final result = await query.getSingleOrNull();
return result != null;
}
/// Updates the name of the team with the given [teamId].
Future<void> updateTeamName({
required String teamId,
required String newName,
}) async {
await (update(teamTable)..where((t) => t.id.equals(teamId))).write(
TeamTableCompanion(name: Value(newName)),
);
}
/// Retrieves the total count of teams in the database.
Future<int> getTeamCount() async {
final count =
await (selectOnly(teamTable)..addColumns([teamTable.id.count()]))
.map((row) => row.read(teamTable.id.count()))
.getSingle();
return count ?? 0;
}
/// Deletes all teams from the database.
/// Returns `true` if more than 0 rows were affected, otherwise `false`.
Future<bool> deleteAllTeams() async {
final query = delete(teamTable);
final rowsAffected = await query.go();
return rowsAffected > 0;
}
}

View File

@@ -1,8 +0,0 @@
// GENERATED CODE - DO NOT MODIFY BY HAND
part of 'team_dao.dart';
// ignore_for_file: type=lint
mixin _$TeamDaoMixin on DatabaseAccessor<AppDatabase> {
$TeamTableTable get teamTable => attachedDatabase.teamTable;
}

View File

@@ -1,22 +1,18 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:drift_flutter/drift_flutter.dart'; import 'package:drift_flutter/drift_flutter.dart';
import 'package:game_tracker/data/dao/group_dao.dart';
import 'package:game_tracker/data/dao/group_match_dao.dart';
import 'package:game_tracker/data/dao/match_dao.dart';
import 'package:game_tracker/data/dao/player_dao.dart';
import 'package:game_tracker/data/dao/player_group_dao.dart';
import 'package:game_tracker/data/dao/player_match_dao.dart';
import 'package:game_tracker/data/db/tables/group_match_table.dart';
import 'package:game_tracker/data/db/tables/group_table.dart';
import 'package:game_tracker/data/db/tables/match_table.dart';
import 'package:game_tracker/data/db/tables/player_group_table.dart';
import 'package:game_tracker/data/db/tables/player_match_table.dart';
import 'package:game_tracker/data/db/tables/player_table.dart';
import 'package:path_provider/path_provider.dart'; import 'package:path_provider/path_provider.dart';
import 'package:tallee/data/dao/game_dao.dart';
import 'package:tallee/data/dao/group_dao.dart';
import 'package:tallee/data/dao/match_dao.dart';
import 'package:tallee/data/dao/player_dao.dart';
import 'package:tallee/data/dao/player_group_dao.dart';
import 'package:tallee/data/dao/player_match_dao.dart';
import 'package:tallee/data/dao/score_dao.dart';
import 'package:tallee/data/dao/team_dao.dart';
import 'package:tallee/data/db/tables/game_table.dart';
import 'package:tallee/data/db/tables/group_table.dart';
import 'package:tallee/data/db/tables/match_table.dart';
import 'package:tallee/data/db/tables/player_group_table.dart';
import 'package:tallee/data/db/tables/player_match_table.dart';
import 'package:tallee/data/db/tables/player_table.dart';
import 'package:tallee/data/db/tables/score_table.dart';
import 'package:tallee/data/db/tables/team_table.dart';
part 'database.g.dart'; part 'database.g.dart';
@@ -27,9 +23,7 @@ part 'database.g.dart';
MatchTable, MatchTable,
PlayerGroupTable, PlayerGroupTable,
PlayerMatchTable, PlayerMatchTable,
GameTable, GroupMatchTable,
TeamTable,
ScoreTable,
], ],
daos: [ daos: [
PlayerDao, PlayerDao,
@@ -37,9 +31,7 @@ part 'database.g.dart';
MatchDao, MatchDao,
PlayerGroupDao, PlayerGroupDao,
PlayerMatchDao, PlayerMatchDao,
GameDao, GroupMatchDao,
ScoreDao,
TeamDao
], ],
) )
class AppDatabase extends _$AppDatabase { class AppDatabase extends _$AppDatabase {
@@ -60,7 +52,9 @@ class AppDatabase extends _$AppDatabase {
static QueryExecutor _openConnection() { static QueryExecutor _openConnection() {
return driftDatabase( return driftDatabase(
name: 'gametracker_db', name: 'gametracker_db',
native: const DriftNativeOptions(databaseDirectory: getApplicationSupportDirectory), native: const DriftNativeOptions(
databaseDirectory: getApplicationSupportDirectory,
),
); );
} }
} }

File diff suppressed because it is too large Load Diff

View File

@@ -1,14 +0,0 @@
import 'package:drift/drift.dart';
class GameTable extends Table {
TextColumn get id => text()();
TextColumn get name => text()();
TextColumn get ruleset => text()();
TextColumn get description => text()();
TextColumn get color => text()();
TextColumn get icon => text()();
DateTimeColumn get createdAt => dateTime()();
@override
Set<Column<Object>> get primaryKey => {id};
}

View File

@@ -0,0 +1,13 @@
import 'package:drift/drift.dart';
import 'package:game_tracker/data/db/tables/group_table.dart';
import 'package:game_tracker/data/db/tables/match_table.dart';
class GroupMatchTable extends Table {
TextColumn get groupId =>
text().references(GroupTable, #id, onDelete: KeyAction.cascade)();
TextColumn get matchId =>
text().references(MatchTable, #id, onDelete: KeyAction.cascade)();
@override
Set<Column<Object>> get primaryKey => {groupId, matchId};
}

View File

@@ -3,7 +3,6 @@ import 'package:drift/drift.dart';
class GroupTable extends Table { class GroupTable extends Table {
TextColumn get id => text()(); TextColumn get id => text()();
TextColumn get name => text()(); TextColumn get name => text()();
TextColumn get description => text()();
DateTimeColumn get createdAt => dateTime()(); DateTimeColumn get createdAt => dateTime()();
@override @override

View File

@@ -1,19 +1,11 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/tables/game_table.dart';
import 'package:tallee/data/db/tables/group_table.dart';
class MatchTable extends Table { class MatchTable extends Table {
TextColumn get id => text()(); TextColumn get id => text()();
TextColumn get gameId => TextColumn get name => text()();
text().references(GameTable, #id, onDelete: KeyAction.cascade)(); late final winnerId = text().nullable()();
// Nullable if not part of a group
TextColumn get groupId =>
text().references(GroupTable, #id, onDelete: KeyAction.cascade).nullable()();
TextColumn get name => text().nullable()();
TextColumn get notes => text().nullable()();
DateTimeColumn get createdAt => dateTime()(); DateTimeColumn get createdAt => dateTime()();
DateTimeColumn get endedAt => dateTime().nullable()();
@override @override
Set<Column<Object>> get primaryKey => {id}; Set<Column<Object>> get primaryKey => {id};
} }

View File

@@ -1,6 +1,6 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/tables/group_table.dart'; import 'package:game_tracker/data/db/tables/group_table.dart';
import 'package:tallee/data/db/tables/player_table.dart'; import 'package:game_tracker/data/db/tables/player_table.dart';
class PlayerGroupTable extends Table { class PlayerGroupTable extends Table {
TextColumn get playerId => TextColumn get playerId =>

View File

@@ -1,16 +1,12 @@
import 'package:drift/drift.dart'; import 'package:drift/drift.dart';
import 'package:tallee/data/db/tables/match_table.dart'; import 'package:game_tracker/data/db/tables/match_table.dart';
import 'package:tallee/data/db/tables/player_table.dart'; import 'package:game_tracker/data/db/tables/player_table.dart';
import 'package:tallee/data/db/tables/team_table.dart';
class PlayerMatchTable extends Table { class PlayerMatchTable extends Table {
TextColumn get playerId => TextColumn get playerId =>
text().references(PlayerTable, #id, onDelete: KeyAction.cascade)(); text().references(PlayerTable, #id, onDelete: KeyAction.cascade)();
TextColumn get matchId => TextColumn get matchId =>
text().references(MatchTable, #id, onDelete: KeyAction.cascade)(); text().references(MatchTable, #id, onDelete: KeyAction.cascade)();
TextColumn get teamId =>
text().references(TeamTable, #id).nullable()();
IntColumn get score => integer()();
@override @override
Set<Column<Object>> get primaryKey => {playerId, matchId}; Set<Column<Object>> get primaryKey => {playerId, matchId};

View File

@@ -3,7 +3,6 @@ import 'package:drift/drift.dart';
class PlayerTable extends Table { class PlayerTable extends Table {
TextColumn get id => text()(); TextColumn get id => text()();
TextColumn get name => text()(); TextColumn get name => text()();
TextColumn get description => text()();
DateTimeColumn get createdAt => dateTime()(); DateTimeColumn get createdAt => dateTime()();
@override @override

View File

@@ -1,16 +0,0 @@
import 'package:drift/drift.dart';
import 'package:tallee/data/db/tables/match_table.dart';
import 'package:tallee/data/db/tables/player_table.dart';
class ScoreTable extends Table {
TextColumn get playerId =>
text().references(PlayerTable, #id, onDelete: KeyAction.cascade)();
TextColumn get matchId =>
text().references(MatchTable, #id, onDelete: KeyAction.cascade)();
IntColumn get roundNumber => integer()();
IntColumn get score => integer()();
IntColumn get change => integer()();
@override
Set<Column<Object>> get primaryKey => {playerId, matchId, roundNumber};
}

View File

@@ -1,10 +0,0 @@
import 'package:drift/drift.dart';
class TeamTable extends Table {
TextColumn get id => text()();
TextColumn get name => text()();
DateTimeColumn get createdAt => dateTime()();
@override
Set<Column<Object>> get primaryKey => {id};
}

View File

@@ -1,51 +0,0 @@
import 'package:clock/clock.dart';
import 'package:uuid/uuid.dart';
import 'package:tallee/core/enums.dart';
class Game {
final String id;
final DateTime createdAt;
final String name;
final Ruleset ruleset;
final String description;
final GameColor color;
final String icon;
Game({
String? id,
DateTime? createdAt,
required this.name,
required this.ruleset,
required this.description,
required this.color,
required this.icon,
}) : id = id ?? const Uuid().v4(),
createdAt = createdAt ?? clock.now();
@override
String toString() {
return 'Game{id: $id, name: $name, ruleset: $ruleset, description: $description, color: $color, icon: $icon}';
}
/// Creates a Game instance from a JSON object.
Game.fromJson(Map<String, dynamic> json)
: id = json['id'],
createdAt = DateTime.parse(json['createdAt']),
name = json['name'],
ruleset = Ruleset.values.firstWhere((e) => e.name == json['ruleset']),
description = json['description'],
color = GameColor.values.firstWhere((e) => e.name == json['color']),
icon = json['icon'];
/// Converts the Game instance to a JSON object.
Map<String, dynamic> toJson() => {
'id': id,
'createdAt': createdAt.toIso8601String(),
'name': name,
'ruleset': ruleset.name,
'description': description,
'color': color.name,
'icon': icon,
};
}

View File

@@ -1,43 +1,40 @@
import 'package:clock/clock.dart'; import 'package:clock/clock.dart';
import 'package:tallee/data/dto/player.dart'; import 'package:game_tracker/data/dto/player.dart';
import 'package:uuid/uuid.dart'; import 'package:uuid/uuid.dart';
class Group { class Group {
final String id; final String id;
final String name;
final String description;
final DateTime createdAt; final DateTime createdAt;
final String name;
final List<Player> members; final List<Player> members;
Group({ Group({
String? id, String? id,
DateTime? createdAt, DateTime? createdAt,
required this.name, required this.name,
required this.description,
required this.members, required this.members,
}) : id = id ?? const Uuid().v4(), }) : id = id ?? const Uuid().v4(),
createdAt = createdAt ?? clock.now(); createdAt = createdAt ?? clock.now();
@override @override
String toString() { String toString() {
return 'Group{id: $id, name: $name, description: $description, members: $members}'; return 'Group{id: $id, name: $name,members: $members}';
} }
/// Creates a Group instance from a JSON object (memberIds format). /// Creates a Group instance from a JSON object.
/// Player objects are reconstructed from memberIds by the DataTransferService.
Group.fromJson(Map<String, dynamic> json) Group.fromJson(Map<String, dynamic> json)
: id = json['id'], : id = json['id'],
createdAt = DateTime.parse(json['createdAt']), createdAt = DateTime.parse(json['createdAt']),
name = json['name'], name = json['name'],
description = json['description'], members = (json['members'] as List)
members = []; // Populated during import via DataTransferService .map((memberJson) => Player.fromJson(memberJson))
.toList();
/// Converts the Group instance to a JSON object using normalized format (memberIds only). /// Converts the Group instance to a JSON object.
Map<String, dynamic> toJson() => { Map<String, dynamic> toJson() => {
'id': id, 'id': id,
'createdAt': createdAt.toIso8601String(), 'createdAt': createdAt.toIso8601String(),
'name': name, 'name': name,
'description': description, 'members': members.map((member) => member.toJson()).toList(),
'memberIds': members.map((member) => member.id).toList(),
}; };
} }

View File

@@ -1,60 +1,51 @@
import 'package:clock/clock.dart'; import 'package:clock/clock.dart';
import 'package:tallee/core/enums.dart'; import 'package:game_tracker/data/dto/group.dart';
import 'package:tallee/data/dto/game.dart'; import 'package:game_tracker/data/dto/player.dart';
import 'package:tallee/data/dto/group.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:uuid/uuid.dart'; import 'package:uuid/uuid.dart';
class Match { class Match {
final String id; final String id;
final DateTime createdAt; final DateTime createdAt;
final DateTime? endedAt;
final String name; final String name;
final Game game; final List<Player>? players;
final Group? group; final Group? group;
final List<Player> players;
final String notes;
Player? winner; Player? winner;
Match({ Match({
String? id, String? id,
DateTime? createdAt, DateTime? createdAt,
this.endedAt,
required this.name, required this.name,
required this.game, this.players,
this.group, this.group,
this.players = const [],
required this.notes,
this.winner, this.winner,
}) : id = id ?? const Uuid().v4(), }) : id = id ?? const Uuid().v4(),
createdAt = createdAt ?? clock.now(); createdAt = createdAt ?? clock.now();
@override @override
String toString() { String toString() {
return 'Match{id: $id, name: $name, game: $game, group: $group, players: $players, notes: $notes, endedAt: $endedAt}'; return 'Match{\n\tid: $id,\n\tname: $name,\n\tplayers: $players,\n\tgroup: $group,\n\twinner: $winner\n}';
} }
/// Creates a Match instance from a JSON object (ID references format). /// Creates a Match instance from a JSON object.
/// Related objects are reconstructed from IDs by the DataTransferService.
Match.fromJson(Map<String, dynamic> json) Match.fromJson(Map<String, dynamic> json)
: id = json['id'], : id = json['id'],
createdAt = DateTime.parse(json['createdAt']), name = json['name'],
endedAt = json['endedAt'] != null ? DateTime.parse(json['endedAt']) : null, createdAt = DateTime.parse(json['createdAt']),
name = json['name'], players = json['players'] != null
game = Game(name: '', ruleset: Ruleset.singleWinner, description: '', color: GameColor.blue, icon: ''), // Populated during import via DataTransferService ? (json['players'] as List)
group = null, // Populated during import via DataTransferService .map((playerJson) => Player.fromJson(playerJson))
players = [], // Populated during import via DataTransferService .toList()
notes = json['notes'] ?? ''; : null,
group = json['group'] != null ? Group.fromJson(json['group']) : null,
winner = json['winner'] != null ? Player.fromJson(json['winner']) : null;
/// Converts the Match instance to a JSON object using normalized format (ID references only). /// Converts the Match instance to a JSON object.
Map<String, dynamic> toJson() => { Map<String, dynamic> toJson() => {
'id': id, 'id': id,
'createdAt': createdAt.toIso8601String(), 'createdAt': createdAt.toIso8601String(),
'endedAt': endedAt?.toIso8601String(),
'name': name, 'name': name,
'gameId': game.id, 'players': players?.map((player) => player.toJson()).toList(),
'groupId': group?.id, 'group': group?.toJson(),
'playerIds': players.map((player) => player.id).toList(), 'winner': winner?.toJson(),
'notes': notes,
}; };
} }

View File

@@ -5,33 +5,26 @@ class Player {
final String id; final String id;
final DateTime createdAt; final DateTime createdAt;
final String name; final String name;
final String description;
Player({ Player({String? id, DateTime? createdAt, required this.name})
String? id, : id = id ?? const Uuid().v4(),
DateTime? createdAt, createdAt = createdAt ?? clock.now();
required this.name,
required this.description,
}) : id = id ?? const Uuid().v4(),
createdAt = createdAt ?? clock.now();
@override @override
String toString() { String toString() {
return 'Player{id: $id, name: $name, description: $description}'; return 'Player{id: $id,name: $name}';
} }
/// Creates a Player instance from a JSON object. /// Creates a Player instance from a JSON object.
Player.fromJson(Map<String, dynamic> json) Player.fromJson(Map<String, dynamic> json)
: id = json['id'], : id = json['id'],
createdAt = DateTime.parse(json['createdAt']), createdAt = DateTime.parse(json['createdAt']),
name = json['name'], name = json['name'];
description = json['description'];
/// Converts the Player instance to a JSON object. /// Converts the Player instance to a JSON object.
Map<String, dynamic> toJson() => { Map<String, dynamic> toJson() => {
'id': id, 'id': id,
'createdAt': createdAt.toIso8601String(), 'createdAt': createdAt.toIso8601String(),
'name': name, 'name': name,
'description': description,
}; };
} }

View File

@@ -1,40 +0,0 @@
import 'package:clock/clock.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:uuid/uuid.dart';
class Team {
final String id;
final String name;
final DateTime createdAt;
final List<Player> members;
Team({
String? id,
required this.name,
DateTime? createdAt,
required this.members,
}) : id = id ?? const Uuid().v4(),
createdAt = createdAt ?? clock.now();
@override
String toString() {
return 'Team{id: $id, name: $name, members: $members}';
}
/// Creates a Team instance from a JSON object (memberIds format).
/// Player objects are reconstructed from memberIds by the DataTransferService.
Team.fromJson(Map<String, dynamic> json)
: id = json['id'],
name = json['name'],
createdAt = DateTime.parse(json['createdAt']),
members = []; // Populated during import via DataTransferService
/// Converts the Team instance to a JSON object using normalized format (memberIds only).
Map<String, dynamic> toJson() => {
'id': id,
'name': name,
'createdAt': createdAt.toIso8601String(),
'memberIds': members.map((member) => member.id).toList(),
};
}

View File

@@ -3,7 +3,7 @@
"all_players": "Alle Spieler:innen", "all_players": "Alle Spieler:innen",
"all_players_selected": "Alle Spieler:innen ausgewählt", "all_players_selected": "Alle Spieler:innen ausgewählt",
"amount_of_matches": "Anzahl der Spiele", "amount_of_matches": "Anzahl der Spiele",
"app_name": "Tallee", "app_name": "Game Tracker",
"best_player": "Beste:r Spieler:in", "best_player": "Beste:r Spieler:in",
"cancel": "Abbrechen", "cancel": "Abbrechen",
"choose_game": "Spielvorlage wählen", "choose_game": "Spielvorlage wählen",
@@ -82,9 +82,6 @@
"settings": "Einstellungen", "settings": "Einstellungen",
"single_loser": "Ein:e Verlierer:in", "single_loser": "Ein:e Verlierer:in",
"single_winner": "Ein:e Gewinner:in", "single_winner": "Ein:e Gewinner:in",
"highest_score": "Höchste Punkte",
"lowest_score": "Niedrigste Punkte",
"multiple_winners": "Mehrere Gewinner:innen",
"statistics": "Statistiken", "statistics": "Statistiken",
"stats": "Statistiken", "stats": "Statistiken",
"successfully_added_player": "Spieler:in {playerName} erfolgreich hinzugefügt", "successfully_added_player": "Spieler:in {playerName} erfolgreich hinzugefügt",

View File

@@ -301,7 +301,7 @@
"all_players": "All players", "all_players": "All players",
"all_players_selected": "All players selected", "all_players_selected": "All players selected",
"amount_of_matches": "Amount of Matches", "amount_of_matches": "Amount of Matches",
"app_name": "Tallee", "app_name": "Game Tracker",
"best_player": "Best Player", "best_player": "Best Player",
"cancel": "Cancel", "cancel": "Cancel",
"choose_game": "Choose Game", "choose_game": "Choose Game",
@@ -380,9 +380,6 @@
"settings": "Settings", "settings": "Settings",
"single_loser": "Single Loser", "single_loser": "Single Loser",
"single_winner": "Single Winner", "single_winner": "Single Winner",
"highest_score": "Highest Score",
"lowest_score": "Lowest Score",
"multiple_winners": "Multiple Winners",
"statistics": "Statistics", "statistics": "Statistics",
"stats": "Stats", "stats": "Stats",
"successfully_added_player": "Successfully added player {playerName}", "successfully_added_player": "Successfully added player {playerName}",

View File

@@ -119,7 +119,7 @@ abstract class AppLocalizations {
/// The name of the App /// The name of the App
/// ///
/// In en, this message translates to: /// In en, this message translates to:
/// **'Tallee'** /// **'Game Tracker'**
String get app_name; String get app_name;
/// Label for best player statistic /// Label for best player statistic
@@ -590,24 +590,6 @@ abstract class AppLocalizations {
/// **'Single Winner'** /// **'Single Winner'**
String get single_winner; String get single_winner;
/// No description provided for @highest_score.
///
/// In en, this message translates to:
/// **'Highest Score'**
String get highest_score;
/// No description provided for @lowest_score.
///
/// In en, this message translates to:
/// **'Lowest Score'**
String get lowest_score;
/// No description provided for @multiple_winners.
///
/// In en, this message translates to:
/// **'Multiple Winners'**
String get multiple_winners;
/// Statistics tab label /// Statistics tab label
/// ///
/// In en, this message translates to: /// In en, this message translates to:

View File

@@ -18,7 +18,7 @@ class AppLocalizationsDe extends AppLocalizations {
String get amount_of_matches => 'Anzahl der Spiele'; String get amount_of_matches => 'Anzahl der Spiele';
@override @override
String get app_name => 'Tallee'; String get app_name => 'Game Tracker';
@override @override
String get best_player => 'Beste:r Spieler:in'; String get best_player => 'Beste:r Spieler:in';
@@ -266,15 +266,6 @@ class AppLocalizationsDe extends AppLocalizations {
@override @override
String get single_winner => 'Ein:e Gewinner:in'; String get single_winner => 'Ein:e Gewinner:in';
@override
String get highest_score => 'Höchste Punkte';
@override
String get lowest_score => 'Niedrigste Punkte';
@override
String get multiple_winners => 'Mehrere Gewinner:innen';
@override @override
String get statistics => 'Statistiken'; String get statistics => 'Statistiken';

View File

@@ -18,7 +18,7 @@ class AppLocalizationsEn extends AppLocalizations {
String get amount_of_matches => 'Amount of Matches'; String get amount_of_matches => 'Amount of Matches';
@override @override
String get app_name => 'Tallee'; String get app_name => 'Game Tracker';
@override @override
String get best_player => 'Best Player'; String get best_player => 'Best Player';
@@ -266,15 +266,6 @@ class AppLocalizationsEn extends AppLocalizations {
@override @override
String get single_winner => 'Single Winner'; String get single_winner => 'Single Winner';
@override
String get highest_score => 'Highest Score';
@override
String get lowest_score => 'Lowest Score';
@override
String get multiple_winners => 'Multiple Winners';
@override @override
String get statistics => 'Statistics'; String get statistics => 'Statistics';

View File

@@ -1,9 +1,9 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:game_tracker/core/custom_theme.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:game_tracker/presentation/views/main_menu/custom_navigation_bar.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:tallee/core/custom_theme.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/views/main_menu/custom_navigation_bar.dart';
void main() { void main() {
runApp( runApp(
@@ -29,7 +29,9 @@ class GameTracker extends StatelessWidget {
return supportedLocale; return supportedLocale;
} }
} }
return supportedLocales.firstWhere((locale) => locale.languageCode == 'en'); return supportedLocales.firstWhere(
(locale) => locale.languageCode == 'en',
);
}, },
debugShowCheckedModeBanner: false, debugShowCheckedModeBanner: false,
onGenerateTitle: (context) => AppLocalizations.of(context).app_name, onGenerateTitle: (context) => AppLocalizations.of(context).app_name,

View File

@@ -1,15 +1,15 @@
import 'dart:ui'; import 'dart:ui';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:tallee/core/adaptive_page_route.dart'; import 'package:game_tracker/core/adaptive_page_route.dart';
import 'package:tallee/core/custom_theme.dart'; import 'package:game_tracker/core/custom_theme.dart';
import 'package:tallee/l10n/generated/app_localizations.dart'; import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/views/main_menu/group_view/groups_view.dart'; import 'package:game_tracker/presentation/views/main_menu/group_view/groups_view.dart';
import 'package:tallee/presentation/views/main_menu/home_view.dart'; import 'package:game_tracker/presentation/views/main_menu/home_view.dart';
import 'package:tallee/presentation/views/main_menu/match_view/match_view.dart'; import 'package:game_tracker/presentation/views/main_menu/match_view/match_view.dart';
import 'package:tallee/presentation/views/main_menu/settings_view/settings_view.dart'; import 'package:game_tracker/presentation/views/main_menu/settings_view/settings_view.dart';
import 'package:tallee/presentation/views/main_menu/statistics_view.dart'; import 'package:game_tracker/presentation/views/main_menu/statistics_view.dart';
import 'package:tallee/presentation/widgets/navbar_item.dart'; import 'package:game_tracker/presentation/widgets/navbar_item.dart';
class CustomNavigationBar extends StatefulWidget { class CustomNavigationBar extends StatefulWidget {
/// A custom navigation bar widget that provides tabbed navigation /// A custom navigation bar widget that provides tabbed navigation

View File

@@ -1,15 +1,15 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:game_tracker/core/constants.dart';
import 'package:game_tracker/core/custom_theme.dart';
import 'package:game_tracker/core/enums.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/group.dart';
import 'package:game_tracker/data/dto/player.dart';
import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:game_tracker/presentation/widgets/buttons/custom_width_button.dart';
import 'package:game_tracker/presentation/widgets/player_selection.dart';
import 'package:game_tracker/presentation/widgets/text_input/text_input_field.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:tallee/core/constants.dart';
import 'package:tallee/core/custom_theme.dart';
import 'package:tallee/core/enums.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/dto/group.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:tallee/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/widgets/buttons/custom_width_button.dart';
import 'package:tallee/presentation/widgets/player_selection.dart';
import 'package:tallee/presentation/widgets/text_input/text_input_field.dart';
class CreateGroupView extends StatefulWidget { class CreateGroupView extends StatefulWidget {
/// A view that allows the user to create a new group /// A view that allows the user to create a new group
@@ -84,7 +84,6 @@ class _CreateGroupViewState extends State<CreateGroupView> {
bool success = await db.groupDao.addGroup( bool success = await db.groupDao.addGroup(
group: Group( group: Group(
name: _groupNameController.text.trim(), name: _groupNameController.text.trim(),
description: '',
members: selectedPlayers, members: selectedPlayers,
), ),
); );

View File

@@ -1,19 +1,19 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:game_tracker/core/custom_theme.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/group.dart';
import 'package:game_tracker/data/dto/match.dart';
import 'package:game_tracker/data/dto/player.dart';
import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:game_tracker/presentation/widgets/app_skeleton.dart';
import 'package:game_tracker/presentation/widgets/buttons/animated_dialog_button.dart';
import 'package:game_tracker/presentation/widgets/buttons/main_menu_button.dart';
import 'package:game_tracker/presentation/widgets/colored_icon_container.dart';
import 'package:game_tracker/presentation/widgets/custom_alert_dialog.dart';
import 'package:game_tracker/presentation/widgets/tiles/info_tile.dart';
import 'package:game_tracker/presentation/widgets/tiles/text_icon_tile.dart';
import 'package:intl/intl.dart'; import 'package:intl/intl.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:tallee/core/custom_theme.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/dto/group.dart';
import 'package:tallee/data/dto/match.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:tallee/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/widgets/app_skeleton.dart';
import 'package:tallee/presentation/widgets/buttons/animated_dialog_button.dart';
import 'package:tallee/presentation/widgets/buttons/main_menu_button.dart';
import 'package:tallee/presentation/widgets/colored_icon_container.dart';
import 'package:tallee/presentation/widgets/custom_alert_dialog.dart';
import 'package:tallee/presentation/widgets/tiles/info_tile.dart';
import 'package:tallee/presentation/widgets/tiles/text_icon_tile.dart';
class GroupProfileView extends StatefulWidget { class GroupProfileView extends StatefulWidget {
/// A view that displays the profile of a group /// A view that displays the profile of a group
@@ -78,9 +78,7 @@ class _GroupProfileViewState extends State<GroupProfileView> {
onPressed: () => Navigator.of(context).pop(true), onPressed: () => Navigator.of(context).pop(true),
child: Text( child: Text(
loc.delete, loc.delete,
style: const TextStyle( style: TextStyle(color: CustomTheme.secondaryColor),
color: CustomTheme.secondaryColor,
),
), ),
), ),
], ],

View File

@@ -1,18 +1,19 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:game_tracker/core/adaptive_page_route.dart';
import 'package:game_tracker/core/constants.dart';
import 'package:game_tracker/core/custom_theme.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/group.dart';
import 'package:game_tracker/data/dto/player.dart';
import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:game_tracker/presentation/views/main_menu/group_view/create_group_view.dart';
import 'package:game_tracker/presentation/views/main_menu/group_view/group_profile_view.dart';
import 'package:game_tracker/presentation/widgets/app_skeleton.dart';
import 'package:game_tracker/presentation/widgets/buttons/main_menu_button.dart';
import 'package:game_tracker/presentation/widgets/tiles/group_tile.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:tallee/core/adaptive_page_route.dart';
import 'package:tallee/core/constants.dart'; import 'package:game_tracker/presentation/widgets/top_centered_message.dart';
import 'package:tallee/core/custom_theme.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/dto/group.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:tallee/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/views/main_menu/group_view/create_group_view.dart';
import 'package:tallee/presentation/views/main_menu/group_view/group_profile_view.dart';
import 'package:tallee/presentation/widgets/app_skeleton.dart';
import 'package:tallee/presentation/widgets/buttons/main_menu_button.dart';
import 'package:tallee/presentation/widgets/tiles/group_tile.dart';
import 'package:tallee/presentation/widgets/top_centered_message.dart';
class GroupsView extends StatefulWidget { class GroupsView extends StatefulWidget {
/// A view that displays a list of groups /// A view that displays a list of groups
@@ -35,8 +36,7 @@ class _GroupsViewState extends State<GroupsView> {
7, 7,
Group( Group(
name: 'Skeleton Group', name: 'Skeleton Group',
description: '', members: List.filled(6, Player(name: 'Skeleton Player')),
members: List.filled(6, Player(name: 'Skeleton Player', description: '')),
), ),
); );

View File

@@ -1,20 +1,18 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:game_tracker/core/adaptive_page_route.dart';
import 'package:game_tracker/core/constants.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/group.dart';
import 'package:game_tracker/data/dto/match.dart';
import 'package:game_tracker/data/dto/player.dart';
import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:game_tracker/presentation/views/main_menu/match_view/match_result_view.dart';
import 'package:game_tracker/presentation/widgets/app_skeleton.dart';
import 'package:game_tracker/presentation/widgets/buttons/quick_create_button.dart';
import 'package:game_tracker/presentation/widgets/tiles/info_tile.dart';
import 'package:game_tracker/presentation/widgets/tiles/match_tile.dart';
import 'package:game_tracker/presentation/widgets/tiles/quick_info_tile.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:tallee/core/adaptive_page_route.dart';
import 'package:tallee/core/constants.dart';
import 'package:tallee/core/enums.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/dto/game.dart';
import 'package:tallee/data/dto/group.dart';
import 'package:tallee/data/dto/match.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:tallee/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/views/main_menu/match_view/match_result_view.dart';
import 'package:tallee/presentation/widgets/app_skeleton.dart';
import 'package:tallee/presentation/widgets/buttons/quick_create_button.dart';
import 'package:tallee/presentation/widgets/tiles/info_tile.dart';
import 'package:tallee/presentation/widgets/tiles/match_tile.dart';
import 'package:tallee/presentation/widgets/tiles/quick_info_tile.dart';
class HomeView extends StatefulWidget { class HomeView extends StatefulWidget {
/// The main home view of the application, displaying quick info, /// The main home view of the application, displaying quick info,
@@ -42,16 +40,13 @@ class _HomeViewState extends State<HomeView> {
2, 2,
Match( Match(
name: 'Skeleton Match', name: 'Skeleton Match',
game: Game(name: '', ruleset: Ruleset.singleWinner, description: '', color: GameColor.blue, icon: ''),
group: Group( group: Group(
name: 'Skeleton Group', name: 'Skeleton Group',
description: '',
members: [ members: [
Player(name: 'Skeleton Player 1', description: ''), Player(name: 'Skeleton Player 1'),
Player(name: 'Skeleton Player 2', description: ''), Player(name: 'Skeleton Player 2'),
], ],
), ),
notes: '',
), ),
); );
@@ -104,7 +99,9 @@ class _HomeViewState extends State<HomeView> {
if (recentMatches.isNotEmpty) if (recentMatches.isNotEmpty)
for (Match match in recentMatches) for (Match match in recentMatches)
Padding( Padding(
padding: const EdgeInsets.symmetric(vertical: 6.0), padding: const EdgeInsets.symmetric(
vertical: 6.0,
),
child: MatchTile( child: MatchTile(
compact: true, compact: true,
width: constraints.maxWidth * 0.9, width: constraints.maxWidth * 0.9,
@@ -113,15 +110,19 @@ class _HomeViewState extends State<HomeView> {
await Navigator.of(context).push( await Navigator.of(context).push(
adaptivePageRoute( adaptivePageRoute(
fullscreenDialog: true, fullscreenDialog: true,
builder: (context) => MatchResultView(match: match), builder: (context) =>
MatchResultView(match: match),
), ),
); );
await updatedWinnerInRecentMatches(match.id); await updatedWinnerinRecentMatches(match.id);
}, },
), ),
) )
else else
Center(heightFactor: 5, child: Text(loc.no_recent_matches_available)), Center(
heightFactor: 5,
child: Text(loc.no_recent_matches_available),
),
], ],
), ),
), ),
@@ -137,22 +138,40 @@ class _HomeViewState extends State<HomeView> {
Row( Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly, mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [ children: [
QuickCreateButton(text: 'Category 1', onPressed: () {}), QuickCreateButton(
QuickCreateButton(text: 'Category 2', onPressed: () {}), text: 'Category 1',
onPressed: () {},
),
QuickCreateButton(
text: 'Category 2',
onPressed: () {},
),
], ],
), ),
Row( Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly, mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [ children: [
QuickCreateButton(text: 'Category 3', onPressed: () {}), QuickCreateButton(
QuickCreateButton(text: 'Category 4', onPressed: () {}), text: 'Category 3',
onPressed: () {},
),
QuickCreateButton(
text: 'Category 4',
onPressed: () {},
),
], ],
), ),
Row( Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly, mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [ children: [
QuickCreateButton(text: 'Category 5', onPressed: () {}), QuickCreateButton(
QuickCreateButton(text: 'Category 6', onPressed: () {}), text: 'Category 5',
onPressed: () {},
),
QuickCreateButton(
text: 'Category 6',
onPressed: () {},
),
], ],
), ),
], ],
@@ -181,9 +200,11 @@ class _HomeViewState extends State<HomeView> {
matchCount = results[0] as int; matchCount = results[0] as int;
groupCount = results[1] as int; groupCount = results[1] as int;
loadedRecentMatches = results[2] as List<Match>; loadedRecentMatches = results[2] as List<Match>;
recentMatches = (loadedRecentMatches..sort((a, b) => b.createdAt.compareTo(a.createdAt))) recentMatches =
.take(2) (loadedRecentMatches
.toList(); ..sort((a, b) => b.createdAt.compareTo(a.createdAt)))
.take(2)
.toList();
if (mounted) { if (mounted) {
setState(() { setState(() {
isLoading = false; isLoading = false;
@@ -193,7 +214,7 @@ class _HomeViewState extends State<HomeView> {
} }
/// Updates the winner information for a specific match in the recent matches list. /// Updates the winner information for a specific match in the recent matches list.
Future<void> updatedWinnerInRecentMatches(String matchId) async { Future<void> updatedWinnerinRecentMatches(String matchId) async {
final db = Provider.of<AppDatabase>(context, listen: false); final db = Provider.of<AppDatabase>(context, listen: false);
final winner = await db.matchDao.getWinner(matchId: matchId); final winner = await db.matchDao.getWinner(matchId: matchId);
final matchIndex = recentMatches.indexWhere((match) => match.id == matchId); final matchIndex = recentMatches.indexWhere((match) => match.id == matchId);

View File

@@ -1,9 +1,9 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:tallee/core/custom_theme.dart'; import 'package:game_tracker/core/custom_theme.dart';
import 'package:tallee/core/enums.dart'; import 'package:game_tracker/core/enums.dart';
import 'package:tallee/l10n/generated/app_localizations.dart'; import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/widgets/text_input/custom_search_bar.dart'; import 'package:game_tracker/presentation/widgets/text_input/custom_search_bar.dart';
import 'package:tallee/presentation/widgets/tiles/title_description_list_tile.dart'; import 'package:game_tracker/presentation/widgets/tiles/title_description_list_tile.dart';
class ChooseGameView extends StatefulWidget { class ChooseGameView extends StatefulWidget {
/// A view that allows the user to choose a game from a list of available games /// A view that allows the user to choose a game from a list of available games

View File

@@ -1,10 +1,10 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:tallee/core/custom_theme.dart'; import 'package:game_tracker/core/custom_theme.dart';
import 'package:tallee/data/dto/group.dart'; import 'package:game_tracker/data/dto/group.dart';
import 'package:tallee/l10n/generated/app_localizations.dart'; import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/widgets/text_input/custom_search_bar.dart'; import 'package:game_tracker/presentation/widgets/text_input/custom_search_bar.dart';
import 'package:tallee/presentation/widgets/tiles/group_tile.dart'; import 'package:game_tracker/presentation/widgets/tiles/group_tile.dart';
import 'package:tallee/presentation/widgets/top_centered_message.dart'; import 'package:game_tracker/presentation/widgets/top_centered_message.dart';
class ChooseGroupView extends StatefulWidget { class ChooseGroupView extends StatefulWidget {
/// A view that allows the user to choose a group from a list of groups. /// A view that allows the user to choose a group from a list of groups.

View File

@@ -1,22 +1,21 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:game_tracker/core/adaptive_page_route.dart';
import 'package:game_tracker/core/constants.dart';
import 'package:game_tracker/core/custom_theme.dart';
import 'package:game_tracker/core/enums.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/group.dart';
import 'package:game_tracker/data/dto/match.dart';
import 'package:game_tracker/data/dto/player.dart';
import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:game_tracker/presentation/views/main_menu/match_view/create_match/choose_game_view.dart';
import 'package:game_tracker/presentation/views/main_menu/match_view/create_match/choose_group_view.dart';
import 'package:game_tracker/presentation/views/main_menu/match_view/match_result_view.dart';
import 'package:game_tracker/presentation/widgets/buttons/custom_width_button.dart';
import 'package:game_tracker/presentation/widgets/player_selection.dart';
import 'package:game_tracker/presentation/widgets/text_input/text_input_field.dart';
import 'package:game_tracker/presentation/widgets/tiles/choose_tile.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:tallee/core/adaptive_page_route.dart';
import 'package:tallee/core/constants.dart';
import 'package:tallee/core/custom_theme.dart';
import 'package:tallee/core/enums.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/dto/game.dart';
import 'package:tallee/data/dto/group.dart';
import 'package:tallee/data/dto/match.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:tallee/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/views/main_menu/match_view/create_match/choose_game_view.dart';
import 'package:tallee/presentation/views/main_menu/match_view/create_match/choose_group_view.dart';
import 'package:tallee/presentation/views/main_menu/match_view/match_result_view.dart';
import 'package:tallee/presentation/widgets/buttons/custom_width_button.dart';
import 'package:tallee/presentation/widgets/player_selection.dart';
import 'package:tallee/presentation/widgets/text_input/text_input_field.dart';
import 'package:tallee/presentation/widgets/tiles/choose_tile.dart';
class CreateMatchView extends StatefulWidget { class CreateMatchView extends StatefulWidget {
/// A view that allows creating a new match /// A view that allows creating a new match
@@ -63,7 +62,7 @@ class _CreateMatchViewState extends State<CreateMatchView> {
int selectedGameIndex = -1; int selectedGameIndex = -1;
/// The currently selected players /// The currently selected players
List<Player> selectedPlayers = []; List<Player>? selectedPlayers;
@override @override
void initState() { void initState() {
@@ -100,7 +99,7 @@ class _CreateMatchViewState extends State<CreateMatchView> {
} }
List<(String, String, Ruleset)> games = [ List<(String, String, Ruleset)> games = [
('Example Game 1', 'This is a description', Ruleset.lowestScore), ('Example Game 1', 'This is a description', Ruleset.leastPoints),
('Example Game 2', '', Ruleset.singleWinner), ('Example Game 2', '', Ruleset.singleWinner),
]; ];
@@ -166,8 +165,8 @@ class _CreateMatchViewState extends State<CreateMatchView> {
filteredPlayerList = playerList filteredPlayerList = playerList
.where( .where(
(p) => (p) =>
!selectedGroup!.members.any((m) => m.id == p.id), !selectedGroup!.members.any((m) => m.id == p.id),
) )
.toList(); .toList();
} else { } else {
filteredPlayerList = List.from(playerList); filteredPlayerList = List.from(playerList);
@@ -178,7 +177,7 @@ class _CreateMatchViewState extends State<CreateMatchView> {
Expanded( Expanded(
child: PlayerSelection( child: PlayerSelection(
key: ValueKey(selectedGroup?.id ?? 'no_group'), key: ValueKey(selectedGroup?.id ?? 'no_group'),
initialSelectedPlayers: selectedPlayers, initialSelectedPlayers: selectedPlayers ?? [],
availablePlayers: filteredPlayerList, availablePlayers: filteredPlayerList,
onChanged: (value) { onChanged: (value) {
setState(() { setState(() {
@@ -193,56 +192,28 @@ class _CreateMatchViewState extends State<CreateMatchView> {
buttonType: ButtonType.primary, buttonType: ButtonType.primary,
onPressed: _enableCreateGameButton() onPressed: _enableCreateGameButton()
? () async { ? () async {
// Use a game from the games list Match match = Match(
Game? gameToUse; name: _matchNameController.text.isEmpty
if (selectedGameIndex == -1) { ? (hintText ?? '')
// Use the first game as default if none selected : _matchNameController.text.trim(),
final selectedGame = games[0]; createdAt: DateTime.now(),
gameToUse = Game( group: selectedGroup,
name: selectedGame.$1, players: selectedPlayers,
description: selectedGame.$2, );
ruleset: selectedGame.$3, await db.matchDao.addMatch(match: match);
color: GameColor.blue, if (context.mounted) {
icon: '', Navigator.pushReplacement(
); context,
} else { adaptivePageRoute(
// Use the selected game from the list fullscreenDialog: true,
final selectedGame = games[selectedGameIndex]; builder: (context) => MatchResultView(
gameToUse = Game( match: match,
name: selectedGame.$1, onWinnerChanged: widget.onWinnerChanged,
description: selectedGame.$2, ),
ruleset: selectedGame.$3, ),
color: GameColor.blue, );
icon: '', }
); }
}
// Add the game to the database if it doesn't exist
await db.gameDao.addGame(game: gameToUse);
Match match = Match(
name: _matchNameController.text.isEmpty
? (hintText ?? '')
: _matchNameController.text.trim(),
createdAt: DateTime.now(),
game: gameToUse,
group: selectedGroup,
players: selectedPlayers,
notes: '',
);
await db.matchDao.addMatch(match: match);
if (context.mounted) {
Navigator.pushReplacement(
context,
adaptivePageRoute(
fullscreenDialog: true,
builder: (context) => MatchResultView(
match: match,
onWinnerChanged: widget.onWinnerChanged,
),
),
);
}
}
: null, : null,
), ),
], ],
@@ -259,6 +230,6 @@ class _CreateMatchViewState extends State<CreateMatchView> {
/// - Either a group is selected OR at least 2 players are selected /// - Either a group is selected OR at least 2 players are selected
bool _enableCreateGameButton() { bool _enableCreateGameButton() {
return (selectedGroup != null || return (selectedGroup != null ||
(selectedPlayers.length > 1)); (selectedPlayers != null && selectedPlayers!.length > 1));
} }
} }

View File

@@ -1,11 +1,11 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:game_tracker/core/custom_theme.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/match.dart';
import 'package:game_tracker/data/dto/player.dart';
import 'package:game_tracker/l10n/generated/app_localizations.dart';
import 'package:game_tracker/presentation/widgets/tiles/custom_radio_list_tile.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:tallee/core/custom_theme.dart';
import 'package:tallee/data/db/database.dart';
import 'package:tallee/data/dto/match.dart';
import 'package:tallee/data/dto/player.dart';
import 'package:tallee/l10n/generated/app_localizations.dart';
import 'package:tallee/presentation/widgets/tiles/custom_radio_list_tile.dart';
class MatchResultView extends StatefulWidget { class MatchResultView extends StatefulWidget {
/// A view that allows selecting and saving the winner of a match /// A view that allows selecting and saving the winner of a match
@@ -153,10 +153,12 @@ class _MatchResultViewState extends State<MatchResultView> {
List<Player> getAllPlayers(Match match) { List<Player> getAllPlayers(Match match) {
List<Player> players = []; List<Player> players = [];
if (match.group == null) { if (match.group == null && match.players != null) {
players = [...match.players]; players = [...match.players!];
} else if (match.group != null && match.players != null) {
players = [...match.players!, ...match.group!.members];
} else { } else {
players = [...match.players, ...match.group!.members]; players = [...match.group!.members];
} }
players.sort((a, b) => a.name.compareTo(b.name)); players.sort((a, b) => a.name.compareTo(b.name));

Some files were not shown because too many files have changed in this diff Show More