forked from anixart-mod/patcher
139 lines
4.6 KiB
Python
139 lines
4.6 KiB
Python
"""
|
|
Добавляет в настройки ссылки и добвляет текст к версии приложения
|
|
|
|
"settings_urls": {
|
|
"enabled": true,
|
|
"menu": {
|
|
"Раздел": [
|
|
{
|
|
"title": "Заголовок",
|
|
"description": "Описание",
|
|
"url": "ссылка",
|
|
"icon": "@drawable/ic_custom_telegram",
|
|
"icon_space_reserved": "false"
|
|
},
|
|
...
|
|
],
|
|
...
|
|
]
|
|
},
|
|
"version": " by wowlikon"
|
|
}
|
|
"""
|
|
|
|
priority = 0
|
|
|
|
# imports
|
|
import shutil
|
|
from lxml import etree
|
|
from tqdm import tqdm
|
|
from typing import Dict, List, Any
|
|
from pydantic import Field
|
|
|
|
from utils.config import PatchConfig
|
|
from utils.public import insert_after_public
|
|
|
|
#Config
|
|
DEFAULT_MENU = {
|
|
"Мы в социальных сетях": [
|
|
{
|
|
"title": "wowlikon",
|
|
"description": "Разработчик",
|
|
"url": "https://t.me/wowlikon",
|
|
"icon": "@drawable/ic_custom_telegram",
|
|
"icon_space_reserved": "false"
|
|
},
|
|
{
|
|
"title": "Kentai Radiquum",
|
|
"description": "Разработчик",
|
|
"url": "https://t.me/radiquum",
|
|
"icon": "@drawable/ic_custom_telegram",
|
|
"icon_space_reserved": "false"
|
|
},
|
|
{
|
|
"title": "Мы в Telegram",
|
|
"description": "Подпишитесь на канал, чтобы быть в курсе последних новостей.",
|
|
"url": "https://t.me/http_teapod",
|
|
"icon": "@drawable/ic_custom_telegram",
|
|
"icon_space_reserved": "false"
|
|
}
|
|
],
|
|
"Прочее": [
|
|
{
|
|
"title": "Помочь проекту",
|
|
"description": "Вы можете помочь нам в разработке мода, написании кода или тестировании.",
|
|
"url": "https://git.wowlikon.tech/anixart-mod",
|
|
"icon": "@drawable/ic_custom_crown",
|
|
"icon_space_reserved": "false"
|
|
}
|
|
]
|
|
}
|
|
|
|
class Config(PatchConfig):
|
|
version: str = Field(" by wowlikon", description="Суффикс версии")
|
|
menu: Dict[str, List[Dict[str, str]]] = Field(DEFAULT_MENU, description="Меню")
|
|
|
|
# Patch
|
|
def make_category(ns, name, items):
|
|
cat = etree.Element("PreferenceCategory", nsmap=ns)
|
|
cat.set(f"{{{ns['android']}}}title", name)
|
|
cat.set(f"{{{ns['app']}}}iconSpaceReserved", "false")
|
|
|
|
for item in items:
|
|
pref = etree.SubElement(cat, "Preference", nsmap=ns)
|
|
pref.set(f"{{{ns['android']}}}title", item["title"])
|
|
pref.set(f"{{{ns['android']}}}summary", item["description"])
|
|
pref.set(f"{{{ns['app']}}}icon", item["icon"])
|
|
pref.set(f"{{{ns['app']}}}iconSpaceReserved", item["icon_space_reserved"])
|
|
|
|
intent = etree.SubElement(pref, "intent", nsmap=ns)
|
|
intent.set(f"{{{ns['android']}}}action", "android.intent.action.VIEW")
|
|
intent.set(f"{{{ns['android']}}}data", item["url"])
|
|
intent.set(f"{{{ns['app']}}}iconSpaceReserved", item["icon_space_reserved"])
|
|
|
|
return cat
|
|
|
|
def apply(config: Config, base: Dict[str, Any]) -> bool:
|
|
shutil.copy(
|
|
"./resources/ic_custom_crown.xml",
|
|
"./decompiled/res/drawable/ic_custom_crown.xml",
|
|
)
|
|
insert_after_public("warning_error_counter_background", "ic_custom_crown")
|
|
|
|
shutil.copy(
|
|
"./resources/ic_custom_telegram.xml",
|
|
"./decompiled/res/drawable/ic_custom_telegram.xml",
|
|
)
|
|
insert_after_public("warning_error_counter_background", "ic_custom_telegram")
|
|
|
|
file_path = "./decompiled/res/xml/preference_main.xml"
|
|
parser = etree.XMLParser(remove_blank_text=True)
|
|
tree = etree.parse(file_path, parser)
|
|
root = tree.getroot()
|
|
|
|
# Insert new PreferenceCategory before the last element
|
|
last = root[-1] # last element
|
|
pos = root.index(last)
|
|
for section, items in config.menu.items():
|
|
root.insert(pos, make_category(base["xml_ns"], section, items))
|
|
pos += 1
|
|
|
|
# Save back
|
|
tree.write(file_path, pretty_print=True, xml_declaration=True, encoding="utf-8")
|
|
|
|
filepaths = [
|
|
"./decompiled/smali_classes2/com/swiftsoft/anixartd/ui/activity/UpdateActivity.smali",
|
|
"./decompiled/smali_classes2/com/swiftsoft/anixartd/ui/fragment/main/preference/MainPreferenceFragment.smali",
|
|
]
|
|
for filepath in filepaths:
|
|
content = ""
|
|
with open(filepath, "r", encoding="utf-8") as file:
|
|
for line in file.readlines():
|
|
if '"\u0412\u0435\u0440\u0441\u0438\u044f'.encode("unicode_escape").decode() in line:
|
|
content += line[:line.rindex('"')] + config.version + line[line.rindex('"'):]
|
|
else:
|
|
content += line
|
|
with open(filepath, "w", encoding="utf-8") as file:
|
|
file.write(content)
|
|
return True
|