CRM系统实现根据业绩确定提成比例并计算提成

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

前期准备:

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

开发平台:本文是根据白码低代码平台进行crm系统搭建,白码是国内可私有化低代码平台

开发地址:https://www.bnocode.com

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

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

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

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

实现步骤:

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. 创建定时任务,设置好执行的功能及其执行时间

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

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

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

功能效果:

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

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

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

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值