提成明细加上服务时间范围查询、优化订单营养师助理售后绑定关系逻辑

This commit is contained in:
xiezhijun
2021-08-23 15:29:49 +08:00
parent a5a0da6cd2
commit e80c11a27c
10 changed files with 92 additions and 21 deletions

View File

@@ -267,8 +267,15 @@ public class SysCommisionController extends BaseController {
@PreAuthorize("@ss.hasPermi('commisionDay:detail:list')") @PreAuthorize("@ss.hasPermi('commisionDay:detail:list')")
@GetMapping("/detailDay") @GetMapping("/detailDay")
public TableDataInfo getDetailDay(SysCommision sysCommision) { public TableDataInfo getDetailDay(SysCommision sysCommision) {
startPage(); int count = sysCommissionDayService.getAfterSaleAndNutriCount(sysCommision);
return getDataTable(sysCommissionDayService.calculateCommissionByDay(sysCommision)); List<SysCommissionDayDetail> list = null;
if(count > 0){
startPage();
list = sysCommissionDayService.calculateCommissionByDay(sysCommision);
}else{
list = new ArrayList<>();
}
return new TableDataInfo(list, count);
} }
/** /**

View File

@@ -69,5 +69,7 @@ public interface SysCommisionMapper
*/ */
List<SysCommision> getAfterSaleAndNutri(SysCommision sysCommision); List<SysCommision> getAfterSaleAndNutri(SysCommision sysCommision);
int getAfterSaleAndNutriCount(SysCommision sysCommision);
List<Long> getAfterSaleId(SysCommision sysCommision); List<Long> getAfterSaleId(SysCommision sysCommision);
} }

View File

@@ -46,4 +46,11 @@ public interface ISysCommissionDayService {
*/ */
Map<String, List<SysCommision>> getRateMapByStartTime(List<SysCommision> tmpComList); Map<String, List<SysCommision>> getRateMapByStartTime(List<SysCommision> tmpComList);
/**
* 查询营养师、售后数量
* @param sysCommision
* @return
*/
int getAfterSaleAndNutriCount(SysCommision sysCommision);
} }

View File

@@ -969,4 +969,9 @@ public class SysCommissionDayServiceImpl implements ISysCommissionDayService {
} }
} }
@Override
public int getAfterSaleAndNutriCount(SysCommision sysCommision){
return sysCommisionMapper.getAfterSaleAndNutriCount(sysCommision);
}
} }

View File

@@ -260,6 +260,16 @@
<if test="userId != null and userId != ''">and su.user_id = #{userId}</if> <if test="userId != null and userId != ''">and su.user_id = #{userId}</if>
</select> </select>
<!-- 查询售后和营养师数量 -->
<select id="getAfterSaleAndNutriCount" parameterType="SysCommision" resultType="int">
SELECT count(su.user_id) FROM sys_user su
LEFT JOIN sys_user_post sup ON sup.user_id = su.user_id
LEFT JOIN sys_post sp ON sp.post_id = sup.post_id
WHERE su.del_flag = 0 AND su.status = 0 AND sp.remark = 'sale_post' AND (sp.post_code = 'after_sale' OR sp.post_code = 'nutri')
<if test="postId != null and postId != ''">and sp.post_id = #{postId}</if>
<if test="userId != null and userId != ''">and su.user_id = #{userId}</if>
</select>
<select id="getAfterSaleId" parameterType="SysCommision" resultType="Long"> <select id="getAfterSaleId" parameterType="SysCommision" resultType="Long">
SELECT su.user_id FROM sys_user su SELECT su.user_id FROM sys_user su
LEFT JOIN sys_user_post sup ON sup.user_id = su.user_id LEFT JOIN sys_user_post sup ON sup.user_id = su.user_id

View File

@@ -807,6 +807,10 @@ export default {
}; };
this.screenNutriAssisIdOptions = this.nutriAssisIdOptions; this.screenNutriAssisIdOptions = this.nutriAssisIdOptions;
this.screenAfterSaleIdOptions = this.afterSaleIdOptions; this.screenAfterSaleIdOptions = this.afterSaleIdOptions;
//处理原先设定的营养师、助理、售后绑定关系发生变化(比如原先订单的售后或助理发生变化)之后,需要自动更换
this.handleOnDietIdChange(this.form.nutritionistIdList);
this.resetForm("form"); this.resetForm("form");
}, },
handleOnClosed() { handleOnClosed() {
@@ -851,15 +855,21 @@ export default {
}, },
//监听营养师下拉列表 //监听营养师下拉列表
handleOnDietIdChange(val) { handleOnDietIdChange(val) {
let assistantAfterArray = orderUtils.getAfterSaleAndAssistantByDietId(this.dietitianAfterAssistantOptions, (val && val.length != null) ? val[val.length-1] : 0); let assistantAfterArray = orderUtils.getAfterSaleAndAssistantByDietId(this.dietitianAfterAssistantOptions, (val && val != null) ? val[val.length-1] : 0);
this.form = { /*this.form = {
...this.form, ...this.form,
nutriAssisId: assistantAfterArray ? orderUtils.getRandomValueByArray(assistantAfterArray[0]) : 0, nutriAssisId: assistantAfterArray ? orderUtils.getRandomValueByArray(assistantAfterArray[0]) : 0,
afterSaleId: assistantAfterArray ? orderUtils.getRandomValueByArray(assistantAfterArray[1]) : 0, afterSaleId: assistantAfterArray ? orderUtils.getRandomValueByArray(assistantAfterArray[1]) : 0,
}; };*/
if(this.form.nutriAssisId == null || assistantAfterArray[0].indexOf(this.form.nutriAssisId) == -1){
this.form.nutriAssisId = assistantAfterArray ? orderUtils.getRandomValueByArray(assistantAfterArray[0]) : 0;
}
if(this.form.afterSaleId == null || assistantAfterArray[1].indexOf(this.form.afterSaleId) == -1){
this.form.afterSaleId = assistantAfterArray ? orderUtils.getRandomValueByArray(assistantAfterArray[1]) : 0;
}
this.screenNutriAssisIdOptions = orderUtils.getAfterSaleOrAssistantByIds(this.nutriAssisIdOptions, assistantAfterArray[0]); this.screenNutriAssisIdOptions = orderUtils.getAfterSaleOrAssistantByIds(this.nutriAssisIdOptions, assistantAfterArray[0]);
this.screenAfterSaleIdOptions = orderUtils.getAfterSaleOrAssistantByIds(this.afterSaleIdOptions, assistantAfterArray[1]); this.screenAfterSaleIdOptions = orderUtils.getAfterSaleOrAssistantByIds(this.afterSaleIdOptions, assistantAfterArray[1]);
}, }
}, },
watch: { watch: {
// 监听收款账号的变化 // 监听收款账号的变化

View File

@@ -664,7 +664,7 @@ export default {
}, },
//监听营养师下拉列表 //监听营养师下拉列表
handleOnDietIdChange(val) { handleOnDietIdChange(val) {
console.log(val); //console.log(val);
let assistantAfterArray = orderUtils.getAfterSaleAndAssistantByDietId(this.dietitianAfterAssistantOptions, val); let assistantAfterArray = orderUtils.getAfterSaleAndAssistantByDietId(this.dietitianAfterAssistantOptions, val);
console.log(assistantAfterArray); console.log(assistantAfterArray);
this.form = { this.form = {

View File

@@ -261,6 +261,7 @@ export default {
this.queryParam.userId = this.data.userId; this.queryParam.userId = this.data.userId;
this.queryParam.reviewStatus = this.data.reviewStatus; this.queryParam.reviewStatus = this.data.reviewStatus;
this.queryParam.endTime = this.data.endTime; this.queryParam.endTime = this.data.endTime;
this.serverDateScope = this.data.serverDateScope;
this.title = `「${this.data.name}`; this.title = `「${this.data.name}`;
this.fileName = this.data.name; this.fileName = this.data.name;
if (this.data.yearMonth) { if (this.data.yearMonth) {

View File

@@ -823,8 +823,8 @@ export function dealHealthy(customerHealthy) {
return customerHealthy; return customerHealthy;
} }
export const extendHealthyTitle = {"0":"减脂","5":"降血压","6":"降血糖","3": "备孕营养", "1": "月经不调", "2": "多囊调理", "11":"心脑血管调理","13":"胃肠肿瘤调理","4":"产后调理","7":"高血脂","10":"消化系统理","14":"增重"}; export const extendHealthyTitle = {"0":"减脂","1": "月经不调","2": "多囊调理", "3": "备孕营养", "4":"产后调理","5":"降血压","6":"降血糖","7":"高血脂调理","8":"高尿酸调理","9":"营养性贫血调理","10":"消化系统调理","11":"心脑血管调理","12":"99体验","13":"胃肠肿瘤调理","14":"增重"};
export const projectName = {"0":"减脂","5":"高血压","6":"高血糖","3": "备孕营养", "1":"月经不调", "2":"多囊卵巢综合症", "13":"胃肠肿瘤","4":"产后调理","7":"高血脂","10":"消化系统管理","14":"增重"}; export const projectName = {"0":"减脂","1":"月经不调","2":"多囊卵巢综合症", "3": "备孕营养", "4":"产后调理", "5":"高血压","6":"高血糖","7":"高血脂","8":"高尿酸","9":"营养性贫血","10":"消化系统管理","11":"心脑血管系统","12":"99体验","13":"胃肠肿瘤","14":"增重"};
//需要填写慢病调查问卷的项目 //需要填写慢病调查问卷的项目
export const extendHealthyIndex = [5, 6, 1, 2, 13,4,7]; export const extendHealthyIndex = [5, 6, 1, 2, 13,4,7];
//跳过减脂经历问卷的项目 //跳过减脂经历问卷的项目

View File

@@ -39,7 +39,7 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="截止月份" prop="month"> <el-form-item label="截止订单成交月份" prop="month" label-width="140px">
<el-date-picker <el-date-picker
v-model="month" v-model="month"
@change="monthRangeChange" @change="monthRangeChange"
@@ -48,6 +48,7 @@
> >
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
<el-form-item label="订单状态" prop="reviewStatus"> <el-form-item label="订单状态" prop="reviewStatus">
<el-select <el-select
v-model="queryParams.reviewStatus" v-model="queryParams.reviewStatus"
@@ -63,7 +64,19 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item label="服务时间" prop="dateScope">
<el-date-picker
v-model="serverDateScope"
type="daterange"
range-separator=""
start-placeholder="开始日期"
end-placeholder="结束日期"
format="yyyy-MM-dd"
value-format="yyyy-MM-dd"
>
</el-date-picker>
</el-form-item>
<el-form-item style="margin-left:25lpx">
<el-button <el-button
type="cyan" type="cyan"
icon="el-icon-search" icon="el-icon-search"
@@ -283,6 +296,7 @@ export default {
sendCommissionPlanTable: false, sendCommissionPlanTable: false,
sendCommissionPlan: {}, sendCommissionPlan: {},
fixLength: 2, fixLength: 2,
serverDateScope: null
}; };
}, },
components: { components: {
@@ -332,12 +346,17 @@ export default {
/** 查询业务提成比例列表 */ /** 查询业务提成比例列表 */
getList() { getList() {
this.loading = true; this.loading = true;
const dateRange = [ let dateRange = null;
dayjs(this.month).startOf("month").format("YYYY-MM-DD"), if(this.month && this.month != null){
dayjs(this.month).endOf("month").format("YYYY-MM-DD"), dateRange = [
]; dayjs(this.month).startOf("month").format("YYYY-MM-DD"),
dayjs(this.month).endOf("month").format("YYYY-MM-DD"),
];
}
this.queryParams.serverScopeStartTime = this.serverDateScope && this.serverDateScope.length > 0 ? this.serverDateScope[0] : null;
this.queryParams.serverScopeEndTime = this.serverDateScope && this.serverDateScope.length > 0 ? this.serverDateScope[1] : null;
// console.log(dateRange) // console.log(dateRange)
detailDayCommision(this.addDateRange(this.queryParams, dateRange)).then( detailDayCommision(dateRange != null ? this.addDateRange(this.queryParams, dateRange) : this.queryParams).then(
(response) => { (response) => {
this.commisionList = response.rows; this.commisionList = response.rows;
this.total = response.total; this.total = response.total;
@@ -416,11 +435,21 @@ export default {
}, },
handleDetailClick(row) { handleDetailClick(row) {
// console.log(row); // console.log(row);
const dateRange = [ let dateRange = null;
dayjs(this.month).startOf("month").format("YYYY-MM-DD"), if(this.month && this.month != null){
dayjs(this.month).endOf("month").format("YYYY-MM-DD"), dateRange = [
]; dayjs(this.month).startOf("month").format("YYYY-MM-DD"),
this.$refs["ordercommissDetailRef"].showDrawer(this.addDateRange({'yearMonth': dayjs(this.month).endOf("month").format("YYYY-MM-DD"),'name': row.nickName, 'userId': row.userId, 'reviewStatus': this.queryParams.reviewStatus}, dateRange)); dayjs(this.month).endOf("month").format("YYYY-MM-DD"),
];
}
let param = {
'name': row.nickName,
'userId': row.userId,
'reviewStatus': this.queryParams.reviewStatus,
'yearMonth': this.month == null ? null : dayjs(this.month).endOf("month").format("YYYY-MM-DD"),
'serverDateScope': this.serverDateScope
}
this.$refs["ordercommissDetailRef"].showDrawer(dateRange != null ? this.addDateRange(param, dateRange) : param);
}, },
getSummaries(param) { getSummaries(param) {
//param 是固定的对象,里面包含 columns与 data参数的对象 {columns: Array[4], data: Array[5]},包含了表格的所有的列与数据信息 //param 是固定的对象,里面包含 columns与 data参数的对象 {columns: Array[4], data: Array[5]},包含了表格的所有的列与数据信息