using System;

    using Microsoft.Xrm.Sdk;

    using Microsoft.Xrm.Sdk.Query;

    using Microsoft.Crm.Sdk.Messages;

/// <summary>

    /// 销售订单

    /// </summary>

    public class SoleOrderHelper

    {

        public static readonly string entityName = "salesorder";

        public Guid soleorderId = Guid.Empty;

        public IOrganizationService service;

/// <summary>

        /// 创建销售订单

        /// </summary>

        public void Create(Guid accountId)

        {

            Entity en = new Entity() { LogicalName = entityName,Id = accountId };

            en["name"] = "销售订单測试";

            en["accountid"] = new EntityReference() { LogicalName = "account" ,Id = accountId };

            soleorderId = service.Create(en);

        }

/// <summary>

        /// 将销售订单分派给其它用户或团队

        /// </summary>

        /// <param name="assignee">用户或团队引用</param>

        public void Assign(EntityReference assignee)

        {

            AssignRequest request = new AssignRequest();

            request.Target = new EntityReference() { LogicalName = entityName,Id = soleorderId };

            request.Assignee = assignee;

            AssignResponse response = (AssignResponse)service.Execute(request);

        }

/// <summary>

        /// 取消销售订单

        /// </summary>

        /// <param name="status">取消的状态</param>

        public void CancelSalesOrder(int status)

        {

            CancelSalesOrderRequest request = new CancelSalesOrderRequest();

            request.OrderClose = new Entity() { LogicalName = entityName,Id = soleorderId };

            request.Status = new OptionSetValue(status);

            CancelSalesOrderResponse response = (CancelSalesOrderResponse)service.Execute(request);

        }

/// <summary>

        /// 将销售订单转换为发票

        /// </summary>

        public void ConvertSalesOrderToInvoice()

        {

            ConvertSalesOrderToInvoiceRequest request = new ConvertSalesOrderToInvoiceRequest();

            request.SalesOrderId = soleorderId;

            request.ColumnSet = new ColumnSet("name","accountid");

            ConvertSalesOrderToInvoiceResponse response = (ConvertSalesOrderToInvoiceResponse)service.Execute(request);

            Entity invoiceEn = response.Entity;

        }

/// <summary>

        /// 完毕销售订单

        /// </summary>

        /// <param name="status">完毕的状态</param>

        public void FulfillSalesOrder(int status)

        {

            FulfillSalesOrderRequest request = new FulfillSalesOrderRequest();

            request.OrderClose = new Entity() { LogicalName = entityName,Id = soleorderId };

            request.Status = new OptionSetValue(status);

            FulfillSalesOrderResponse response = (FulfillSalesOrderResponse)service.Execute(request);

        }

/// <summary>

        /// 从指定商机中检索销售订单的产品组

        /// </summary>

        /// <param name="opportunityId">商机id</param>

        public void GetSalesOrderProductsFromOpportunity(Guid opportunityId)

        {

            GetSalesOrderProductsFromOpportunityRequest request = new GetSalesOrderProductsFromOpportunityRequest();

            request.OpportunityId = opportunityId;

            request.SalesOrderId = soleorderId;

            GetSalesOrderProductsFromOpportunityResponse response =

                (GetSalesOrderProductsFromOpportunityResponse)service.Execute(request);

        }

/// <summary>

        /// 锁定销售订单定价

        /// </summary>

        public void LockSalesOrderPricing()

        {

            LockSalesOrderPricingRequest request = new LockSalesOrderPricingRequest();

            request.SalesOrderId = soleorderId;

            LockSalesOrderPricingResponse response = (LockSalesOrderPricingResponse)service.Execute(request); 


        }

/// <summary>

        /// 解锁指定的销售订单(订单)中产品的单位价格

        /// </summary>

        public void UnlockSalesOrderPricing()

        {

            UnlockSalesOrderPricingRequest request = new UnlockSalesOrderPricingRequest();

            request.SalesOrderId = soleorderId;

            UnlockSalesOrderPricingResponse response = (UnlockSalesOrderPricingResponse)service.Execute(request);


        }

/// <summary>

        /// 取消指定安全主体(用户或团队)对销售订单的全部訪问权限

        /// </summary>

        /// <param name="revokee">用户或团队引用</param>

        public void RevokeAccess(EntityReference revokee)

        {

            RevokeAccessRequest request = new RevokeAccessRequest();

            request.Target = new EntityReference() { LogicalName = entityName,Id = soleorderId };

            request.Revokee = revokee;

            RevokeAccessResponse response = (RevokeAccessResponse)service.Execute(request);

        }

/// <summary>

        /// 删除销售订单

        /// </summary>

        public void Delete()

        {

            service.Delete(entityName, soleorderId);

        }

    }

crm操作销售订单实体的更多相关文章

  1. crm操作知识库文章实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages;     using Microsoft ...

  2. crm操作报价单实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages;     using Microsoft ...

  3. Netsharp快速入门(之11) 销售管理(开发销售订单工作区)

    作者:秋时 杨昶   时间:2014-02-15  转载须说明出处 4.3     销售订单开发 4.3.1  部件工作区设置 1.创建部件工作区,建工作区向导中要注意勾选组合并系部分.具体要建立的部 ...

  4. Netsharp快速入门(之13) 销售管理(单据流转 销售订单生成发货单)

    作者:秋时 杨昶   转载须说明出处 4.5     单据流转 4.5.1  单据流转的目的 单据流转主要为了实现业务关系的流转,并记录相互之间的关系.例如从销售订单生成销货单,两张单据之间有对应的关 ...

  5. Odoo开源ERP:功能模块操作-销售功能篇

    客户基础资料 1. 所有的客户基础资料,智云ERP开账启用时,期初的客户数据如果大于200条,可以批量导入: 2. 点“销售/订单/客户”菜单可以查看.编辑修改.搜索所有的客户基础资料: 3. 多层级 ...

  6. [置顶]生鲜配送管理系统_升鲜宝V2.0 销售订单汇总_采购任务分配功能_操作说明

    做好生鲜供应链系统,要注意三个方面,1.分拣 2 采购  3 库存,市面上做的比较成熟的功能,还是分拣这一块(按客户分拣.按订单分拣.按商品分类分拣.按商品分拣.按线路分拣.客户自由组合分拣)[下篇文 ...

  7. 转载]SAP囚徒 - 通过销售订单领用到成本中心,FI替代

    转载]SAP囚徒 - 通过销售订单领用到成本中心,FI替代   原文地址:SAP囚徒 - 通过销售订单领用到成本中心,FI替代实现不同成本中心记账科目不同作者:SAP囚徒 物品领用通常是库存管理的范畴 ...

  8. AR_销售订单收款基本操作(流程)

    2014-06-04 Created By BaoXinjian

  9. 为什么S/4HANA的销售订单创建会触发生产订单的创建

    调用S/4HANA销售订单创建函数SD_SALES_DOCU_MAINTAIN创建一个销售订单时,会触发生产订单的创建. 销售订单的每个行项目对应一个独立的生产订单,SD_SALES_DOCU_MAI ...

随机推荐

  1. P2622 关灯问题II (状态压缩,最短路)

    题目链接 Solution 这道题算是很经典的状压问题了,好题. 考虑到 \(n\) 的范围仅为 \(10\) , 那么也就是说所有状态压起来也只有 \(1024\) 种情况. 然后我们发现 \(m\ ...

  2. hdu 1087 最大上升子序列的和(dp或线段树)

    Super Jumping! Jumping! Jumping! Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 ...

  3. BNU 12846 LCM Extreme 最小公倍数之和(线性欧拉筛选+递推)

    LCM Extreme Time Limit: 3000ms Memory Limit: 131072KB   This problem will be judged on UVALive. Orig ...

  4. Linq技巧3——何时及怎么使用预先加载

    通常情况在你的应用程序中,一旦你要查询完数据的的时候,你知道使用实体来做什么. 假如你打印一份订单给顾客,你知道不包括组成订单的Items和Products信息,打印的信息是不完整的,所以查询时也需要 ...

  5. java8 函数式接口——Function/Predict/Supplier/Consumer

    Function 我们知道Java8的最大特性就是函数式接口.所有标注了@FunctionalInterface注解的接口都是函数式接口,具体来说,所有标注了该注解的接口都将能用在lambda表达式上 ...

  6. 免费CSS鼠标样式代码大全

    原文发布时间为:2008-08-01 -- 来源于本人的百度文章 [由搬家工具导入] http://5211.91.tc/sb.htm

  7. Intent显示启动与隐式启动

    Android的Acitivity启动大致有两种方式:显式启动与隐式启动.下面分别介绍: 1.显示启动: 清单文件注册Activity <activity android:name=" ...

  8. JS对象直接量,数组直接量和函数直接量

    对象直接量创建一个对象: var obj = {x:[1,2],y:23}; 代码跟下面是一样的. var obj=new Object(); obj.x=new Array(1,2); obj.y= ...

  9. 标准C程序设计七---74

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  10. vue 上传文件 和 下载文件

    Vue上传文件,不必使用什么element 的uplaod, 也不用什么npm上找的个人写的包,就用原生的Vue加axios就行了, 废话不多说,直接上代码:html: <input type= ...