zoukankan      html  css  js  c++  java
  • 项目一:第七天 CRM 和bos系统实现定区关联客户,关联快递员. 通过CXF框架实现

    定区关联客户

     

    需求:为了快递方便客户下订单(发快递),派快递员上门取件。  所以说需要让定区关联客户(知道客户属于哪个定区),定区跟快递员关系:多对多。知道让哪个快递员上门取件。

    CRM系统中,客户表中逻辑外键c_fixed_area_id 设置为定区ID

     

    实现步骤:

    第一步:在服务端CRM系统扩展方法(CXF服务端)

    ***注意服务端扩展新增方法后需要自测

    第二步:在客户端BOS中调用CRM中查询客户方法-展示客户记录

    ***判断选中定区记录数

    ***发送ajax请求获取客户记录

    ***将返回客户记录(json数组)遍历展示在下拉框中

    第三步:实现数据左右移动

    ***通过js代码实现

    第四步:在CRM中扩展客户关联定区方法

    第五步:在BOS中调用CRM完成客户关联定区

    (1),在CXF的服务端的CRM编写 未关联到定区客户数据, 和关联到某个定区的客户数据,通过cmd黑窗口生成 刚才写的两个代码. 将生成的接口代码复制到Bos系统的service层. 

     

    (2) 修改前台页面.   

    通过datagrid判断只能选中一条,  使用$.post(

    ${pageContext.request.contextPath}/fixedAreaAction_findNotAssociation.action",null,function(data){)  

    for(var i= 0;i<data.length;i++){

    var id = data[i].id;

    var name = data[i].username+"("+data[i].address +")";

    //给左侧下拉框中追加option

    $("#noassociationSelect").append('<option value="'+id+'">'+name+'</option>')

    }

    //发送请求获取关联到当前定区的客户记录--提交定区id

    $.post("${pageContext.request.contextPath}/fixedAreaAction_findHasAssociationByFixedAreaId.action",{"id":rows[0].id},function(data){

    //data返回客户数据;返回json数组;遍历数组中内容

    for(var i= 0;i<data.length;i++){

    var id = data[i].id;

    var name = data[i].username+"("+data[i].mobilePhone+")";

    //给左侧下拉框中追加option

    $("#associationSelect").append('<option value="'+id+'">'+name+'</option>')

    }

    })

    $('#customerWindow').window('open');

     在Action中注入CRM的CustomerService  执行两个方法

     

    1.1 下拉框数据左右移动效果

    <script type="text/javascript">

    $(function(){

    $("#toRight").click(function(){

    //目的:给右侧下拉框追加选型option,来源于左侧选中option选型

    $("#associationSelect").append($("#noassociationSelect option:selected"));

    })

    $("#toLeft").click(function(){

    //目的:给右侧下拉框追加选型option,来源于左侧选中option选型

    $("#noassociationSelect").append($("#associationSelect option:selected"));

    })

    //给左侧select元素增加双击事件

    $("#noassociationSelect").dblclick(function(){

    //目的:给右侧下拉框追加选型option,来源于左侧选中option选型

    $("#associationSelect").append($("#noassociationSelect option:selected"));

    })

    $("#associationSelect").dblclick(function(){

    $("#noassociationSelect").append($("#associationSelect option:selected"));

    })

    })

    </script>

     

    1.1 提交表单完成定区关联客户

    1、 给关联客户绑定事件

    a) 给隐藏域赋值:定区id

    b) 给下拉框设置选中效果

    1.1 完成定区关联客户

    1.1.1 CRM中扩展方法定区关联客户

    定区关联客户:关联逻辑CRM中实现;

    Service:注意service开启事务管理

    注意:服务端如果方法名称,参数,返回类型如果没变,不需要重新生成本地代码。

    新增方法/修改方法参数/方法名称/返回类型,必须重新发布服务,重新生成本地代码

    1.1.1 定区action远程调用CRM完成定区关联客户

    后台管理系统中定区action中添加定区关联客户方法

    定区关联快递员

    定区-快递员:多对多关联;向中间表添加数据;

     

    需求:给定区分配负责快递员。 将来某个客户发送快递;现在已经完成定区关联客户(客户属于哪个定区),接着完成定区关联快递员。

     

     

     

    定区-快递员:多对多关联向中间表添加记录。向定区快递员关系表新增记录

    收派时间-快递员:一对多关联更新子表(多方)外键。更新快递员表中收派时间外键字段。

     

    1、未删除,未关联到当前定区快递员记录

    2、收派时间-简化处理

    第一步:页面展示数据

    **以下拉框展示在职并且未关联到当前定区快递员记录

    **展示收派时间记录简化处理

    第二步:提交表单 提交定区id,快递员id,收派时间id

    第三步:服务器端接收参数 1、快递员关联定区(新增)  2、快递员关联收派时间(更新)

    1.1 使用combobox展示快递员数据

    定区是物流公司进行物流分配基本单位,快递员负责定区。定区关联快递员,谁来管理某个定区。

     

    下拉框中数据:未删除快递员数据:查询deltag标识等于 null

    1、 页面fixed_area.jsp

    2、 设置comboboxurl发出请求-改为js方式创建下拉列表

    {

    id : 'button-association-courier',

    text : '关联快递员',

    iconCls : 'icon-sum',

    handler : function(){

    // 判断是否已经选中了一个定区,弹出关联快递员窗口

    var rows = $("#grid").datagrid('getSelections');

    if(rows.length==1){

    // 只选择了一个定区

    //通过js方式创建下拉列表

    /* <input data-options="ditable:false, url:'${pageContext.request.contextPath}/courierAction_listajax.action?fixedAreaId=',valueField:'id',textField:'name'"

     type="text" name="courierId" class="easyui-combobox" required="true" /> */

    $("#courierId").combobox({

    url:'${pageContext.request.contextPath}/courierAction_listajax.action?fixedAreaId='+rows[0].id,

    valueField:'id',

    textField:'name',

    editable:false

    });

    // 弹出定区关联快递员 窗口

    $("#courierWindow").window('open');

    }else{

    // 没有选中定区,或者选择 了多个定区

    $.messager.alert("警告","关联快递员,只能(必须)选择一个定区","warning");

    }

    }

    }

    3、 courierAction中添加查询未删除快递员,返回json的数组数据

     

     

    Dao:

    //第一步子查询:根据定区id 查询该定区下现在已经负责快递员id

    @Query(nativeQuery=true, value="select * from t_courier c where c.c_deltag = '0' "

    + "and c.c_id not in(select  fc.c_courier_id from t_fixedarea_courier fc where fc.c_fixed_area_id = ?)")

    List<Courier> listajax(String fixedAreaId);

    1、 数据展示

     

    让定区关联快递员,让快递员关联收派时间!

    1.1 展示收派时间

    收派时间简化处理:上班时间id在页面中定死

    1.1 提交快递员表单

    1、 给按钮绑定单击事件

    1.1 服务端执行定区关联快递员

    1、 在定区Action中添加定区关联快递员的方法

  • 相关阅读:
    oracle数据库版本进化的关键节点
    到底什么是数据库呢?
    迁移数据之后,读取数据库变得很慢
    为什么越来越多的人使用python呢?
    20135306 2.4 ELF文件格式分析
    20135306 2.3程序破解实践
    20135306黄韧模块实践报告
    Linux内核学习总结
    Linux内核分析期中知识点总结
    LINUX内核分析第八周学习总结——进程的切换和系统的一般执行过程
  • 原文地址:https://www.cnblogs.com/shan1393/p/9211266.html
Copyright © 2011-2022 走看看