PGRData/Script/matrix/xmanager/XFubenDailyManager.lua

371 lines
14 KiB
Lua
Raw Permalink Normal View History

2024-09-01 22:49:41 +02:00
local XExFubenBaseManager = require("XEntity/XFuben/XExFubenBaseManager")
local XChapterViewModel = require("XEntity/XFuben/XChapterViewModel")
XFubenDailyManagerCreator = function()
2024-09-01 22:49:41 +02:00
local XFubenDailyManager = XExFubenBaseManager.New(XFubenConfigs.ChapterType.Daily)
local METHOD_NAME = {
ReceiveDailyReward = "ReceiveDailyRewardRequest",
}
local ConditionType = {
LeverCondition = 1,
EventCondition = 2,
}
local WEEK = 7
local RefreshTime = 0
local DailySectionData = {}
local DailyRecord = {}
function XFubenDailyManager.Init()
end
function XFubenDailyManager.OpenFightLoading(stageId)
XEventManager.DispatchEvent(XEventId.EVENT_FIGHT_LOADINGFINISHED)
local stageCfg = XDataCenter.FubenManager.GetStageCfg(stageId)
if stageCfg and stageCfg.LoadingType then
XLuaUiManager.Open("UiLoading", stageCfg.LoadingType)
else
XLuaUiManager.Open("UiLoading", LoadingType.Fight)
end
end
function XFubenDailyManager.CloseFightLoading(stageId)
local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId)
if stageInfo.DailyType == XDataCenter.FubenManager.ChapterType.EMEX then
-- XLuaUiManager.Remove("UiOnLineLoading")
XLuaUiManager.Remove("UiLoading")
else
XLuaUiManager.Remove("UiLoading")
end
end
-- function XFubenDailyManager.ShowReward(winData)
-- local stageInfo = XDataCenter.FubenManager.GetStageInfo(winData.StageId)
-- if stageInfo.DailyType == XDataCenter.FubenManager.ChapterType.EMEX then
-- XEventManager.DispatchEvent(XEventId.EVENT_FUBEN_SHOW_REWARD, winData)
-- else
-- XLuaUiManager.Open("UiSettleWin", winData)
-- end
-- end
-- 需要显示多重挑战则需要加ShowReward
function XFubenDailyManager.ShowReward(winData)
if not winData then return end
XLuaUiManager.Open("UiRepeatChallengeSettleWin", winData)
end
function XFubenDailyManager.InitFubenDailyData()
-- if fubenDailyData.DailySectionData then
-- for k, v in pairs(fubenDailyData.DailySectionData) do
-- DailySectionData[k] = v
-- end
-- end
end
function XFubenDailyManager.GetDailySectionData(sectionId)
return DailySectionData[sectionId]
end
function XFubenDailyManager.SyncDailyReward(sectionId)
DailySectionData[sectionId].ReceiveReward = true
end
function XFubenDailyManager.IsDayLock(Id)
for k, v in pairs(XDailyDungeonConfigs.GetDailyDungeonDayOfWeek(Id)) do
if v > 0 and k == XFubenDailyManager.GetNowDayOfWeekByRefreshTime() then
return false
end
end
return true
end
function XFubenDailyManager.GetConditionData(Id)
local functionNameId = {}
local data = {}
local dungeonRule = XDailyDungeonConfigs.GetDailyDungeonRulesById(Id)
if dungeonRule.Type == XDataCenter.FubenManager.ChapterType.GZTX then--日常構造體特訓
functionNameId = XFunctionManager.FunctionName.FubenDailyGZTX
elseif dungeonRule.Type == XDataCenter.FubenManager.ChapterType.XYZB then--日常稀有裝備
functionNameId = XFunctionManager.FunctionName.FubenDailyXYZB
elseif dungeonRule.Type == XDataCenter.FubenManager.ChapterType.TPCL then--日常突破材料
functionNameId = XFunctionManager.FunctionName.FubenDailyTPCL
elseif dungeonRule.Type == XDataCenter.FubenManager.ChapterType.ZBJY then--日常裝備經驗
functionNameId = XFunctionManager.FunctionName.FubenDailyZBJY
elseif dungeonRule.Type == XDataCenter.FubenManager.ChapterType.LMDZ then--日常螺母大戰
functionNameId = XFunctionManager.FunctionName.FubenDailyLMDZ
elseif dungeonRule.Type == XDataCenter.FubenManager.ChapterType.JNQH then--日常技能强化
functionNameId = XFunctionManager.FunctionName.FubenDailyJNQH
elseif dungeonRule.Type == XDataCenter.FubenManager.ChapterType.FZJQH then--日常辅助机强化
functionNameId = XFunctionManager.FunctionName.FubenDailyFZJQH
elseif dungeonRule.Type == XDataCenter.FubenManager.ChapterType.Assign then--边界公约
functionNameId = XFunctionManager.FunctionName.FubenAssign
end
data.IsLock = not XFunctionManager.JudgeCanOpen(functionNameId)
data.functionNameId = functionNameId
return data
end
function XFubenDailyManager.GetOpenDayString(rule)
--開放日顯示
local tmpNum = { "One", "Two", "Three", "Four", "Five", "Six", "Diary" }
local dayStr = ""
local dayCount = 0
local IsAllDay = false
for i = 1, WEEK do
if rule.OpenDayOfWeek[i] ~= 0 then
dayStr = dayStr .. CS.XTextManager.GetText(tmpNum[i])
dayCount = dayCount + 1
end
end
if dayCount == WEEK then
dayStr = CS.XTextManager.GetText("FubenDailyAllDayOpen")
IsAllDay = true
end
return dayStr, IsAllDay
end
function XFubenDailyManager.GetMainLineFubenOrderId(stageId)
local chapterCfg = XFubenMainLineConfigs.GetChapterCfg()
for _, v1 in pairs(chapterCfg) do
for _, v2 in pairs(v1.StageId) do
if stageId == v2 then
return v1.OrderId .. "-" .. XDataCenter.FubenManager.GetStageCfg(v2).OrderId
end
end
end
return ""
end
function XFubenDailyManager.GetEventOpen(Id)
local eventOpenData = {}
local eventText = ""
local dungeonRule = XDailyDungeonConfigs.GetDailyDungeonRulesById(Id)
local specialCondition = XDailyDungeonConfigs.GetDailySpecialConditionList()
local eventOpen = false
local nowTime = XTime.GetServerNowTimestamp()
local stratTime
local endTime
for _, v in pairs(dungeonRule.SpecialConditionId) do
if v ~= 0 then
if specialCondition[v].Type == ConditionType.LeverCondition then
local tmpCon = XConditionManager.CheckPlayerCondition(specialCondition[v].IntParam[1])
eventOpen = eventOpen or tmpCon
if tmpCon and eventText == "" then eventText = specialCondition[v].Text end
elseif specialCondition[v].Type == ConditionType.EventCondition then
stratTime = XTime.ParseToTimestamp(specialCondition[v].StringParam[1])
endTime = XTime.ParseToTimestamp(specialCondition[v].StringParam[2])
if stratTime and endTime then
local tmpCon = nowTime > stratTime and nowTime < endTime
eventOpen = eventOpen or tmpCon
if tmpCon and eventText == "" then eventText = specialCondition[v].Text end
end
end
else
eventOpen = eventOpen or false
end
end
eventOpenData.IsOpen = eventOpen
eventOpenData.Text = eventText
return eventOpenData
end
function XFubenDailyManager.GetDropDataList(Id, dayOfWeek)--根据日期获得掉落的物品组
local RandomDrop = {}
local FixedDrop = {}
local DropGroupDatas = {}
for _, v in pairs(XDailyDungeonConfigs.GetDailyDropGroupList()) do
if v.DungeonId == Id then
table.insert(DropGroupDatas, v)
end
end
for _, v in pairs(DropGroupDatas) do
if v.OpenDayOfWeek == dayOfWeek then
RandomDrop = XRewardManager.GetRewardList(v.RandomRewardId)
FixedDrop = XRewardManager.GetRewardList(v.FixedRewardId)
end
end
return RandomDrop, FixedDrop
end
function XFubenDailyManager.GetNowDayOfWeekByRefreshTime()
local nowTime = XTime.GetServerNowTimestamp()
local toDay = XTime.GetWeekDay(nowTime, true)
local tmpTime
RefreshTime = RefreshTime or 0
if RefreshTime - XTime.GetTodayTime(0, 0, 0) >= CS.XDateUtil.ONE_DAY_SECOND then
tmpTime = RefreshTime - CS.XDateUtil.ONE_DAY_SECOND
else
tmpTime = RefreshTime
end
if nowTime < tmpTime then
toDay = toDay - 1
end
if toDay <= 0 then
toDay = toDay + 7
end
return toDay
end
function XFubenDailyManager.InitStageInfo()
local DungeonDataList = XDailyDungeonConfigs.GetDailyDungeonDataList()
for _, chapter in pairs(DungeonDataList) do
for _, stageId in pairs(chapter.StageId) do
local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId)
if stageInfo then
stageInfo.Type = XDataCenter.FubenManager.StageType.Daily
stageInfo.mode = XDataCenter.FubenManager.ModeType.SINGLE
stageInfo.stageDataName = chapter.Name
end
end
end
end
-- 领取挑战奖励
function XFubenDailyManager.ReceiveDailyReward(cb, dailySectionId)
local req = { DailySectionId = dailySectionId }
XNetwork.Call(METHOD_NAME.ReceiveDailyReward, req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
XFubenDailyManager.SyncDailyReward(dailySectionId)
if cb then
cb(res.RewardGoodsList)
end
end)
end
function XFubenDailyManager.GetRemainCount()
end
function XFubenDailyManager.NotifyFubenDailyData(req)
XTool.LoopMap(req.FubenDailyData.DailySectionData, function(k, v)
DailySectionData[k] = v
XEventManager.DispatchEvent(XEventId.EVENT_FUBEN_DAILY_REFRESH)
end)
end
function XFubenDailyManager.NotifyDailyFubenRefreshTime(req)
RefreshTime = req.RefreshTime
end
function XFubenDailyManager.NotifyDailyFubenLoginData(req)
RefreshTime = req.RefreshTime
for _, v in pairs(req.Records) do
DailyRecord[v.ChapterId] = v.StageId
end
end
function XFubenDailyManager.GetLastStageId(dailyDungeonId)
return DailyRecord[dailyDungeonId]
end
function XFubenDailyManager.SetFubenDailyRecord(stageId)
local dailyDungeonId = XDailyDungeonConfigs.GetDailyDungeonIdByStageId(stageId)
if dailyDungeonId and DailyRecord then
DailyRecord[dailyDungeonId] = stageId
end
end
2024-09-01 22:49:41 +02:00
------------------副本入口扩展(带ChapterViewModel) start-------------------------
function XFubenDailyManager:ExGetFunctionNameType()
return XFunctionManager.FunctionName.FubenDaily
end
-- 检查是否展示红点
function XFubenDailyManager:ExCheckIsShowRedPoint()
for _, viewModel in ipairs(self:ExGetChapterViewModels()) do
if viewModel:CheckHasRedPoint() then
return true
end
end
return false
end
function XFubenDailyManager:ExGetChapterViewModels()
if self.__ChapterViewModelDic == nil then self.__ChapterViewModelDic = {} end
if next(self.__ChapterViewModelDic) then return self.__ChapterViewModelDic end
local chapterConfigs = XDailyDungeonConfigs.GetDailyDungeonRulesList()
for _, config in pairs(chapterConfigs) do
local id = config.Id
local chapterMainId = XFubenShortStoryChapterConfigs.GetChapterMainIdByChapterId(id)
table.insert(self.__ChapterViewModelDic, CreateAnonClassInstance({
GetProgress = function(proxy)
return nil
end,
CheckHasRedPoint = function(proxy)
return false
end,
GetIsLocked = function(proxy)
return XFubenDailyManager.GetConditionData(id).IsLock
end,
GetLockTip = function(proxy)
local tmpCon = XFubenDailyManager.GetConditionData(config.Id)
return XFunctionManager.GetFunctionOpenCondition(tmpCon.functionNameId)
end,
GetOpenDayString = function(proxy)
return XFubenDailyManager.GetOpenDayString(config)
end,
IsDayLock = function(proxy)
return XFubenDailyManager.IsDayLock(id)
end,
CheckHasTimeLimitTag = function(proxy) -- 这个就是资源商店标签,用这个接口名顶替
local shopId = XDailyDungeonConfigs.GetFubenDailyShopId(id)
local tagName = ""
if shopId > 0 then
tagName = XShopManager.GetShopTypeDataById(XShopManager.ShopType.FubenDaily).Desc
end
return (shopId > 0 and not proxy:GetIsLocked()), tagName
end,
OpenUi = function(proxy)
XLuaUiManager.Open("UiFubenDaily", config)
end,
}, XChapterViewModel
, {
Id = id,
ExtralName = config.Title,
Name = config.Title,
Desc = config.Describe,
Icon = config.Icon,
ExtralData = config,
}))
table.sort(self.__ChapterViewModelDic, function (a, b)
return a:GetExtralData().Priority < b:GetExtralData().Priority
end)
end
return self.__ChapterViewModelDic
end
------------------副本入口扩展 end-------------------------
XFubenDailyManager.Init()
return XFubenDailyManager
end
XRpc.NotifyFubenDailyData = function(req)
XDataCenter.FubenDailyManager.NotifyFubenDailyData(req)
end
XRpc.NotifyDailyFuBenRefreshTime = function(req)
XDataCenter.FubenDailyManager.NotifyDailyFubenRefreshTime(req)
end
XRpc.NotifyDailyFubenLoginData = function(req)
XDataCenter.FubenDailyManager.NotifyDailyFubenLoginData(req)
end