Compare commits
1 commit
170c6a1771
...
906926b6bf
Author | SHA1 | Date | |
---|---|---|---|
|
906926b6bf |
|
@ -1,6 +1,6 @@
|
||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
<img src="https://armcord.vercel.app/logo.png" width="520">
|
<img src="https://armcord.vercel.app/armcord_full_logo.png" width="520">
|
||||||
<br>ArmCord is a custom client designed to enhance your Discord experience while keeping everything lightweight.
|
<br>ArmCord is a custom client designed to enhance your Discord experience while keeping everything lightweight.
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -45,9 +45,6 @@ ArmCord is also available on the Snap store [here](https://snapcraft.io/armcord)
|
||||||
<a href="https://snapcraft.io/armcord">
|
<a href="https://snapcraft.io/armcord">
|
||||||
<img alt="Get it from the Snap Store" src="https://snapcraft.io/static/images/badges/en/snap-store-black.svg" />
|
<img alt="Get it from the Snap Store" src="https://snapcraft.io/static/images/badges/en/snap-store-black.svg" />
|
||||||
</a>
|
</a>
|
||||||
### Pi-Apps
|
|
||||||
ArmCord is also available in [Pi-Apps](https://github.com/Botspot/pi-apps).
|
|
||||||
[![badge](https://github.com/Botspot/pi-apps/blob/master/icons/badge.png?raw=true)](https://github.com/Botspot/pi-apps)
|
|
||||||
### Manual:
|
### Manual:
|
||||||
Alternatively you can run ArmCord from source (npm, nodejs required):
|
Alternatively you can run ArmCord from source (npm, nodejs required):
|
||||||
1. Clone ArmCord repo: `git clone https://github.com/ArmCord/ArmCord.git`
|
1. Clone ArmCord repo: `git clone https://github.com/ArmCord/ArmCord.git`
|
||||||
|
|
Before Width: | Height: | Size: 8.5 KiB |
Before Width: | Height: | Size: 10 KiB |
Before Width: | Height: | Size: 8.5 KiB After Width: | Height: | Size: 10 KiB |
BIN
assets/ac_white_plug_filled.png
Normal file
After Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 10 KiB |
|
@ -3,9 +3,9 @@
|
||||||
"loading_screen_offline": "You appear to be offline. Please connect to the Internet and try again.",
|
"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.",
|
"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": "Select what kind of setup you want to perform:",
|
||||||
"setup_question1_answer1": "Express Setup",
|
"setup_question1_answer1": "Express setup",
|
||||||
"setup_question1_answer2": "Full Setup",
|
"setup_question1_answer2": "Full setup",
|
||||||
"setup_offline": "You appear to be offline. Please connect to the internet and restart ArmCord.",
|
"setup_offline": "You appear to be offline. Please connect to the Internet and restart the ArmCord setup.",
|
||||||
"setup_question2": "Choose your Discord channel/instance:",
|
"setup_question2": "Choose your Discord channel/instance:",
|
||||||
"setup_question3": "Should ArmCord handle client mods installation?",
|
"setup_question3": "Should ArmCord handle client mods installation?",
|
||||||
"yes": "Yes",
|
"yes": "Yes",
|
||||||
|
|
|
@ -1,30 +0,0 @@
|
||||||
{
|
|
||||||
"loading_screen_start": "درحال پیاده سازی ArmCord…",
|
|
||||||
"loading_screen_offline": "به نظر میرسد شما آفلاین هستید. لطفا به اینترنت متصل شده و سپس دوباره تلاش کنید.",
|
|
||||||
"loading_screen_update": "نسخه جدید ArmCord در دسترس است. لطفا به آخرین نسخه بروزرسانی کنید.",
|
|
||||||
"setup_question1": "انتخاب کنید که چگونه میخواهید نصب کنید:",
|
|
||||||
"setup_question1_answer1": "راهاندازی سریع",
|
|
||||||
"setup_question1_answer2": "راهاندازی کامل",
|
|
||||||
"setup_offline": "به نظر میرسد شما آفلاین هستید. لطفا به اینترنت وصل شده و سپس نصب ArmCord را از ابتدا شروع کنید.",
|
|
||||||
"setup_question2": "نوع دیسکورد را انتخاب کنید:",
|
|
||||||
"setup_question3": "آیا میخواهید ArmCord تغییرات کلاینت را خودکار اعمال کند؟",
|
|
||||||
"yes": "بله",
|
|
||||||
"no": "خیر",
|
|
||||||
"next": "بعدی",
|
|
||||||
"setup_question4": "نوع اصلاحساز برنامه که میخواهید نصب کنید انتخاب کنید:",
|
|
||||||
"setup_question4_clientmodnotice": "چرا همه نه؟ داشتن اصلاحسازهای زیاد به صورت همزمان میتواند خرابی به بار آورد. اگر واقعا میخواهید انجامش دهید، به دیسکورد ما سر بزنید.",
|
|
||||||
"settings-theme": "تم ArmCord:",
|
|
||||||
"settings-theme-default": "پیشفرض",
|
|
||||||
"settings-theme-native": "محلی",
|
|
||||||
"settings-tray": "مینیماز در نوارابزار کوچک",
|
|
||||||
"settings-patches": "اعمال تغییرات به صورت خودکار",
|
|
||||||
"settings-channel": "نوع دیسکورد:",
|
|
||||||
"settings-invitewebsocket": "وب سوکت دعوت",
|
|
||||||
"settings-mod": "نوع اصلاحساز کلاینت:",
|
|
||||||
"settings-prfmMode": "حالت عملکرد:",
|
|
||||||
"settings-prfmMode-performance": "قدرت بیشتر",
|
|
||||||
"settings-prfmMode-battery": "ذخیره برای باتری",
|
|
||||||
"settings-none": "هیچکدام",
|
|
||||||
"settings-save": "ذخیره تنظیمات",
|
|
||||||
"settings-updater": "بررسی برای بروزرسانی"
|
|
||||||
}
|
|
|
@ -13,15 +13,15 @@
|
||||||
"setup_question4_clientmodnotice": "Pourquoi pas tous ? Le fait d'avoir plusieurs clients mods en même temps peut causer des problèmes. Si vous voulez vraiment le faire, consultez notre Discord.",
|
"setup_question4_clientmodnotice": "Pourquoi pas tous ? Le fait d'avoir plusieurs clients mods en même temps peut causer des problèmes. Si vous voulez vraiment le faire, consultez notre Discord.",
|
||||||
"loading_screen_offline": "Vous semblez être hors ligne. Veuillez vous connecter à internet et réessayer.",
|
"loading_screen_offline": "Vous semblez être hors ligne. Veuillez vous connecter à internet et réessayer.",
|
||||||
"setup_offline": "Vous semblez être hors ligne. Veuillez vous connecter à internet et redémarrer l'installateur ArmCord.",
|
"setup_offline": "Vous semblez être hors ligne. Veuillez vous connecter à internet et redémarrer l'installateur ArmCord.",
|
||||||
"settings-tray": "Minimiser dans la zone de notification",
|
"settings-tray": "Minimize to tray",
|
||||||
"settings-channel": "Canaux Discord :",
|
"settings-channel": "Discord channel:",
|
||||||
"settings-mod": "Modification client :",
|
"settings-mod": "Client mod:",
|
||||||
"settings-save": "Sauvegarder les paramètres",
|
"settings-save": "Save settings",
|
||||||
"settings-updater": "Vérifier les mises à jour",
|
"settings-updater": "Check for updates",
|
||||||
"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": "Automatic Patches",
|
||||||
"settings-invitewebsocket": "Lien discord.gg",
|
"settings-invitewebsocket": "Lien discord.gg",
|
||||||
"settings-prfmMode": "Mode performance :",
|
"settings-prfmMode": "Mode performance :",
|
||||||
"settings-prfmMode-performance": "Performance",
|
"settings-prfmMode-performance": "Performance",
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
"setup_question4": "Select a client mod you want to install:",
|
"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 documentation.",
|
"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 documentation.",
|
||||||
"settings-theme": "ArmCord Theme:",
|
"settings-theme": "ArmCord Theme:",
|
||||||
|
"settings-theme-tabs": "Tabs (experimental)",
|
||||||
"settings-theme-default": "Default",
|
"settings-theme-default": "Default",
|
||||||
"settings-theme-native": "Native",
|
"settings-theme-native": "Native",
|
||||||
"settings-tray": "Minimize to tray",
|
"settings-tray": "Minimize to tray",
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
"settings-updater": "Controlla gli aggiornamenti",
|
"settings-updater": "Controlla gli aggiornamenti",
|
||||||
"settings-mod": "Client mod:",
|
"settings-mod": "Client mod:",
|
||||||
"settings-theme": "ArmCord Theme:",
|
"settings-theme": "ArmCord Theme:",
|
||||||
|
"settings-theme-tabs": "Tabs (experimental)",
|
||||||
"settings-theme-default": "Default",
|
"settings-theme-default": "Default",
|
||||||
"settings-theme-native": "Native",
|
"settings-theme-native": "Native",
|
||||||
"settings-patches": "Automatic Patches",
|
"settings-patches": "Automatic Patches",
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
"settings-save": "Save settings",
|
"settings-save": "Save settings",
|
||||||
"settings-updater": "Check for updates",
|
"settings-updater": "Check for updates",
|
||||||
"settings-theme": "ArmCord Theme:",
|
"settings-theme": "ArmCord Theme:",
|
||||||
|
"settings-theme-tabs": "Tabs (experimental)",
|
||||||
"settings-theme-default": "Default",
|
"settings-theme-default": "Default",
|
||||||
"settings-theme-native": "Native",
|
"settings-theme-native": "Native",
|
||||||
"settings-patches": "Automatic Patches",
|
"settings-patches": "Automatic Patches",
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
"settings-updater": "Check voor updates",
|
"settings-updater": "Check voor updates",
|
||||||
"settings-patches": "Automatische Patches",
|
"settings-patches": "Automatische Patches",
|
||||||
"settings-theme": "ArmCord Thema:",
|
"settings-theme": "ArmCord Thema:",
|
||||||
|
"settings-theme-tabs": "Tabs (experimenteel)",
|
||||||
"settings-theme-default": "Standaard",
|
"settings-theme-default": "Standaard",
|
||||||
"settings-theme-native": "Native",
|
"settings-theme-native": "Native",
|
||||||
"settings-invitewebsocket": "discord.gg support",
|
"settings-invitewebsocket": "discord.gg support",
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
"settings-save": "Zapisz ustawienia",
|
"settings-save": "Zapisz ustawienia",
|
||||||
"settings-mod": "Modyfikacja klienta:",
|
"settings-mod": "Modyfikacja klienta:",
|
||||||
"settings-theme": "Motyw ArmCord:",
|
"settings-theme": "Motyw ArmCord:",
|
||||||
|
"settings-theme-tabs": "Karty (eksperymentalne)",
|
||||||
"settings-theme-default": "Domyślny",
|
"settings-theme-default": "Domyślny",
|
||||||
"settings-theme-native": "Natywny",
|
"settings-theme-native": "Natywny",
|
||||||
"settings-patches": "Automatyczne łatki",
|
"settings-patches": "Automatyczne łatki",
|
||||||
|
|
|
@ -1,28 +1,28 @@
|
||||||
{
|
{
|
||||||
"loading_screen_start": "กำลังเริ่มต้น ArmCord…",
|
"loading_screen_start": "กำลังเริ่ม ArmCord…",
|
||||||
"loading_screen_offline": "ดูเหมือนว่าคุณออฟไลน์อยู่ โปรดเชื่อมต่ออินเทอร์เน็ตและลองใหม่อีกครั้ง",
|
"loading_screen_offline": "ดูเหมือนว่าคุณออฟไลน์อยู่ โปรดเชื่อมต่ออินเทอร์เน็ตและลองใหม่อีกครั้ง",
|
||||||
"loading_screen_update": "ArmCord เวอร์ชันใหม่พร้อมใช้งานแล้ว โปรดอัปเดตเป็นเวอร์ชันล่าสุด",
|
"loading_screen_update": "ArmCord เวอร์ชันใหม่พร้อมใช้งานแล้ว โปรดอัปเดตเป็นเวอร์ชันล่าสุด",
|
||||||
"setup_question1": "เลือกประเภทการติดตั้งที่คุณต้องการ:",
|
"setup_question1": "เลือกประเภทการติดตั้งที่คุณต้องการ:",
|
||||||
"setup_question1_answer1": "ติดตั้งแบบรวดเร็ว",
|
"setup_question1_answer1": "ติดตั้งแบบน้ำหนักเบา",
|
||||||
"setup_question1_answer2": "ติดตั้งเต็มรูปแบบ",
|
"setup_question1_answer2": "ติดตั้งแบบเต็ม",
|
||||||
"setup_offline": "ดูเหมือนว่าคุณออฟไลน์อยู่ โปรดเชื่อมต่ออินเทอร์เน็ตและลองเริ่ม ArmCord ใหม่อีกครั้ง",
|
"setup_offline": "ดูเหมือนว่าคุณออฟไลน์อยู่ โปรดเชื่อมต่ออินเทอร์เน็ตและลองใหม่อีกครั้ง",
|
||||||
"setup_question2": "เลือกช่อง/อินสแตนส์ Discord:",
|
"setup_question2": "เลือกช่อง/อินสแตนส์ Discord:",
|
||||||
"setup_question3": "ต้องการให้ ArmCord จัดการการติดตั้งมอดของไคลเอนต์หรือไม่?",
|
"setup_question3": "ต้องการให้ ArmCord จัดการการติดตั้งมอดของไคลเอนต์หรือไม่?",
|
||||||
"yes": "ใช่",
|
"yes": "ใช่",
|
||||||
"no": "ไม่ใช่",
|
"no": "ไม่",
|
||||||
"next": "ถัดไป",
|
"next": "ถัดไป",
|
||||||
"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": "ย่อลงไปในถาดงาน",
|
||||||
"settings-patches": "แพทช์อัตโนมัติ",
|
"settings-patches": "แพทช์อัตโนมัติ",
|
||||||
"settings-channel": "ช่อง Discord:",
|
"settings-channel": "ช่อง Discord:",
|
||||||
"settings-invitewebsocket": "ใช้ Websocket สำหรับการเชิญ",
|
"settings-invitewebsocket": "ใช้ Websocket สำหรับการเชิญ",
|
||||||
"settings-prfmMode": "โหมดประสิทธิภาพ:",
|
"settings-prfmMode": "โหมดประสิทธิภาพ:",
|
||||||
"settings-prfmMode-performance": "ประสิทธิภาพสูงสุด",
|
"settings-prfmMode-performance": "ประสิทธิภาพ",
|
||||||
"settings-mod": "ไคลแอนต์มอด:",
|
"settings-mod": "ไคลแอนต์มอด:",
|
||||||
"settings-none": "ไม่มี",
|
"settings-none": "ไม่มี",
|
||||||
"settings-save": "บันทึกการตั้งค่า",
|
"settings-save": "บันทึกการตั้งค่า",
|
||||||
|
|
BIN
build/icon.icns
BIN
build/icon.ico
Before Width: | Height: | Size: 66 KiB |
|
@ -26,7 +26,7 @@
|
||||||
"@types/node": "^17.0.42",
|
"@types/node": "^17.0.42",
|
||||||
"@types/ws": "^8.5.3",
|
"@types/ws": "^8.5.3",
|
||||||
"copyfiles": "^2.4.1",
|
"copyfiles": "^2.4.1",
|
||||||
"electron": "^19.0.7",
|
"electron": "^19.0.4",
|
||||||
"electron-builder": "^23.0.3",
|
"electron-builder": "^23.0.3",
|
||||||
"husky": "^8.0.1",
|
"husky": "^8.0.1",
|
||||||
"prettier": "^2.7.1",
|
"prettier": "^2.7.1",
|
||||||
|
@ -47,7 +47,7 @@
|
||||||
"linux": {
|
"linux": {
|
||||||
"icon": "build/icon.icns",
|
"icon": "build/icon.icns",
|
||||||
"category": "Network",
|
"category": "Network",
|
||||||
"maintainer": "smartfridge@vivaldi.net",
|
"maintainer": "smartfrigde@gmail.com",
|
||||||
"target": [
|
"target": [
|
||||||
"deb",
|
"deb",
|
||||||
"tar.gz",
|
"tar.gz",
|
||||||
|
|
|
@ -1,16 +1,14 @@
|
||||||
.notice-2HEN-u {
|
.notice-2HEN-u {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
[customTitlebar] .sidebar-1tnWFu {
|
.sidebar-1tnWFu {
|
||||||
border-top-left-radius: 8px;
|
border-top-left-radius: 8px;
|
||||||
}
|
}
|
||||||
[customTitlebar] .scroller-3X7KbA {
|
.scroller-3X7KbA {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
padding-top: 4px;
|
padding-top: 4px;
|
||||||
}
|
}
|
||||||
* {
|
|
||||||
outline: none;
|
|
||||||
}
|
|
||||||
[class^="socialLinks-"] + [class^="info-"] {
|
[class^="socialLinks-"] + [class^="info-"] {
|
||||||
padding-right: 0;
|
padding-right: 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*MIT License
|
/*MIT License
|
||||||
|
|
||||||
Copyright (c) 2022 GooseMod
|
Copyright (c) 2021 GooseMod
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
@ -20,18 +20,11 @@ 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
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
SOFTWARE.*/
|
SOFTWARE.*/
|
||||||
:root {
|
:root {
|
||||||
--background-secondary: #2f3136;
|
--background-primary: #282b30;
|
||||||
--background-secondary-alt: #292b2f;
|
--background-secondary: rgba(255, 255, 255, 0.1);
|
||||||
--background-floating: #18191c;
|
--brand-experiment: #5865f2;
|
||||||
--background-modifier-hover: rgba(106, 116, 128, 0.16);
|
|
||||||
--brand-experiment: #7289da;
|
|
||||||
--brand-experiment-560: #5c6fb1;
|
|
||||||
--brand-experiment-600: #4e5d94;
|
|
||||||
--interactive-normal: #b9bbbe;
|
|
||||||
--interactive-hover: #dcddde;
|
|
||||||
--text-muted: #72767d;
|
|
||||||
--font-primary: "Whitney";
|
|
||||||
--header-primary: #fff;
|
--header-primary: #fff;
|
||||||
|
--text-muted: #72767d;
|
||||||
}
|
}
|
||||||
|
|
||||||
@font-face {
|
@font-face {
|
||||||
|
@ -43,19 +36,12 @@ SOFTWARE.*/
|
||||||
|
|
||||||
html,
|
html,
|
||||||
body {
|
body {
|
||||||
overflow-x: hidden;
|
overflow: hidden;
|
||||||
overflow-y: scroll;
|
|
||||||
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
margin: 2%;
|
margin: 2%;
|
||||||
background: var(--background-secondary);
|
background: var(--background-primary);
|
||||||
}
|
|
||||||
body::-webkit-scrollbar {
|
|
||||||
width: 0.4em;
|
|
||||||
background: transparent;
|
|
||||||
}
|
|
||||||
body::-webkit-scrollbar-thumb {
|
|
||||||
background: var(--background-floating);
|
|
||||||
border-radius: 25px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
* {
|
* {
|
||||||
|
@ -72,39 +58,31 @@ body::-webkit-scrollbar-thumb {
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
.header {
|
.header {
|
||||||
color: var(--header-primary);
|
color: white;
|
||||||
font-size: 1.46em;
|
font-size: 1.5em;
|
||||||
}
|
}
|
||||||
.center {
|
.center {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
left: 50%;
|
|
||||||
margin-right: 50%;
|
|
||||||
transform: translateX(50%);
|
|
||||||
float: right;
|
|
||||||
}
|
}
|
||||||
/*buttons*/
|
/*buttons*/
|
||||||
button {
|
button {
|
||||||
background: var(--brand-experiment);
|
background-color: #7289da;
|
||||||
color: var(--header-primary);
|
font-family: Whitney, "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||||||
outline: none;
|
color: #ffffff;
|
||||||
border: none;
|
padding: 4px;
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
padding: 8px;
|
margin-top: 5px;
|
||||||
transition: 0.17s ease;
|
|
||||||
}
|
text-align: center;
|
||||||
button:hover {
|
border-style: none;
|
||||||
background: var(--brand-experiment-560);
|
outline: none;
|
||||||
cursor: pointer;
|
|
||||||
transition: 0.17s ease;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
button:active {
|
button:hover {
|
||||||
background: var(--brand-experiment-600);
|
background-color: #687dc6;
|
||||||
|
border-style: none;
|
||||||
|
outline: none;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
transition: 0.17s ease;
|
|
||||||
}
|
|
||||||
#save {
|
|
||||||
font-size: 15px;
|
|
||||||
}
|
}
|
||||||
.tgl {
|
.tgl {
|
||||||
display: none;
|
display: none;
|
||||||
|
@ -157,47 +135,42 @@ button:active {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
}
|
}
|
||||||
.tgl + .tgl-btn:after {
|
.tgl + .tgl-btn:after {
|
||||||
left: 1px;
|
left: 0;
|
||||||
}
|
}
|
||||||
.tgl + .tgl-btn:before {
|
.tgl + .tgl-btn:before {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
.tgl:checked + .tgl-btn:after {
|
.tgl:checked + .tgl-btn:after {
|
||||||
left: 56%;
|
left: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tgl-light + .tgl-btn {
|
.tgl-light + .tgl-btn {
|
||||||
background: var(--text-muted);
|
background: #5c5757;
|
||||||
border-radius: 25px;
|
border-radius: 2em;
|
||||||
padding: 4px;
|
padding: 2px;
|
||||||
transition: all 0.4s ease;
|
transition: all 0.4s ease;
|
||||||
}
|
}
|
||||||
.tgl-light + .tgl-btn:after {
|
.tgl-light + .tgl-btn:after {
|
||||||
border-radius: 50px;
|
border-radius: 50%;
|
||||||
position: relative;
|
|
||||||
top: 50%;
|
|
||||||
transform: translateY(-50%);
|
|
||||||
width: 24px;
|
|
||||||
height: 24px;
|
|
||||||
background: rgb(255, 255, 255);
|
background: rgb(255, 255, 255);
|
||||||
transition: all 0.2s ease;
|
transition: all 0.2s ease;
|
||||||
}
|
}
|
||||||
.tgl-light:checked + .tgl-btn {
|
.tgl-light:checked + .tgl-btn {
|
||||||
background: var(--brand-experiment);
|
background: #47ca5a;
|
||||||
}
|
}
|
||||||
select {
|
select {
|
||||||
-webkit-appearance: button;
|
-webkit-appearance: button;
|
||||||
-moz-appearance: button;
|
-moz-appearance: button;
|
||||||
background-color: var(--background-secondary-alt);
|
background-color: #2c2f33;
|
||||||
background-position: center right;
|
background-position: center right;
|
||||||
background-repeat: no-repeat;
|
background-repeat: no-repeat;
|
||||||
border: 1px solid var(--background-floating);
|
border: 1px solid #aaa;
|
||||||
border-radius: 2px;
|
border-radius: 2px;
|
||||||
|
box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
|
||||||
color: #fff;
|
color: #fff;
|
||||||
font-size: 1.2em;
|
font-size: 1.2em;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
outline: none !important;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
|
@import url("https://armcord.smartfridge.space/logofont.css");
|
||||||
|
|
||||||
/* Meta {{{ */
|
/* Meta {{{ */
|
||||||
:root {
|
:root {
|
||||||
--background-primary: #282b30;
|
--background-primary: #282b30;
|
||||||
--background-secondary: rgba(255, 255, 255, 0.1);
|
--background-secondary: rgba(255, 255, 255, 0.1);
|
||||||
--background-modifier-hover: rgba(106, 116, 128, 0.16);
|
--background-modifier-hover: rgba(106, 116, 128, 0.16);
|
||||||
--brand-experiment: #7289da;
|
--brand-experiment: #7289da;
|
||||||
--brand-experiment-560: #5c6fb1;
|
|
||||||
--brand-experiment-600: #4e5d94;
|
|
||||||
--interactive-normal: #b9bbbe;
|
--interactive-normal: #b9bbbe;
|
||||||
--interactive-hover: #dcddde;
|
--interactive-hover: #dcddde;
|
||||||
--text-muted: #72767d;
|
--text-muted: #72767d;
|
||||||
|
@ -109,12 +109,7 @@ body {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
width: 33%;
|
width: 33%;
|
||||||
}
|
}
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container {
|
|
||||||
margin-left: -26px;
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #minimize {
|
|
||||||
transform: translateX(5px);
|
|
||||||
}
|
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
/* Buttons {{{ */
|
/* Buttons {{{ */
|
||||||
|
@ -135,18 +130,10 @@ button {
|
||||||
border: none;
|
border: none;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
padding: 8px 20px;
|
padding: 8px 20px;
|
||||||
transition: 0.17s ease;
|
|
||||||
}
|
}
|
||||||
button:hover {
|
button:hover {
|
||||||
background: var(--brand-experiment-560);
|
filter: brightness(85%);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
transition: 0.17s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
button:active {
|
|
||||||
background: var(--brand-experiment-600);
|
|
||||||
cursor: pointer;
|
|
||||||
transition: 0.17s ease;
|
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
|
@ -170,9 +157,5 @@ select {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
option {
|
|
||||||
text-align: left;
|
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*MIT License
|
/*MIT License
|
||||||
|
|
||||||
Copyright (c) 2022 GooseMod
|
Copyright (c) 2021 GooseMod
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
@ -22,7 +22,7 @@ SOFTWARE.*/
|
||||||
:root {
|
:root {
|
||||||
--background-primary: #282b30;
|
--background-primary: #282b30;
|
||||||
--background-secondary: rgba(255, 255, 255, 0.1);
|
--background-secondary: rgba(255, 255, 255, 0.1);
|
||||||
--brand-experiment: #7289da;
|
--brand-experiment: #5865f2;
|
||||||
--header-primary: #fff;
|
--header-primary: #fff;
|
||||||
--text-muted: #72767d;
|
--text-muted: #72767d;
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,105 +47,17 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ArmCord on Linux */
|
/* ArmCord on Linux */
|
||||||
[armcord-platform="linux"] .container-2RRFHK {
|
|
||||||
padding-top: 45px;
|
|
||||||
top: -45px;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar {
|
|
||||||
height: 45px;
|
|
||||||
line-height: 45px;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container {
|
|
||||||
line-height: 45px;
|
|
||||||
transform: translateY(-8px);
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #minimize:hover {
|
[armcord-platform="linux"] .titlebar #window-controls-container #minimize:hover {
|
||||||
background-color: var(--background-modifier-hover);
|
background-color: #99aab5;
|
||||||
transition: 0.2s ease;
|
|
||||||
}
|
}
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #maximize:hover {
|
[armcord-platform="linux"] .titlebar #window-controls-container #maximize:hover {
|
||||||
background-color: var(--background-modifier-hover);
|
background-color: #99aab5;
|
||||||
transition: 0.2s ease;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #minimize:hover #minimize-icon {
|
|
||||||
background-color: var(--interactive-hover);
|
|
||||||
transition: 0.2s ease;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #maximize:hover #maximize-icon {
|
|
||||||
background-color: var(--interactive-hover);
|
|
||||||
transition: 0.2s ease;
|
|
||||||
}
|
}
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #quit:hover {
|
[armcord-platform="linux"] .titlebar #window-controls-container #quit:hover {
|
||||||
background-color: var(--brand-experiment-560);
|
background-color: #f04747;
|
||||||
transition: 0.2s ease;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #quit #quit-icon {
|
|
||||||
background-color: #ffffff;
|
|
||||||
display: list-item;
|
|
||||||
transition: 0.1s ease;
|
|
||||||
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='9' height='9' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.279 5.5L11 10.221l-.779.779L5.5 6.279.779 11 0 10.221 4.721 5.5 0 .779.779 0 5.5 4.721 10.221 0 11 .779 6.279 5.5z' fill='%23000'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='9' height='9' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.279 5.5L11 10.221l-.779.779L5.5 6.279.779 11 0 10.221 4.721 5.5 0 .779.779 0 5.5 4.721 10.221 0 11 .779 6.279 5.5z' fill='%23000'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #minimize-icon {
|
|
||||||
background-color: var(--interactive-normal);
|
|
||||||
display: list-item;
|
|
||||||
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='9' height='9' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 4.399V5.5H0V4.399h11z' fill='%23000'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='9' height='9' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 4.399V5.5H0V4.399h11z' fill='%23000'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #maximize-icon {
|
|
||||||
background-color: var(--interactive-normal);
|
|
||||||
display: list-item;
|
|
||||||
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='9' height='9' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 0v11H0V0h11zM9.899 1.101H1.1V9.9h8.8V1.1z' fill='%23000'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='9' height='9' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 0v11H0V0h11zM9.899 1.101H1.1V9.9h8.8V1.1z' fill='%23000'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
}
|
|
||||||
|
|
||||||
[armcord-platform="linux"][isMaximized] .titlebar #window-controls-container #maximize-icon {
|
|
||||||
background-color: var(--interactive-normal);
|
|
||||||
display: list-item;
|
|
||||||
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='9' height='9'%3E%3Cstyle%3E%3C/style%3E%3Cpath fill-rule='evenodd' d='m6 0h24v24h-6v6h-24v-24h6zm3 6h15v15h3v-18h-18zm-6 21h18v-18h-18z'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='9' height='9'%3E%3Cstyle%3E%3C/style%3E%3Cpath fill-rule='evenodd' d='m6 0h24v24h-6v6h-24v-24h6zm3 6h15v15h3v-18h-18zm-6 21h18v-18h-18z'/%3E%3C/svg%3E")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #minimize {
|
|
||||||
background-color: transparent;
|
|
||||||
transition: 0.1s ease;
|
|
||||||
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='25' height='25'%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%;
|
|
||||||
mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='25' height='25'%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%;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #maximize {
|
|
||||||
background-color: transparent;
|
|
||||||
transition: 0.1s ease;
|
|
||||||
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='25' height='25'%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%;
|
|
||||||
mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='25' height='25'%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%;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #quit {
|
|
||||||
background-color: var(--brand-experiment);
|
|
||||||
transition: 0.1s ease;
|
|
||||||
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='25' height='25'%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%;
|
|
||||||
mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='25' height='25'%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%;
|
|
||||||
}
|
|
||||||
[armcord-platform="linux"] .titlebar #window-controls-container #quit:active {
|
|
||||||
background-color: var(--brand-experiment-600);
|
|
||||||
transition: 0.1s ease;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ArmCord on Windows */
|
/* ArmCord on Windows */
|
||||||
[armcord-platform="win32"] .titlebar #window-controls-container {
|
|
||||||
width: 142px;
|
|
||||||
}
|
|
||||||
[armcord-platform="win32"] .titlebar #window-controls-container #minimize:hover {
|
[armcord-platform="win32"] .titlebar #window-controls-container #minimize:hover {
|
||||||
background-color: var(--background-modifier-hover);
|
background-color: var(--background-modifier-hover);
|
||||||
transition: 0.2s ease;
|
transition: 0.2s ease;
|
||||||
|
@ -190,7 +102,8 @@
|
||||||
background-color: #000000cc;
|
background-color: #000000cc;
|
||||||
transition: 0.1s ease;
|
transition: 0.1s ease;
|
||||||
}
|
}
|
||||||
[armcord-platform="win32"] .titlebar #window-controls-container #quit-icon {
|
|
||||||
|
.titlebar #window-controls-container #quit-icon {
|
||||||
background-color: var(--interactive-normal);
|
background-color: var(--interactive-normal);
|
||||||
display: list-item;
|
display: list-item;
|
||||||
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.279 5.5L11 10.221l-.779.779L5.5 6.279.779 11 0 10.221 4.721 5.5 0 .779.779 0 5.5 4.721 10.221 0 11 .779 6.279 5.5z' fill='%23000'/%3E%3C/svg%3E")
|
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.279 5.5L11 10.221l-.779.779L5.5 6.279.779 11 0 10.221 4.721 5.5 0 .779.779 0 5.5 4.721 10.221 0 11 .779 6.279 5.5z' fill='%23000'/%3E%3C/svg%3E")
|
||||||
|
@ -198,7 +111,7 @@
|
||||||
mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.279 5.5L11 10.221l-.779.779L5.5 6.279.779 11 0 10.221 4.721 5.5 0 .779.779 0 5.5 4.721 10.221 0 11 .779 6.279 5.5z' fill='%23000'/%3E%3C/svg%3E")
|
mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.279 5.5L11 10.221l-.779.779L5.5 6.279.779 11 0 10.221 4.721 5.5 0 .779.779 0 5.5 4.721 10.221 0 11 .779 6.279 5.5z' fill='%23000'/%3E%3C/svg%3E")
|
||||||
no-repeat 50% 50%;
|
no-repeat 50% 50%;
|
||||||
}
|
}
|
||||||
[armcord-platform="win32"] .titlebar #window-controls-container #minimize-icon {
|
.titlebar #window-controls-container #minimize-icon {
|
||||||
background-color: var(--interactive-normal);
|
background-color: var(--interactive-normal);
|
||||||
display: list-item;
|
display: list-item;
|
||||||
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 4.399V5.5H0V4.399h11z' fill='%23000'/%3E%3C/svg%3E")
|
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 4.399V5.5H0V4.399h11z' fill='%23000'/%3E%3C/svg%3E")
|
||||||
|
@ -206,7 +119,7 @@
|
||||||
mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 4.399V5.5H0V4.399h11z' fill='%23000'/%3E%3C/svg%3E")
|
mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 4.399V5.5H0V4.399h11z' fill='%23000'/%3E%3C/svg%3E")
|
||||||
no-repeat 50% 50%;
|
no-repeat 50% 50%;
|
||||||
}
|
}
|
||||||
[armcord-platform="win32"] .titlebar #window-controls-container #maximize-icon {
|
.titlebar #window-controls-container #maximize-icon {
|
||||||
background-color: var(--interactive-normal);
|
background-color: var(--interactive-normal);
|
||||||
display: list-item;
|
display: list-item;
|
||||||
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 0v11H0V0h11zM9.899 1.101H1.1V9.9h8.8V1.1z' fill='%23000'/%3E%3C/svg%3E")
|
-webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 0v11H0V0h11zM9.899 1.101H1.1V9.9h8.8V1.1z' fill='%23000'/%3E%3C/svg%3E")
|
||||||
|
@ -215,7 +128,7 @@
|
||||||
no-repeat 50% 50%;
|
no-repeat 50% 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
[armcord-platform="win32"][isMaximized] .titlebar #window-controls-container #maximize-icon {
|
[isMaximized] .titlebar #window-controls-container #maximize-icon {
|
||||||
background-color: var(--interactive-normal);
|
background-color: var(--interactive-normal);
|
||||||
display: list-item;
|
display: list-item;
|
||||||
-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30' width='11' height='11'%3E%3Cstyle%3E%3C/style%3E%3Cpath fill-rule='evenodd' d='m6 0h24v24h-6v6h-24v-24h6zm3 6h15v15h3v-18h-18zm-6 21h18v-18h-18z'/%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='11' height='11'%3E%3Cstyle%3E%3C/style%3E%3Cpath fill-rule='evenodd' d='m6 0h24v24h-6v6h-24v-24h6zm3 6h15v15h3v-18h-18zm-6 21h18v-18h-18z'/%3E%3C/svg%3E")
|
||||||
|
@ -224,124 +137,7 @@
|
||||||
no-repeat 50% 50%;
|
no-repeat 50% 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ArmCord on MacOS (Why would you do this?) */
|
.window-title {
|
||||||
[armcord-platform="darwin"] .container-2RRFHK {
|
|
||||||
padding-top: 45px;
|
|
||||||
top: -45px;
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar {
|
|
||||||
height: 45px;
|
|
||||||
line-height: 45px;
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container {
|
|
||||||
float: left;
|
|
||||||
width: 150px;
|
|
||||||
height: 60%;
|
|
||||||
line-height: 45px;
|
|
||||||
-webkit-app-region: no-drag;
|
|
||||||
transform: translate(-78px, 4px);
|
|
||||||
}
|
|
||||||
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container:hover #minimize #minimize-icon,
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container:hover #maximize #maximize-icon,
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container:hover #quit #quit-icon {
|
|
||||||
display: list-item;
|
|
||||||
}
|
|
||||||
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #quit #quit-icon {
|
|
||||||
background-color: #79282b;
|
|
||||||
-webkit-mask: url("")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
mask: url("")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
transform: translate(-0.3px, -11.7px);
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #minimize #minimize-icon {
|
|
||||||
background-color: #7d631b;
|
|
||||||
-webkit-mask: url("")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
mask: url("")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
transform: translate(-0px, -11.7px);
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #maximize #maximize-icon {
|
|
||||||
background-color: #1d7525;
|
|
||||||
-webkit-mask: url("")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
mask: url("")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
transform: translate(-0.2px, -11.7px);
|
|
||||||
}
|
|
||||||
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #minimize {
|
|
||||||
background-color: #fac536;
|
|
||||||
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")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
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%;
|
|
||||||
transform: translateX(-21.5px);
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #maximize {
|
|
||||||
background-color: #39ea49;
|
|
||||||
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")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
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%;
|
|
||||||
transform: translateX(21.5px);
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #quit {
|
|
||||||
background-color: #f25056;
|
|
||||||
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")
|
|
||||||
no-repeat 50% 50%;
|
|
||||||
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%;
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container:hover #maximize:active {
|
|
||||||
background-color: #13c11e;
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container:hover #minimize:active {
|
|
||||||
background-color: #da9e10;
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container:hover #quit:active {
|
|
||||||
background-color: #d52735;
|
|
||||||
}
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #spacer,
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #minimize,
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #maximize,
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #quit {
|
|
||||||
float: right;
|
|
||||||
height: 80%;
|
|
||||||
width: 13%;
|
|
||||||
text-align: center;
|
|
||||||
color: transparent;
|
|
||||||
cursor: default;
|
|
||||||
}
|
|
||||||
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #minimize-icon,
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #maximize-icon,
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #quit-icon {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
[armcord-platform="darwin"] .titlebar #window-controls-container #spacer {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
[armcord-platform="darwin"] .window-title {
|
|
||||||
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="win32"] .window-title {
|
|
||||||
content: var(--wordmark-svg);
|
content: var(--wordmark-svg);
|
||||||
height: 10px;
|
height: 10px;
|
||||||
margin-left: initial;
|
margin-left: initial;
|
||||||
|
@ -350,12 +146,6 @@
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
[wordmark="discord"] .window-title {
|
|
||||||
content: var(--discord-wordmark-svg);
|
|
||||||
height: 11.7px;
|
|
||||||
width: 56px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.withFrame-haYltI {
|
.withFrame-haYltI {
|
||||||
height: 30px !important;
|
height: 30px !important;
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,9 @@
|
||||||
<body>
|
<body>
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div id="warning" class="hidden">
|
<div id="warning" class="hidden">
|
||||||
<p id="setup_offline">You appear to be offline. Please connect to the internet and restart ArmCord.</p>
|
<p id="setup_offline">
|
||||||
|
You appear to be offline. Please connect to the internet and restart ArmCord Setup.
|
||||||
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div id="setup">
|
<div id="setup">
|
||||||
<div id="logo" class="hidden"></div>
|
<div id="logo" class="hidden"></div>
|
||||||
|
@ -121,7 +123,6 @@
|
||||||
automaticPatches: false,
|
automaticPatches: false,
|
||||||
mods: "cumcord",
|
mods: "cumcord",
|
||||||
inviteWebsocket: true,
|
inviteWebsocket: true,
|
||||||
trayIcon: "ac_plug_colored",
|
|
||||||
performanceMode: "none"
|
performanceMode: "none"
|
||||||
});
|
});
|
||||||
setTimeout(() => window.armcordinternal.restart(), 5000);
|
setTimeout(() => window.armcordinternal.restart(), 5000);
|
||||||
|
@ -152,7 +153,6 @@
|
||||||
minimizeToTray: true,
|
minimizeToTray: true,
|
||||||
automaticPatches: false,
|
automaticPatches: false,
|
||||||
performanceMode: "none",
|
performanceMode: "none",
|
||||||
trayIcon: "ac_plug_colored",
|
|
||||||
mods: options.mod,
|
mods: options.mod,
|
||||||
inviteWebsocket: true
|
inviteWebsocket: true
|
||||||
});
|
});
|
||||||
|
@ -168,13 +168,11 @@
|
||||||
autoLaunch: true,
|
autoLaunch: true,
|
||||||
mods: "none",
|
mods: "none",
|
||||||
performanceMode: "none",
|
performanceMode: "none",
|
||||||
trayIcon: "ac_plug_colored",
|
|
||||||
inviteWebsocket: true
|
inviteWebsocket: true
|
||||||
});
|
});
|
||||||
setTimeout(() => window.armcordinternal.restart(), 500);
|
setTimeout(() => window.armcordinternal.restart(), 500);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
document.body.setAttribute("insetup", "");
|
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -6,13 +6,6 @@
|
||||||
<style>
|
<style>
|
||||||
@import url("css/splash.css");
|
@import url("css/splash.css");
|
||||||
</style>
|
</style>
|
||||||
<script>
|
|
||||||
window.onbeforeunload = function () {
|
|
||||||
const style = document.createElement("style");
|
|
||||||
style.textContent = "body { display: none; }";
|
|
||||||
document.head.append(style);
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
|
@ -30,7 +23,7 @@
|
||||||
text.innerHTML = await armcord.getLang("loading_screen_offline");
|
text.innerHTML = await armcord.getLang("loading_screen_offline");
|
||||||
} else {
|
} else {
|
||||||
text.innerHTML = await armcord.getLang("loading_screen_start");
|
text.innerHTML = await armcord.getLang("loading_screen_start");
|
||||||
if (window.armcord.version === "3.1.0") {
|
if (window.armcord.version === "DEV") {
|
||||||
console.log("Running a development build of ArmCord. Skipping updater.");
|
console.log("Running a development build of ArmCord. Skipping updater.");
|
||||||
} else {
|
} else {
|
||||||
const response = await fetch("https://armcord.xyz/latest.json");
|
const response = await fetch("https://armcord.xyz/latest.json");
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
//https://github.com/GooseMod/GooseMod/wiki/Stuck-Updater-or-Blank-Window-Fix
|
//https://github.com/GooseMod/GooseMod/wiki/Stuck-Updater-or-Blank-Window-Fix
|
||||||
/*
|
/*
|
||||||
Copyright 2022 GooseMod
|
Copyright 2021 GooseMod
|
||||||
|
|
||||||
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:
|
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:
|
||||||
|
|
||||||
|
@ -60,6 +60,6 @@ electron.app.whenReady().then(async () => {
|
||||||
if (await getConfig("armcordCSP")) {
|
if (await getConfig("armcordCSP")) {
|
||||||
unstrictCSP();
|
unstrictCSP();
|
||||||
} else {
|
} else {
|
||||||
console.log("ArmCord CSP is disabled. The CSP should be managed by a third-party plugin(s).");
|
console.log("ArmCord CSP is disabled. The CSP should be managed by third-party plugin.");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
24
src/ipc.ts
|
@ -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} from "./utils";
|
import {setConfigBulk, getVersion, getConfig, setLang, getLang} 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() {
|
||||||
|
@ -23,9 +23,6 @@ export function registerIpc() {
|
||||||
ipcMain.on("win-isMaximized", (event, arg) => {
|
ipcMain.on("win-isMaximized", (event, arg) => {
|
||||||
event.returnValue = mainWindow.isMaximized();
|
event.returnValue = mainWindow.isMaximized();
|
||||||
});
|
});
|
||||||
ipcMain.on("win-isNormal", (event, arg) => {
|
|
||||||
event.returnValue = mainWindow.isNormal();
|
|
||||||
});
|
|
||||||
ipcMain.on("win-minimize", (event, arg) => {
|
ipcMain.on("win-minimize", (event, arg) => {
|
||||||
mainWindow.minimize();
|
mainWindow.minimize();
|
||||||
});
|
});
|
||||||
|
@ -44,22 +41,8 @@ export function registerIpc() {
|
||||||
ipcMain.on("get-app-version", (event) => {
|
ipcMain.on("get-app-version", (event) => {
|
||||||
event.returnValue = getVersion();
|
event.returnValue = getVersion();
|
||||||
});
|
});
|
||||||
ipcMain.on("splashEnd", async (event, arg) => {
|
ipcMain.on("splashEnd", (event, arg) => {
|
||||||
try {
|
|
||||||
var width = await getWindowState("width") ?? 800;
|
|
||||||
var height= await getWindowState("height") ?? 600;
|
|
||||||
var isMaximized = await getWindowState("isMaximized") ?? false;
|
|
||||||
} catch (e) {
|
|
||||||
console.log("No window state file found. Fallbacking to default values.")
|
|
||||||
mainWindow.setSize(800, 600);
|
mainWindow.setSize(800, 600);
|
||||||
}
|
|
||||||
if (isMaximized) {
|
|
||||||
mainWindow.setSize(800, 600); //just so the whole thing doesn't cover whole screen
|
|
||||||
mainWindow.maximize()
|
|
||||||
} else {
|
|
||||||
mainWindow.setSize(width, height);
|
|
||||||
console.log("Not maximized.")
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
ipcMain.on("restart", (event, arg) => {
|
ipcMain.on("restart", (event, arg) => {
|
||||||
app.relaunch();
|
app.relaunch();
|
||||||
|
@ -77,9 +60,6 @@ export function registerIpc() {
|
||||||
ipcMain.on("clientmod", async (event, arg) => {
|
ipcMain.on("clientmod", async (event, arg) => {
|
||||||
event.returnValue = await getConfig("mods");
|
event.returnValue = await getConfig("mods");
|
||||||
});
|
});
|
||||||
ipcMain.on("trayIcon", async (event, arg) => {
|
|
||||||
event.returnValue = await getConfig("trayIcon");
|
|
||||||
});
|
|
||||||
ipcMain.on("titlebar", (event, arg) => {
|
ipcMain.on("titlebar", (event, arg) => {
|
||||||
event.returnValue = customTitlebar;
|
event.returnValue = customTitlebar;
|
||||||
});
|
});
|
||||||
|
|
|
@ -10,7 +10,7 @@ import "./shortcuts";
|
||||||
|
|
||||||
export var settings: any;
|
export var settings: any;
|
||||||
export var customTitlebar: boolean;
|
export var customTitlebar: boolean;
|
||||||
export var clientName: "ArmCord";
|
|
||||||
|
|
||||||
if (process.platform == "linux") {
|
if (process.platform == "linux") {
|
||||||
if (process.env.$XDG_SESSION_TYPE == "wayland") {
|
if (process.env.$XDG_SESSION_TYPE == "wayland") {
|
||||||
|
@ -34,7 +34,7 @@ app.whenReady().then(async () => {
|
||||||
case "native":
|
case "native":
|
||||||
createNativeWindow();
|
createNativeWindow();
|
||||||
break;
|
break;
|
||||||
case "basic":
|
case "discord":
|
||||||
createNativeWindow();
|
createNativeWindow();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -68,7 +68,6 @@ app.whenReady().then(async () => {
|
||||||
createCustomWindow();
|
createCustomWindow();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
console.log("userDataPath = " + app.getPath("userData"));
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@ contextBridge.exposeInMainWorld("armcord", {
|
||||||
},
|
},
|
||||||
electron: process.versions.electron,
|
electron: process.versions.electron,
|
||||||
channel: ipcRenderer.sendSync("channel"),
|
channel: ipcRenderer.sendSync("channel"),
|
||||||
|
openTab: (number: number) => ipcRenderer.sendSync("openTab", number),
|
||||||
setLang: (lang: string) => ipcRenderer.send("setLang", lang),
|
setLang: (lang: string) => ipcRenderer.send("setLang", lang),
|
||||||
getLang: (toGet: string) =>
|
getLang: (toGet: string) =>
|
||||||
ipcRenderer.invoke("getLang", toGet).then((result) => {
|
ipcRenderer.invoke("getLang", toGet).then((result) => {
|
||||||
|
|
|
@ -28,9 +28,6 @@ const clientMods = {
|
||||||
};
|
};
|
||||||
|
|
||||||
console.log("ArmCord");
|
console.log("ArmCord");
|
||||||
ipcRenderer.on("themeLoader", (event, message) => {
|
|
||||||
addStyle(message);
|
|
||||||
});
|
|
||||||
if (window.location.href.indexOf("splash.html") > -1) {
|
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 {
|
||||||
|
@ -93,5 +90,6 @@ setInterval(() => {
|
||||||
|
|
||||||
el.textContent = `\nArmCord Version: ${version}`;
|
el.textContent = `\nArmCord Version: ${version}`;
|
||||||
el.onclick = () => ipcRenderer.send("openSettingsWindow");
|
el.onclick = () => ipcRenderer.send("openSettingsWindow");
|
||||||
|
|
||||||
host.append(el);
|
host.append(el);
|
||||||
}, 2000);
|
}, 2000);
|
||||||
|
|
|
@ -2,7 +2,7 @@ import {ipcRenderer} from "electron";
|
||||||
import {addStyle} from "../utils";
|
import {addStyle} from "../utils";
|
||||||
import * as fs from "fs";
|
import * as fs from "fs";
|
||||||
import * as path from "path";
|
import * as path from "path";
|
||||||
import os from "os";
|
import {platform} from "node:process";
|
||||||
export function injectTitlebar() {
|
export function injectTitlebar() {
|
||||||
document.addEventListener("DOMContentLoaded", function (event) {
|
document.addEventListener("DOMContentLoaded", function (event) {
|
||||||
var elem = document.createElement("div");
|
var elem = document.createElement("div");
|
||||||
|
@ -25,8 +25,7 @@ export function injectTitlebar() {
|
||||||
const wordmarkcssPath = path.join(__dirname, "../", "/content/css/logos.css");
|
const wordmarkcssPath = path.join(__dirname, "../", "/content/css/logos.css");
|
||||||
addStyle(fs.readFileSync(titlebarcssPath, "utf8"));
|
addStyle(fs.readFileSync(titlebarcssPath, "utf8"));
|
||||||
addStyle(fs.readFileSync(wordmarkcssPath, "utf8"));
|
addStyle(fs.readFileSync(wordmarkcssPath, "utf8"));
|
||||||
document.body.setAttribute("customTitlebar", "");
|
document.body.setAttribute("armcord-platform", platform);
|
||||||
document.body.setAttribute("armcord-platform", "win32");
|
|
||||||
|
|
||||||
var minimize = document.getElementById("minimize");
|
var minimize = document.getElementById("minimize");
|
||||||
var maximize = document.getElementById("maximize");
|
var maximize = document.getElementById("maximize");
|
||||||
|
@ -39,8 +38,7 @@ export function injectTitlebar() {
|
||||||
maximize!.addEventListener("click", () => {
|
maximize!.addEventListener("click", () => {
|
||||||
if (ipcRenderer.sendSync("win-isMaximized") == true) {
|
if (ipcRenderer.sendSync("win-isMaximized") == true) {
|
||||||
ipcRenderer.send("win-unmaximize");
|
ipcRenderer.send("win-unmaximize");
|
||||||
document.body.removeAttribute("isMaximized");
|
} else {
|
||||||
} else if (ipcRenderer.sendSync("win-isNormal") == true) {
|
|
||||||
ipcRenderer.send("win-maximize");
|
ipcRenderer.send("win-maximize");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -54,3 +52,6 @@ export function injectTitlebar() {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
export function removeTitlebar() {
|
||||||
|
document.querySelector("#titlebar")!.remove();
|
||||||
|
}
|
||||||
|
|
|
@ -66,18 +66,7 @@
|
||||||
</select>
|
</select>
|
||||||
<p class="header" id="settings-prfmMode">Performance mode:</p>
|
<p class="header" id="settings-prfmMode">Performance mode:</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="switch">
|
<button id="settings-save" class="center">Save settings</button>
|
||||||
<select name="trayIcon" id="trayIcon" class="left">
|
|
||||||
<option value="ac_plug_colored">Default</option>
|
|
||||||
<option value="dsc-tray">Discord Icon</option>
|
|
||||||
<option value="ac_white_plug">White Icon</option>
|
|
||||||
<option value="ac_black_plug">Black Icon</option>
|
|
||||||
<option value="ac_white_plug_hollow">White Hollowed Icon</option>
|
|
||||||
<option value="ac_black_plug_hollow">Black Hollowed Icon</option>
|
|
||||||
</select>
|
|
||||||
<p class="header" id="settings-trayIcon">Tray icon:</p>
|
|
||||||
</div>
|
|
||||||
<button id="settings-save" class="center">Save Settings</button>
|
|
||||||
</body>
|
</body>
|
||||||
<script>
|
<script>
|
||||||
async function loadLang() {
|
async function loadLang() {
|
||||||
|
@ -112,7 +101,6 @@
|
||||||
document.getElementById("channel").value = await settings.get("channel");
|
document.getElementById("channel").value = await settings.get("channel");
|
||||||
document.getElementById("theme").value = await settings.get("windowStyle");
|
document.getElementById("theme").value = await settings.get("windowStyle");
|
||||||
document.getElementById("prfmMode").value = await settings.get("performanceMode");
|
document.getElementById("prfmMode").value = await settings.get("performanceMode");
|
||||||
document.getElementById("trayIcon").value = await settings.get("trayIcon");
|
|
||||||
}
|
}
|
||||||
loadSettings();
|
loadSettings();
|
||||||
document.getElementById("settings-save").addEventListener("click", function () {
|
document.getElementById("settings-save").addEventListener("click", function () {
|
||||||
|
@ -125,7 +113,6 @@
|
||||||
mods: document.getElementById("mod").value,
|
mods: document.getElementById("mod").value,
|
||||||
inviteWebsocket: document.getElementById("websocket").checked,
|
inviteWebsocket: document.getElementById("websocket").checked,
|
||||||
performanceMode: document.getElementById("prfmMode").value,
|
performanceMode: document.getElementById("prfmMode").value,
|
||||||
trayIcon: document.getElementById("trayIcon").value,
|
|
||||||
doneSetup: true
|
doneSetup: true
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -14,10 +14,5 @@ app.on("web-contents-created", (webContentsCreatedEvent, webContents) => {
|
||||||
if (shift && control && !alt && !meta && code === "KeyR") {
|
if (shift && control && !alt && !meta && code === "KeyR") {
|
||||||
mainWindow.reload();
|
mainWindow.reload();
|
||||||
}
|
}
|
||||||
// Shortcut: app reload
|
|
||||||
if (alt && control && !shift && !meta && code === "KeyR") {
|
|
||||||
app.relaunch();
|
|
||||||
app.exit();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
87
src/tray.ts
|
@ -1,94 +1,46 @@
|
||||||
import * as fs from "fs";
|
|
||||||
import {app, Menu, Tray} from "electron";
|
import {app, Menu, Tray} from "electron";
|
||||||
import {mainWindow} from "./window";
|
import {mainWindow} from "./window";
|
||||||
import { getConfig, getConfigLocation, setWindowState } from "./utils";
|
import {getConfig} from "./utils";
|
||||||
import * as path from "path";
|
import * as path from "path";
|
||||||
import {createSettingsWindow} from "./settings/main";
|
import {createSettingsWindow} from "./settings/main";
|
||||||
|
import {platform} from "process";
|
||||||
let tray: any = null;
|
let tray: any = null;
|
||||||
|
let defaultIcon = "ac_plug_colored";
|
||||||
app.whenReady().then(async () => {
|
app.whenReady().then(async () => {
|
||||||
let finishedSetup = (await getConfig("doneSetup"));
|
if (platform == "darwin") {
|
||||||
if ((await getConfig("windowStyle")) == "basic") {
|
defaultIcon = "macos"
|
||||||
var clientName = (await getConfig("clientName")) ?? "ArmCord";
|
|
||||||
var trayIcon = (await getConfig("trayIcon")) ?? "ac_plug_colored";
|
|
||||||
tray = new Tray(path.join(__dirname, "../", `/assets/${trayIcon}.png`));
|
|
||||||
const contextMenu = function () {
|
|
||||||
if (finishedSetup == false) {
|
|
||||||
return Menu.buildFromTemplate([
|
|
||||||
{
|
|
||||||
label: `Finish the setup first!`,
|
|
||||||
enabled: false
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: `Quit ${clientName}`,
|
|
||||||
click: async function () {
|
|
||||||
fs.unlink(await getConfigLocation(), (err) => {
|
|
||||||
if (err) throw err;
|
|
||||||
console.log('Closed during setup. "settings.json" was deleted');
|
|
||||||
app.quit();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
if ((await getConfig("windowStyle")) == "discord") {
|
||||||
]);
|
tray = new Tray(path.join(__dirname, "../", "/assets/dsc-tray.png"));
|
||||||
} else {
|
const contextMenu = Menu.buildFromTemplate([
|
||||||
return Menu.buildFromTemplate([
|
|
||||||
{
|
{
|
||||||
label: `Open ${clientName}`,
|
label: "Open ArmCord",
|
||||||
click: function () {
|
click: function () {
|
||||||
mainWindow.show();
|
mainWindow.show();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: `Quit ${clientName}`,
|
label: "Quit ArmCord",
|
||||||
click: function () {
|
click: function () {
|
||||||
let [width, height] = mainWindow.getSize()
|
|
||||||
setWindowState({
|
|
||||||
width: width,
|
|
||||||
height: height,
|
|
||||||
isMaximized: mainWindow.isMaximized()
|
|
||||||
})
|
|
||||||
app.quit();
|
app.quit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]);
|
]);
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tray.setToolTip(clientName);
|
tray.setToolTip("Discord");
|
||||||
tray.setContextMenu(contextMenu);
|
tray.setContextMenu(contextMenu);
|
||||||
} else {
|
} else {
|
||||||
var clientName = (await getConfig("clientName")) ?? "ArmCord";
|
var trayIcon = (await getConfig("trayIcon")) ?? defaultIcon;
|
||||||
var trayIcon = (await getConfig("trayIcon")) ?? "ac_plug_colored";
|
|
||||||
tray = new Tray(path.join(__dirname, "../", `/assets/${trayIcon}.png`));
|
tray = new Tray(path.join(__dirname, "../", `/assets/${trayIcon}.png`));
|
||||||
if (finishedSetup == false) {
|
|
||||||
const contextMenu = Menu.buildFromTemplate([
|
const contextMenu = Menu.buildFromTemplate([
|
||||||
{
|
{
|
||||||
label: `Finish the setup first!`,
|
label: "ArmCord"
|
||||||
enabled: false
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: `Quit ${clientName}`,
|
|
||||||
click: async function () {
|
|
||||||
fs.unlink(await getConfigLocation(), (err) => {
|
|
||||||
if (err) throw err;
|
|
||||||
console.log('Closed during setup. "settings.json" was deleted');
|
|
||||||
app.quit();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
tray.setContextMenu(contextMenu);
|
|
||||||
} else {
|
|
||||||
const contextMenu = Menu.buildFromTemplate([
|
|
||||||
{
|
|
||||||
label: `${clientName} ` + app.getVersion(),
|
|
||||||
enabled: false
|
|
||||||
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: "separator"
|
type: "separator"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: `Open ${clientName}`,
|
label: "Open ArmCord",
|
||||||
click: function () {
|
click: function () {
|
||||||
mainWindow.show();
|
mainWindow.show();
|
||||||
}
|
}
|
||||||
|
@ -110,19 +62,14 @@ app.whenReady().then(async () => {
|
||||||
type: "separator"
|
type: "separator"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: `Quit ${clientName}`,
|
label: "Quit ArmCord",
|
||||||
click: function () {
|
click: function () {
|
||||||
app.quit();
|
app.quit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
tray.setToolTip("ArmCord " + app.getVersion());
|
||||||
tray.setContextMenu(contextMenu);
|
tray.setContextMenu(contextMenu);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
tray.setToolTip(clientName);
|
|
||||||
tray.on('click', function(){
|
|
||||||
mainWindow.show()
|
|
||||||
});
|
});
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
50
src/utils.ts
|
@ -1,6 +1,7 @@
|
||||||
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";
|
||||||
|
import {defaultMaxListeners} from "events";
|
||||||
export var firstRun: boolean;
|
export var firstRun: boolean;
|
||||||
export var isSetup: boolean;
|
export var isSetup: boolean;
|
||||||
export var contentPath: string;
|
export var contentPath: string;
|
||||||
|
@ -43,7 +44,6 @@ export function setup() {
|
||||||
mods: "cumcord",
|
mods: "cumcord",
|
||||||
performanceMode: "none",
|
performanceMode: "none",
|
||||||
inviteWebsocket: true,
|
inviteWebsocket: true,
|
||||||
trayIcon: "ac_plug_colored",
|
|
||||||
doneSetup: false
|
doneSetup: false
|
||||||
};
|
};
|
||||||
setConfigBulk({
|
setConfigBulk({
|
||||||
|
@ -52,8 +52,8 @@ export function setup() {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getVersion() {
|
export function getVersion() {
|
||||||
//I'm too lazy to replace every mf reference so :p
|
//to-do better way of doing this
|
||||||
return app.getVersion();
|
return "3.1.0";
|
||||||
}
|
}
|
||||||
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();
|
||||||
|
@ -119,17 +119,12 @@ export async function setLang(language: string) {
|
||||||
var language: string;
|
var language: string;
|
||||||
export async function getLang(object: string) {
|
export async function getLang(object: string) {
|
||||||
if (language == undefined) {
|
if (language == undefined) {
|
||||||
try {
|
|
||||||
const userDataPath = app.getPath("userData");
|
const userDataPath = app.getPath("userData");
|
||||||
const storagePath = path.join(userDataPath, "/storage/");
|
const storagePath = path.join(userDataPath, "/storage/");
|
||||||
const langConfigFile = storagePath + "lang.json";
|
const langConfigFile = storagePath + "lang.json";
|
||||||
let rawdata = fs.readFileSync(langConfigFile, "utf-8");
|
let rawdata = fs.readFileSync(langConfigFile, "utf-8");
|
||||||
let parsed = JSON.parse(rawdata);
|
let parsed = JSON.parse(rawdata);
|
||||||
language = parsed["lang"];
|
language = parsed["lang"];
|
||||||
} catch (e) {
|
|
||||||
console.log("Language config file doesn't exist. Fallback to English.")
|
|
||||||
language = "en-US"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (language.length == 2) {
|
if (language.length == 2) {
|
||||||
language = language + "-" + language.toUpperCase();
|
language = language + "-" + language.toUpperCase();
|
||||||
|
@ -142,33 +137,6 @@ export async function getLang(object: string) {
|
||||||
let parsed = JSON.parse(rawdata);
|
let parsed = JSON.parse(rawdata);
|
||||||
return parsed[object];
|
return parsed[object];
|
||||||
}
|
}
|
||||||
|
|
||||||
//ArmCord Window State manager
|
|
||||||
export interface WindowState {
|
|
||||||
width: number;
|
|
||||||
height: number;
|
|
||||||
isMaximized: boolean;
|
|
||||||
}
|
|
||||||
export async function setWindowState(object: WindowState) {
|
|
||||||
const userDataPath = app.getPath("userData");
|
|
||||||
const storagePath = path.join(userDataPath, "/storage/");
|
|
||||||
const saveFile = storagePath + "window.json";
|
|
||||||
if (!fs.existsSync(saveFile)) {
|
|
||||||
fs.writeFileSync(saveFile, "{}", "utf-8");
|
|
||||||
}
|
|
||||||
let toSave = JSON.stringify(object);
|
|
||||||
fs.writeFileSync(saveFile, toSave, "utf-8");
|
|
||||||
}
|
|
||||||
export async function getWindowState(object: string) {
|
|
||||||
const userDataPath = app.getPath("userData");
|
|
||||||
const storagePath = path.join(userDataPath, "/storage/");
|
|
||||||
const settingsFile = storagePath + "window.json";
|
|
||||||
let rawdata = fs.readFileSync(settingsFile, "utf-8");
|
|
||||||
let returndata = JSON.parse(rawdata);
|
|
||||||
console.log(object + ": " + returndata[object]);
|
|
||||||
return returndata[object];
|
|
||||||
|
|
||||||
}
|
|
||||||
//ArmCord Settings/Storage manager
|
//ArmCord Settings/Storage manager
|
||||||
|
|
||||||
export interface Settings {
|
export interface Settings {
|
||||||
|
@ -180,7 +148,6 @@ export interface Settings {
|
||||||
mods: string;
|
mods: string;
|
||||||
performanceMode: string;
|
performanceMode: string;
|
||||||
inviteWebsocket: boolean;
|
inviteWebsocket: boolean;
|
||||||
trayIcon: string;
|
|
||||||
doneSetup: boolean;
|
doneSetup: boolean;
|
||||||
}
|
}
|
||||||
export async function getConfig(object: string) {
|
export async function getConfig(object: string) {
|
||||||
|
@ -198,17 +165,6 @@ export async function getConfig(object: string) {
|
||||||
return "setup";
|
return "setup";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
export async function getConfigLocation() {
|
|
||||||
try {
|
|
||||||
const userDataPath = app.getPath("userData");
|
|
||||||
const storagePath = path.join(userDataPath, "/storage/");
|
|
||||||
return storagePath + "settings.json";
|
|
||||||
} catch (e) {
|
|
||||||
console.log("Config probably doesn't exist yet. Returning setup value.");
|
|
||||||
firstRun = true;
|
|
||||||
return "setup";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
export async function setConfig(object: string, toSet: any) {
|
export async function setConfig(object: string, toSet: any) {
|
||||||
try {
|
try {
|
||||||
const userDataPath = app.getPath("userData");
|
const userDataPath = app.getPath("userData");
|
||||||
|
|
|
@ -4,9 +4,8 @@
|
||||||
// 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, isSetup, setConfig, setLang, setWindowState } from "./utils";
|
import {checkIfConfigIsBroken, firstRun, getConfig, contentPath, isSetup, setConfig, setLang} from "./utils";
|
||||||
import {registerIpc} from "./ipc";
|
import {registerIpc} from "./ipc";
|
||||||
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";
|
||||||
import os from "os";
|
import os from "os";
|
||||||
|
@ -72,32 +71,7 @@ async function doAfterDefiningTheWindow() {
|
||||||
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 themesFolder = userDataPath + "/themes/";
|
|
||||||
if (!fs.existsSync(themesFolder)) {
|
|
||||||
fs.mkdirSync(themesFolder);
|
|
||||||
console.log("Created missing theme folder");
|
|
||||||
}
|
|
||||||
mainWindow.webContents.on('did-finish-load', () => {
|
|
||||||
fs.readdirSync(themesFolder).forEach((file) => {
|
|
||||||
try {
|
|
||||||
const manifest = fs.readFileSync(`${themesFolder}/${file}/manifest.json`, "utf8");
|
|
||||||
var themeFile = JSON.parse(manifest);
|
|
||||||
mainWindow.webContents.send("themeLoader", fs.readFileSync(`${themesFolder}/${file}/${themeFile.theme}`, "utf-8"))
|
|
||||||
console.log(`%cLoaded ${themeFile.name} made by ${themeFile.author}`, "color:red");
|
|
||||||
} catch (err) {
|
|
||||||
console.error(err);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
mainWindow.on("close", async (e) => {
|
mainWindow.on("close", async (e) => {
|
||||||
let [width, height] = mainWindow.getSize()
|
|
||||||
setWindowState({
|
|
||||||
width: width,
|
|
||||||
height: height,
|
|
||||||
isMaximized: mainWindow.isMaximized()
|
|
||||||
})
|
|
||||||
if (await getConfig("minimizeToTray")) {
|
if (await getConfig("minimizeToTray")) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
mainWindow.hide();
|
mainWindow.hide();
|
||||||
|
|