Compare commits

..

1 commit

Author SHA1 Message Date
dependabot[bot]
1ead7d6638
Update ws requirement from ^8.8.0 to ^8.8.1
Updates the requirements on [ws](https://github.com/websockets/ws) to permit the latest version.
- [Release notes](https://github.com/websockets/ws/releases)
- [Commits](https://github.com/websockets/ws/compare/8.8.0...8.8.1)

---
updated-dependencies:
- dependency-name: ws
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2022-07-18 18:54:47 +00:00
24 changed files with 278 additions and 467 deletions

View file

@ -31,7 +31,7 @@
"settings-channel-desc2": "you're probably most familiar with this one. It's the one you see in default Discord\n client!", "settings-channel-desc2": "you're probably most familiar with this one. It's the one you see in default Discord\n client!",
"settings-channel-desc3": "this is alpha test release of Discord. By using it you gain access to the newest\n features and fixes.", "settings-channel-desc3": "this is alpha test release of Discord. By using it you gain access to the newest\n features and fixes.",
"settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.", "settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.",
"settings-channel-desc5": "unofficial instance of Discord that takes you back to 2016! Only client mod\n available to run alongside with it is Cordwood. It's run by community, so you take all the risk by\n using it.", "settings-channel-desc5": "unofficial instance of Discord that takes you back to 2016! None of the client mods\n bundled with ArmCord work with it. It's run by community, so you take all the risk by using it.",
"settings-invitewebsocket": "Invite Websocket", "settings-invitewebsocket": "Invite Websocket",
"settings-invitewebsocket-desc": "When enabled ArmCord will support Discord.gg links which means that if you open an invite link in your\n browser, ArmCord will automatically accept the invite. Can be unresponsive at times.", "settings-invitewebsocket-desc": "When enabled ArmCord will support Discord.gg links which means that if you open an invite link in your\n browser, ArmCord will automatically accept the invite. Can be unresponsive at times.",
"settings-altPaste": "Alternative Paste", "settings-altPaste": "Alternative Paste",

View file

@ -2,8 +2,8 @@
"loading_screen_start": "Démarrage d'ArmCord…", "loading_screen_start": "Démarrage d'ArmCord…",
"loading_screen_update": "Une nouvelle version d'ArmCord est disponible. Veuillez mettre à jour vers la dernière version.", "loading_screen_update": "Une nouvelle version d'ArmCord est disponible. Veuillez mettre à jour vers la dernière version.",
"setup_question1": "Sélectionnez le type de configuration que vous souhaitez effectuer :", "setup_question1": "Sélectionnez le type de configuration que vous souhaitez effectuer :",
"setup_question1_answer1": "Configuration Express", "setup_question1_answer1": "Configuration express",
"setup_question1_answer2": "Configuration Complète", "setup_question1_answer2": "Configuration complète",
"setup_question2": "Choisissez votre canal/instance Discord :", "setup_question2": "Choisissez votre canal/instance Discord :",
"setup_question3": "ArmCord doit-il s'occuper de l'installation des mods clients ?", "setup_question3": "ArmCord doit-il s'occuper de l'installation des mods clients ?",
"yes": "Oui", "yes": "Oui",
@ -18,7 +18,7 @@
"settings-mod": "Modification client :", "settings-mod": "Modification client :",
"settings-save": "Sauvegarder les paramètres", "settings-save": "Sauvegarder les paramètres",
"settings-updater": "Vérifier les mises à jour", "settings-updater": "Vérifier les mises à jour",
"settings-theme": "Thème ArmCord", "settings-theme": "Thème ArmCord :",
"settings-theme-default": "Default", "settings-theme-default": "Default",
"settings-theme-native": "Native", "settings-theme-native": "Native",
"settings-patches": "Correctifs automatiques", "settings-patches": "Correctifs automatiques",
@ -28,7 +28,7 @@
"settings-prfmMode-battery": "Batterie", "settings-prfmMode-battery": "Batterie",
"settings-none": "Aucun", "settings-none": "Aucun",
"settings-mobileMode": "Mobile mode", "settings-mobileMode": "Mobile mode",
"settings-theme-desc1": "Les \"thèmes\" d'ArmCord gèrent le comportement et l'apparence des applications.", "settings-theme-desc1": "ArmCord \"themes\" manage apps behaviour and looks.",
"settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.", "settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.",
"settings-altPaste": "Alternative Paste", "settings-altPaste": "Alternative Paste",
"settings-storageFolder": "Open storage folder", "settings-storageFolder": "Open storage folder",

View file

@ -1,56 +0,0 @@
{
"setup_question1_answer2": "Full Setup",
"yes": "Yes",
"settings-theme-default": "Default",
"settings-invitewebsocket": "Invite Websocket",
"settings-mod-desc4": "heavily work in progress, doesn't have a working UI.",
"loading_screen_start": "Starting ArmCord…",
"loading_screen_offline": "You appear to be offline. Please connect to the Internet and try again.",
"loading_screen_update": "A new version of ArmCord is available. Please update to the latest version.",
"setup_question1": "Select what kind of setup you want to perform:",
"setup_question1_answer1": "Express Setup",
"setup_offline": "You appear to be offline. Please connect to the internet and restart ArmCord.",
"setup_question2": "Choose your Discord channel/instance:",
"setup_question3": "Should ArmCord handle client mods installation?",
"no": "No",
"next": "Next",
"setup_question4": "Select a client mod you want to install:",
"setup_question4_clientmodnotice": "Why not all of them? Having many client mods at the same time can cause issues. If you really want to do it though, check our Discord.",
"settings-theme": "ArmCord theme",
"settings-theme-desc1": "ArmCord \"themes\" manage apps behaviour and looks.",
"settings-theme-desc2": "this is how ArmCord looks when you first launch it. It includes recreation of Discord's\n custom titlebar and ArmCord specific styles injected into Discord.",
"settings-theme-desc3": "uses native titlebar of OS you're currently running (e.g Windows 7/10). Functions more\n similar to actual Discord app on Linux.",
"settings-theme-native": "Native",
"settings-csp-desc": "ArmCord CSP is our system that manages loading custom content loading into the Discord app. Stuff like\n client mods and themes depend on it. Disable if you want to get rid of mods and custom styles.",
"settings-tray": "Minimize to tray",
"settings-tray-desc": "When disabled, ArmCord will close like any other window when closed, otherwise it'll sit back and relax\n in your system tray for later.",
"settings-patches": "Automatic Patches",
"settings-patches-desk": "Fetches automatic patches that are distributed if release turns out to have bugs after release. Usually\n you don't have to keep this enabled, unless notified in support Discord.",
"settings-mobileMode": "Mobile mode",
"settings-mobileMode-desc": "If you're on a device with touch-screen this feature is for you! It activates Discord's hidden mobile\n mode meant for phones and tablets. Only major feature missing is voice chat support. This is ideal for\n users on PinePhone and similar.",
"settings-channel": "Discord channel",
"settings-channel-desc1": "You can use this setting to change current instance of Discord:",
"settings-channel-desc2": "you're probably most familiar with this one. It's the one you see in default Discord\n client!",
"settings-channel-desc3": "this is alpha test release of Discord. By using it you gain access to the newest\n features and fixes.",
"settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.",
"settings-channel-desc5": "unofficial instance of Discord that takes you back to 2016! Only client mod\n available to run alongside with it is Cordwood. It's run by community, so you take all the risk by\n using it.",
"settings-invitewebsocket-desc": "When enabled ArmCord will support Discord.gg links which means that if you open an invite link in your\n browser, ArmCord will automatically accept the invite. Can be unresponsive at times.",
"settings-altPaste": "Alternative Paste",
"settings-altPaste-desc": "If you're on Gnome on Linux or just simply can't paste images copied from other messages, then this is\n for you. This enables alternative module for pasting images. Only enable this when you're experiencing\n issues.",
"settings-mod": "Client mod",
"settings-mod-desc1": "Client mods are programs that allow you customize your Discord experience. They can change appearance of\n the client, modify behaviours or add new features!",
"settings-mod-desc2": "focuses on making the Discord plugin development experience easier. Minimal and\n lightweight.",
"settings-mod-desc3": "light, secure, and easy to use, with out of the box experience. Features a built-in\n store for plugins.",
"settings-prfmMode": "Performance mode is an experimental function that may either increase responsiveness and performance of\n ArmCord or... decrease it. Please try every option and see which fits you the best.",
"settings-prfmMode-performance": "Performance",
"settings-prfmMode-battery": "Battery",
"settings-trayIcon": "Tray icon",
"settings-trayIcon-desc": "Set the icon which will appear in tray menu.",
"settings-advanced": "Advanced user zone",
"settings-pluginsFolder": "Open plugins folder",
"settings-themesFolder": "Open themes folder",
"settings-storageFolder": "Open storage folder",
"settings-none": "None",
"settings-save": "Save Settings",
"settings-updater": "Check for updates"
}

View file

@ -12,7 +12,7 @@
"loading_screen_offline": "Wydaje nam się, że nie jesteś połączony z Internetem. Połącz się z internetem i spróbuj ponownie.", "loading_screen_offline": "Wydaje nam się, że nie jesteś połączony z Internetem. Połącz się z internetem i spróbuj ponownie.",
"setup_question1_answer1": "Ekspresowa konfiguracja", "setup_question1_answer1": "Ekspresowa konfiguracja",
"setup_question1": "Wybierz w jaki sposób chcesz skonfigurować ArmCord:", "setup_question1": "Wybierz w jaki sposób chcesz skonfigurować ArmCord:",
"setup_offline": "Wydaje nam się, że nie jesteś połączony z internetem. Połącz się z internetem i uruchom ponownie konfiguracje ArmCord.", "setup_offline": "Wydaje nam się że nie jesteś połączony z internetem. Połącz się z internetem i uruchom ponownie konfiguracje ArmCord .",
"settings-channel": "Kanał Discorda", "settings-channel": "Kanał Discorda",
"settings-updater": "Sprawdź aktualizacje", "settings-updater": "Sprawdź aktualizacje",
"settings-tray": "Zminimalizuj do zasobnika zadań", "settings-tray": "Zminimalizuj do zasobnika zadań",

View file

@ -1,56 +1,56 @@
{ {
"no": "Não", "no": "Não",
"loading_screen_start": "Iniciando ArmCord…", "loading_screen_start": "Iniciando ArmCord…",
"loading_screen_offline": "Você parece estar offline. Por favor, conecte-se à internet e tente novamente.", "loading_screen_offline": "Você parece estar offline. Conecte-se à internet e tente novamente.",
"loading_screen_update": "Uma nova versão do ArmCord está disponível. Por favor, atualize para a versão mais recente.", "loading_screen_update": "Uma nova versão do ArmCord está disponível. Atualize para a versão mais recente.",
"setup_question1": "Selecione que tipo de instação você deseja fazer:", "setup_question1": "Selecione que tipo de instação você quer fazer:",
"setup_question1_answer1": "Instalação rápida", "setup_question1_answer1": "Instalação rápida",
"setup_question1_answer2": "Instalação completa", "setup_question1_answer2": "Instalação completa",
"setup_offline": "Você parece estar offline. Por favor, conecte-se à internet e tente novamente.", "setup_offline": "Você parece estar offline. Conecte-se à internet e tente novamente.",
"setup_question2": "Escolha o canal/instância do seu Discord:", "setup_question2": "Escolha o canal/instância do seu Discord",
"setup_question3": "O ArmCord deve lidar com a instalação de mods do cliente?", "setup_question3": "O ArmCord deve suportar a instalação dos mods de cliente?",
"yes": "Sim", "yes": "Sim",
"next": "Próximo", "next": "Próximo",
"setup_question4": "Selecione um mod de cliente que você deseja instalar:", "setup_question4": "Selecione um mod de cliente que você quer instalar:",
"setup_question4_clientmodnotice": "Por que não todos eles? Ter muitos mods de cliente ao mesmo tempo pode causar problemas. Se você realmente quiser fazer isso, verifique nosso Discord.", "setup_question4_clientmodnotice": "Por que não todos eles? Tendo vários mods de cliente ao mesmo tempo pode causar problemas, Se você realmente quer fazer isso mesmo assim, veja o nosso Discord.",
"settings-theme": "Tema do ArmCord", "settings-theme": "Tema do ArmCord:",
"settings-theme-default": "Padrão", "settings-theme-default": "Padrão",
"settings-theme-native": "Nativo", "settings-theme-native": "Nativo",
"settings-tray": "Minimizar para a bandeja", "settings-tray": "Minimizar para a bandeja",
"settings-patches": "Patches automáticos", "settings-patches": "Patches automáticos",
"settings-channel": "Canal do Discord", "settings-channel": "Tipo de Discord:",
"settings-invitewebsocket": "Convite por WebSocket", "settings-invitewebsocket": "Invite Websocket",
"settings-mod": "Modificação de cliente", "settings-mod": "Client mod:",
"settings-prfmMode": "O modo de desempenho é uma função experimental que pode aumentar a capacidade de resposta e o desempenho\n do ArmCord, ou... diminuí-lo. Por favor, teste todas as opções e veja qual se adapta melhor a você.", "settings-prfmMode": "Performance mode:",
"settings-prfmMode-performance": "Desempenho", "settings-prfmMode-performance": "Performance",
"settings-prfmMode-battery": "Bateria", "settings-prfmMode-battery": "Battery",
"settings-none": "Nenhum", "settings-none": "None",
"settings-save": "Salvar configurações", "settings-save": "Save Settings",
"settings-updater": "Verificar atualizações", "settings-updater": "Check for updates",
"settings-mobileMode": "Modo móvel", "settings-mobileMode": "Mobile mode",
"settings-channel-desc1": "Você pode usar esta opção para alterar a atual instância do Discord:", "settings-channel-desc1": "You can use this setting to change current instance of Discord:",
"settings-theme-desc1": "Os \"temas\" do ArmCord gerenciam o comportamento e a aparência de aplicativos.", "settings-theme-desc1": "ArmCord \"themes\" manage apps behaviour and looks.",
"settings-theme-desc2": "esta é a aparência do ArmCord quando você o inicia pela primeira vez. Inclui uma recriação\n personalizada da barra de título do Discord e estilos específicos do ArmCord injetados nele.", "settings-theme-desc2": "this is how ArmCord looks when you first launch it. It includes recreation of Discord's\n custom titlebar and ArmCord specific styles injected into Discord.",
"settings-theme-desc3": "utiliza a barra de título nativa do SO que você está executando no momento (no Windows 7/10). Funções mais\n parecidas com o real aplicativo do Discord no Linux.", "settings-theme-desc3": "uses native titlebar of OS you're currently running (e.g Windows 7/10). Functions more\n similar to actual Discord app on Linux.",
"settings-csp-desc": "ArmCord CSP é o nosso sistema que gerencia o carregamento de conteúdo personalizado no aplicativo do Discord. Coisas como\n mods de cliente e temas dependem disso. Desative se você quiser se livrar de mods e estilos personalizados.", "settings-csp-desc": "ArmCord CSP is our system that manages loading custom content loading into the Discord app. Stuff like\n client mods and themes depend on it. Disable if you want to get rid of mods and custom styles.",
"settings-patches-desk": "Busca patches automáticos que são distribuídos se a versão mais recente apresentar bugs após o lançamento. Normalmente\n você não precisa manter isso ativado, a menos que seja notificado no suporte do Discord.", "settings-patches-desk": "Fetches automatic patches that are distributed if release turns out to have bugs after release. Usually\n you don't have to keep this enabled, unless notified in support Discord.",
"settings-mobileMode-desc": "Se estiver em um dispositivo com tela sensível ao toque, este recurso é para você! Ele ativa o modo móvel oculto do Discord\n destinado a celulares e tablets. A única característica importante ausente é o suporte ao bate-papo por voz. Isso é ideal para\n usuários do PinePhone e similares.", "settings-mobileMode-desc": "If you're on a device with touch-screen this feature is for you! It activates Discord's hidden mobile\n mode meant for phones and tablets. Only major feature missing is voice chat support. This is ideal for\n users on PinePhone and similar.",
"settings-tray-desc": "Quando desativado, o ArmCord irá encerrar como qualquer outra janela quando for fechado, caso contrário, permanecerá\n em repouso na bandeja do seu sistema para mais tarde.", "settings-tray-desc": "When disabled, ArmCord will close like any other window when closed, otherwise it'll sit back and relax\n in your system tray for later.",
"settings-channel-desc2": "você provavelmente está mais familiarizado com este. É o que você vê no cliente padrão do\n Discord!", "settings-channel-desc2": "you're probably most familiar with this one. It's the one you see in default Discord\n client!",
"settings-channel-desc3": "esta é a versão de teste alfa do Discord. Ao utilizá-la, você obtém acesso aos recursos e correções\n mais recentes.", "settings-channel-desc3": "this is alpha test release of Discord. By using it you gain access to the newest\n features and fixes.",
"settings-invitewebsocket-desc": "Quando ativado, o ArmCord suportará links Discord.gg; isto é, se você abrir um link de convite em seu\n navegador, o ArmCord irá aceitá-lo automaticamente. Pode não responder às vezes.", "settings-invitewebsocket-desc": "When enabled ArmCord will support Discord.gg links which means that if you open an invite link in your\n browser, ArmCord will automatically accept the invite. Can be unresponsive at times.",
"settings-channel-desc4": "canal de teste público. Recebe recursos mais cedo do que o estável, mas é um pouco mais antigo do que o Canary.", "settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.",
"settings-altPaste": "Colar alternativo", "settings-altPaste": "Alternative Paste",
"settings-altPaste-desc": "Se você usa GNOME no Linux, ou simplesmente não consegue colar imagens copiadas a partir de outras mensagens, então isto é\n para você. Isto habilita o módulo alternativo para colar imagens. Ative isso apenas quando estiver com\n problemas.", "settings-altPaste-desc": "If you're on Gnome on Linux or just simply can't paste images copied from other messages, then this is\n for you. This enables alternative module for pasting images. Only enable this when you're experiencing\n issues.",
"settings-channel-desc5": "instância não oficial do Discord que leva você de volta a 2016! O único cliente modificado\n disponível para rodar junto com ele é o Cordwood. É administrado pela comunidade, portanto você assume todos os riscos\n ao utilizá-lo.", "settings-channel-desc5": "unofficial instance of Discord that takes you back to 2016! None of the client mods\n bundled with ArmCord work with it. It's run by community, so you take all the risk by using it.",
"settings-mod-desc1": "Mods de cliente são programas que permitem personalizar sua experiência no Discord. Eles podem alterar a aparência\n do cliente, modificar comportamentos ou adicionar novos recursos!", "settings-mod-desc1": "Client mods are programs that allow you customize your Discord experience. They can change appearance of\n the client, modify behaviours or add new features!",
"settings-mod-desc2": "concentra-se em tornar a experiência de desenvolvimento de plugins para o Discord mais fácil. Mínimo e\n leve.", "settings-mod-desc2": "focuses on making the Discord plugin development experience easier. Minimal and\n lightweight.",
"settings-mod-desc3": "leve, seguro e fácil, já pronto para usar. Possui uma loja integrada\n para plugins.", "settings-mod-desc3": "light, secure, and easy to use, with out of the box experience. Features a built-in\n store for plugins.",
"settings-mod-desc4": "trabalho pesado em andamento, não possui uma interface do usuário funcional.", "settings-mod-desc4": "heavily work in progress, doesn't have a working UI.",
"settings-trayIcon": "Ícone da bandeja", "settings-trayIcon": "Tray icon",
"settings-trayIcon-desc": "Defina o ícone que aparecerá no menu da bandeja.", "settings-trayIcon-desc": "Set the icon which will appear in tray menu.",
"settings-advanced": "Área para usuários avançados", "settings-advanced": "Advanced user zone",
"settings-pluginsFolder": "Abrir pasta de plugins", "settings-pluginsFolder": "Open plugins folder",
"settings-themesFolder": "Abrir pasta de temas", "settings-themesFolder": "Open themes folder",
"settings-storageFolder": "Abrir pasta de armazenamento" "settings-storageFolder": "Open storage folder"
} }

View file

@ -1,56 +0,0 @@
{
"loading_screen_start": "Starting ArmCord…",
"loading_screen_offline": "You appear to be offline. Please connect to the Internet and try again.",
"loading_screen_update": "A new version of ArmCord is available. Please update to the latest version.",
"setup_question1": "Select what kind of setup you want to perform:",
"setup_question1_answer1": "Express Setup",
"setup_question1_answer2": "Full Setup",
"setup_offline": "You appear to be offline. Please connect to the internet and restart ArmCord.",
"setup_question2": "Choose your Discord channel/instance:",
"setup_question3": "Should ArmCord handle client mods installation?",
"yes": "Yes",
"no": "No",
"next": "Next",
"setup_question4": "Select a client mod you want to install:",
"setup_question4_clientmodnotice": "Why not all of them? Having many client mods at the same time can cause issues. If you really want to do it though, check our Discord.",
"settings-theme": "ArmCord theme",
"settings-theme-desc1": "ArmCord \"themes\" manage apps behaviour and looks.",
"settings-theme-desc2": "this is how ArmCord looks when you first launch it. It includes recreation of Discord's\n custom titlebar and ArmCord specific styles injected into Discord.",
"settings-theme-desc3": "uses native titlebar of OS you're currently running (e.g Windows 7/10). Functions more\n similar to actual Discord app on Linux.",
"settings-theme-default": "Default",
"settings-theme-native": "Native",
"settings-mod": "Client mod",
"settings-prfmMode-performance": "Performance",
"settings-mod-desc2": "focuses on making the Discord plugin development experience easier. Minimal and\n lightweight.",
"settings-csp-desc": "ArmCord CSP is our system that manages loading custom content loading into the Discord app. Stuff like\n client mods and themes depend on it. Disable if you want to get rid of mods and custom styles.",
"settings-tray": "Minimize to tray",
"settings-tray-desc": "When disabled, ArmCord will close like any other window when closed, otherwise it'll sit back and relax\n in your system tray for later.",
"settings-patches": "Automatic Patches",
"settings-patches-desk": "Fetches automatic patches that are distributed if release turns out to have bugs after release. Usually\n you don't have to keep this enabled, unless notified in support Discord.",
"settings-mobileMode": "Mobile mode",
"settings-mobileMode-desc": "If you're on a device with touch-screen this feature is for you! It activates Discord's hidden mobile\n mode meant for phones and tablets. Only major feature missing is voice chat support. This is ideal for\n users on PinePhone and similar.",
"settings-channel": "Discord channel",
"settings-channel-desc1": "You can use this setting to change current instance of Discord:",
"settings-channel-desc2": "you're probably most familiar with this one. It's the one you see in default Discord\n client!",
"settings-channel-desc3": "this is alpha test release of Discord. By using it you gain access to the newest\n features and fixes.",
"settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.",
"settings-channel-desc5": "unofficial instance of Discord that takes you back to 2016! Only client mod\n available to run alongside with it is Cordwood. It's run by community, so you take all the risk by\n using it.",
"settings-invitewebsocket": "Invite Websocket",
"settings-invitewebsocket-desc": "When enabled ArmCord will support Discord.gg links which means that if you open an invite link in your\n browser, ArmCord will automatically accept the invite. Can be unresponsive at times.",
"settings-altPaste": "Alternative Paste",
"settings-altPaste-desc": "If you're on Gnome on Linux or just simply can't paste images copied from other messages, then this is\n for you. This enables alternative module for pasting images. Only enable this when you're experiencing\n issues.",
"settings-mod-desc1": "Client mods are programs that allow you customize your Discord experience. They can change appearance of\n the client, modify behaviours or add new features!",
"settings-mod-desc3": "light, secure, and easy to use, with out of the box experience. Features a built-in\n store for plugins.",
"settings-mod-desc4": "heavily work in progress, doesn't have a working UI.",
"settings-prfmMode": "Performance mode is an experimental function that may either increase responsiveness and performance of\n ArmCord or... decrease it. Please try every option and see which fits you the best.",
"settings-prfmMode-battery": "Battery",
"settings-trayIcon": "Tray icon",
"settings-trayIcon-desc": "Set the icon which will appear in tray menu.",
"settings-advanced": "Advanced user zone",
"settings-pluginsFolder": "Open plugins folder",
"settings-themesFolder": "Open themes folder",
"settings-storageFolder": "Open storage folder",
"settings-none": "None",
"settings-save": "Save Settings",
"settings-updater": "Check for updates"
}

View file

@ -14,7 +14,7 @@
"setup_question4": "เลือกไคลเอนต์มอดที่ต้องการติดตั้ง:", "setup_question4": "เลือกไคลเอนต์มอดที่ต้องการติดตั้ง:",
"settings-prfmMode-battery": "ประหยัดแบตเตอรี่", "settings-prfmMode-battery": "ประหยัดแบตเตอรี่",
"setup_question4_clientmodnotice": "ทำไมไม่ใช้พร้อมกันทั้งหมดล่ะ? การมีไคลเอนต์มอดหลายตัวพร้อมกันอาจทำให้เกิดปัญหาได้ หากต้องการที่จะทำจริงๆ ให้ไปดูใน Discord ของเรา", "setup_question4_clientmodnotice": "ทำไมไม่ใช้พร้อมกันทั้งหมดล่ะ? การมีไคลเอนต์มอดหลายตัวพร้อมกันอาจทำให้เกิดปัญหาได้ หากต้องการที่จะทำจริงๆ ให้ไปดูใน Discord ของเรา",
"settings-theme": "ธีม ArmCord", "settings-theme": "ธีม ArmCord:",
"settings-theme-default": "ค่าเริ่มต้น", "settings-theme-default": "ค่าเริ่มต้น",
"settings-theme-native": "ดั้งเดิม", "settings-theme-native": "ดั้งเดิม",
"settings-tray": "ย่อขนาดหน้าต่าง", "settings-tray": "ย่อขนาดหน้าต่าง",
@ -28,17 +28,17 @@
"settings-save": "บันทึกการตั้งค่า", "settings-save": "บันทึกการตั้งค่า",
"settings-updater": "ตรวจหาการอัปเดต", "settings-updater": "ตรวจหาการอัปเดต",
"settings-mobileMode": "โหมดมือถือ", "settings-mobileMode": "โหมดมือถือ",
"settings-theme-desc1": "\"ธีม\" ของ ArmCord เป็นการจัดการลักษณะและการทำงานของแอป", "settings-theme-desc1": "ArmCord \"themes\" manage apps behaviour and looks.",
"settings-patches-desk": "Fetches automatic patches that are distributed if release turns out to have bugs after release. Usually\n you don't have to keep this enabled, unless notified in support Discord.", "settings-patches-desk": "Fetches automatic patches that are distributed if release turns out to have bugs after release. Usually\n you don't have to keep this enabled, unless notified in support Discord.",
"settings-mobileMode-desc": "If you're on a device with touch-screen this feature is for you! It activates Discord's hidden mobile\n mode meant for phones and tablets. Only major feature missing is voice chat support. This is ideal for\n users on PinePhone and similar.", "settings-mobileMode-desc": "If you're on a device with touch-screen this feature is for you! It activates Discord's hidden mobile\n mode meant for phones and tablets. Only major feature missing is voice chat support. This is ideal for\n users on PinePhone and similar.",
"settings-channel-desc1": "You can use this setting to change current instance of Discord:", "settings-channel-desc1": "You can use this setting to change current instance of Discord:",
"settings-channel-desc2": "you're probably most familiar with this one. It's the one you see in default Discord\n client!", "settings-channel-desc2": "you're probably most familiar with this one. It's the one you see in default Discord\n client!",
"settings-altPaste": "Alternative Paste", "settings-altPaste": "Alternative Paste",
"settings-trayIcon": "Tray icon", "settings-trayIcon": "Tray icon",
"settings-theme-desc2": "นี่คือหน้าตา ArmCord ตอนที่เปิดครั้งแรก เป็นการปรับปรุงจากหน้าตาเดิมของ Discord\n แถบชื่อหน้าต่างและหน้าตาใหม่ ๆ ที่ ArmCord เปลี่ยน Discord", "settings-theme-desc2": "this is how ArmCord looks when you first launch it. It includes recreation of Discord's\n custom titlebar and ArmCord specific styles injected into Discord.",
"settings-theme-desc3": "ใช้แถบชื่อหน้าต่างเริ่มต้นของระบบปฏิบัติการที่กำลังใช้อยู่ (เช่น Windows 7/10) ตัวเลือกคล้ายกันกับ\n แอป Discord ใน Linux", "settings-theme-desc3": "uses native titlebar of OS you're currently running (e.g Windows 7/10). Functions more\n similar to actual Discord app on Linux.",
"settings-csp-desc": "ArmCord CSP คือระบบที่จัดการการโหลดเนื้อหากำหนดเองลงไปในแอป Discord สิ่งอย่างเช่น สิ่งอย่างเช่น\n ไคลแอนต์มอด ธีม ต้องใช้มัน สามารถปิดใช้งานได้หากต้องการปิดมอดและหน้าตากำหนดเอง", "settings-csp-desc": "ArmCord CSP is our system that manages loading custom content loading into the Discord app. Stuff like\n client mods and themes depend on it. Disable if you want to get rid of mods and custom styles.",
"settings-tray-desc": "เมื่อปิด ArmCord จะปิดเหมือนหน้าตาอื่น ๆ เมื่อปิด ไม่อย่างนั้นมันจะนั่งนิ่ง\n ในถาดระบบภายหลัง", "settings-tray-desc": "When disabled, ArmCord will close like any other window when closed, otherwise it'll sit back and relax\n in your system tray for later.",
"settings-channel-desc3": "this is alpha test release of Discord. By using it you gain access to the newest\n features and fixes.", "settings-channel-desc3": "this is alpha test release of Discord. By using it you gain access to the newest\n features and fixes.",
"settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.", "settings-channel-desc4": "public test build. Receives features earlier than stable but is a bit older than Canary.",
"settings-channel-desc5": "unofficial instance of Discord that takes you back to 2016! None of the client mods\n bundled with ArmCord work with it. It's run by community, so you take all the risk by using it.", "settings-channel-desc5": "unofficial instance of Discord that takes you back to 2016! None of the client mods\n bundled with ArmCord work with it. It's run by community, so you take all the risk by using it.",

View file

@ -11,9 +11,7 @@
"packageQuick": "npm run build && electron-builder --dir", "packageQuick": "npm run build && electron-builder --dir",
"format": "prettier --write src/**/*", "format": "prettier --write src/**/*",
"CIbuild": "npm run build && electron-builder --linux zip && electron-builder --windows zip && electron-builder --macos zip", "CIbuild": "npm run build && electron-builder --linux zip && electron-builder --windows zip && electron-builder --macos zip",
"postinstall": "husky install", "postinstall": "husky install"
"precommit-fix": "husky uninstall && echo - && echo !Make sure to run 'npm run format' before commiting! | chalk --stdin yellow inverse && echo -",
"precommit-fix:format": "husky uninstall && npm run format"
}, },
"repository": { "repository": {
"type": "git", "type": "git",
@ -33,8 +31,7 @@
"electron-builder": "^23.0.3", "electron-builder": "^23.0.3",
"husky": "^8.0.1", "husky": "^8.0.1",
"prettier": "^2.7.0", "prettier": "^2.7.0",
"typescript": "^4.7.3", "typescript": "^4.7.3"
"chalk-cli": "^5.0.0"
}, },
"dependencies": { "dependencies": {
"electron-context-menu": "github:ArmCord/electron-context-menu", "electron-context-menu": "github:ArmCord/electron-context-menu",

View file

@ -8,10 +8,6 @@
padding: 0; padding: 0;
padding-top: 4px; padding-top: 4px;
} }
[customTitlebar] .backdrop-2ByYRN {
top: -30px;
padding-top: 30px;
}
* { * {
outline: none; outline: none;
} }
@ -37,7 +33,7 @@
} }
.none-2-_0dP:hover::-webkit-scrollbar { .none-2-_0dP:hover::-webkit-scrollbar {
width: 0.3em !important; width: 0.29em !important;
border-radius: 25px; border-radius: 25px;
height: 0px !important; height: 0px !important;
background: transparent !important; background: transparent !important;

View file

@ -85,10 +85,6 @@ p {
z-index: 999; z-index: 999;
font-size: 10px; font-size: 10px;
} }
.saveBar > button {
width: 90px;
}
.header { .header {
color: var(--header-primary); color: var(--header-primary);
font-size: 1.5em; font-size: 1.5em;
@ -132,7 +128,6 @@ p {
color: var(--header-primary); color: var(--header-primary);
font-size: 1.5em; font-size: 1.5em;
font-weight: bold; font-weight: bold;
width: max-content;
} }
/*buttons*/ /*buttons*/
button { button {
@ -278,12 +273,9 @@ select {
.acClientMod { .acClientMod {
height: 18em !important; height: 18em !important;
} }
.acCordwood {
height: 8em !important;
}
.acPrfmMode { .acPrfmMode {
height: 10em !important; height: 10em !important;
} }
.acTray { .acTray {
height: 8em !important; height: 7em !important;
} }

View file

@ -12,6 +12,7 @@
height: 30px; height: 30px;
line-height: 30px; line-height: 30px;
-webkit-app-region: drag; -webkit-app-region: drag;
width: 100%;
user-select: none; user-select: none;
-webkit-user-select: none; -webkit-user-select: none;
position: fixed; position: fixed;
@ -224,22 +225,13 @@
} }
/* ArmCord on MacOS (Why would you do this?) */ /* ArmCord on MacOS (Why would you do this?) */
[armcord-platform="darwin"] .withFrame-haYltI {
height: 0px !important;
}
[armcord-platform="darwin"] .sidebar-1tnWFu {
border-top-left-radius: 0px !important;
}
[armcord-platform="darwin"] .scroller-3X7KbA {
padding-top: 35px !important;
}
[armcord-platform="darwin"] .container-2RRFHK { [armcord-platform="darwin"] .container-2RRFHK {
padding-top: 48px; padding-top: 45px;
top: -48px; top: -45px;
} }
[armcord-platform="darwin"] .titlebar { [armcord-platform="darwin"] .titlebar {
height: 48px; height: 45px;
line-height: 48px; line-height: 45px;
} }
[armcord-platform="darwin"] .titlebar #window-controls-container { [armcord-platform="darwin"] .titlebar #window-controls-container {
float: left; float: left;
@ -247,7 +239,7 @@
height: 60%; height: 60%;
line-height: 45px; line-height: 45px;
-webkit-app-region: no-drag; -webkit-app-region: no-drag;
transform: translate(-82px, 4px); transform: translate(-78px, 4px);
} }
[armcord-platform="darwin"] .titlebar #window-controls-container:hover #minimize #minimize-icon, [armcord-platform="darwin"] .titlebar #window-controls-container:hover #minimize #minimize-icon,
@ -256,13 +248,6 @@
display: list-item; display: list-item;
} }
[armcord-platform="darwin"][unFocused] .titlebar #window-controls-container #minimize,
[armcord-platform="darwin"][unFocused] .titlebar #window-controls-container #maximize,
[armcord-platform="darwin"][unFocused] .titlebar #window-controls-container #quit {
background-color: #d6d6d5 !important;
transition: background-color 0.1s ease-in;
}
[armcord-platform="darwin"] .titlebar #window-controls-container #quit #quit-icon { [armcord-platform="darwin"] .titlebar #window-controls-container #quit #quit-icon {
background-color: #79282b; background-color: #79282b;
-webkit-mask: url("") -webkit-mask: url("")
@ -290,7 +275,6 @@
[armcord-platform="darwin"] .titlebar #window-controls-container #minimize { [armcord-platform="darwin"] .titlebar #window-controls-container #minimize {
background-color: #fac536; background-color: #fac536;
transition: background-color 0.1s ease-in;
border: 1px solid #da9e10; border: 1px solid #da9e10;
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='13' height='13'%3E%3Cstyle%3E.a%7Bfill:%23808080%7D%3C/style%3E%3Ccircle class='a' cx='15' cy='15' r='15'/%3E%3C/svg%3E") -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='13' height='13'%3E%3Cstyle%3E.a%7Bfill:%23808080%7D%3C/style%3E%3Ccircle class='a' cx='15' cy='15' r='15'/%3E%3C/svg%3E")
no-repeat 50% 50%; no-repeat 50% 50%;
@ -300,7 +284,6 @@
} }
[armcord-platform="darwin"] .titlebar #window-controls-container #maximize { [armcord-platform="darwin"] .titlebar #window-controls-container #maximize {
background-color: #39ea49; background-color: #39ea49;
transition: background-color 0.1s ease-in;
border: 1px solid #13c11e; border: 1px solid #13c11e;
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='13' height='13'%3E%3Cstyle%3E.a%7Bfill:%23808080%7D%3C/style%3E%3Ccircle class='a' cx='15' cy='15' r='15'/%3E%3C/svg%3E") -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='13' height='13'%3E%3Cstyle%3E.a%7Bfill:%23808080%7D%3C/style%3E%3Ccircle class='a' cx='15' cy='15' r='15'/%3E%3C/svg%3E")
no-repeat 50% 50%; no-repeat 50% 50%;
@ -310,7 +293,6 @@
} }
[armcord-platform="darwin"] .titlebar #window-controls-container #quit { [armcord-platform="darwin"] .titlebar #window-controls-container #quit {
background-color: #f25056; background-color: #f25056;
transition: background-color 0.1s ease-in;
border: 1px solid #d52735; border: 1px solid #d52735;
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='13' height='13'%3E%3Cstyle%3E.a%7Bfill:%23808080%7D%3C/style%3E%3Ccircle class='a' cx='15' cy='15' r='15'/%3E%3C/svg%3E") -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='13' height='13'%3E%3Cstyle%3E.a%7Bfill:%23808080%7D%3C/style%3E%3Ccircle class='a' cx='15' cy='15' r='15'/%3E%3C/svg%3E")
no-repeat 50% 50%; no-repeat 50% 50%;
@ -349,7 +331,13 @@
} }
[armcord-platform="darwin"] .window-title { [armcord-platform="darwin"] .window-title {
display: none; content: var(--wordmark-svg);
height: 10px;
left: 50%;
margin-right: 50%;
transform: translate(50%, 9.5px);
float: right;
padding: 0;
} }
[armcord-platform="linux"] .window-title, [armcord-platform="linux"] .window-title,

View file

@ -1,7 +1,7 @@
//ipc stuff //ipc stuff
import {app, ipcMain, shell, desktopCapturer} from "electron"; import {app, ipcMain, shell, desktopCapturer} from "electron";
import {mainWindow} from "./window"; import {mainWindow} from "./window";
import {setConfigBulk, getVersion, getConfig, setLang, getLang, getWindowState, packageVersion} from "./utils"; import {setConfigBulk, getVersion, getConfig, setLang, getLang, getWindowState} from "./utils";
import {customTitlebar} from "./main"; import {customTitlebar} from "./main";
import {createSettingsWindow} from "./settings/main"; import {createSettingsWindow} from "./settings/main";
export function registerIpc() { export function registerIpc() {
@ -44,24 +44,21 @@ export function registerIpc() {
ipcMain.on("get-app-version", (event) => { ipcMain.on("get-app-version", (event) => {
event.returnValue = getVersion(); event.returnValue = getVersion();
}); });
ipcMain.on("get-package-version", (event) => {
event.returnValue = packageVersion;
});
ipcMain.on("splashEnd", async (event, arg) => { ipcMain.on("splashEnd", async (event, arg) => {
try { try {
var width = (await getWindowState("width")) ?? 800; var width = await getWindowState("width") ?? 800;
var height = (await getWindowState("height")) ?? 600; var height= await getWindowState("height") ?? 600;
var isMaximized = (await getWindowState("isMaximized")) ?? false; var isMaximized = await getWindowState("isMaximized") ?? false;
} catch (e) { } catch (e) {
console.log("[Window state manager] No window state file found. Fallbacking to default values."); console.log("[Window state manager] No window state file found. Fallbacking to default values.")
mainWindow.setSize(800, 600); mainWindow.setSize(800, 600);
} }
if (isMaximized) { if (isMaximized) {
mainWindow.setSize(800, 600); //just so the whole thing doesn't cover whole screen mainWindow.setSize(800, 600); //just so the whole thing doesn't cover whole screen
mainWindow.maximize(); mainWindow.maximize()
} else { } else {
mainWindow.setSize(width, height); mainWindow.setSize(width, height);
console.log("[Window state manager] Not maximized."); console.log("[Window state manager] Not maximized.")
} }
}); });
ipcMain.on("restart", (event, arg) => { ipcMain.on("restart", (event, arg) => {

View file

@ -43,7 +43,7 @@ app.whenReady().then(async () => {
break; break;
} }
} }
await init(); await init()
session.fromPartition("some-partition").setPermissionRequestHandler((webContents, permission, callback) => { session.fromPartition("some-partition").setPermissionRequestHandler((webContents, permission, callback) => {
if (permission === "notifications") { if (permission === "notifications") {
// Approves the permissions request // Approves the permissions request
@ -55,6 +55,7 @@ app.whenReady().then(async () => {
} }
}); });
app.on("activate", async function () { app.on("activate", async function () {
if (BrowserWindow.getAllWindows().length === 0) await init(); if (BrowserWindow.getAllWindows().length === 0)
await init()
}); });
}); });

View file

@ -1,84 +1,76 @@
import {Menu, app, clipboard, globalShortcut} from "electron"; import { Menu, app, clipboard, globalShortcut } from "electron";
import {mainWindow} from "./window"; import {mainWindow} from "./window";
import {getConfig} from "./utils"; import {getConfig} from "./utils";
function paste(contents: any) { function paste(contents: any) {
const contentTypes = clipboard.availableFormats().toString(); const contentTypes = clipboard.availableFormats().toString();
//Workaround: fix pasting the images. //Workaround: fix pasting the images.
if (contentTypes.includes("image/") && contentTypes.includes("text/html")) { if(contentTypes.includes('image/') && contentTypes.includes('text/html')) {
clipboard.writeImage(clipboard.readImage()); clipboard.writeImage(clipboard.readImage());
} }
contents.paste(); contents.paste();
} }
export async function setMenu() { export async function setMenu() {
if ((await getConfig("alternativePaste")) == true) { if (await getConfig("alternativePaste") == true) {
mainWindow.on("focus", function () { mainWindow.on("focus", function () {
console.log("[Window state manager] Focus"); console.log("[Window state manager] Focus")
globalShortcut.register("CmdOrCtrl+V", function () { globalShortcut.register("CmdOrCtrl+V", function () {
if (mainWindow.isFocused()) { if (mainWindow.isFocused()) {
paste(mainWindow.webContents); paste(mainWindow.webContents)
} }
}); })
}); })
mainWindow.on("show", function () { mainWindow.on("show", function () {
console.log("[Window state manager] Show"); console.log("[Window state manager] Show")
mainWindow.focus(); mainWindow.focus()
globalShortcut.register("CmdOrCtrl+V", function () { globalShortcut.register("CmdOrCtrl+V", function () {
if (mainWindow.isFocused()) { if (mainWindow.isFocused()) {
paste(mainWindow.webContents); paste(mainWindow.webContents)
} }
}); })
}); })
mainWindow.on("blur", function () { mainWindow.on("blur", function () {
console.log("[Window state manager] Defocus"); console.log("[Window state manager] Defocus")
globalShortcut.unregister("CmdOrCtrl+V"); globalShortcut.unregister("CmdOrCtrl+V")
}); })
mainWindow.on("hide", function () { mainWindow.on("hide", function () {
console.log("[Window state manager] Hide"); console.log("[Window state manager] Hide")
globalShortcut.unregister("CmdOrCtrl+V"); globalShortcut.unregister("CmdOrCtrl+V")
}); })
} }
var template: Electron.MenuItemConstructorOptions[] = [ var template: Electron.MenuItemConstructorOptions[] = [{
{ label: "ArmCord",
label: "ArmCord", submenu: [
submenu: [ {label: "About ArmCord", role: "about"},//orderFrontStandardAboutPanel
{label: "About ArmCord", role: "about"}, //orderFrontStandardAboutPanel {type: "separator"},
{type: "separator"}, {
{ label: "Developer tools", accelerator: "CmdOrCtrl+Shift+I", click: function () {
label: "Developer tools", mainWindow.webContents.openDevTools()
accelerator: "CmdOrCtrl+Shift+I",
click: function () {
mainWindow.webContents.openDevTools();
}
},
{
label: "Quit",
accelerator: "CmdOrCtrl+Q",
click: function () {
app.quit();
}
} }
] },
}, {
{ label: "Quit", accelerator: "CmdOrCtrl+Q", click: function () {
label: "Edit", app.quit();
submenu: [ }
{label: "Undo", accelerator: "CmdOrCtrl+Z", role: "undo"}, }
{label: "Redo", accelerator: "Shift+CmdOrCtrl+Z", role: "redo"}, ]
{type: "separator"}, }, {
{label: "Cut", accelerator: "CmdOrCtrl+X", role: "cut"}, label: "Edit",
{label: "Copy", accelerator: "CmdOrCtrl+C", role: "copy"}, submenu: [
{ {label: "Undo", accelerator: "CmdOrCtrl+Z", role: "undo"},
label: "Paste", {label: "Redo", accelerator: "Shift+CmdOrCtrl+Z", role: "redo"},
accelerator: "CmdOrCtrl+V", {type: "separator"},
click: function () { {label: "Cut", accelerator: "CmdOrCtrl+X", role: "cut"},
paste(mainWindow.webContents); {label: "Copy", accelerator: "CmdOrCtrl+C", role: "copy"},
} {
}, label: "Paste", accelerator: "CmdOrCtrl+V", click: function () {
{label: "Select All", accelerator: "CmdOrCtrl+A", role: "selectAll"} paste(mainWindow.webContents)
] }
} },
]; {label: "Select All", accelerator: "CmdOrCtrl+A", role: "selectAll"}
]
}
]
Menu.setApplicationMenu(Menu.buildFromTemplate(template)); Menu.setApplicationMenu(Menu.buildFromTemplate(template));
} }

View file

@ -21,7 +21,6 @@ contextBridge.exposeInMainWorld("armcord", {
return result; return result;
}), }),
version: ipcRenderer.sendSync("get-app-version", "app-version"), version: ipcRenderer.sendSync("get-app-version", "app-version"),
packageVersion: ipcRenderer.sendSync("get-package-version", "app-version"),
getDisplayMediaSelector: getDisplayMediaSelector, getDisplayMediaSelector: getDisplayMediaSelector,
openSettingsWindow: () => ipcRenderer.send("openSettingsWindow") openSettingsWindow: () => ipcRenderer.send("openSettingsWindow")
}); });

View file

@ -8,7 +8,6 @@ import {sleep, addStyle, injectJS, addScript} from "../utils";
import {ipcRenderer} from "electron"; import {ipcRenderer} from "electron";
import {injectMobileStuff} from "./mobile"; import {injectMobileStuff} from "./mobile";
var version = ipcRenderer.sendSync("get-app-version", "app-version"); var version = ipcRenderer.sendSync("get-app-version", "app-version");
var channel = ipcRenderer.sendSync("channel");
async function updateLang() { async function updateLang() {
if (window.location.href.indexOf("setup.html") > -1) { if (window.location.href.indexOf("setup.html") > -1) {
console.log("Setup, skipping lang update"); console.log("Setup, skipping lang update");
@ -38,7 +37,7 @@ if (window.location.href.indexOf("splash.html") > -1) {
console.log("Skipping titlebar injection and client mod injection."); console.log("Skipping titlebar injection and client mod injection.");
} else { } else {
if (ipcRenderer.sendSync("titlebar")) { if (ipcRenderer.sendSync("titlebar")) {
if (channel == "hummus") { if (ipcRenderer.sendSync("channel")) {
injectHummusTitlebar(); injectHummusTitlebar();
} else { } else {
injectTitlebar(); injectTitlebar();

View file

@ -64,18 +64,9 @@ export function injectHummusTitlebar() {
elem.classList.add("win-buttons-light"); elem.classList.add("win-buttons-light");
document.getElementsByClassName("titlebar")[0].appendChild(elem); document.getElementsByClassName("titlebar")[0].appendChild(elem);
document.body.setAttribute("customTitlebar", ""); document.body.setAttribute("customTitlebar", "");
document.body.setAttribute("hummus", "");
document.body.setAttribute("armcord-platform", os.platform()); document.body.setAttribute("armcord-platform", os.platform());
addStyle(` addStyle(".chat>.title-wrap {width: 87% !important;}");
html, body { addStyle(".friends-header {width: 91% !important;}");
background-color: #1e2124;
}
.friends-header,
.chat > .title-wrap {
float: right !important;
padding-right: 140px !important;
}`);
var minimize = document.getElementById("minimize"); var minimize = document.getElementById("minimize");
var maximize = document.getElementById("maximize"); var maximize = document.getElementById("maximize");
var quit = document.getElementById("quit"); var quit = document.getElementById("quit");

View file

@ -5,9 +5,6 @@
<title>ArmCord Settings</title> <title>ArmCord Settings</title>
<style> <style>
@import url("../content/css/settings.css"); @import url("../content/css/settings.css");
.acAdvSettings {
height: 19em !important;
}
</style> </style>
</head> </head>
@ -82,7 +79,7 @@
</div> </div>
</div> </div>
<br /> <br />
<div class="switch acCordwood"> <div class="switch acAltPaste">
<label class="header2" id="settings-cordwood">Cordwood client mod</label> <label class="header2" id="settings-cordwood">Cordwood client mod</label>
<input class="tgl tgl-light left" id="cordwood" type="checkbox" /> <input class="tgl tgl-light left" id="cordwood" type="checkbox" />
<label class="tgl-btn left" for="cordwood"></label> <label class="tgl-btn left" for="cordwood"></label>
@ -119,16 +116,14 @@
</div> </div>
<br /> <br />
<br /> <br />
<div class="switch acAdvSettings"> <h1 class="center advancedText">Advanced user zone⚠</h1>
<h1 class="center advancedText">⚠️ Advanced User Zone ⚠️</h1> <button id="settings-pluginsFolder" class="center">Open plugins folder</button>
<button id="settings-pluginsFolder" class="center">Open Plugins Folder</button> <br />
<br /> <button id="settings-themesFolder" class="center">Open themes folder</button>
<button id="settings-themesFolder" class="center">Open Themes Folder</button> <br />
<br /> <button id="settings-storageFolder" class="center">Open storage folder</button>
<button id="settings-storageFolder" class="center">Open Storage Folder</button> <br />
<br /> <button id="settings-copyDebugInfo" class="center">Copy debug info</button>
<button id="settings-copyDebugInfo" class="center">Copy Debug Info</button>
</div>
</body> </body>
<script> <script>
async function loadLang() { async function loadLang() {

View file

@ -29,14 +29,6 @@ export function createSettingsWindow() {
preload: path.join(__dirname, "preload.js") preload: path.join(__dirname, "preload.js")
} }
}); });
async function settingsLoadPage() {
if ((await getConfig("channel")) == "hummus") {
settingsWindow.loadURL(`file://${__dirname}/hummus.html`);
} else {
settingsWindow.loadURL(`file://${__dirname}/settings.html`);
}
}
ipcMain.on("saveSettings", (event, args: Settings) => { ipcMain.on("saveSettings", (event, args: Settings) => {
console.log(args); console.log(args);
setConfigBulk(args); setConfigBulk(args);
@ -75,7 +67,7 @@ export function createSettingsWindow() {
shell.openExternal(url); shell.openExternal(url);
return {action: "deny"}; return {action: "deny"};
}); });
settingsLoadPage(); settingsWindow.loadURL(`file://${__dirname}/settings.html`);
settingsWindow.on("close", (event: Event) => { settingsWindow.on("close", (event: Event) => {
ipcMain.removeHandler("getSetting"); ipcMain.removeHandler("getSetting");
ipcMain.removeAllListeners("saveSettings"); ipcMain.removeAllListeners("saveSettings");

View file

@ -5,9 +5,6 @@
<title>ArmCord Settings</title> <title>ArmCord Settings</title>
<style> <style>
@import url("../content/css/settings.css"); @import url("../content/css/settings.css");
.acAdvSettings {
height: 26em !important;
}
</style> </style>
</head> </head>
@ -171,22 +168,21 @@
</div> </div>
<br /> <br />
<br /> <br />
<div class="switch acAdvSettings"> <h1 class="center advancedText">Advanced user zone⚠</h1>
<h1 class="center advancedText">⚠️ Advanced User Zone ⚠️</h1> <div class="switch acAltPaste">
<br /> <label class="header2" id="settings-skipSplash">Skip splash screen (experimental)</label>
<label class="header2" id="settings-skipSplash">Skip Splash Screen (Experimental)</label>
<input class="tgl tgl-light left" id="skipSplash" type="checkbox" /> <input class="tgl tgl-light left" id="skipSplash" type="checkbox" />
<label class="tgl-btn left" for="skipSplash"></label> <label class="tgl-btn left" for="skipSplash"></label>
<p class="description2">Skips ArmCord splash screen when you start up the app.</p> <p class="description2">Skips ArmCord splash screen when you start up the app.</p>
<br />
<button id="settings-pluginsFolder" class="center">Open Plugins Folder</button>
<br />
<button id="settings-themesFolder" class="center">Open Themes Folder</button>
<br />
<button id="settings-storageFolder" class="center">Open Storage Folder</button>
<br />
<button id="settings-copyDebugInfo" class="center">Copy Debug Info</button>
</div> </div>
<br />
<button id="settings-pluginsFolder" class="center">Open plugins folder</button>
<br />
<button id="settings-themesFolder" class="center">Open themes folder</button>
<br />
<button id="settings-storageFolder" class="center">Open storage folder</button>
<br />
<button id="settings-copyDebugInfo" class="center">Copy debug info</button>
</body> </body>
<script> <script>
async function loadLang() { async function loadLang() {

View file

@ -1,28 +1,27 @@
// MIT License
// Copyright (c) 2020-2022 Dawid Papiewski "SpacingBat3"
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
import type {Server, WebSocket} from "ws"; import type {Server, WebSocket} from "ws";
import {inviteWindow, createInviteWindow} from "./window"; import {inviteWindow, createInviteWindow} from "./window";
/*
MIT License
Copyright (c) 2020-2022 Dawid Papiewski "SpacingBat3"
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
async function wsLog(message: string, ...args: unknown[]) { async function wsLog(message: string, ...args: unknown[]) {
console.log("[WebSocket] " + message, ...args); console.log("[WebSocket] " + message, ...args);
} }

View file

@ -1,15 +1,16 @@
import * as fs from "fs"; import * as fs from "fs";
import {app, Menu, Tray, nativeImage} from "electron"; import { app, Menu, Tray, nativeImage} from "electron";
import {mainWindow} from "./window"; import { mainWindow } from "./window";
import {getConfig, getConfigLocation, setWindowState} from "./utils"; import { getConfig, getConfigLocation, setWindowState } from "./utils";
import * as path from "path"; import * as path from "path";
import {createSettingsWindow} from "./settings/main"; import { createSettingsWindow } from "./settings/main";
let tray: any = null; let tray: any = null;
app.whenReady().then(async () => { app.whenReady().then(async () => {
let finishedSetup = await getConfig("doneSetup"); let finishedSetup = (await getConfig("doneSetup"));
var trayIcon = (await getConfig("trayIcon")) ?? "ac_plug_colored"; var trayIcon = (await getConfig("trayIcon")) ?? "ac_plug_colored";
let trayPath = nativeImage.createFromPath(path.join(__dirname, "../", `/assets/${trayIcon}.png`)); let trayPath = nativeImage.createFromPath(path.join(__dirname, "../", `/assets/${trayIcon}.png`));
if (process.platform === "darwin" && trayPath.getSize().height > 22) trayPath = trayIcon.resize({height: 22}); if(process.platform === "darwin" && trayPath.getSize().height > 22)
trayPath = trayIcon.resize({height: 22});
if ((await getConfig("windowStyle")) == "basic") { if ((await getConfig("windowStyle")) == "basic") {
var clientName = (await getConfig("clientName")) ?? "ArmCord"; var clientName = (await getConfig("clientName")) ?? "ArmCord";
tray = new Tray(trayPath); tray = new Tray(trayPath);
@ -27,7 +28,7 @@ app.whenReady().then(async () => {
if (err) throw err; if (err) throw err;
console.log('Closed during setup. "settings.json" was deleted'); console.log('Closed during setup. "settings.json" was deleted');
app.quit(); app.quit();
}); });
} }
} }
]); ]);
@ -42,18 +43,18 @@ app.whenReady().then(async () => {
{ {
label: `Quit ${clientName}`, label: `Quit ${clientName}`,
click: function () { click: function () {
let [width, height] = mainWindow.getSize(); let [width, height] = mainWindow.getSize()
setWindowState({ setWindowState({
width: width, width: width,
height: height, height: height,
isMaximized: mainWindow.isMaximized() isMaximized: mainWindow.isMaximized()
}); })
app.quit(); app.quit();
} }
} }
]); ]);
} }
}; }
tray.setToolTip(clientName); tray.setToolTip(clientName);
tray.setContextMenu(contextMenu); tray.setContextMenu(contextMenu);
@ -73,55 +74,57 @@ app.whenReady().then(async () => {
if (err) throw err; if (err) throw err;
console.log('Closed during setup. "settings.json" was deleted'); console.log('Closed during setup. "settings.json" was deleted');
app.quit(); app.quit();
}); });
} }
} }
]); ]);
tray.setContextMenu(contextMenu); tray.setContextMenu(contextMenu);
} else { } else {
const contextMenu = Menu.buildFromTemplate([ const contextMenu = Menu.buildFromTemplate([
{ {
label: `${clientName} ` + app.getVersion(), label: `${clientName} ` + app.getVersion(),
enabled: false enabled: false
},
{
type: "separator"
},
{
label: `Open ${clientName}`,
click: function () {
mainWindow.show();
}
},
{
label: "Open Settings",
click: function () {
createSettingsWindow();
}
},
{
label: "Support Discord Server",
click: function () {
mainWindow.show();
mainWindow.loadURL("https://discord.gg/TnhxcqynZ2");
}
},
{
type: "separator"
},
{
label: `Quit ${clientName}`,
click: function () {
app.quit();
}
}
]);
tray.setContextMenu(contextMenu);
}
}
tray.setToolTip(clientName); },
tray.on("click", function () { {
mainWindow.show(); type: "separator"
}); },
}); {
label: `Open ${clientName}`,
click: function () {
mainWindow.show();
}
},
{
label: "Open Settings",
click: function () {
createSettingsWindow();
}
},
{
label: "Support Discord Server",
click: function () {
mainWindow.show();
mainWindow.loadURL("https://discord.gg/TnhxcqynZ2");
}
},
{
type: "separator"
},
{
label: `Quit ${clientName}`,
click: function () {
app.quit();
}
}
]);
tray.setContextMenu(contextMenu);
}
}
tray.setToolTip(clientName);
tray.on('click', function(){
mainWindow.show()
});
}
);

View file

@ -1,5 +1,5 @@
import * as fs from "fs"; import * as fs from "fs";
import {app, dialog} from "electron"; import { app, dialog } from "electron";
import path from "path"; import path from "path";
export var firstRun: boolean; export var firstRun: boolean;
export var contentPath: string; export var contentPath: string;
@ -53,17 +53,15 @@ export function setup() {
}); });
} }
//Get the version value from the "package.json" file
export var packageVersion = require("../package.json").version;
//I'm too lazy to replace every mf reference so :p
export function getVersion() { export function getVersion() {
//Checks if the app version # has 4 sections (3.1.0.0) instead of 3 (3.1.0) / Shitty way to check if Kernel Mod is installed //Checks if the version # has 4 sections (3.1.0.0) instead of 3 (3.1.0) / Shitty way to check if Kernel Mod is installed
if ((app.getVersion() == packageVersion) == false) { if (((app.getVersion()).split('.').length > 3) == true) {
return `${packageVersion} [Kernel Mod]`; return app.getVersion().split('.')[0] + "." + app.getVersion().split('.')[1] + "." + app.getVersion().split('.')[2] + " [Kernel Mod]";
} else { } else {
return packageVersion; return app.getVersion();
} }}
}
export async function injectJS(inject: string) { export async function injectJS(inject: string) {
const js = await (await fetch(`${inject}`)).text(); const js = await (await fetch(`${inject}`)).text();
@ -134,8 +132,8 @@ export async function getLang(object: string) {
let parsed = JSON.parse(rawdata); let parsed = JSON.parse(rawdata);
language = parsed["lang"]; language = parsed["lang"];
} catch (e) { } catch (e) {
console.log("Language config file doesn't exist. Fallback to English."); console.log("Language config file doesn't exist. Fallback to English.")
language = "en-US"; language = "en-US"
} }
} }
if (language.length == 2) { if (language.length == 2) {
@ -148,11 +146,11 @@ export async function getLang(object: string) {
let rawdata = fs.readFileSync(langPath, "utf-8"); let rawdata = fs.readFileSync(langPath, "utf-8");
let parsed = JSON.parse(rawdata); let parsed = JSON.parse(rawdata);
if (parsed[object] == undefined) { if (parsed[object] == undefined) {
console.log(object + " is undefined in " + language); console.log(object + " is undefined in " + language)
langPath = path.join(__dirname, "../", "/assets/lang/en-US.json"); langPath = path.join(__dirname, "../", "/assets/lang/en-US.json");
rawdata = fs.readFileSync(langPath, "utf-8"); rawdata = fs.readFileSync(langPath, "utf-8");
parsed = JSON.parse(rawdata); parsed = JSON.parse(rawdata);
return parsed[object]; return parsed[object]
} else { } else {
return parsed[object]; return parsed[object];
} }
@ -193,8 +191,8 @@ export interface Settings {
automaticPatches: boolean; automaticPatches: boolean;
alternativePaste: boolean; alternativePaste: boolean;
mods: string; mods: string;
mobileMode: boolean; mobileMode: boolean,
skipSplash: boolean; skipSplash: boolean,
performanceMode: string; performanceMode: string;
inviteWebsocket: boolean; inviteWebsocket: boolean;
trayIcon: string; trayIcon: string;

View file

@ -2,11 +2,11 @@
// I had to add most of the window creation code here to split both into seperete functions // I had to add most of the window creation code here to split both into seperete functions
// WHY? Because I can't use the same code for both due to annoying bug with value `frame` not responding to variables // WHY? Because I can't use the same code for both due to annoying bug with value `frame` not responding to variables
// I'm sorry for this mess but I'm not sure how to fix it. // I'm sorry for this mess but I'm not sure how to fix it.
import {BrowserWindow, shell, app, dialog} from "electron"; import { BrowserWindow, shell, app, dialog } from "electron";
import path from "path"; import path from "path";
import {checkIfConfigIsBroken, firstRun, getConfig, contentPath, setConfig, setLang, setWindowState} from "./utils"; import { checkIfConfigIsBroken, firstRun, getConfig, contentPath, setConfig, setLang, setWindowState } from "./utils";
import {registerIpc} from "./ipc"; import { registerIpc } from "./ipc";
import {setMenu} from "./menu"; import { setMenu } from "./menu";
import * as fs from "fs"; import * as fs from "fs";
import startServer from "./socket"; import startServer from "./socket";
import contextMenu from "electron-context-menu"; import contextMenu from "electron-context-menu";
@ -14,7 +14,7 @@ import os from "os";
export var icon: string; export var icon: string;
export let mainWindow: BrowserWindow; export let mainWindow: BrowserWindow;
export let inviteWindow: BrowserWindow; export let inviteWindow: BrowserWindow;
var osType = os.type(); var osType = os.type()
contextMenu({ contextMenu({
showSaveImageAs: true, showSaveImageAs: true,
@ -27,17 +27,16 @@ async function doAfterDefiningTheWindow() {
checkIfConfigIsBroken(); checkIfConfigIsBroken();
registerIpc(); registerIpc();
if (await getConfig("mobileMode")) { if (await getConfig("mobileMode")) {
mainWindow.webContents.userAgent = mainWindow.webContents.userAgent = "Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.5005.149 Mobile Safari/537.36"
"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.5005.149 Mobile Safari/537.36";
} else { } else {
// A little sloppy but it works :p // A little sloppy but it works :p
if (osType == "Windows_NT") { if (osType == 'Windows_NT') {
osType = "Windows " + os.release().split(".")[0] + " (" + os.release() + ")"; osType = "Windows " + os.release().split('.')[0] + " (" + os.release() + ")";
} }
mainWindow.webContents.userAgent = `Mozilla/5.0 (X11; ${osType} ${os.arch()}) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.102 Safari/537.36`; //fake useragent for screenshare to work mainWindow.webContents.userAgent = `Mozilla/5.0 (X11; ${osType} ${os.arch()}) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.102 Safari/537.36`; //fake useragent for screenshare to work
} }
mainWindow.webContents.setWindowOpenHandler(({url}) => { mainWindow.webContents.setWindowOpenHandler(({ url }) => {
if (url.startsWith("https:" || url.startsWith("http:") || url.startsWith("mailto:"))) { if (url.startsWith("https:" || url.startsWith("http:") || url.startsWith("mailto:"))) {
shell.openExternal(url); shell.openExternal(url);
} else { } else {
@ -55,7 +54,7 @@ async function doAfterDefiningTheWindow() {
checkboxChecked: false checkboxChecked: false
}; };
dialog.showMessageBox(mainWindow, options).then(({response, checkboxChecked}) => { dialog.showMessageBox(mainWindow, options).then(({ response, checkboxChecked }) => {
console.log(response, checkboxChecked); console.log(response, checkboxChecked);
if (checkboxChecked) { if (checkboxChecked) {
if (response == 0) { if (response == 0) {
@ -72,10 +71,10 @@ async function doAfterDefiningTheWindow() {
}); });
} }
} }
return {action: "deny"}; return { action: "deny" };
}); });
mainWindow.webContents.session.webRequest.onBeforeRequest((details, callback) => { mainWindow.webContents.session.webRequest.onBeforeRequest((details, callback) => {
if (/api\/v\d\/science$/g.test(details.url)) return callback({cancel: true}); if (/api\/v\d\/science$/g.test(details.url)) return callback({ cancel: true });
return callback({}); return callback({});
}); });
const userDataPath = app.getPath("userData"); const userDataPath = app.getPath("userData");
@ -84,29 +83,26 @@ async function doAfterDefiningTheWindow() {
fs.mkdirSync(themesFolder); fs.mkdirSync(themesFolder);
console.log("Created missing theme folder"); console.log("Created missing theme folder");
} }
mainWindow.webContents.on("did-finish-load", () => { mainWindow.webContents.on('did-finish-load', () => {
fs.readdirSync(themesFolder).forEach((file) => { fs.readdirSync(themesFolder).forEach((file) => {
try { try {
const manifest = fs.readFileSync(`${themesFolder}/${file}/manifest.json`, "utf8"); const manifest = fs.readFileSync(`${themesFolder}/${file}/manifest.json`, "utf8");
var themeFile = JSON.parse(manifest); var themeFile = JSON.parse(manifest);
mainWindow.webContents.send( mainWindow.webContents.send("themeLoader", fs.readFileSync(`${themesFolder}/${file}/${themeFile.theme}`, "utf-8"))
"themeLoader",
fs.readFileSync(`${themesFolder}/${file}/${themeFile.theme}`, "utf-8")
);
console.log(`%cLoaded ${themeFile.name} made by ${themeFile.author}`, "color:red"); console.log(`%cLoaded ${themeFile.name} made by ${themeFile.author}`, "color:red");
} catch (err) { } catch (err) {
console.error(err); console.error(err);
} }
}); });
}); });
setMenu(); setMenu()
mainWindow.on("close", async (e) => { mainWindow.on("close", async (e) => {
let [width, height] = mainWindow.getSize(); let [width, height] = mainWindow.getSize()
setWindowState({ setWindowState({
width: width, width: width,
height: height, height: height,
isMaximized: mainWindow.isMaximized() isMaximized: mainWindow.isMaximized()
}); })
if (await getConfig("minimizeToTray")) { if (await getConfig("minimizeToTray")) {
e.preventDefault(); e.preventDefault();
mainWindow.hide(); mainWindow.hide();
@ -115,30 +111,22 @@ async function doAfterDefiningTheWindow() {
app.quit(); app.quit();
} }
}); });
mainWindow.on('maximize', () => {
mainWindow.on("focus", () => { mainWindow.webContents.executeJavaScript(`document.body.setAttribute("isMaximized", "");`)
mainWindow.webContents.executeJavaScript(`document.body.removeAttribute("unFocused");`); })
}); mainWindow.on('unmaximize', () => {
mainWindow.on("blur", () => { mainWindow.webContents.executeJavaScript(`document.body.removeAttribute("isMaximized");`)
mainWindow.webContents.executeJavaScript(`document.body.setAttribute("unFocused", "");`); })
});
mainWindow.on("maximize", () => {
mainWindow.webContents.executeJavaScript(`document.body.setAttribute("isMaximized", "");`);
});
mainWindow.on("unmaximize", () => {
mainWindow.webContents.executeJavaScript(`document.body.removeAttribute("isMaximized");`);
});
console.log(contentPath); console.log(contentPath);
if ((await getConfig("inviteWebsocket")) == true) { if ((await getConfig("inviteWebsocket")) == true) {
await startServer(); await startServer();
} }
if (firstRun) { if (firstRun) {
await setLang(Intl.DateTimeFormat().resolvedOptions().locale); await setLang(Intl.DateTimeFormat().resolvedOptions().locale)
mainWindow.setSize(390, 470); mainWindow.setSize(390, 470);
await mainWindow.loadFile(path.join(__dirname, "/content/setup.html")); await mainWindow.loadFile(path.join(__dirname, "/content/setup.html"));
} else { } else {
if ((await getConfig("skipSplash")) == true) { if (await getConfig("skipSplash") == true) {
switch (await getConfig("channel")) { switch (await getConfig("channel")) {
case "stable": case "stable":
mainWindow.loadURL("https://discord.com/app"); mainWindow.loadURL("https://discord.com/app");