2023-02-19 00:13:53 +08:00
|
|
|
from calendar import day_name
|
|
|
|
|
2021-11-27 12:55:09 +08:00
|
|
|
from module.base.timer import Timer
|
2022-10-30 03:56:58 +08:00
|
|
|
from module.campaign.campaign_status import CampaignStatus
|
2021-11-27 12:55:09 +08:00
|
|
|
from module.combat.assets import GET_ITEMS_1, GET_ITEMS_2
|
2023-02-19 00:13:53 +08:00
|
|
|
from module.config.utils import get_server_weekday
|
2022-10-18 13:23:30 +08:00
|
|
|
from module.freebies.assets import *
|
2021-11-27 12:55:09 +08:00
|
|
|
from module.logger import logger
|
|
|
|
from module.ui.page import page_supply_pack
|
|
|
|
|
|
|
|
|
2022-10-30 03:56:58 +08:00
|
|
|
class SupplyPack(CampaignStatus):
|
2021-11-27 12:55:09 +08:00
|
|
|
def supply_pack_buy(self, supply_pack, skip_first_screenshot=True):
|
|
|
|
"""
|
|
|
|
Args:
|
|
|
|
supply_pack (Button): Button of supply pack, click to buy.
|
|
|
|
skip_first_screenshot (bool):
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
bool: If bought.
|
|
|
|
"""
|
|
|
|
logger.hr('Supply pack buy')
|
|
|
|
[self.interval_clear(asset) for asset in [GET_ITEMS_1, GET_ITEMS_2, supply_pack, BUY_CONFIRM]]
|
|
|
|
|
|
|
|
logger.info(f'Buying {supply_pack}')
|
|
|
|
executed = False
|
2022-09-12 13:14:29 +08:00
|
|
|
click_count = 0
|
2021-11-27 12:55:09 +08:00
|
|
|
confirm_timer = Timer(1, count=3).start()
|
|
|
|
while 1:
|
|
|
|
if skip_first_screenshot:
|
|
|
|
skip_first_screenshot = False
|
|
|
|
else:
|
|
|
|
self.device.screenshot()
|
|
|
|
|
2022-09-12 13:14:29 +08:00
|
|
|
if self.appear(supply_pack, offset=(20, 20), interval=3):
|
|
|
|
if click_count >= 3:
|
|
|
|
logger.warning(f'Failed to buy {supply_pack} after 3 trail, probably reached resource limit, skip')
|
|
|
|
break
|
|
|
|
self.device.click(supply_pack)
|
|
|
|
click_count += 1
|
2021-11-27 12:55:09 +08:00
|
|
|
confirm_timer.reset()
|
|
|
|
continue
|
|
|
|
if self.appear_then_click(BUY_CONFIRM, offset=(20, 20), interval=3):
|
|
|
|
confirm_timer.reset()
|
|
|
|
continue
|
|
|
|
if self.handle_popup_confirm('BUY_SUPPLY_PACK'):
|
|
|
|
self.interval_reset(supply_pack)
|
|
|
|
self.interval_reset(BUY_CONFIRM)
|
|
|
|
executed = True
|
|
|
|
continue
|
|
|
|
for button in [GET_ITEMS_1, GET_ITEMS_2]:
|
|
|
|
if self.appear_then_click(button, offset=(30, 30), interval=3):
|
|
|
|
confirm_timer.reset()
|
|
|
|
continue
|
|
|
|
|
|
|
|
# End
|
|
|
|
if self.appear(page_supply_pack.check_button, offset=(20, 20)) \
|
|
|
|
and not self.appear(supply_pack, offset=(20, 20)):
|
|
|
|
if confirm_timer.reached():
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
confirm_timer.reset()
|
|
|
|
|
2022-02-12 22:48:42 +08:00
|
|
|
logger.info(f'Supply pack buy finished, executed={executed}')
|
2021-11-27 12:55:09 +08:00
|
|
|
return executed
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
"""
|
|
|
|
Pages:
|
|
|
|
in: Any page
|
|
|
|
out: page_supply_pack, supply pack tab
|
|
|
|
"""
|
|
|
|
self.ui_ensure(page_supply_pack)
|
|
|
|
|
2022-08-21 02:05:08 +08:00
|
|
|
if self.get_oil() < 21000:
|
2023-02-19 00:45:35 +08:00
|
|
|
server_today = get_server_weekday()
|
|
|
|
target = self.config.SupplyPack_DayOfWeek
|
|
|
|
target_name = day_name[target]
|
|
|
|
if server_today >= target:
|
2023-02-19 00:13:53 +08:00
|
|
|
self.supply_pack_buy(FREE_SUPPLY_PACK)
|
|
|
|
else:
|
|
|
|
logger.info(f'Delaying free week supply pack to {target_name}')
|
2021-11-27 21:57:18 +08:00
|
|
|
else:
|
|
|
|
logger.info('Oil > 21000, unable to buy free weekly supply pack')
|