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. cocos2dx项目创建

    射击类游戏文档 作者:浙江传媒学院  新媒体  张勇 1>编译环境 首先我们先去cocos2dx官网上下载cocos2dx最新版本号 http://www.cocos2d-x.org/ 我下载的 ...

  2. OC-JS交互(WebViewJavascriptBridge使用说明)

    首先确保一份已经配好功能的html文件. 1.初始化一个webview(viewdidload) UIWebView* webView = [[UIWebView alloc] initWithFra ...

  3. elcipse 编译cocos2d-x android

    http://blog.csdn.net/eyu8874521/article/details/22605695 最開始学习cocos2dx.大多数人可能是被复杂的环境配置过程搞死的,尤其是和Andr ...

  4. angularjs1-1

    <!DOCTYPE html> <html> <body> <header> <meta http-equiv="Content-Typ ...

  5. JDBC整理

    JDBC提供了独立于数据库的统一Api,用以执行SQL命令.JDBC API由以下常用的接口和类组成: DriverManagement:用于管理JDBC驱动的服务类,程序中使用该类的主要功能是获取C ...

  6. oracle 11gR2 如何修改public ip

    修改public ip 修改前后ip信息 修改前ip信息 p570a 192.168.1.10 p570b 192.168.1.11 修改后ip信息 p570a 1.7.3.112 p570a 1.7 ...

  7. 杂项-DB:数据库

    ylbtech-杂项-DB:数据库   数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新增.截取.更新.删除等操作. 所谓“数据库”是以一定方式储存在一起.能与 ...

  8. 动态连通性问题:union-find算法

    写在前面的话: 一枚自学Java和算法的工科妹子. 算法学习书目:算法(第四版) Robert Sedgewick 算法视频教程:Coursera  Algorithms Part1&2 本文 ...

  9. Oracle 复合索引设计原理——前缀性和可选性

    前缀性: 复合索引的前缀性是指只有当复合索引的第一个字段出现在SQL语句的谓词条件中时,该索引才会被用到.如复合索引为(ename,job,mgr),只要谓词条件中出现第一个字段ename,就可以用复 ...

  10. 查看md文件

    使用命令将md文件转为html,在浏览器中演示 通过npm安装i5ting_toc 安装好node之后,可以直接使用npm.Windows+R打开运行框,输入cmd,打开命令窗口.连网的情况下,输入如 ...