using System;

    using Microsoft.Xrm.Sdk;

    using Microsoft.Crm.Sdk.Messages;

    using Microsoft.Xrm.Sdk.Query;

/// <summary>

    /// 报价单

    /// </summary>

    public class QuoteHelper

    {

        public static readonly string entityName = "quote";

        public Guid quoteId = Guid.Empty;

        public IOrganizationService service;

/// <summary>

        /// 创建报价单

        /// </summary>

        public void Create(Guid accountId)

        {

            Entity en = new Entity() { LogicalName = entityName };

            en["name"] = "报价单測试";

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

            quoteId = service.Create(en);

        }

/// <summary>

        /// 创建报价单及其相关报价单具体信息

        /// </summary>

        /// <param name="childEn">报价单具体信息</param>

        public void CompoundCreate(EntityCollection childEn)

        {

            CompoundCreateRequest request = new CompoundCreateRequest();

            request.Entity = new Entity() { LogicalName = entityName };

            request.ChildEntities = childEn;

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

            quoteId = response.Id;

        }

/// <summary>

        /// 将报价单分派给其它用户或团队

        /// </summary>

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

        public void Assign(EntityReference assignee)

        {

            AssignRequest request = new AssignRequest();

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

            request.Assignee = assignee;

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

        }

/// <summary>

        /// 指定结束报价单

        /// </summary>

        /// <param name="status">结束的状态值</param>

        public void CloseQuote(int status)

        {

            CloseQuoteRequest request = new CloseQuoteRequest();

            request.QuoteClose = new Entity() { LogicalName = entityName,Id = quoteId };

            request.Status = new OptionSetValue(status);

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

        }

/// <summary>

        /// 将报价单转换为销售订单

        /// </summary>

        public Entity ConvertQuoteToSalesOrder()

        {

            ConvertQuoteToSalesOrderRequest request = new ConvertQuoteToSalesOrderRequest();

            request.QuoteId = quoteId;

            request.ColumnSet = new Microsoft.Xrm.Sdk.Query.ColumnSet("name","accountid");

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

            //销售订单

            Entity solrorderEn = response.Entity;

            return solrorderEn;

        }

/// <summary>

        /// 为目标值中指定的实体获取产品的数量小数值

        /// </summary>

        /// <param name="productId">产品id</param>

        /// <param name="uoMId">单位id</param>

        public int GetQuantityDecimal(Guid productId, Guid uoMId)

        {

            GetQuantityDecimalRequest request = new GetQuantityDecimalRequest();

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

            request.ProductId = productId;

            request.UoMId = uoMId;

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

            return response.Quantity;

        }

/// <summary>

        /// 从商机中检索产品并将其拷贝到报价单

        /// </summary>

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

        public void GetQuoteProductsFromOpportunity(Guid opportunityId)

        {

            GetQuoteProductsFromOpportunityRequest request = new GetQuoteProductsFromOpportunityRequest();

            request.OpportunityId = opportunityId;

            request.QuoteId = quoteId;

            GetQuoteProductsFromOpportunityResponse response =

                (GetQuoteProductsFromOpportunityResponse)service.Execute(request);

        }

/// <summary>

        /// 与其它安全主体(用户或团队)共享报价单

        /// </summary>

        /// <param name="accessMask">訪问权限</param>

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

        public void GrantAccessRequest(AccessRights accessMask,EntityReference principal)


        {

            GrantAccessRequest request = new GrantAccessRequest();

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

            request.PrincipalAccess = new PrincipalAccess() { AccessMask = accessMask,Principal = principal };

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

        }

/// <summary>

        /// 将报价单的状态设置为“草稿”

        /// </summary>

        public void ReviseQuote()

        {

            ReviseQuoteRequest request = new ReviseQuoteRequest();

            request.QuoteId = quoteId;

            request.ColumnSet = new Microsoft.Xrm.Sdk.Query.ColumnSet("name","accountid");

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

            //草稿状态的报价单

            Entity quoteEn = response.Entity;

        }

/// <summary>

        /// 汇总或检索与指定的记录(客户或联系人)相关的全部报价单

        /// </summary>

        /// <param name="target">客户或联系人引用</param>

        /// <param name="query">查询条件</param>

        /// <param name="rollupType">关联类型</param>

        public void Rollup(EntityReference target, QueryBase query, RollupType rollupType)


        {

            RollupRequest request = new RollupRequest();

            request.Target = target;

            request.Query = query;

            request.RollupType = rollupType;

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

            EntityCollection entityCollection = response.EntityCollection;

        }

/// <summary>

        /// 删除报价单

        /// </summary>

        public void Delete()

        {

            service.Delete(entityName, quoteId);

        }

       

    }

crm操作报价单实体的更多相关文章

  1. crm操作货币实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages; /// <summary> ...

  2. crm操作产品实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages; /// <summary> ...

  3. crm操作约会实体

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

  4. crm操作发票实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Xrm.Sdk.Query;     using Microsoft.Cr ...

  5. Winform开发框架之客户关系管理系统(CRM)的报价单和销售单的处理

    在前面介绍了很多CRM相关的界面和实现思路的随笔文章,本篇继续介绍一下系统中用到的一些经验和技巧片段.本篇随笔主要介绍客户关系管理系统(CRM)的报价单和销售单的处理界面效果,使用列表内置的选择代替弹 ...

  6. crm工作机会实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages; public class Opport ...

  7. Microsoft Dynamics CRM 2011 新建实体 需要注意的细节

    新建一个实体,需要红色框内的是否勾选的意义,可以进一步加深对CRM的理解.如图: 下面对部分的进行了自我的理解,不对的地方,还请大家指出来.互相学习. 1.CRM2011中,在活动方面加强的新特性包括 ...

  8. Hibernate_day02--课程安排_主键生成策略_对实体类crud操作_实体类对象状态

    Hibernate_day02 上节内容 今天内容 实体类编写规则 Hibernate主键生成策略 实体类操作 对实体类crud操作 添加操作 根据id查询 修改操作 删除操作 实体类对象状态(概念) ...

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

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

随机推荐

  1. 0x01 位运算

    都比较基础吧. 知识点 1.快速幂和快速乘(这里有一个用long double舍弃精度的做法,但是感觉既不稳又没用) 2.懒人写边目录的时候的k^1 3.lowbit,得到的是低到高第一个1的位.求一 ...

  2. Linux 下 新增Oracle10g 实例

    主要分为5步:创建实例目录,创建密码文件,创建参数文件,创建建库脚本并建库,创建数据字典. 其中,需要特别注意2点: 目录的权限,即用户和所属用户组都要是oracle.可以切换到已存在的oracle用 ...

  3. 19.QT对话框(文件对话框,颜色对话框,字体框,自定义对话框)

    文件对话框 #include<QFileDialog> //文件对话框 void Dialog::on_pushButton_clicked() { //定义显示文件的类型 窗口标题 可供 ...

  4. luogu 3952 时间复杂度(模拟)

    时间复杂度 这道题从两个月前开始做,一直没做出来,最后今晚决心一定要做出来.于是开始认真的在打草纸上写思路,最后在AC的那一刻,差点哭了出来!! 题目大意 这个自己看吧,noip2017的D1T2 s ...

  5. linux压缩(解压缩)命令详解

    一.tar命令          tar可以为文件和目录创建档案.利用tar,用户可以为某一特定文件创建档案(备份文件),也可以在档案中改变文件,或者向档案中加入新的文件.tar 最初被用来在磁带上创 ...

  6. Oracle学习系类篇(二)

    1.Oracle对表的增删改 1.1添加列 1.2修改列 1.3 删除列 1.4 修改表名称 1.5 修改列名称 1.6 删除主键约束 1.7 添加主键约束 1.8 添加外键约束

  7. Zeplin(for Windows)无缝集成到了 Adobe XD

    Zeplin(for Windows)无缝集成到了 Adobe XD 大约6个月前,推出了 Zeplin 的新Adobe XD CC集成.从那时起,数十万个设计从Adobe XD导出到Zeplin.Z ...

  8. Broadcast Receiver广播接收器

    1.概述 广播接收器不仅能接受来自系统的内容,也可以接受来自其他app的内容.广播分为标准广播和有序广播. 2.标准广播 一种完全异步执行的广播,在广播发出之后几乎所有的广播接收器都在同一时刻接受到广 ...

  9. Python爬虫:爬取某网站关键词对应商品ID,且存入DB2数据库

    公司研发不给力,我就自己写了一个,专门爬关键词对应的商品ID. 其中还学会了用Python操作DB2数据库.Python发送邮件.写日志文件.处理浏览器访问限制. #!/usr/bin/python# ...

  10. List of features and minimum Clang version with support

    #1: C++11 Language Feature C++11 Proposal Available in Clang? Rvalue references N2118 Clang 2.9      ...