slot0 = class("ActivityProxy", import(".NetProxy")) slot0.ACTIVITY_ADDED = "ActivityProxy ACTIVITY_ADDED" slot0.ACTIVITY_UPDATED = "ActivityProxy ACTIVITY_UPDATED" slot0.ACTIVITY_DELETED = "ActivityProxy ACTIVITY_DELETED" slot0.ACTIVITY_OPERATION_DONE = "ActivityProxy ACTIVITY_OPERATION_DONE" slot0.ACTIVITY_SHOW_AWARDS = "ActivityProxy ACTIVITY_SHOW_AWARDS" slot0.ACTIVITY_SHOP_SHOW_AWARDS = "ActivityProxy ACTIVITY_SHOP_SHOW_AWARDS" slot0.ACTIVITY_SHOW_BB_RESULT = "ActivityProxy ACTIVITY_SHOW_BB_RESULT" slot0.ACTIVITY_LOTTERY_SHOW_AWARDS = "ActivityProxy ACTIVITY_LOTTERY_SHOW_AWARDS" slot0.ACTIVITY_HITMONSTER_SHOW_AWARDS = "ActivityProxy ACTIVITY_HITMONSTER_SHOW_AWARDS" slot0.ACTIVITY_SHOW_REFLUX_AWARDS = "ActivityProxy ACTIVITY_SHOW_REFLUX_AWARDS" slot0.ACTIVITY_OPERATION_ERRO = "ActivityProxy ACTIVITY_OPERATION_ERRO" slot0.ACTIVITY_SHOW_LOTTERY_AWARD_RESULT = "ActivityProxy ACTIVITY_SHOW_LOTTERY_AWARD_RESULT" slot0.ACTIVITY_SHOW_RED_PACKET_AWARDS = "ActivityProxy ACTIVITY_SHOW_RED_PACKET_AWARDS" slot0.ACTIVITY_SHOW_SHAKE_BEADS_RESULT = "ActivityProxy ACTIVITY_SHOW_SHAKE_BEADS_RESULT" slot0.ACTIVITY_PT_ID = 110 function slot0.register(slot0) slot0:on(11200, function (slot0) uv0.data = {} uv0.params = {} for slot4, slot5 in ipairs(slot0.activity_list) do if not pg.activity_template[slot5.id] then Debugger.LogError("活动acvitity_template不存在: " .. slot5.id) else if Activity.Create(slot5):getConfig("type") == ActivityConst.ACTIVITY_TYPE_BOSS_BATTLE_MARK_2 or slot7 == ActivityConst.ACTIVITY_TYPE_CHALLENGE then uv0:updateActivityFleet(slot5) elseif slot7 == ActivityConst.ACTIVITY_TYPE_PARAMETER then uv0:addActivityParameter(slot6) end uv0.data[slot5.id] = slot6 end end for slot4, slot5 in pairs(uv0.data) do uv0:sendNotification(GAME.ACTIVITY_BE_UPDATED, { isInit = true, activity = slot5 }) end if uv0.data[ActivityConst.MILITARY_EXERCISE_ACTIVITY_ID] then getProxy(MilitaryExerciseProxy):addSeasonOverTimer() end if uv0:getActivityByType(ActivityConst.ACTIVITY_TYPE_CHALLENGE) and not slot1:isEnd() then uv0:sendNotification(GAME.CHALLENGE2_INFO, {}) end if uv0:getActivityByType(ActivityConst.ACTIVITY_TYPE_TASK_LIST_MONITOR) and not slot2:isEnd() and slot2.data1 == 0 then uv0:monitorTaskList(slot2) end if uv0:getActivityByType(ActivityConst.ACTIVITY_TYPE_BOSS_BATTLE_MARK_2) and not slot3:isEnd() then uv0:InitActivityBossData(uv0.data[slot3.id]) end pg.ShipFlagMgr.GetInstance():UpdateFlagShips("inElite") end) slot0:on(11201, function (slot0) if Activity.Create(slot0.activity_info):getConfig("type") == ActivityConst.ACTIVITY_TYPE_PARAMETER then uv0:addActivityParameter(slot1) end if not uv0.data[slot1.id] then uv0:addActivity(slot1) else uv0:updateActivity(slot1) end if slot2 == ActivityConst.ACTIVITY_TYPE_BOSS_BATTLE_MARK_2 then uv0:updateActivityFleet(slot0.activity_info) uv0:InitActivityBossData(slot1) end uv0:sendNotification(GAME.ACTIVITY_BE_UPDATED, { activity = slot1 }) end) slot0.requestTime = {} end function slot0.getActivityByType(slot0, slot1) slot2 = nil for slot6, slot7 in pairs(slot0.data) do if slot7:getConfig("type") == slot1 then slot2 = slot7 break end end return slot2 end function slot0.getActivitiesByType(slot0, slot1) slot2 = {} for slot6, slot7 in pairs(slot0.data) do if slot7:getConfig("type") == slot1 then table.insert(slot2, slot7) end end return slot2 end function slot0.getActivitiesByTypes(slot0, slot1) slot2 = {} for slot6, slot7 in pairs(slot0.data) do if table.contains(slot1, slot7:getConfig("type")) then table.insert(slot2, slot7) end end return slot2 end function slot0.GetEarliestActByType(slot0, slot1) slot3 = _.select(slot0:getActivitiesByType(slot1), function (slot0) return not slot0:isEnd() end) table.sort(slot3, function (slot0, slot1) return slot0.id < slot1.id end) return slot3[1] end function slot0.getMilitaryExerciseActivity(slot0) slot1 = nil for slot5, slot6 in pairs(slot0.data) do if slot6:getConfig("type") == ActivityConst.ACTIVITY_TYPE_MILITARY_EXERCISE then slot1 = slot6 break end end return Clone(slot1) end function slot0.getPanelActivities(slot0) return _(_.values(slot0.data)):chain():filter(function (slot0) if slot0:isShow() and not slot0:isAfterShow() then if slot0:getConfig("type") == ActivityConst.ACTIVITY_TYPE_CHARGEAWARD then slot2 = slot0.data2 == 0 elseif slot1 == ActivityConst.ACTIVITY_TYPE_PROGRESSLOGIN then slot2 = slot0.data1 < 7 or not slot0.achieved end end return slot2 and not slot0:isEnd() end):sort(function (slot0, slot1) if slot0:getConfig("login_pop") == slot1:getConfig("login_pop") then return slot0.id < slot1.id else return slot3 < slot2 end end):value() end function slot0.getBannerDisplays(slot0) return _(pg.activity_banner.all):chain():map(function (slot0) return pg.activity_banner[slot0] end):filter(function (slot0) return pg.TimeMgr.GetInstance():inTime(slot0.time) and slot0.type ~= GAMEUI_BANNER_9 and slot0.type ~= GAMEUI_BANNER_10 end):value() end function slot0.getActiveBannerByType(slot0, slot1) if #_(pg.activity_banner.all):chain():map(function (slot0) return pg.activity_banner[slot0] end):filter(function (slot0) return pg.TimeMgr.GetInstance():inTime(slot0.time) and slot0.type == uv0 end):value() > 0 then return slot2[1] end return nil end function slot0.getNoticeBannerDisplays(slot0) return _.map(pg.activity_banner_notice.all, function (slot0) return pg.activity_banner_notice[slot0] end) end function slot0.findNextAutoActivity(slot0) slot1 = nil slot3 = pg.TimeMgr.GetInstance():GetServerTime() for slot7, slot8 in ipairs(slot0:getPanelActivities()) do if slot8:isShow() and not slot8.autoActionForbidden then if slot8:getConfig("type") == ActivityConst.ACTIVITY_TYPE_7DAYSLOGIN then slot10 = slot8:getConfig("config_id") slot12 = #pg.activity_7_day_sign[slot10].front_drops + 1 if slot10 == 3 then slot12 = #slot11 end if slot8.data1 < slot12 and not slot2:IsSameDay(slot3, slot8.data2) then slot1 = slot8 break end elseif slot9 == ActivityConst.ACTIVITY_TYPE_PROGRESSLOGIN then if slot8.data1 < 7 and not slot2:IsSameDay(slot3, slot8.data2) or slot8.data1 == 7 and not slot8.achieved and getProxy(ChapterProxy):isClear(204) then slot1 = slot8 break end elseif slot9 == ActivityConst.ACTIVITY_TYPE_MONTHSIGN then slot8:setSpecialData("reMonthSignDay", nil) if pg.TimeMgr.GetInstance():STimeDescS(slot3, "*t").year ~= slot8.data1 or slot10.month ~= slot8.data2 then slot8.data1 = slot10.year slot8.data2 = slot10.month slot8.data1_list = {} slot1 = slot8 break elseif not table.contains(slot8.data1_list, slot10.day) then slot1 = slot8 break elseif slot10.day > #slot8.data1_list and slot8.data3 < pg.activity_month_sign[slot8.data2].resign_count then for slot15 = slot10.day, 1, -1 do if not table.contains(slot8.data1_list, slot15) then slot8:setSpecialData("reMonthSignDay", slot15) break end end slot1 = slot8 end elseif slot8.id == ActivityConst.SHADOW_PLAY_ID and slot8.clientData1 == 0 and (getProxy(TaskProxy):getTaskById(slot8:getConfig("config_data")[1]) or slot11:getFinishTaskById(slot10)) and not slot12:isReceive() then slot1 = slot8 break end end end return slot1 end function slot0.findRefluxAutoActivity(slot0) if slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_REFLUX) and not slot1:isEnd() and not slot1.autoActionForbidden then slot2 = pg.TimeMgr.GetInstance() if slot1.data1_list[2] < #pg.return_sign_template.all and not slot2:IsSameDay(slot2:GetServerTime(), slot1.data1_list[1]) then return 1 end end end function slot0.existRefluxAwards(slot0) if slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_REFLUX) and not slot1:isEnd() then for slot6 = #pg.return_pt_template.all, 1, -1 do if slot2[slot2.all[slot6]].pt_require <= slot1.data3 and slot1.data4 < slot7 then return true end end slot3 = getProxy(TaskProxy) if _.any(_(slot1:getConfig("config_data")[7]):chain():map(function (slot0) return slot0[2] end):flatten():map(function (slot0) return uv0:getTaskById(slot0) or uv0:getFinishTaskById(slot0) or false end):filter(function (slot0) return not not slot0 end):value(), function (slot0) return slot0:getTaskStatus() == 1 end) then return true end end end function slot0.getActivityById(slot0, slot1) return Clone(slot0.data[slot1]) end function slot0.updateActivity(slot0, slot1) if slot1:getConfig("type") == ActivityConst.ACTIVITY_TYPE_PT_CRUSING then slot2 = pg.battlepass_event_pt[slot1.id].target if slot0.data[slot1.id].data1 < slot2[#slot2] and slot1.data1 - slot0.data[slot1.id].data1 > 0 then pg.ToastMgr.GetInstance():ShowToast(pg.ToastMgr.TYPE_CRUSING, { ptId = pg.battlepass_event_pt[slot1.id].pt, ptCount = slot1.data1 - slot0.data[slot1.id].data1 }) end end slot0.data[slot1.id] = slot1 slot0.facade:sendNotification(uv0.ACTIVITY_UPDATED, slot1:clone()) end function slot0.addActivity(slot0, slot1) slot0.data[slot1.id] = slot1 slot0.facade:sendNotification(uv0.ACTIVITY_ADDED, slot1:clone()) end function slot0.deleteActivityById(slot0, slot1) slot0.data[slot1] = nil slot0.facade:sendNotification(uv0.ACTIVITY_DELETED, slot1) end function slot0.IsActivityNotEnd(slot0, slot1) return slot0.data[slot1] and not slot0.data[slot1]:isEnd() end function slot0.readyToAchieveByType(slot0, slot1) slot2 = false for slot7, slot8 in ipairs(slot0:getActivitiesByType(slot1)) do if slot8:readyToAchieve() then slot2 = true break end end return slot2 end function slot0.getBuildBgActivityByID(slot0, slot1) for slot6, slot7 in ipairs(slot0:getActivitiesByType(ActivityConst.ACTIVITY_TYPE_BUILD)) do if not slot7:isEnd() and slot7:getConfig("config_client") and slot8.id == slot1 then return slot8.bg end end return nil end function slot0.getBuildTipActivityByID(slot0, slot1) for slot6, slot7 in ipairs(slot0:getActivitiesByType(ActivityConst.ACTIVITY_TYPE_BUILD)) do if not slot7:isEnd() and slot7:getConfig("config_client") and slot8.id == slot1 then return slot8.rate_tip end end return nil end function slot0.getBuildActivityCfgByID(slot0, slot1) for slot6, slot7 in ipairs(slot0:getActivitiesByType(ActivityConst.ACTIVITY_TYPE_BUILD)) do if not slot7:isEnd() and slot7:getConfig("config_client") and slot8.id == slot1 then return slot8 end end return nil end function slot0.getBuffShipList(slot0) _.each(slot0:getActivitiesByType(ActivityConst.ACTIVITY_TYPE_SHIP_BUFF), function (slot0) if slot0 and not slot0:isEnd() then if not pg.activity_expup_ship[slot0:getConfig("config_id")] then return end for slot7, slot8 in pairs(slot2.expup) do uv0[slot8[1]] = slot8[2] end end end) return {} end function slot0.getVirtualItemNumber(slot0, slot1) if slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_VIRTUAL_BAG) and not slot2:isEnd() then return slot2.data1KeyValueList[1][slot1] and slot2.data1KeyValueList[1][slot1] or 0 end return 0 end function slot0.removeVitemById(slot0, slot1, slot2) if slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_VIRTUAL_BAG) and not slot3:isEnd() then slot3.data1KeyValueList[1][slot1] = slot3.data1KeyValueList[1][slot1] - slot2 end slot0:updateActivity(slot3) end function slot0.addVitemById(slot0, slot1, slot2) if slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_VIRTUAL_BAG) and not slot3:isEnd() then if not slot3.data1KeyValueList[1][slot1] then slot3.data1KeyValueList[1][slot1] = 0 end slot3.data1KeyValueList[1][slot1] = slot3.data1KeyValueList[1][slot1] + slot2 end slot0:updateActivity(slot3) if pg.item_data_statistics[slot1].link_id ~= 0 and slot0:getActivityById(slot5) and not slot6:isEnd() then PlayerResChangeCommand.UpdateActivity(slot6, slot2) end end function slot0.monitorTaskList(slot0, slot1) if slot1 and not slot1:isEnd() and slot1:getConfig("type") == ActivityConst.ACTIVITY_TYPE_TASK_LIST_MONITOR and getProxy(TaskProxy):isReceiveTasks(slot1:getConfig("config_data")[1] or {}) then pg.m02:sendNotification(GAME.ACTIVITY_OPERATION, { cmd = 1, activity_id = slot1.id }) end end function slot0.updateActivityFleet(slot0, slot1) getProxy(FleetProxy):addActivityFleet(slot1.id, slot1.group_list) end function slot0.recommendActivityFleet(slot0, slot1, slot2) slot5 = getProxy(BayProxy) slot6 = getProxy(FleetProxy):getActivityFleets()[slot1][slot2] if Fleet.SUBMARINE_FLEET_ID <= slot2 then if not slot6:isFull() then function (slot0, slot1) slot7 = slot1 slot8 = uv2 for slot7, slot8 in ipairs(uv0:getActivityRecommendShips(TeamType.TeamToTypeList(slot0), uv1.ships, slot7, slot8)) do uv1:insertShip(slot8, nil, slot0) end end(TeamType.Submarine, TeamType.SubmarineMax - #slot6.subShips) end else slot9 = TeamType.MainMax - #slot6.mainShips if TeamType.VanguardMax - #slot6.vanguardShips > 0 then slot7(TeamType.Vanguard, slot8) end if slot9 > 0 then slot7(TeamType.Main, slot9) end end getProxy(FleetProxy):updateActivityFleet(slot1, slot2, slot6) end function slot0.GetVoteBookActivty(slot0) return slot0:getActivityById(ActivityConst.VOTE_ORDER_BOOK_PHASE_1) or slot0:getActivityById(ActivityConst.VOTE_ORDER_BOOK_PHASE_3) or slot0:getActivityById(ActivityConst.VOTE_ORDER_BOOK_PHASE_4) or slot0:getActivityById(ActivityConst.VOTE_ORDER_BOOK_PHASE_5) or slot0:getActivityById(ActivityConst.VOTE_ORDER_BOOK_PHASE_6) or slot0:getActivityById(ActivityConst.VOTE_ORDER_BOOK_PHASE_7) or slot0:getActivityById(ActivityConst.VOTE_ORDER_BOOK_PHASE_8) end function slot0.GetVoteActivity(slot0) for slot5, slot6 in ipairs(slot0:getActivitiesByType(ActivityConst.ACTIVITY_TYPE_VOTE)) do if slot6:getConfig("config_id") ~= 6 then return slot6 end end end function slot0.InitActivityBossData(slot0, slot1) if not pg.activity_event_worldboss[slot1:getConfig("config_id")] then return end slot3 = slot1.data1KeyValueList for slot7, slot8 in pairs(slot2.normal_expedition_drop_num or {}) do for slot12, slot13 in pairs(slot8[1]) do slot3[1][slot13] = math.max(slot8[2] - (slot3[1][slot13] or 0), 0) slot3[2][slot13] = slot3[2][slot13] or 0 end end end function slot0.AddInstagramTimer(slot0, slot1) slot0:RemoveInstagramTimer() slot3, slot4 = slot0.data[slot1]:GetNextPushTime() if slot3 then if slot3 - pg.TimeMgr.GetInstance():GetServerTime() <= 0 then function () uv0:sendNotification(GAME.ACT_INSTAGRAM_OP, { arg2 = 0, activity_id = uv1, cmd = ActivityConst.INSTAGRAM_OP_ACTIVE, arg1 = uv2 }) end() else slot0.instagramTimer = Timer.New(function () uv0() uv1:RemoveInstagramTimer() end, slot6, 1) slot0.instagramTimer:Start() end end end function slot0.RemoveInstagramTimer(slot0) if slot0.instagramTimer then slot0.instagramTimer:Stop() slot0.instagramTimer = nil end end function slot0.RegisterRequestTime(slot0, slot1, slot2) if not slot1 or slot1 <= 0 then return end slot0.requestTime[slot1] = slot2 end function slot0.remove(slot0) slot0:RemoveInstagramTimer() end function slot0.ShouldShowInsTip(slot0) if not slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_INSTAGRAM) or slot1:isEnd() then return false end return slot1:ShouldShowTip() end function slot0.ExistSkinCouponActivityAndShopId(slot0, slot1) return slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_SKIN_COUPON) and not slot2:isEnd() and table.contains(slot2.data1_list, slot1) end function slot0.ExistSkinCouponActivity(slot0) return slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_SKIN_COUPON) and not slot1:isEnd() end function slot0.MarkSkinCoupon(slot0, slot1) if slot0:getActivityByType(ActivityConst.ACTIVITY_TYPE_SKIN_COUPON) and not slot2:isEnd() then slot2.data1 = slot2.data1 + 1 if not table.contains(slot2.data1_list, slot1) then table.insert(slot2.data1_list, slot1) end slot0:updateActivity(slot2) end end function slot0.addActivityParameter(slot0, slot1) for slot7, slot8 in ipairs(slot1:getConfig("config_data")) do slot0.params[slot8[1]] = { slot8[2], slot1.stopTime } end end function slot0.getActivityParameter(slot0, slot1) if slot0.params[slot1] then slot2, slot3 = unpack(slot0.params[slot1]) if slot3 <= 0 or slot3 > pg.TimeMgr.GetInstance():GetServerTime() then return slot2 end end end return slot0