mirror of
https://github.com/hydralauncher/hydra.git
synced 2026-01-19 01:03:57 +00:00
Compare commits
18 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0a86ec89aa | ||
|
|
238d207590 | ||
|
|
98e2d2ec0d | ||
|
|
717dab5c90 | ||
|
|
d73a46aac2 | ||
|
|
9f9a4eba18 | ||
|
|
3bddd7e76b | ||
|
|
7cfc871be2 | ||
|
|
5705de7d7a | ||
|
|
b6fb29ca2d | ||
|
|
e89f459c78 | ||
|
|
0dac4d5cf3 | ||
|
|
93fb26c89b | ||
|
|
446d6b75c0 | ||
|
|
8dd29c7461 | ||
|
|
0ad1a2e3fe | ||
|
|
3c03d5ce16 | ||
|
|
8d8b714c68 |
4
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
4
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
@@ -1,5 +1,5 @@
|
|||||||
name: Bug Report
|
name: Bug Report
|
||||||
description: Create a report to help us improve. Write in English, please.
|
description: Create a report to help us improve. Write in English.
|
||||||
title: "[BUG] Write a title for your bug"
|
title: "[BUG] Write a title for your bug"
|
||||||
labels: ["bug"]
|
labels: ["bug"]
|
||||||
body:
|
body:
|
||||||
@@ -61,3 +61,5 @@ body:
|
|||||||
required: true
|
required: true
|
||||||
- label: I am aware that Hydra team does not offer any support or help regarding the downloaded games.
|
- label: I am aware that Hydra team does not offer any support or help regarding the downloaded games.
|
||||||
required: true
|
required: true
|
||||||
|
- label: I have read the [Frequently Asked Questions (FAQ)](https://github.com/hydralauncher/hydra/wiki/FAQ).
|
||||||
|
required: true
|
||||||
|
|||||||
24
README.md
24
README.md
@@ -13,19 +13,19 @@
|
|||||||
[](https://github.com/hydralauncher/hydra/actions)
|
[](https://github.com/hydralauncher/hydra/actions)
|
||||||
[](https://github.com/hydralauncher/hydra/releases)
|
[](https://github.com/hydralauncher/hydra/releases)
|
||||||
|
|
||||||
[](./README.pt-BR.md)
|
[](./docs/README.pt-BR.md)
|
||||||
[](./README.md)
|
[](./README.md)
|
||||||
[](./README.ru.md)
|
[](./docs/README.ru.md)
|
||||||
[](./README.uk-UA.md)
|
[](./docs/README.uk-UA.md)
|
||||||
[](./README.be.md)
|
[](./docs/README.be.md)
|
||||||
[](./README.es.md)
|
[](./docs/README.es.md)
|
||||||
[](./README.fr.md)
|
[](./docs/README.fr.md)
|
||||||
[](./README.de.md)
|
[](./docs/README.de.md)
|
||||||
[](./README.it.md)
|
[](./docs/README.it.md)
|
||||||
[](./README.cs.md)
|
[](./docs/README.cs.md)
|
||||||
[](./README.da.md)
|
[](./docs/README.da.md)
|
||||||
[](./README.nb.md)
|
[](./docs/README.nb.md)
|
||||||
[](./README.et.md)
|
[](./docs/README.et.md)
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "hydralauncher",
|
"name": "hydralauncher",
|
||||||
"version": "3.0.2",
|
"version": "3.0.4",
|
||||||
"description": "Hydra",
|
"description": "Hydra",
|
||||||
"main": "./out/main/index.js",
|
"main": "./out/main/index.js",
|
||||||
"author": "Los Broxas",
|
"author": "Los Broxas",
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
@@ -312,7 +312,7 @@
|
|||||||
"sending": "Saatmine",
|
"sending": "Saatmine",
|
||||||
"friend_request_sent": "Sõbrakutse saadetud",
|
"friend_request_sent": "Sõbrakutse saadetud",
|
||||||
"friends": "Sõbrad",
|
"friends": "Sõbrad",
|
||||||
"friends_list": "Sõbrade nimekiri",
|
"friends_list": "Sõprade nimekiri",
|
||||||
"user_not_found": "Kasutajat ei leitud",
|
"user_not_found": "Kasutajat ei leitud",
|
||||||
"block_user": "Blokeeri kasutaja",
|
"block_user": "Blokeeri kasutaja",
|
||||||
"add_friend": "Lisa sõbraks",
|
"add_friend": "Lisa sõbraks",
|
||||||
|
|||||||
@@ -57,14 +57,14 @@
|
|||||||
"remove_from_library": "Supprimer de la bibliothèque",
|
"remove_from_library": "Supprimer de la bibliothèque",
|
||||||
"no_downloads": "Aucun téléchargement disponible",
|
"no_downloads": "Aucun téléchargement disponible",
|
||||||
"next_suggestion": "Suggestion suivante",
|
"next_suggestion": "Suggestion suivante",
|
||||||
"play_time": "Joué pour {{montant}}",
|
"play_time": "Joué pour {{amount}}",
|
||||||
"install": "Installer",
|
"install": "Installer",
|
||||||
"play": "Jouer",
|
"play": "Jouer",
|
||||||
"not_played_yet": "Vous n'avez pas encore joué à {{title}}",
|
"not_played_yet": "Vous n'avez pas encore joué à {{title}}",
|
||||||
"close": "Fermer",
|
"close": "Fermer",
|
||||||
"deleting": "Suppression du programme d'installation…",
|
"deleting": "Suppression du programme d'installation…",
|
||||||
"playing_now": "Jeu en cours",
|
"playing_now": "Jeu en cours",
|
||||||
"last_time_played": "Dernièrement joué {{période}}"
|
"last_time_played": "Dernièrement joué {{period}}"
|
||||||
},
|
},
|
||||||
"activation": {
|
"activation": {
|
||||||
"title": "Activer Hydra",
|
"title": "Activer Hydra",
|
||||||
|
|||||||
@@ -130,7 +130,7 @@
|
|||||||
"achievements": "Conquistas",
|
"achievements": "Conquistas",
|
||||||
"achievements_count": "Conquistas ({{unlockedCount}}/{{achievementsCount}})",
|
"achievements_count": "Conquistas ({{unlockedCount}}/{{achievementsCount}})",
|
||||||
"cloud_save": "Salvamento em nuvem",
|
"cloud_save": "Salvamento em nuvem",
|
||||||
"cloud_save_description": "Matenha seu progresso na nuvem e continue de onde parou em qualquer dispositivo",
|
"cloud_save_description": "Mantenha seu progresso na nuvem e continue de onde parou em qualquer dispositivo",
|
||||||
"backups": "Backups",
|
"backups": "Backups",
|
||||||
"install_backup": "Restaurar",
|
"install_backup": "Restaurar",
|
||||||
"delete_backup": "Apagar",
|
"delete_backup": "Apagar",
|
||||||
@@ -190,7 +190,7 @@
|
|||||||
"install": "Instalar",
|
"install": "Instalar",
|
||||||
"download_in_progress": "Baixando agora",
|
"download_in_progress": "Baixando agora",
|
||||||
"queued_downloads": "Na fila",
|
"queued_downloads": "Na fila",
|
||||||
"downloads_completed": "Completo",
|
"downloads_completed": "Concluído",
|
||||||
"queued": "Na fila",
|
"queued": "Na fila",
|
||||||
"no_downloads_title": "Nada por aqui…",
|
"no_downloads_title": "Nada por aqui…",
|
||||||
"no_downloads_description": "Você ainda não baixou nada pelo Hydra, mas nunca é tarde para começar.",
|
"no_downloads_description": "Você ainda não baixou nada pelo Hydra, mas nunca é tarde para começar.",
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ const { autoUpdater } = updater;
|
|||||||
const restartAndInstallUpdate = async (_event: Electron.IpcMainInvokeEvent) => {
|
const restartAndInstallUpdate = async (_event: Electron.IpcMainInvokeEvent) => {
|
||||||
autoUpdater.removeAllListeners();
|
autoUpdater.removeAllListeners();
|
||||||
if (app.isPackaged) {
|
if (app.isPackaged) {
|
||||||
autoUpdater.quitAndInstall(true, true);
|
autoUpdater.quitAndInstall(false);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -24,6 +24,7 @@ const createGameShortcut = async (
|
|||||||
const options = {
|
const options = {
|
||||||
filePath,
|
filePath,
|
||||||
name: removeSymbolsFromName(game.title),
|
name: removeSymbolsFromName(game.title),
|
||||||
|
outputPath: app.getPath("desktop"),
|
||||||
};
|
};
|
||||||
|
|
||||||
return createDesktopShortcut({
|
return createDesktopShortcut({
|
||||||
|
|||||||
@@ -219,7 +219,6 @@ export class AchievementWatcherManager {
|
|||||||
const games = await gameRepository.find({
|
const games = await gameRepository.find({
|
||||||
where: {
|
where: {
|
||||||
isDeleted: false,
|
isDeleted: false,
|
||||||
winePrefixPath: Not(IsNull()),
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,6 @@ import { HydraApi } from "../hydra-api";
|
|||||||
import { getUnlockedAchievements } from "@main/events/user/get-unlocked-achievements";
|
import { getUnlockedAchievements } from "@main/events/user/get-unlocked-achievements";
|
||||||
import { Game } from "@main/entity";
|
import { Game } from "@main/entity";
|
||||||
import { achievementsLogger } from "../logger";
|
import { achievementsLogger } from "../logger";
|
||||||
import { SubscriptionRequiredError } from "@shared";
|
|
||||||
|
|
||||||
const saveAchievementsOnLocal = async (
|
const saveAchievementsOnLocal = async (
|
||||||
objectId: string,
|
objectId: string,
|
||||||
@@ -119,14 +118,10 @@ export const mergeAchievements = async (
|
|||||||
const mergedLocalAchievements = unlockedAchievements.concat(newAchievements);
|
const mergedLocalAchievements = unlockedAchievements.concat(newAchievements);
|
||||||
|
|
||||||
if (game.remoteId) {
|
if (game.remoteId) {
|
||||||
await HydraApi.put(
|
await HydraApi.put("/profile/games/achievements", {
|
||||||
"/profile/games/achievements",
|
id: game.remoteId,
|
||||||
{
|
achievements: mergedLocalAchievements,
|
||||||
id: game.remoteId,
|
})
|
||||||
achievements: mergedLocalAchievements,
|
|
||||||
},
|
|
||||||
{ needsSubscription: true }
|
|
||||||
)
|
|
||||||
.then((response) => {
|
.then((response) => {
|
||||||
return saveAchievementsOnLocal(
|
return saveAchievementsOnLocal(
|
||||||
response.objectId,
|
response.objectId,
|
||||||
@@ -136,9 +131,7 @@ export const mergeAchievements = async (
|
|||||||
);
|
);
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
if (!(err instanceof SubscriptionRequiredError)) {
|
achievementsLogger.error(err);
|
||||||
achievementsLogger.error(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
return saveAchievementsOnLocal(
|
return saveAchievementsOnLocal(
|
||||||
game.objectID,
|
game.objectID,
|
||||||
|
|||||||
@@ -167,7 +167,7 @@ export function GameDetailsContent() {
|
|||||||
>
|
>
|
||||||
<Lottie
|
<Lottie
|
||||||
animationData={cloudAnimation}
|
animationData={cloudAnimation}
|
||||||
loop
|
loop={false}
|
||||||
autoplay
|
autoplay
|
||||||
style={{ width: 26, position: "absolute", top: -3 }}
|
style={{ width: 26, position: "absolute", top: -3 }}
|
||||||
/>
|
/>
|
||||||
|
|||||||
@@ -202,7 +202,7 @@ export default function GameDetails() {
|
|||||||
top: -28,
|
top: -28,
|
||||||
left: -27,
|
left: -27,
|
||||||
}}
|
}}
|
||||||
loop
|
loop={false}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
{t("next_suggestion")}
|
{t("next_suggestion")}
|
||||||
|
|||||||
@@ -126,7 +126,7 @@ export default function Home() {
|
|||||||
<Lottie
|
<Lottie
|
||||||
lottieRef={flameAnimationRef}
|
lottieRef={flameAnimationRef}
|
||||||
animationData={flameAnimation}
|
animationData={flameAnimation}
|
||||||
loop
|
loop={false}
|
||||||
autoplay={false}
|
autoplay={false}
|
||||||
style={{
|
style={{
|
||||||
width: 30,
|
width: 30,
|
||||||
@@ -153,7 +153,7 @@ export default function Home() {
|
|||||||
<Lottie
|
<Lottie
|
||||||
animationData={starsAnimation}
|
animationData={starsAnimation}
|
||||||
style={{ width: 70, position: "absolute", top: -28, left: -27 }}
|
style={{ width: 70, position: "absolute", top: -28, left: -27 }}
|
||||||
loop={Boolean(randomGame)}
|
loop={false}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
{t("surprise_me")}
|
{t("surprise_me")}
|
||||||
@@ -165,7 +165,7 @@ export default function Home() {
|
|||||||
<div style={{ width: 24, height: 24, position: "relative" }}>
|
<div style={{ width: 24, height: 24, position: "relative" }}>
|
||||||
<Lottie
|
<Lottie
|
||||||
animationData={flameAnimation}
|
animationData={flameAnimation}
|
||||||
loop
|
loop={false}
|
||||||
autoplay
|
autoplay
|
||||||
style={{
|
style={{
|
||||||
width: 40,
|
width: 40,
|
||||||
|
|||||||
Reference in New Issue
Block a user