Upd: [EN] Assignment navs without event

This commit is contained in:
LmeSzinc 2023-10-15 02:18:27 +08:00
parent e5261ca9fb
commit 4434e12bbe
9 changed files with 122 additions and 52 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

View File

@ -144,15 +144,25 @@ class ButtonWrapper(Resource):
def __bool__(self): def __bool__(self):
return True return True
def iter_buttons(self) -> t.Iterator[Button]:
for _, assets in self.data_buttons.items():
if isinstance(assets, Button):
yield assets
elif isinstance(assets, list):
for asset in assets:
yield asset
@cached_property @cached_property
def buttons(self) -> t.List[Button]: def buttons(self) -> t.List[Button]:
for trial in [server.lang, 'share', 'cn']: for trial in [server.lang, 'share', 'cn']:
assets = self.data_buttons.get(trial, None) try:
if assets is not None: assets = self.data_buttons[trial]
if isinstance(assets, Button): if isinstance(assets, Button):
return [assets] return [assets]
elif isinstance(assets, list): elif isinstance(assets, list):
return assets return assets
except KeyError:
pass
raise ScriptError(f'ButtonWrapper({self}) on server {server.lang} has no fallback button') raise ScriptError(f'ButtonWrapper({self}) on server {server.lang} has no fallback button')
@ -221,13 +231,24 @@ class ButtonWrapper(Resource):
""" """
if isinstance(button, ButtonWrapper): if isinstance(button, ButtonWrapper):
button = button.matched_button button = button.matched_button
for b in self.buttons: for b in self.iter_buttons():
b.load_offset(button) b.load_offset(button)
def clear_offset(self): def clear_offset(self):
for b in self.buttons: for b in self.iter_buttons():
b.clear_offset() b.clear_offset()
def load_search(self, area):
"""
Set `search` attribute.
Note that this method is irreversible.
Args:
area:
"""
for b in self.iter_buttons():
b.search = area
class ClickButton: class ClickButton:
def __init__(self, button, name='CLICK_BUTTON'): def __init__(self, button, name='CLICK_BUTTON'):

View File

@ -1,4 +1,3 @@
from module.config.server import VALID_LANG
from tasks.assignment.assets.assets_assignment_ui import ( from tasks.assignment.assets.assets_assignment_ui import (
CHARACTER_MATERIALS_CHECK, CHARACTER_MATERIALS_CLICK, CHARACTER_MATERIALS_CHECK, CHARACTER_MATERIALS_CLICK,
EXP_MATERIALS_CREDITS_CHECK, EXP_MATERIALS_CREDITS_CLICK, GROUP_SEARCH, EXP_MATERIALS_CREDITS_CHECK, EXP_MATERIALS_CREDITS_CLICK, GROUP_SEARCH,
@ -12,8 +11,4 @@ for group_button_wrapper in (
EXP_MATERIALS_CREDITS_CHECK, EXP_MATERIALS_CREDITS_CLICK, EXP_MATERIALS_CREDITS_CHECK, EXP_MATERIALS_CREDITS_CLICK,
SYNTHESIS_MATERIALS_CHECK, SYNTHESIS_MATERIALS_CLICK, SYNTHESIS_MATERIALS_CHECK, SYNTHESIS_MATERIALS_CLICK,
): ):
for lang in VALID_LANG: group_button_wrapper.load_search(GROUP_SEARCH.button)
button = group_button_wrapper.data_buttons.get(lang, None)
if button is None:
continue
button.search = GROUP_SEARCH.button

View File

@ -12,13 +12,22 @@ CHARACTER_MATERIALS_CHECK = ButtonWrapper(
color=(177, 176, 173), color=(177, 176, 173),
button=(346, 97, 421, 117), button=(346, 97, 421, 117),
), ),
en=Button( en=[
file='./assets/en/assignment/ui/CHARACTER_MATERIALS_CHECK.png', Button(
area=(339, 88, 429, 126), file='./assets/en/assignment/ui/CHARACTER_MATERIALS_CHECK.png',
search=(319, 68, 449, 146), area=(339, 88, 429, 126),
color=(193, 192, 189), search=(319, 68, 449, 146),
button=(339, 88, 429, 126), color=(193, 192, 189),
), button=(339, 88, 429, 126),
),
Button(
file='./assets/en/assignment/ui/CHARACTER_MATERIALS_CHECK.2.png',
area=(142, 98, 234, 119),
search=(319, 68, 449, 146),
color=(203, 202, 199),
button=(142, 98, 234, 119),
),
],
) )
CHARACTER_MATERIALS_CLICK = ButtonWrapper( CHARACTER_MATERIALS_CLICK = ButtonWrapper(
name='CHARACTER_MATERIALS_CLICK', name='CHARACTER_MATERIALS_CLICK',
@ -29,13 +38,22 @@ CHARACTER_MATERIALS_CLICK = ButtonWrapper(
color=(60, 60, 60), color=(60, 60, 60),
button=(347, 97, 421, 117), button=(347, 97, 421, 117),
), ),
en=Button( en=[
file='./assets/en/assignment/ui/CHARACTER_MATERIALS_CLICK.png', Button(
area=(339, 88, 429, 127), file='./assets/en/assignment/ui/CHARACTER_MATERIALS_CLICK.png',
search=(319, 68, 449, 147), area=(339, 88, 429, 127),
color=(49, 49, 49), search=(319, 68, 449, 147),
button=(339, 88, 429, 127), color=(49, 49, 49),
), button=(339, 88, 429, 127),
),
Button(
file='./assets/en/assignment/ui/CHARACTER_MATERIALS_CLICK.2.png',
area=(143, 98, 234, 120),
search=(319, 68, 449, 147),
color=(61, 59, 57),
button=(143, 98, 234, 120),
),
],
) )
DISPATCHED = ButtonWrapper( DISPATCHED = ButtonWrapper(
name='DISPATCHED', name='DISPATCHED',
@ -73,13 +91,22 @@ EXP_MATERIALS_CREDITS_CHECK = ButtonWrapper(
color=(178, 177, 174), color=(178, 177, 174),
button=(514, 97, 614, 117), button=(514, 97, 614, 117),
), ),
en=Button( en=[
file='./assets/en/assignment/ui/EXP_MATERIALS_CREDITS_CHECK.png', Button(
area=(529, 88, 599, 126), file='./assets/en/assignment/ui/EXP_MATERIALS_CREDITS_CHECK.png',
search=(509, 68, 619, 146), area=(529, 88, 599, 126),
color=(202, 201, 198), search=(509, 68, 619, 146),
button=(529, 88, 599, 126), color=(202, 201, 198),
), button=(529, 88, 599, 126),
),
Button(
file='./assets/en/assignment/ui/EXP_MATERIALS_CREDITS_CHECK.2.png',
area=(373, 98, 458, 119),
search=(509, 68, 619, 146),
color=(191, 190, 187),
button=(373, 98, 458, 119),
),
],
) )
EXP_MATERIALS_CREDITS_CLICK = ButtonWrapper( EXP_MATERIALS_CREDITS_CLICK = ButtonWrapper(
name='EXP_MATERIALS_CREDITS_CLICK', name='EXP_MATERIALS_CREDITS_CLICK',
@ -90,13 +117,22 @@ EXP_MATERIALS_CREDITS_CLICK = ButtonWrapper(
color=(61, 60, 60), color=(61, 60, 60),
button=(514, 97, 614, 117), button=(514, 97, 614, 117),
), ),
en=Button( en=[
file='./assets/en/assignment/ui/EXP_MATERIALS_CREDITS_CLICK.png', Button(
area=(528, 88, 599, 127), file='./assets/en/assignment/ui/EXP_MATERIALS_CREDITS_CLICK.png',
search=(508, 68, 619, 147), area=(528, 88, 599, 127),
color=(42, 42, 42), search=(508, 68, 619, 147),
button=(528, 88, 599, 127), color=(42, 42, 42),
), button=(528, 88, 599, 127),
),
Button(
file='./assets/en/assignment/ui/EXP_MATERIALS_CREDITS_CLICK.2.png',
area=(374, 98, 459, 119),
search=(508, 68, 619, 147),
color=(49, 49, 49),
button=(374, 98, 459, 119),
),
],
) )
GROUP_SEARCH = ButtonWrapper( GROUP_SEARCH = ButtonWrapper(
name='GROUP_SEARCH', name='GROUP_SEARCH',
@ -198,13 +234,22 @@ SYNTHESIS_MATERIALS_CHECK = ButtonWrapper(
color=(180, 179, 176), color=(180, 179, 176),
button=(708, 97, 783, 117), button=(708, 97, 783, 117),
), ),
en=Button( en=[
file='./assets/en/assignment/ui/SYNTHESIS_MATERIALS_CHECK.png', Button(
area=(703, 88, 790, 126), file='./assets/en/assignment/ui/SYNTHESIS_MATERIALS_CHECK.png',
search=(683, 68, 810, 146), area=(703, 88, 790, 126),
color=(189, 188, 185), search=(683, 68, 810, 146),
button=(703, 88, 790, 126), color=(189, 188, 185),
), button=(703, 88, 790, 126),
),
Button(
file='./assets/en/assignment/ui/SYNTHESIS_MATERIALS_CHECK.2.png',
area=(624, 97, 715, 119),
search=(683, 68, 810, 146),
color=(197, 196, 193),
button=(624, 97, 715, 119),
),
],
) )
SYNTHESIS_MATERIALS_CLICK = ButtonWrapper( SYNTHESIS_MATERIALS_CLICK = ButtonWrapper(
name='SYNTHESIS_MATERIALS_CLICK', name='SYNTHESIS_MATERIALS_CLICK',
@ -215,11 +260,20 @@ SYNTHESIS_MATERIALS_CLICK = ButtonWrapper(
color=(68, 66, 65), color=(68, 66, 65),
button=(709, 97, 783, 117), button=(709, 97, 783, 117),
), ),
en=Button( en=[
file='./assets/en/assignment/ui/SYNTHESIS_MATERIALS_CLICK.png', Button(
area=(702, 88, 790, 126), file='./assets/en/assignment/ui/SYNTHESIS_MATERIALS_CLICK.png',
search=(682, 68, 810, 146), area=(702, 88, 790, 126),
color=(61, 59, 58), search=(682, 68, 810, 146),
button=(702, 88, 790, 126), color=(61, 59, 58),
), button=(702, 88, 790, 126),
),
Button(
file='./assets/en/assignment/ui/SYNTHESIS_MATERIALS_CLICK.2.png',
area=(624, 97, 715, 119),
search=(682, 68, 810, 146),
color=(51, 50, 49),
button=(624, 97, 715, 119),
),
],
) )