Compare commits

...

4 Commits

3 changed files with 38 additions and 12 deletions

View File

@ -124,6 +124,19 @@ async fn update_game(
if let Some(existing) = games.iter_mut().find(|g| { if let Some(existing) = games.iter_mut().find(|g| {
(g.remote_id == game.remote_id && g.source == game.source) || (g.title == game.title) (g.remote_id == game.remote_id && g.source == game.source) || (g.title == game.title)
}) { }) {
if existing.title != game.title {
// Update title for every opinion
for person in user_list.lock().await.iter_mut() {
let opinion = person
.person
.opinion
.iter_mut()
.find(|o| o.title == existing.title);
if let Some(opinion) = opinion {
opinion.title = game.title.clone();
}
}
}
existing.title = game.title.clone(); existing.title = game.title.clone();
existing.source = game.source; existing.source = game.source;
existing.min_players = game.min_players; existing.min_players = game.min_players;
@ -133,6 +146,9 @@ async fn update_game(
r_existing = Some(existing.clone()); r_existing = Some(existing.clone());
} }
games.sort_unstable_by(|g1, g2| g1.title.cmp(&g2.title));
let users = user_list.lock().await; let users = user_list.lock().await;
save_state(&games, &users); save_state(&games, &users);
@ -154,7 +170,12 @@ async fn delete_game(
{ {
let game = games.remove(pos); let game = games.remove(pos);
let users = user_list.lock().await; let mut users = user_list.lock().await;
for person in users.iter_mut() {
person.person.opinion.retain_mut(|o| o.title != game.title);
}
save_state(&games, &users); save_state(&games, &users);
return Some(game); return Some(game);

View File

@ -53,7 +53,7 @@ importers:
version: 16.5.0 version: 16.5.0
ts-proto: ts-proto:
specifier: ^2.8.3 specifier: ^2.8.3
version: 2.8.3 version: 2.10.1
typescript: typescript:
specifier: ~5.9.3 specifier: ~5.9.3
version: 5.9.3 version: 5.9.3
@ -152,6 +152,9 @@ packages:
'@bufbuild/protobuf@2.10.1': '@bufbuild/protobuf@2.10.1':
resolution: {integrity: sha512-ckS3+vyJb5qGpEYv/s1OebUHDi/xSNtfgw1wqKZo7MR9F2z+qXr0q5XagafAG/9O0QPVIUfST0smluYSTpYFkg==} resolution: {integrity: sha512-ckS3+vyJb5qGpEYv/s1OebUHDi/xSNtfgw1wqKZo7MR9F2z+qXr0q5XagafAG/9O0QPVIUfST0smluYSTpYFkg==}
'@bufbuild/protobuf@2.10.2':
resolution: {integrity: sha512-uFsRXwIGyu+r6AMdz+XijIIZJYpoWeYzILt5yZ2d3mCjQrWUTVpVD9WL/jZAbvp+Ed04rOhrsk7FiTcEDseB5A==}
'@emnapi/core@1.7.1': '@emnapi/core@1.7.1':
resolution: {integrity: sha512-o1uhUASyo921r2XtHYOHy7gdkGLge8ghBEQHMWmyJFoXlpU58kIrhhN3w26lpQb6dspetweapMn2CSNwQ8I4wg==} resolution: {integrity: sha512-o1uhUASyo921r2XtHYOHy7gdkGLge8ghBEQHMWmyJFoXlpU58kIrhhN3w26lpQb6dspetweapMn2CSNwQ8I4wg==}
@ -425,7 +428,7 @@ packages:
resolution: {integrity: sha512-EcA07pHJouywpzsoTUqNh5NwGayl2PPVEJKUSinGGSxFGYn+shYbqMGBg6FXDqgXum9Ou/ecb+411ssw8HImJQ==} resolution: {integrity: sha512-EcA07pHJouywpzsoTUqNh5NwGayl2PPVEJKUSinGGSxFGYn+shYbqMGBg6FXDqgXum9Ou/ecb+411ssw8HImJQ==}
engines: {node: ^20.19.0 || >=22.12.0} engines: {node: ^20.19.0 || >=22.12.0}
peerDependencies: peerDependencies:
vite: ^4.2.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 vite: npm:rolldown-vite@7.2.5
acorn-jsx@5.3.2: acorn-jsx@5.3.2:
resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==} resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==}
@ -990,11 +993,11 @@ packages:
ts-poet@6.12.0: ts-poet@6.12.0:
resolution: {integrity: sha512-xo+iRNMWqyvXpFTaOAvLPA5QAWO6TZrSUs5s4Odaya3epqofBu/fMLHEWl8jPmjhA0s9sgj9sNvF1BmaQlmQkA==} resolution: {integrity: sha512-xo+iRNMWqyvXpFTaOAvLPA5QAWO6TZrSUs5s4Odaya3epqofBu/fMLHEWl8jPmjhA0s9sgj9sNvF1BmaQlmQkA==}
ts-proto-descriptors@2.0.0: ts-proto-descriptors@2.1.0:
resolution: {integrity: sha512-wHcTH3xIv11jxgkX5OyCSFfw27agpInAd6yh89hKG6zqIXnjW9SYqSER2CVQxdPj4czeOhGagNvZBEbJPy7qkw==} resolution: {integrity: sha512-S5EZYEQ6L9KLFfjSRpZWDIXDV/W7tAj8uW7pLsihIxyr62EAVSiKuVPwE8iWnr849Bqa53enex1jhDUcpgquzA==}
ts-proto@2.8.3: ts-proto@2.10.1:
resolution: {integrity: sha512-TdXInqG+61pj/TvORqITWjvjTTsL1EZxwX49iEj89+xFAcqPT8tjChpAGQXzfcF4MJwvNiuoCEbBOKqVf3ds3g==} resolution: {integrity: sha512-4sOE1hCs0uobJgdRCtcEwdbc8MAyKP+LJqUIKxZIiKac0rPBlVKsRGEGo2oQ1MnKA2Wwk0KuGP2POkiCwPtebw==}
hasBin: true hasBin: true
tslib@2.8.1: tslib@2.8.1:
@ -1169,6 +1172,8 @@ snapshots:
'@bufbuild/protobuf@2.10.1': {} '@bufbuild/protobuf@2.10.1': {}
'@bufbuild/protobuf@2.10.2': {}
'@emnapi/core@1.7.1': '@emnapi/core@1.7.1':
dependencies: dependencies:
'@emnapi/wasi-threads': 1.1.0 '@emnapi/wasi-threads': 1.1.0
@ -1938,16 +1943,16 @@ snapshots:
dependencies: dependencies:
dprint-node: 1.0.8 dprint-node: 1.0.8
ts-proto-descriptors@2.0.0: ts-proto-descriptors@2.1.0:
dependencies: dependencies:
'@bufbuild/protobuf': 2.10.1 '@bufbuild/protobuf': 2.10.1
ts-proto@2.8.3: ts-proto@2.10.1:
dependencies: dependencies:
'@bufbuild/protobuf': 2.10.1 '@bufbuild/protobuf': 2.10.2
case-anything: 2.1.13 case-anything: 2.1.13
ts-poet: 6.12.0 ts-poet: 6.12.0
ts-proto-descriptors: 2.0.0 ts-proto-descriptors: 2.1.0
tslib@2.8.1: tslib@2.8.1:
optional: true optional: true

View File

@ -86,7 +86,7 @@ export function FilteredGamesList({
fontWeight: 600, fontWeight: 600,
}} }}
> >
{price === 0 ? "0 (Free)" : price} {price === 0 ? "0€ (Free)" : `${price}`}
</div> </div>
</div> </div>
<GameImage game={game} /> <GameImage game={game} />