|
|
- %% ---------------------------------------------------------------------------
- %% @doc 全民动员.
- %% @author zmh
- %% @since 20200811
- %% ---------------------------------------------------------------------------
-
- -define(MOBILIZE_ACT_DATA(Type, SubType), {mobilize_act_data, Type, SubType}).
- -define(MOBILIZE_DAY_REWARD_DEFAULT_NEED, 999). %% 天数奖励默认需要完成任务数量(配置缺失时)
-
- -define(MOBILIZE_CALC_UPDATE, 1). %% 数值更新
- -define(MOBILIZE_CALC_SUM, 2). %% 数值累加
-
- -define(MOBILIZE_POWER_CALC_DAY, 7). %% 战力任务计算天数
- -define(MOBILIZE_EQUIP_GEM_CALC_DAY, 6). %% 装备宝石任务计算天数
-
- -define(MOBILIZE_SPEC_TASK_TYPE_LIST, [gems, combat]).
-
- %% 假数据进度
- -record(fake_cord, {
- id = {0,0,0}, %% {tasktype, fakeid, start_day}
- act = 0, %% 活动子ID
- stime = 0, %% 活动开启时间
- etime = 0, %% 活动结束时间(任务结束时间)
- ltime = 0, %% 上次更新时间
-
- remain_score = 0, %% 待补助分(还剩需要补助多少)
- per_score = 0, %% 单次补助分
- remain_times = 0, %% 如果还不够,继续补助次数(事实上很少用)
- remain_click = 0, %% 多出来的补助次数(事实上很少用)
-
- process = 0, %% 进度
- real_pro = 0 %% 真实进度
- }).
-
- %% 活动数据
- -record(mobilize_act_data, {
- type = 0,
- subtype = 0,
- act_data = [],
- time = 0 %% 上次更新时间
- }).
-
- %% 全员动员 玩家完整数据
- -record(mobilize_role, {
- day_list = [] %% 天数区间奖励[#mobilize_day{}...]
- ,task_stat = #{} %% 任务完成度统计{{start,end}=>[#mobilize_task{}...]}
- }).
-
- %% 全员动员 玩家大奖进度数据
- -record(mobilize_day, {
- day_interval = {} %% {start, end} 天数区间
- ,total = 0 %% 任务总进度
- ,state = 0 %% 是否已领取奖励
- }).
-
- %% 全员动员 玩家任务进度
- -record(mobilize_task, {
- task_type = 0 %% 任务类型Id - Key
- ,task_pro = 0 %% 任务进度
- ,day_interval = {} %% {start, end} 天数区间(非重要数据)
- ,task_award_log = [] %% 任务奖励领取进度[task_id1,id2...]
- ,time = 0 %% 最近更新任务进度时间戳
- }).
-
- %% ------------------------------- 配置 -------------------------------------------
- %% 任务奖励配置
- -record(custom_mobilize_task, {
- task_type = 0 %% 任务类型Id
- ,task_id = 0 %% 任务Id
- ,day = 0 %% 开始天数
- ,end_day = 0 %% 结算天数
- ,server_pro = 0 %% 全服进度
- ,person_pro = 0 %% 个人进度
- ,gain_con = 0 %% 领取条件
-
- ,desc = 0 %% 任务描述
- ,reward = [] %% 任务奖励
- ,link = [] %% 前端跳转
- }).
-
- %% 天数奖励配置
- -record(base_custom_mobilize_day, {
- subtype = 0 %% 活动子Id
- ,day = 0 %% 开始天数
- ,end_day = 0 %% 结算天数
- ,reward = [] %% 奖励
- ,need_num = 0 %% 需要完成任务数量
- ,show_model = [] %% 前端展示模型
- }).
-
- %% ------------------------------- db -------------------------------------------
- %% db mobilize_task
- %% mobilize_days_reward
-
- %% 任务
- -define(SAVE_MOBILIZE_TASK,
- <<"REPLACE INTO mobilize_task (`role_id`, `sub_type`, `start_day`, `end_day`, `task_type`, `progress`, `award_log`, `time`) VALUES (~p, ~p, ~p, ~p, ~p, ~p, '~ts', ~p)">>).
- -define(SELECT_MOBILIZE_TASK,
- <<"SELECT `start_day`, `end_day`, `task_type`, `progress`, `award_log`, `time` FROM mobilize_task WHERE `role_id` = ~p AND `sub_type` = ~p">>).
-
- %% 天数大奖
- -define(SAVE_MOBILIZE_DAYS_REWARD,
- <<"REPLACE INTO mobilize_days_reward (`role_id`, `sub_type`, `start_day`, `end_day`, `total`, `state`) VALUES (~p, ~p, ~p, ~p, ~p, ~p)">>).
- -define(SELECT_MOBILIZE_DAYS_REWARD,
- <<"SELECT `start_day`, `end_day`, `total`, `state` FROM mobilize_days_reward WHERE `role_id`=~p AND `sub_type`=~p">>).
-
- %% 假数据
- -define(SQL_MOBILIZE_FAKE_GET,<<"SELECT `task_type`,`fake_id`,`act`,`day`,`stime`,`etime`,`ltime`,`remain_score`,`per_score`,`remain_times`,`remain_click`,`process`,`real_pro` FROM `mobilize_fake_cord`">>).
- -define(SQL_MOBILIZE_FAKE_SAVE,
- "REPLACE INTO `mobilize_fake_cord` (`task_type`,`fake_id`,`act`,`day`,`stime`,`etime`,`ltime`,`remain_score`,`per_score`,`remain_times`,`remain_click`,`process`,`real_pro`) values ~ts").
- -define(SQL_MOBILIZE_FAKE_LOG_BATCH,
- "REPLACE INTO `log_mobilize_progress` (`act`,`task_type`,`desc`,`fake`,`process`,`real_pro`,`day`,`time`) values ~ts").
-
- -define(SQL_FAKE_PROCESS_UPDATE, <<"UPDATE `mobilize_fake_cord` SET `ltime`= ~p,`process`=~p,`real_pro`=~p WHERE `task_type` = ~p and `fake_id`=~p and `act` = ~p and `day` =~p">>). %%进度相关
- -define(SQL_FAKE_CLICK_UPDATE, <<"UPDATE `mobilize_fake_cord` SET `ltime`= ~p,`remain_score`= ~p,`per_score`= ~p,`remain_times`= ~p,`remain_click`= ~p,`process`=~p,`real_pro`=~p WHERE `task_type` = ~p and `fake_id`=~p and `act` = ~p and `day` =~p">>). %%计数器相关更新
-
- %% 战力任务数据
- -define(SQL_SAVE_MOBILIZE_POWER, <<"insert into mobilize_power (`role_id`, `power`) values (~p, ~p)">>).
- -define(SQL_SELECT_MOBILIZE_POWER, <<"select `power` from mobilize_power where `role_id` = ~p limit 1">>).
|