23 Ekim 2012 Salı

CRM 2011-Teklife Ürün Ekleme ( Create Quote Detail)


QuoteDetail detail = new QuoteDetail();

 detail.ProductId = urun.ToEntityReference();
 detail.UoMId = priceListItem.UoMId;
 detail.Quantity = miktar;
 detail.QuoteId = teklif.ToEntityReference();
 detail.ManualDiscountAmount = new Microsoft.Xrm.Sdk.Money(100,43);
 detail.IsPriceOverridden = true;
 detail.PricePerUnit = new Microsoft.Xrm.Sdk.Money(fiyat);

  //detail.ExtendedAmount = new Microsoft.Xrm.Sdk.Money(30);

  Guid _teklifurunId = service.Create(detail);

Burada dikkat edilmesi gerekenler;
UoMId=Teklifin fiyat listesindeki ürün kaleminin uomId sidir.
IsPriceOverridden=true =>FiyatListesiKalemindeki ürün degerını kullanmayıp yanı atanan fiyatı kullanır.

Yukarıdaki kodda urun degiskeni Product tipinde,teklif değiskeni de Quote tipindedir.

CRM 2011-IFrame Link Verme


Asagısaı javascript fonksıyonu sayfanın onLoad , onSave ya da fieldların onChange ine yazılabilir.
function IFrameLinkSet() {

    var entityid = Xrm.Page.data.entity.getId();
    var pricelistValue = new Array(); /*Guid deger alınıyor.*/
    pricelistValue = Xrm.Page.getAttribute("pricelevelid").getValue();
    var pricelistid = pricelistValue != null ? pricelistValue[0].id : null;

    var formType = Xrm.Page.ui.getFormType();
    if (formType == 2) {
        if (entityid != null && pricelistid != null) {

     /*IFrame de acılacak sayfanın adresi veriliyor.Ve adresle birlikte sayfaya veri gönderiliyor.*/
            var url = "http://localhost:8989/SalesAddProduct/SalesOrderProductView.aspx?entityid=" + entityid + "&pricelistid=" + pricelistid;

/*Link IFrame e setSrc() kullanılarak verildi.*/
            Xrm.Page.getControl("IFRAME_SalesOrderDetailsView").setSrc(url);
        }
    }
}

Crm 2011-ProductPriceLevel (Fiyat Listesi Kalemi) Bulma


Fiyatlistesi id ve ürün id ye göre fiyatlistesi kalemi bulma


Metot geriye productpricelevel döndürür.
public static ProductPriceLevel FindProductPriceLevel(Guid pricelevelid, Guid productId, IOrganizationService ser)
        {
            try
            {
                QueryExpression sorgu = new QueryExpression()
                {
                    EntityName = "productpricelevel",
                    ColumnSet = new ColumnSet() { AllColumns = true },
                };

                FilterExpression anaFilter = new FilterExpression(LogicalOperator.And);

                ConditionExpression sart1 = new ConditionExpression("pricelevelid", ConditionOperator.Equal, pricelevelid);
                ConditionExpression sart2 = new ConditionExpression("productid", ConditionOperator.Equal, productId);

                anaFilter.AddCondition(sart1);
                anaFilter.AddCondition(sart2);

                sorgu.Criteria.AddFilter(anaFilter);

                EntityCollection ec = null;

                ec = ser.RetrieveMultiple(sorgu);

                if (ec != null)
                {
                    if (ec.Entities.Count == 1)
                    {
                        return (ProductPriceLevel)ec.Entities[0];
                    }
                    else
                    {
                        return new ProductPriceLevel();
                       /*Eger fiyat listesinde ilgili üründen bir tane varsa geriye döndürür.Ürün yoksa ve birden fazlaysa geriye bos productpricelevel döndürür.*/
                    }
                }
                else
                {
                    return new ProductPriceLevel();
                }
            }

            catch (Exception)
            {
                return new ProductPriceLevel();
            }
        }
Sorularınızı gkhnmnts@gmail adresine atabilirsiniz.

Crm de Guid Bir Değere Göre Entity nin Bulunması


Aşagıdaki metoda veriyi çekeceğimiz entity nın adını,hangi field a göre sorgunun cekilecegi ve neye göre çekilecegi degerleriyle birlikte IOrganization nesnesini göndererek verimizi cekebiliriz.

public class Metotlar{
   public static Entity GetLookUp(string entityname, Guid id, string conditionField, IOrganizationService service)
        {
            try
            {
                QueryExpression sorgu = new QueryExpression()
                {
                    EntityName = entityname,
                    ColumnSet = new ColumnSet() { AllColumns = true },/*Tum kolonlar cekilir.*/
                };

                FilterExpression anaFilter = new FilterExpression(LogicalOperator.And);

                ConditionExpression sart1 = new ConditionExpression(conditionField, ConditionOperator.Equal, id);
                anaFilter.AddCondition(sart1);

                sorgu.Criteria.AddFilter(anaFilter);

                EntityCollection ec = null;

                ec = service.RetrieveMultiple(sorgu);

                if (ec != null)
                {
                    if (ec.Entities.Count > 0)
                    {
                        return ec.Entities[0];
                    }
                    else
                    {
                        return new Entity();
                    }
                }
                else
                {
                    return new Entity();
                }
            }

            catch (Exception)
            {
                return new Entity();
            }
        }
}
Örnek:
IOrganizationService crmService=DynamicCrmBaglanma.GetCrmService();
/*Crm e baglanılır.DynamicCrmBaglanma classı blog da bulunmaktadır.*/
if(crmService !=null){
Guid _productId=guid.NewGuid();
/*Ben yeni bir guid deger olusturarak parametre olarak gönderdim.*/
Entity product=Metotlar.GetLookUp(Product.EntityLogicalName,_productId,"productid",crmService);
if(product !=null && product.Id !=Guid.Empty){
Product urun=(Product)product;/*Entity Product a cast edildi.*/
}
}

CRM 2011 - INVOICE CANCELED


Şimdi sizlere formun ribbonundan bir butona tıklanarak invoice un nasıl canceled edilecegini anlatacağım.
İlk olarak formun ribbonuna bir buton ekleyelim ve javascript yazarak bu butona tıklanınca bir aspx sayfasına yönlendirilmesini sağlayalım.(ribbona buton ekleme ve bunun calıstırılacagı javascript dosyasının nasıl verildiğini bir başka yazımda anlatmıştım. )

namespace TestCRM.InvoiceInterface
{
    public partial class InvoiceCanceled : System.Web.UI.Page
    {
        IOrganizationService crmService;
//İlk olarak bir web sayfasından aspx sayfasına veri göndermeyi ve veri alıs verişini saglamak için Render metodunu kullandık.Gonderdıgımız veriyi queryString ile okuyoruz.
Verinin javascriptle nasıl yollandıgı sayfanın en alt kısmında bulabilirsiniz.
        protected override void Render(HtmlTextWriter writer)
        {
            Response.Clear();
            Response.ContentType = "text/xml";
            string entityID = Request.QueryString["entityid"];
            Session["entityid"] = entityID;// entity id yi postback olsa da kullanabiliyoruz.Sayfa kapanana kadar session da saklayıp ,istediğimiz zaman kullanabiliriz.
            if (!string.IsNullOrEmpty(entityID))
            {
                CanceledInvoice();
            }
            else
            {
                Response.Redirect("../ErrorPage.aspx");
//entity id javascript ile gönderilemezse hata sayfasına yonlendırıyoruz.
            }
        }
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
            }
        }
        private void CanceledInvoice()
        {
            string invoiceId = (string)Session["entityid"];
            Guid _invoiceId = Guid.Empty;

            if (!string.IsNullOrEmpty(invoiceId))
                _invoiceId = Guid.Parse(invoiceId);
            if (_invoiceId != Guid.Empty)
            {
//Crm e baglanıyoruz.
                crmService = DynamicCrmConnection.GetCrmService();
                if (crmService != null)
                {
                    Invoice invoice = (Invoice)crmService.Retrieve("invoice", invoice.Id, new ColumnSet() { AllColumns=true});
                    if (invoice != null && invoice.Id != Guid.Empty)
                    {
                        if (invoice.StateCode ==InvoiceState.Active)
                        {//invoice active se cancel edilebilir.
                            try
                            {
//SetStateRequest ile invoice un id si ve logical name ini vererek cancel edebiliyoruz.
//Statecode=3 invoice formunun canceled oldugunu gosterir.
//Status  =100003 de canceled formunun bir durumudur.
                                SetStateRequest setStateRequest = new SetStateRequest()
                                {
                                    EntityMoniker = new EntityReference
                                    {
                                        Id = invoice.Id,
                                        LogicalName = "invoice"
                                    },
                                    State = new OptionSetValue(3),// inactive
                                    Status = new OptionSetValue(100003)// qualified
                                };
                                crmService.Execute(setStateRequest); 
                            }
                            catch (Exception)
                            {
//Hata alınmazsa invoice canceled olmus demektir.  
                            }
                        }
                    }
                }
            }
        }
    }
}

Javascript

function CanceledInvoice() {

    var entityid = Xrm.Page.data.entity.getId();
/*invoice  formunun id si alınır ve XML.Dom kullanılarak aspx sayfasına veri gönderilir ve geriye veri okunur.*/
    var xmldoc_sendApp = new ActiveXObject("Microsoft.XMLDOM");
    xmldoc_sendApp.async = false;
    xmldoc_sendApp.load("http://denemehost:8989/InvoiceInterface/InvoiceCanceled.aspx?entityid=" + entityid);
/*yukarıdakı url sayfanızı host ettiğiniz sayfanın adresidir.Ben IIS teki yolunu verdim.8989 ise sayfanın bulundugu hostdakı port numarasıdır.*/
    var logMessage = xmldoc_sendApp.selectSingleNode("logmessage");
/*logmessage tagları arasında geriye veri gönderilir.*/
    if (logMessage != null) {
        if (logMessage.text != "") {
            alert(logMessage.text);
            window.location.reload();//Sayfa refresh olur.
        }
    }
}
Sorularınızı gkhnmnts@gmail adresine atabilirsiniz.