根据业绩确定提成比例并计算提成
Up
• 发表于:2021-04-16 16:25:11 • 更新于:2021-12-04 21:22:40
1083

描述:

根据当月订单的成交量计算业务员的当月的业绩总额,确定业务员当月的提成档次,得出提成比例,并在月底自动算出业务员当月成交订单的所有提成。

前期准备:

创建业务员表、提成阶级表、订单表、业绩提成表;其中业务员表集合提成阶级表,提成阶级表字段:“业绩左区间(元)”表示大于等于这个数值,例如“业绩左区间(元)”填50000,即表示大于等于50000元;“业绩右区间”表示小于这个数值,例如“业绩右区间(元)”填100000,即表示小于100000元。订单表则简单表示。

 根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

实现步骤:

1. 新建一个“新增业务员”功能,录入业务员的基础信息,以及最重要的“提成阶级”。

 根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

示例效果:

根据业绩确定提成比例并计算提成

2. 新建一个“新增订单”功能,录入对应的订单数据;在新建一条订单数据的时候,会同步创建一条对应业务员的业绩提成信息。

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

示例效果:

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

3. 新建一个“单个业务员提成计算”功能,用于统计单个业务员的月累计业绩,从而在该业务员的提成阶级中获取到业绩总额对应的提成比例,算出当月所有提成并更新到业绩提成表上。

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

新加一个“交互”类型的步骤,“操作”选为“输入”,并在属性选项卡里“添加属性”,别名设为“当前时间”

根据业绩确定提成比例并计算提成

计算业绩步骤是“编程”类型,效果如下:

 根据业绩确定提成比例并计算提成

代码:

async function runProcess($model = model, $plugin = plugin, $params) {

    let commission_list = $params.commission_list;//获取业务员提成阶级

    let salesman = $params.salesman; //获取业务员

    let date = new Date();

    date.setMonth(date.getMonth()-1);//上个月

    date.setDate(1);//上个月1号

    let params = await $model.getValue("6077ed6363070c5016868574");

    let now_str = params["field_1618472308212"];//当前日期YYYY-MM-DD

    let YY = date.getFullYear();

    let MM = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1);

    let DD = (date.getDate() + 1 <= 10 ? '0' + date.getDate() : date.getDate());

    let time = YY + "-" + MM + "-" + DD;//上个月1号日期str

    await $model.log("now:" + now_str);

    await $model.log("time:" + time);

    let achievement_list = await $plugin.data.queryData("607656e51221966e7625ae4c", {

        "$and": [{

            "6076578923ebd46e75f74344": salesman._id,     //业务员id

            "607657951221966e7625ae4d": { "$gte": time }  //大于等于上月1号

        }, {

            "6076578923ebd46e75f74344": salesman._id,     //业务员id

            "607657951221966e7625ae4d": { "$lt": now_str } //小于当前日期(1号)

        }

        ]

    }, {

        all: true

    });//查询该业务员上个月的所有业绩

    await $model.log(achievement_list.length);//获取到业务员业务提成数据量

    let total_amount = await $plugin.data.summaryData("607656e51221966e7625ae4c", "6076573e23ebd46e75f74341","6076578923ebd46e75f74344",{

        "$and": [{

            "6076578923ebd46e75f74344": salesman._id,     //业务员id

            "607657951221966e7625ae4d": { "$gte": time }  //大于等于上月1号

        }, {

            "6076578923ebd46e75f74344": salesman._id,     //业务员id

            "607657951221966e7625ae4d": { "$lt": now_str } //小于当前日期(1号)

        }

        ]

    });//统计当月销售业绩

    total_amount = total_amount[0]["sum"];//合计销售业绩

    await $model.log("total:" + total_amount);//打印总业绩

    for (let i = 0; i < commission_list.length; i++) {

        if (total_amount >= commission_list[i]["6075506114b72e6e88545005"] && total_amount < commission_list[i]["60755074cbbb586e7aa6b5ec"]) {//找到对应的提成区间,大于等于左区间,小于右区间

            let rate = commission_list[i]["60755081e609b06e81432714"];//对应提成阶级的比例

            for (let j = 0; j < achievement_list.length; j++) {

                await $plugin.data.updateData("607656e51221966e7625ae4c", achievement_list[j]._id, {

                    "6076575823ebd46e75f74342": new Number(rate),

                    "6076576723ebd46e75f74343": achievement_list[j]["6076573e23ebd46e75f74341"] * new Number(rate) * 0.01 //业绩提成=业绩金额*提成比例*0.01

                });//循环计算出业绩提成

            }

        }

    }

 

}

 

 

4. 新建一个“自动计算提成功能”,获取到所有的业务员,并用编程代码调用3步骤中的“单个业务员提成计算”功能,循环算出所有业务员的所有业绩提成。

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

循环计算业务员提成步骤是“编程”类型,效果如下:

根据业绩确定提成比例并计算提成

代码:

async function runProcess($model = model, $plugin = plugin, $params) {

    let list = $params.list;//获取所有的业务员

    for (let i = 0; i < list.length; i++) {

        await $plugin.program.exec("6076d0f41221966e7625b4ae", {//调用计算提成功能id

            "6077eb7263070c5016868568": { //被调用功能,选择业务员步骤的步骤id

                "_id": list[i]._id

            }

        });

    }

}

其中,被调用功能的id可在其功能画布里边去获取

根据业绩确定提成比例并计算提成

获取选择业务员业务员步骤的id

根据业绩确定提成比例并计算提成

5. 创建定时任务,设置好执行的功能及其执行时间

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

至此功能的实现步骤全部完成。


功能效果:

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

根据业绩确定提成比例并计算提成

本文是否对您有帮助?
有帮助
没帮助
您是否遇到了以下问题?
内容过期或不准确
缺少场景、事例
链接有误
太简单,步骤待完善
其他
提交反馈
如需获取即时帮助,请联系
小助理
微信扫码添加小助理
让你的想法快速变成软件吧~
联系我们
售前咨询电话
020-88520693
意见箱 · 建议反馈
您的宝贵建议,使白码更完美!
微信扫码添加白码小助理