教你完成贩卖漏斗(sales funnel)

媒介

一个比较完全的CRM,贩卖漏斗必不可少。它能直观的经由过程图形体式格局,指出公司的客户资源从潜伏客户阶段,发展到意向客户阶段、商洽阶段和成交阶段的比例关系,或许说是转换率。这些信息关于任何一个贩卖者都是非常重要的,传统体式格局运用纸和笔盘算统计出来,费时辛苦,不直观。贩卖漏斗的涌现就是要处理如许一个题目的。
那末,贩卖漏斗怎样完成呢?这个应该是人人比较关心的题目,听我逐一报告。

需求剖析

经由过程Highcharts插件完成贩卖漏斗图。(这是一个Yii2的插件,人人自行下载安装,文章末端我会附上下载地点)

效果图

《教你完成贩卖漏斗(sales funnel)》

完成思绪

网上查过材料,没有找到任何一篇文章是直接申明贩卖漏斗的PHP用法,都是说Js用法的。没有母本参照,只能本身下功夫。心血来潮,我把百度找来的Js用法的数组花样转换成了PHP言语,胜利了。插件虽言语差别,但用法照样有共性的哈哈。

代码剖析

1、插件需求数组的参照花样。

  $funnel=['0'=>[
     'name'=> 'Unique users',
         'data'=> [
            ['Website visits',   15654],
            ['Downloads',       4064],
            ['Requested price list', 1987],
            ['Invoice sent',    976],
            ['Finalized',    846]
        ]
      ]
  ];

2、根据插件需求的数组花样组数组。

    public function actionIndex()
    {  
       $company_id=isset(Yii::$app->user->identity->attributes['company_id'])?Yii::$app->user->identity->attributes['company_id']:"-1";
       $company=Company::getAllN($company_id);
       $funnel=[];
       $_time=$this->currentMonth();  
       //挪用贩卖漏斗要领
       $funnel=$this->actionCountMoney($_time['begin_time'],$_time['end_time']);       

        return $this->render('index', [
            'funnel'=>$funnel,
            'company'=>$company,
        ]);
    }
    
     /*
    *贩卖漏斗
    *按公司按贩卖阶段统计线索的贩卖金额
   */
    public function actionCountMoney($begin_time,$end_time)
    {   
      $company_id=isset(Yii::$app->user->identity->attributes['company_id'])?Yii::$app->user->identity->attributes['company_id']:"-1";
      $uids=UserService::getCUser($company_id);
      $query = new Query();
      $query->select([
            'sell_status.status as status',
            'sum(`money`) as count_money'
        ])
            ->from('t_chance')
            ->groupBy([
            'status'
        ])
            ->join('left join','sell_status','t_chance.status = sell_status.id')
            ->orderBy('status');
      //婚配公司一切员工
      $query->andWhere(['in','owner_id',$uids]);    
      //按本月、本季度、今年查找 
      $query->andWhere(['between','end_date',strtotime($begin_time),strtotime($end_time)]);          
      $data=$query->all(); 
      //贩卖漏斗的重要数组花样部份(重点)
      $_data=[];
      if(!empty($data)){
        foreach ($data as $k => $val) { 
          $data1[0]=$val['status'];
          if(empty($val['status'])){
             $data1[0]=Yii::t('yii','Not status');
          }
          $data1[1]=(int)$val['count_money'];//数字部份必需转为整型(int)才行
          $_data[]=$data1;
        }
      }else{
        $_data[]=[Yii::t('yii','Not status'),0]; 
      } 
     
      $data2['name']=Yii::t('yii','Sales amount');
      $data2['data']=$_data;  
      $_data2[0]=$data2;

      return $_data2;
    }

    

3、视图挪用。

 <?php 
use yii\helpers\Html;
use hr\assets\AppAsset;
use miloschuman\highcharts\Highcharts; 
use yii\web\JsExpression;
?>
 <?php 
    //这部份参设置的数组花样就是我前面说的仿制Js花样来的。
    echo Highcharts::widget([
           'id'=>'funnel_highcharts', //定义一个唯一的id
           'scripts' => [
           'modules/funnel',
           'themes/funnel.src',
           ],
           'options'=>[
                'chart'=>[
                      'type'=> 'funnel',
                      'height'=>300,  //设置图表的高度
                      'marginRight'=>100 
                ],
                'title'=> [
                      'text'=>Yii::t('yii','Funnel chart of sales amount in different sales stages'),
                      'x'=>-50
                ],
                'plotOptions'=>[
                      'series'=> [
                            'dataLabels'=> [
                                    'enabled'=>true,
                                    'format'=>'<b>{point.name}</b>: {point.y:,.0f}',
                                    'color'=> '(Highcharts.theme && Highcharts.theme.contrastTextColor) || black',
                                    'color' => new JsExpression('(Highcharts.theme && Highcharts.theme.contrastTextColor) || "black"'),
                                    'softConnector'=> true
                                                                    
                             ],
                           'neckWidth'=>'15%',
                           'neckHeight'=>'12.5%'
                    ],
                   'funnel'=>[
                           'height'=>250,  //设置漏斗的高度
                           'width' => 200
                    ],
                ],
                'legend'=>[
                    'enabled'=>false
                 ],
                'series'=> $funnel,
        ]
 ]);
?>

注意事项

1、给插件定义一个唯一的id,防止一个页面屡次运用一样的插件形成争执。

2、根据插件需求的数组花样组数组,花样必需一致,数字部份必需转为整型(int)。

相干材料

Highcharts插件下载地点

    原文作者:zacklee
    原文地址: https://segmentfault.com/a/1190000007254528
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞