更新时间:2024-06-25 GMT+08:00
分享

创建“处理工单”脚本

“维修工程师处理工单”功能包含两个页面,一个是工程师查看待处理工单列表页面,一个是处理工单对话框页面。首先需要创建“处理工单”脚本。

操作步骤

  1. 在经典版开发环境“首页 > 我的应用”中,单击“设备维修管理系统”,进入应用。
  2. 在“WorkOrder”目录中,将鼠标放在“Script”上,单击界面上出现的“+”,在弹出菜单中选择“脚本”。
  3. 在弹窗中,选中“创建一个新脚本”,在“名称”文本框中输入“modifyOrderStatus”,单击“添加”。

    当编辑已有脚本时,为防止编辑时多人篡改,编辑前请单击进行锁定。

  4. 在代码编辑器中插入如下脚本代码。

    脚本中加红色内容请替换为实际的对象名、字段名。

    //本脚本用于派发工单
    import * as db from 'db';//导入处理object相关的标准库
    import * as context from 'context';//导入上下文相关的标准库
    import * as date from 'date';
    //定义入参结构,入参包含1个参数:工单的状态信息,为必填字段
    @action.object({ type: "param" })
    export class ActionInput {
        @action.param({ type: 'Object', required: true, label: 'object' })
        statusInfo: object;
    }
    //定义出参结构,出参包含2个参数,workOrder的记录id和当前状态
    @action.object({ type: "param" })
    export class ActionOutput {
        @action.param({ type: 'String' })
        id: string;
        @action.param({ type: 'String' })
        status: string;
    }
    //使用数据对象HW__WorkOrder__CST
    @useObject(['HW__WorkOrder__CST'])
    @action.object({ type: "method" })
    export class ModifyOrderStatus {    //定义接口类,接口的入参为ActionInput,出参为ActionOutput
        @action.method({ input: 'ActionInput', output: 'ActionOutput' })
        public modifyOrderStatus(input: ActionInput): ActionOutput {
            let out = new ActionOutput();    //新建出参ActionOutput类型的实例,作为返回值
            let error = new Error();    //新建错误类型的实例,用于在发生错误时保存错误信息
            try {
                let statusInfo = input.statusInfo;     //将入参赋值给statusInfo变量,方便后面使用
                let s = db.object('HW__WorkOrder__CST');    //获取HW__WorkOrder__CST这个Object的操作实例
     
                //查询条件
                let condition = {
                    "conjunction": "AND",
                    "conditions": [{
                        "field": "id",
                        "operator": "eq",
                        "value": statusInfo['id']
                    }]
                };
                //查找workOrderId所代表的工单信息
                let workOrder = s.queryByCondition(condition);
                if (statusInfo['HW__status__CST'] == "接单") {
                    workOrder[0]['HW__status__CST'] = "处理中";
                } else if (statusInfo['HW__status__CST'] == "拒单") {
                    workOrder[0]['HW__status__CST'] = "待派单";
                    workOrder[0]['HW__assignedFme__CST'] = "派单员";
                } else if (statusInfo['HW__status__CST'] == "关单") {
                    workOrder[0]['HW__status__CST'] = "关闭";
                }
                let isUpdated = s.updateByCondition(condition, workOrder[0]);
                if (isUpdated) {
                    out.id = workOrder[0]['id'];
                    out.status = statusInfo['HW__status__CST'];
                } else {
                    error.name = "WOERROR";
                    error.message = "修改工单状态失败!";
                    throw error;
                }
            } catch (error) {
                console.error(error.name, error.message);
                context.setError(error.name, error.message);
            }
            return out;
        }
    }

  5. 单击编辑器上方的,保存脚本。
  6. 测试脚本能否正常执行。

    1. 单击编辑器上方的,执行脚本。
    2. 在界面底部,输入如下示例,单击测试窗口右上角执行图标。
      “ceHg000000e0glLbDQ2K”则是派单员操作的当前工单记录的工单id,您可以在派单功能脚本的测试结果中获取一个id值。
      {
          "statusInfo": {
              "id": "ceHg000000e0glLbDQ2K",
              "HW__status__CST": "接单"
          }
      }

      执行成功,会在“输出”页签返回查询结果。

      图1 输出处理后工单信息

  7. 测试成功,单击编辑器上方的,启用发布脚本。

相关文档