Skip to main content

D365 Calculate unitwise product quantity into Opportunity field using javascript

 

 function CalculateOpportunityProductQuantity(executionContext) {  
      var formContext = executionContext.getFormContext();  
      var opportunityRecordId = formContext.data.entity.getId().slice(1, -1);  
      var globalContext = Xrm.Utility.getGlobalContext();  
       // Retrive unitwise product quantity data  
   var fetchXml = "<fetch mapping='logical' >" +  
       "<entity name= 'opportunity' >"+  
           "<link-entity name='opportunityproduct' from='opportunityid' to='opportunityid' alias='opportunityprod' >"+  
           "<attribute name='quantity' />"+  
            "<filter>"+  
                "<condition attribute='opportunityid' operator= 'eq' value='" + opportunityRecordId + "' uiname='Will be ordering' uitype='opportunity' />"+  
            "</filter>"+  
            "<link-entity name='uom' from='uomid' to='uomid' alias='unitdata' >"+  
                "<attribute name='name' />"+                 
                "<attribute name='uomid' />"+  
                "<order attribute='name' />"+  
            "</link-entity>"+  
           "</link-entity>"+  
       "</entity>"+  
      "</fetch>";  
      fetchXml = "?fetchXml=" + encodeURIComponent(fetchXml);  
           Xrm.WebApi.retrieveMultipleRecords("opportunity", fetchXml).then(  
                     function success(response) {  
                          // Odata response value set into a json array  
                          unitwisequantitys = [];  
                           for (var i = 0; i < response.entities.length; i++) {                                            
                               unititem = {}  
                               unititem ["unitname"] = response.entities[i]["unitdata.name"];  
                               unititem ["quantity"] = response.entities[i]["opportunityprod.quantity"];  
                               unitwisequantitys.push(unititem);  
                          }    
                          // Quantity sum Group by Unitname                            
                          var helper = {};  
                          var groupbyunit = unitwisequantitys.reduce(function(r, o) {  
                           var key = o.unitname;  
                           if(!helper[key]) {  
                               helper[key] = Object.assign({}, o); // create a copy of o  
                               r.push(helper[key]);  
                           } else {  
                               helper[key].quantity += o.quantity;                            
                           }  
                           return r;  
                          }, []);  
                          // Get specific unit name quantity   
                          let maunitquantity = groupbyunit.find(o => o.unitname === 'MA');  
                          let qaunitquantity = groupbyunit.find(o => o.unitname === 'qm');  
                          // Set the quantity value   
                          formContext.getAttribute("qm_quantity").setValue(qaunitquantity.quantity);  
                          formContext.getAttribute("ma_quantity").setValue(maunitquantity.quantity);  
                     },  
                     function (error) {  
                          console.log(error.message);                            
                     }  
           );                 
 }  


Comments

Popular posts from this blog

The calling thread must be STA, because many UI components require this.

Using Thread: // Create a thread Thread newWindowThread = new Thread(new ThreadStart(() => { // You can use your code // Create and show the Window FaxImageLoad obj = new FaxImageLoad(destination); obj.Show(); // Start the Dispatcher Processing System.Windows.Threading.Dispatcher.Run(); })); // Set the apartment state newWindowThread.SetApartmentState(ApartmentState.STA); // Make the thread a background thread newWindowThread.IsBackground = true; // Start the thread newWindowThread.Start(); Using Task and Thread: // Creating Task Pool, Each task will work asyn and as an indivisual thread component Task[] tasks = new Task[3]; // Control drug data disc UI load optimize tasks[0] = Task.Run(() => { //This will handle the ui thread :The calling thread must be STA, because many U...

An error occurred while updating the entries. See the inner exception for details.

If you are using EF then you may get the error. This error is not specify where the error exactly occur in your table. To specify the error use this code & use debugger to see the exact error message. try { //Your code db = new FEDALIC_AGRI_DBEntities (); model.FarmerVillage = new Guid(village); model.FarmerThana = new Guid(thana); model.FarmerDistrict = new Guid(district); var _SET_FARMER_INFO = EMFermar.SetToModelObject(model); db.SET_FARMER_INFO.Add(_SET_FARMER_INFO); db.SaveChanges(); } catch (DbUpdateException e) { var innerEx = e.InnerException; while (innerEx.InnerException != null) innerEx = innerEx.InnerException; throw new Exception(innerEx.Message); } catch (DbEntityValidationException e...

SQL Query Execution time of you in SQL Management Studio

You can check the Execution time of you SQL Query in SQL Management Studio. like this It is very simple that you just put your SQL Query in to the Estimated time execution query DECLARE @StartTime datetime DECLARE @EndTime datetime SELECT @StartTime=GETDATE() -- Write Your Query SELECT @EndTime=GETDATE() --This will return execution time of your query SELECT DATEDIFF(NS,@StartTime,@EndTime) AS [Duration in millisecs]