SAP Addon SDK Syntax Help Cheat Sheet

 ---------------------------to Click on Matrix specific row Start--------------------

__mtrx.Columns.Item("V_3").Cells.Item(pVal.Row).Click(BoCellClickType.ct_Regular);


---------------------------to Click on Matrix specific row END--------------------

-------------------------disable/enable specific cell on the matrix Start-------------------

oMatrix.CommonSetting.SetCellEditable(Row number, Column Number , false);

----------------------disable/enable specific cell on the matrix END-----------------------


----------------------disable/enable specific Column on the matrix Start--------------------

oMatrix.Columns.Item("U_CIN_QTYINKG").Editable=false;

-----------------------disable/enable specific Column on the matrix END----------------------


--------------------Recordset Entry value getting and converting to string Start-------------------

Convert.ToString(oRecoEntry.Fields.Item(0).Value);

--------------------Recordset Entry value getting and converting to string end-------------------

--------------------wRITING QUERY WITH NEWLINE AND RECORDSET START-----------------------

 string serialNo_query = Environment.NewLine + "    Select Row_Number() over (order By  IntrSerial)[RowNo],T0.SysSerial,T1.MnfSerial, IntrSerial                    "

                                   + Environment.NewLine + "   into #a from OSRI T0                                                "

                                   + Environment.NewLine + "     Inner Join OSRN T1 on T0.ItemCode=T1.ItemCode and T0.SysSerial=T1.SysNumber   "

                                   + Environment.NewLine + "     Where T0.ExpDate is null and T0.ItemCode='" + ItemCode + "' and WhsCode='" + WarehouseCode + "' and T0.Status=0 "

                                   + Environment.NewLine + "     Order By SysSerial "

                                   + Environment.NewLine + "     Select * from #a Where RowNo<='" + Quantity + "' "

                                   + Environment.NewLine + "     Drop Table #a";

            SAPbobsCOM.Recordset oReco_Sr = ClsQC_SBOAddOn.SBOCompany.GetBusinessObject(SAPbobsCOM.BoObjectTypes.BoRecordset) as SAPbobsCOM.Recordset;

            oReco_Sr.DoQuery(serialNo_query);

            int recCount = oReco_Sr.RecordCount;

--------------------wRITING QUERY WITH NEWLINE AND RECORDSET end---------------------------

-------------------------------------------

SAPbobsCOM.BoUTBTableType.bott_Document

-------------------------------------------

-----------SETTING FOCUS ON PERTICULAR ITEM START---------------------------

Form.Items.Item("etFocus").Click(SAPbouiCOM.BoCellClickType.ct_Regular)

-----------SETTING FOCUS ON PERTICULAR ITEM END---------------------------


------------------------- select and delete a row in the system Matrix START------------------------------------------


do the following


'SELECT ROW

oMatrix.Columns.Item(0).Cells.Item(row2delete).Click(SAPbouiCOM.BoCellClickType.ct_Regular, SAPbouiCOM.BoModifiersEnum.mt_CTRL)


'CALL CLICK

oMatrix.Columns.Item(1).Cells.Item(row2delete).Click()


'DELETE ROW same as CTRL +  K

oApplication.Menus.Item("1293").Activate() 

------------------------- select and delete a row in the system Matrix END-----------------------------------------

--------------------------GETTING MATRIX COLUMN CELL VALUE AND SETTING TO STRING VARIABLE START------------------------------------------------

 string MParty = (oMatrix.Columns.Item("PRTY").Cells.Item(v).Specific as SAPbouiCOM.EditText).Value.ToString();

--------------------------GETTING MATRIX COLUMN CELL VALUE AND SETTING TO STRING VARIABLE END----------------------------------------------------------


--------------------------SETTING MATRIX COLUMN CELLS VALUE FROM VARIABLE START------------------------------------------


  ((SAPbouiCOM.EditText)oMatrix.Columns.Item("BQTY").Cells.Item(J).Specific).Value = BQty;

  

--------------------------SETTING MATRIX COLUMN CELLS VALUE FROM VARIABLE END------------------------------------------

------------------------------Setting Combo box value Start------------------------------------------

     (__form__.Items.Item("10").Specific as SAPbouiCOM.ComboBox).Select("R", BoSearchKey.psk_ByValue);

------------------------------Setting Combo box value END------------------------------------------

------------------------------Release Recordset component start---------------------------------------------

System.Runtime.InteropServices.Marshal.ReleaseComObject(oRecord);

------------------------------Release Recordset component End---------------------------------------------

------------------------------Making Right Click disable on specific case Start----------------------------

protected override void RIGHT_CLICK_BEFOREACTION(ref ContextMenuInfo eventInfo, out bool BubbleEvent)

        {

            BubbleEvent = true;

            if ((eventInfo.ItemUID == "edtx" || eventInfo.ItemUID == "12" || eventInfo.ItemUID == "78" || eventInfo.ItemUID == "255000122") && (__form__.Mode == BoFormMode.fm_OK_MODE || __form__.Mode == BoFormMode.fm_UPDATE_MODE))

            {

                 BubbleEvent = false;

                 ClsQC_SBOAddOn.SBOApplication.SetStatusBarMessage("RightClick not allowed ", SAPbouiCOM.BoMessageTime.bmt_Short, false);

                 return;

            }

            if (eventInfo.ItemUID == "37" && eventInfo.ColUID == "14")

            {

                 BubbleEvent = false;

                 ClsQC_SBOAddOn.SBOApplication.SetStatusBarMessage("RightClick not allowed ", SAPbouiCOM.BoMessageTime.bmt_Short, false);

                 return;

            }

        }

------------------------------Making Right Click disable on specific case END----------------------------

-------------------------Syntax to Activate menu Start------------------------------------------------


ClsQC_SBOAddOn.SBOApplication.ActivateMenuItem("1304");


-------------------------Syntax to Activate menu Start------------------------------------------------

-------------------------READING AND PARSING VALUE TYPE START------------------------------------------------

 string Planned = __OWOR.GetValue("PlannedQty", 0).Trim();

                            string Total = Convert.ToString(oRecord.Fields.Item(0).Value);

                            decimal pl = 0, to = 0;

                            decimal.TryParse(Planned, out pl);

                            decimal.TryParse(Total, out to);

                            if (to < pl)

                            {


                            }

-------------------------READING AND PARSING VALUE TYPE END------------------------------------------------

------------------------- GETTING LAST ADDED DOCENTRY FROM SYSTEM FORM START-------------------------------------------------------------

string  name;

        protected override void etoForm_DATA_ADDAfterAction(ref BusinessObjectInfo BusinessObjectInfo, out bool BubbleEvent)

        {

            BubbleEvent = true;

            string SerialNumber = (__form__.Items.Item("edtx").Specific as SAPbouiCOM.EditText).Value.ToString();

            if (BusinessObjectInfo.ActionSuccess == true)

            {

                var document = System.Xml.Linq.XDocument.Parse(BusinessObjectInfo.ObjectKey);

                 name = document.Element("ProductionOrderParams").Element("AbsoluteEntry").Value.ToString();


                 

                 if (CheckProductionStage(name))

                 {

                     try

                     {

                         string Query = "Update OWOR Set U_CINN_3SPD='" + name + "'  Where DocEntry in ('" + pdNo + "','" + pd2STNo + "')";

                        SAPbobsCOM.Recordset oRecordset;

                        oRecordset = (SAPbobsCOM.Recordset)ClsQC_SBOAddOn.SBOCompany.GetBusinessObject(SAPbobsCOM.BoObjectTypes.BoRecordset);

                        oRecordset.DoQuery(Query);

                     }

                     catch (Exception)

                     {

                         

                         throw;

                     }

                 }

                                               

            }

        }

------------------------- GETTING LAST ADDED DOCENTRY FROM SYSTEM FORM END-------------------------------------------------------------

--------------------------ADDING FORM ITEM VIA CODE START-----------------------------------------------------------------------

oItem = __form__.Items.Item("255000113");

            SAPbouiCOM.Item oNewItemxlnk = __form__.Items.Add("lnk1", SAPbouiCOM.BoFormItemTypes.it_LINKED_BUTTON);

            oNewItemxlnk.Left = oItem.Left;

            oNewItemxlnk.Width = oItem.Width;

            oNewItemxlnk.Top = oItem.Top + 19;

            oNewItemxlnk.Height = oItem.Height;

            SAPbouiCOM.LinkedButton lnk = (SAPbouiCOM.LinkedButton)oNewItemxlnk.Specific;

            lnk.LinkedObjectType = "22";

            lnk.LinkedObject = BoLinkedObject.lf_PurchaseOrder;

            lnk.Item.LinkTo = "txt8";

            oNewItemxlnk.Visible = true;

--------------------------ADDING FORM ITEM VIA CODE END-----------------------------------------------------------------------

--------------------------INITIALIZING OBJECT ON FORM LOAD  START--------------------------------------------------------------------------

   this.__form__ = ClsQC_SBOAddOn.SBOApplication.Forms.GetForm(pVal.FormTypeEx, pVal.FormTypeCount);

                    this.__OWOR = this.__form__.DataSources.DBDataSources.Add("OWOR");

                    this.__WOR1 = this.__form__.DataSources.DBDataSources.Add("WOR1");

                    this.__matrix__ = this.__form__.Items.Item("37").Specific as SAPbouiCOM.Matrix;

                    SAPbouiCOM.Item oItem = __form__.Items.Item("234000002");

--------------------------INITIALIZING OBJECT ON FORM LOAD  END--------------------------------------------------------------------------


--------------------------ADDING FORM ITEM COMBO BOX AND FILLING WITH QUERY RESULT START---------------------------------------------------------------------------

oItem = __form__.Items.Item("edtx");

                    oNewItemx = __form__.Items.Add("comb1", SAPbouiCOM.BoFormItemTypes.it_COMBO_BOX);

                    oNewItemx.Left = oItem.Left;

                    oNewItemx.Width = oItem.Width;

                    oNewItemx.Top = oItem.Top+17;

                    oNewItemx.Height = oItem.Height;

                    SAPbouiCOM.ComboBox comb = (SAPbouiCOM.ComboBox)oNewItemx.Specific;

                    comb.Item.LinkTo = "comb";

                    comb.DataBind.SetBound(true, "OWOR", "U_CINN_WORK");

                    comb.ExpandType = BoExpandType.et_DescriptionOnly;

                    comb.Item.DisplayDesc = true;

                    ClsQC_SBOAddOn.FillCombo(ref comb, "   SELECT Code, ISNULL(Name,'')+ISNULL('-'+CAST(U_CNN_NAME AS VARCHAR),'')+ISNULL('-'+CAST(U_CNN_CNTRNM AS VARCHAR),'') AS U_CNN_NAME FROM \"@CNN_WORKER\"  ");

--------------------------ADDING FORM ITEM COMBO BOX AND FILLING WITH QUERY RESULT END---------------------------------------------------------------------------

---------------------------fORCEFULLY BINDING VALUE IN MATRIX COMBO BOX WITH QUERY VALUE START-------------------------------------------------------------------------

SAPbouiCOM.ComboBox _cmbDr = (SAPbouiCOM.ComboBox)_mtrx.Columns.Item("U_CINN_DRMAN").Cells.Item(1).Specific;

                    _cmbDr.Item.DisplayDesc = true;

                    _cmbDr.ExpandType = BoExpandType.et_DescriptionOnly;

                    string sSQL = "Select empID,CONCAT(FirstName,' ',LastName)[Name] from OHEM Where Dept='3' ";

                    SAPbobsCOM.Recordset businessObject = (SAPbobsCOM.Recordset)ClsQC_SBOAddOn.SBOCompany.GetBusinessObject(BoObjectTypes.BoRecordset);

                    businessObject.DoQuery(sSQL);

                    businessObject.MoveFirst();

                    while (!businessObject.EoF)

                    {

                        _cmbDr.ValidValues.Add(businessObject.Fields.Item((object)0).Value.ToString(), businessObject.Fields.Item((object)1).Value.ToString());

                        businessObject.MoveNext();

                    }

                    Marshal.ReleaseComObject((object)businessObject);

---------------------------fORCEFULLY BINDING VALUE IN MATRIX COMBO BOX WITH QUERY VALUE END-------------------------------------------------------------------------

---------------------------- checking duplicate value in matrix Start----------------------------------------------------------------------

 #region CHECK DUPLICATE VALUE IN MATRIX


        public bool CheckDuplicateMatrixValue(SAPbouiCOM.Matrix oMatrix, string oColumnNo)

        {

            bool oFlag = false;

            for (int i = 1; i <= oMatrix.RowCount; i++)

            {

                string oNewValue = ((SAPbouiCOM.EditText)oMatrix.Columns.Item(oColumnNo).Cells.Item(i).Specific).String;

                for (int j = 1; j < oMatrix.RowCount; j++)

                {

                    if (i != j)

                    {

                        string oOldValue = ((SAPbouiCOM.EditText)oMatrix.Columns.Item(oColumnNo).Cells.Item(j).Specific).String;

                        if (oNewValue == oOldValue)

                        {

                            oFlag = true;

                            break;

                        }

                    }

                }

            }

            return oFlag;

        }


        #endregion

---------------------------- checking duplicate value in matrix End----------------------------------------------------------------------

-----------------------------setting line number on matrix  Start-----------------------------------------------------------------------------------------------------------

        public void LineNumber()

        {

            for (int i = 1; i <= __mtrx.VisualRowCount; i++)

            {

                (__mtrx.Columns.Item("V_-1").Cells.Item(i).Specific as SAPbouiCOM.EditText).Value = i.ToString();

            }

        }

-----------------------------setting line number on matrix  End-----------------------------------------------------------------------------------------------------------

--------------------------------------------------------------------------------------------------

 if (oRecoEntry.RecordCount > 0)

            {

               

                int i = 1;

                while(!oRecoEntry.EoF)

                {

                   // __mtrx.FlushToDataSource();

                   // _MSR1.SetValue("LineID", i, (i + 1).ToString());

                   // _MSR1.SetValue("U_CNN_S1ISRNO", i, Convert.ToString(oRecoEntry.Fields.Item(0).Value));

                    //_MSR1.SetValue("CNN_S1ISRNO", i, Convert.ToString(oRecoEntry.Fields.Item(0).Value));

                    __mtrx.AddRow(1, i);

                    ((IEditText)this.__mtrx.Columns.Item((object)"V_-1").Cells.Item((object)i).Specific).Value = i.ToString();

                    ((IEditText)this.__mtrx.Columns.Item((object)"V_3").Cells.Item((object)i).Specific).Value = Convert.ToString(oRecoEntry.Fields.Item(0).Value);

                    i++;

                   

                    oRecoEntry.MoveNext();

                   


                }



            }

----------------------------------------------------------------------------------------------------

--------------------------------validation for Not adding with no row detail Start--------------------------------------------------------------------

if (pVal.ItemUID == "1" && (oForm.Mode == SAPbouiCOM.BoFormMode.fm_ADD_MODE || oForm.Mode == SAPbouiCOM.BoFormMode.fm_UPDATE_MODE))

                {


                    oMatrix.FlushToDataSource();


                    if (ODBDetail.Size == 0 || String.IsNullOrEmpty(ODBDetail.GetValue("U_ITMCD", 0).Trim()))

                    {


                        ClsSBOAddOn.ShowErrorMessage("Document cannot be added Without Details");


                        BubbleEvent = false;

                        

                        return;

                    }


                }

--------------------------------validation for Not adding with no row detail end--------------------------------------------------------------------

-------------------------------------------------------------------------------------------------------

if (pVal.ItemUID == "btnImport" && oForm.Mode == SAPbouiCOM.BoFormMode.fm_ADD_MODE)

                {

                    if (dt.Rows.Count > 0)

                    {

                        Regex regex = new Regex(@"^[0-9]\d*(\.\d+)?$");

                        ClsSBOAddOn.ShowWarningMessage("Please wait Data refreshing....");

                        int J = 1;


                        for (int i = 0; i < dt.Rows.Count; i++)

                        {

                            oMatrix.AddRow(1, i);

                           // ((SAPbouiCOM.EditText)oMatrix.Columns.Item("SNO").Cells.Item(J).Specific).Value = dt.Rows[i][0].ToString().Trim();

                            if (this.CheckDepotExist(dt.Rows[i][1].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("DEPT").Cells.Item(J).Specific).Value = dt.Rows[i][1].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Depot/Godown Code not exist in system for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (this.CheckMonthMatch(dt.Rows[i][2].ToString().Trim(), ODBmaster.GetValue("U_MONTH", 0).ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("DATE").Cells.Item(J).Specific).Value = dt.Rows[i][2].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Form Month and Sheet Month not match for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (this.CheckPartyExist(dt.Rows[i][3].ToString().Trim()))

                            {


                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("PRTY").Cells.Item(J).Specific).Value = dt.Rows[i][3].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("PartyCode not exist in system for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (this.CheckItemExist(dt.Rows[i][4].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("ItemCode").Cells.Item(J).Specific).Value = dt.Rows[i][4].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Itemcode not exist in system for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            ((SAPbouiCOM.EditText)oMatrix.Columns.Item("Itmnm").Cells.Item(J).Specific).Value = dt.Rows[i][5].ToString().Trim();

                            ((SAPbouiCOM.EditText)oMatrix.Columns.Item("BRND").Cells.Item(J).Specific).Value = dt.Rows[i][6].ToString().Trim();

                            ((SAPbouiCOM.EditText)oMatrix.Columns.Item("PLC").Cells.Item(J).Specific).Value = dt.Rows[i][8].ToString().Trim();

                            ((SAPbouiCOM.EditText)oMatrix.Columns.Item("SIZE").Cells.Item(J).Specific).Value = dt.Rows[i][7].ToString().Trim();

                            ((SAPbouiCOM.EditText)oMatrix.Columns.Item("OWN").Cells.Item(J).Specific).Value = dt.Rows[i][9].ToString().Trim();

                            if (regex.IsMatch(dt.Rows[i][10].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("SQTY").Cells.Item(J).Specific).Value = dt.Rows[i][10].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Sales Quantity is not valid format for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (regex.IsMatch(dt.Rows[i][11].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("BQTY").Cells.Item(J).Specific).Value = dt.Rows[i][11].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Sales Quantity in Btl is not in valid format for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (regex.IsMatch(dt.Rows[i][12].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("CQTY").Cells.Item(J).Specific).Value = dt.Rows[i][12].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Quantity of closing in case is not in valid format for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (regex.IsMatch(dt.Rows[i][13].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("CBQTY").Cells.Item(J).Specific).Value = dt.Rows[i][13].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Quantity of closing in Btl is not in valid format for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (regex.IsMatch(dt.Rows[i][14].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("TCQTY").Cells.Item(J).Specific).Value = dt.Rows[i][14].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Total Quantity In case is not in valid format for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            if (regex.IsMatch(dt.Rows[i][15].ToString().Trim()))

                            {

                                ((SAPbouiCOM.EditText)oMatrix.Columns.Item("TBQTY").Cells.Item(J).Specific).Value = dt.Rows[i][15].ToString().Trim();

                            }

                            else

                            {

                                ClsSBOAddOn.ShowErrorMessage("Total Quantity In Btl is not in valid format for import Sheet S.No " + dt.Rows[i][0].ToString().Trim());

                                oMatrix.DeleteRow(J);

                                BubbleEvent = false;

                                return;

                            }

                            oMatrix.AutoResizeColumns();

                            J++;

                        }

                        ClsSBOAddOn.ShowSucessMessage("Data Refresh Successfully");

                    }

                }

---------------------------------------------------------------------------------------------------------

----------------------------GRID making assigning datatable Start----------------------------------------------

 _Grd = (SAPbouiCOM.Grid)oform.Items.Item("3").Specific;

            oform.DataSources.DataTables.Add("MyDataTable");

            oform.DataSources.DataTables.Item(0).ExecuteQuery(Query);

            _Grd.DataTable = oform.DataSources.DataTables.Item("MyDataTable");

            _Grd.SelectionMode = BoMatrixSelect.ms_Auto;

            _Grd.Columns.Item("Select").Type = SAPbouiCOM.BoGridColumnType.gct_CheckBox;

            _Grd.Columns.Item("Image").Type = SAPbouiCOM.BoGridColumnType.gct_Picture;

            _Grd.Columns.Item("Serial Number").Editable     = false;

            _Grd.Columns.Item("ItemCode").Editable          = false;

            _Grd.Columns.Item("ItemName").Editable          = false;

            _Grd.Columns.Item("DocNum").Editable            = false;

            _Grd.Columns.Item("Posting Date").Editable      = false;

            _Grd.Columns.Item("BarCode").Visible           = false;

            _Grd.Columns.Item("Image").Editable = false;

            _Grd.AutoResizeColumns();

----------------------------GRID making assigning datatable END----------------------------------------------

----------------------------Working on checkbox  on start------------------

if (pVal.ItemUID == "cSelect")

            {

                string CheckValue = oform.DataSources.UserDataSources.Item("cSelect").Value;

                if (CheckValue == "Y")

                {

                    for (int i = 0; i < _Grd.Rows.Count; i++)

                    {


                        ((SAPbouiCOM.CheckBoxColumn)_Grd.Columns.Item("Select")).Check(i, true);


                    }

                }

                else

                {

                    for (int i = 0; i < _Grd.Rows.Count; i++)

                    {


                        ((SAPbouiCOM.CheckBoxColumn)_Grd.Columns.Item("Select")).Check(i, false);


                    }

                }


            }

------------------------Working on checkbox end------------------

------------------Choose from List After Action Start--------------------

 protected override void CHOOSE_FROM_LIST_AFTERACTION(ref SAPbouiCOM.ItemEvent pVal, SAPbouiCOM.DataTable oDataTable, out bool BubbleEvent)

        {

            BubbleEvent = true;

            try

            {

                oForm.Freeze(true);

                                SAPbouiCOM.ChooseFromListEvent cflevent = (SAPbouiCOM.ChooseFromListEvent)pVal;

                                SAPbouiCOM.ChooseFromList oCFLEvento = default(SAPbouiCOM.ChooseFromList);

                                string strUid = cflevent.ChooseFromListUID;

                                oCFLEvento = this.oForm.ChooseFromLists.Item(strUid);

                                //SAPbouiCOM.DataTable oDataTable = cflevent.SelectedObjects;

                                _chooseFromListItem = (SAPbouiCOM.IChooseFromListEvent)pVal;

                                if (_chooseFromListItem.SelectedObjects != null && oForm.Mode != SAPbouiCOM.BoFormMode.fm_FIND_MODE)

                                {

                                    {

                                        if (pVal.ItemUID == "mkt_PL1" && pVal.ColUID=="V_8")

                                        {

                                            try

                                            {

                                                //((SAPbouiCOM.EditText)oForm.Items.Item("etTech").Specific).Value = _chooseFromListItem.SelectedObjects.GetValue("firstName", 0).ToString().Trim();

                                                ODBDetail.SetValue("U_CNAME", pVal.Row - 1, _chooseFromListItem.SelectedObjects.GetValue("CardName", 0).ToString().Trim());

                                            }

                                            catch

                                            { }

                                            finally

                                            {

                                                //((SAPbouiCOM.EditText)oForm.Items.Item("etTech").Specific).Value = _chooseFromListItem.SelectedObjects.GetValue("firstName", 0).ToString().Trim();

                                            }

                                        }

                                    }

                                }

                                oForm.Freeze(false);


            }

            catch (Exception ex)

            {

                oForm.Freeze(false);

                clsUIGeneric.CreateErrorlog(ClsSBOAddOn.SBOCompany.UserName.Trim(), "Namespace:PriceList,class:PL1,Function:CHOOSE_FROM_LIST_BEFOREACTION,Error" + ex.Message, DateTime.Now, clsUIGeneric.strErrorLogFilePath);

            }

        }


------------------Choose from List After Action End------------------------

 #region ADD COLUMNS IN MATRIX

        public void AddControls()

        {

            SAPbouiCOM.Column oCol;


            SAPbouiCOM.ProgressBar oProgressBar = null;


            try

            {

                string col = "";

                string field;

                string caption = "";


                oProgressBar = Utilities.Application.SBO_Application.StatusBar.CreateProgressBar("Creating columns...Please wait.", 50, false);

                oProgressBar.Value = 1;


                for (int i = 10; i <= 209; i++)

                {

                    field = "U_ObsvVal" + (i - 9).ToString().Trim();

                    caption = "Observed Value " + (i - 9);


                    col = i.ToString();

                    _mtMatrix.Columns.Add(col, SAPbouiCOM.BoFormItemTypes.it_EDIT);

                    _mtMatrix.Columns.Item(col).Visible = false;

                    _mtMatrix.Columns.Item(col).TitleObject.Caption = caption;

                    oCol = _mtMatrix.Columns.Item(col);

                    oCol.DataBind.SetBound(true, "@KBR_QltyChk1", field);

                }


                oProgressBar.Stop();

            }

            catch (Exception)

            {


                throw;

            }

        }

        #endregion


-----------------------Sql usefull function Start-----------------------------------------------------

 

  STRING_SPLIT--used to split Value separated by any specified character

STRING_AGG--used to concat column value in one cell separeted by specific character


DECLARE @tags NVARCHAR(400) = 'clothing,road,,touring,bike'  

  

SELECT value  

FROM STRING_SPLIT(@tags, ',')  

WHERE RTRIM(value) <> ''


--ALTER DATABASE Intex_190520

--SET COMPATIBILITY_LEVEL = 150 -- For SQL Server 2019

--GO

-----------------------Sql usefull function Start End---------------------------------------------------------------

  

 --------------------------HANA Connection String pattern Start----------------------------

 Driver={HDBODBC32};UID=B1ADMIN;PWD=Cinntra#@123;ServerNode=103.118.16.158:31115;CS=ADSTESTDB


Driver={HDBODBC32};UID=B1ADMIN;PWD=Cinntra@123;ServerNode=103.138.188.143:31115;CS=ADSTESTDB

 --------------------------HANA Connection String pattern END----------------------------

 Driver={HDBODBC32};UID=B1ADMIN;PWD=Cinntra#@123;ServerNode=103.118.16.158:30015;CS=ADSTESTDB


Driver={HDBODBC32};UID=B1ADMIN;PWD=Cinntra@123;ServerNode=103.138.188.143:31115;CS=ADSTESTDB


DRIVER={B1CRHPROXY32};SERVERNODE=103.118.16.158:30013;DATABASENAME=HDB;DATABASE=ADSTESTDB;UID=B1ADMIN;PWD=Cinntra#@123

DRIVER={B1CRHPROXY32};SERVERNODE=103.118.16.158:30013;DATABASENAME=HDB;DATABASE=ADSCRP;UID=B1ADMIN;PWD=Cinntra#@123


Driver={HDBODBC32};ServerNode=192.168.199.2:30015;CS=LIBRA;UID=B1ADMIN;PWD=Sap@273395


---------------------------------------------------------------------------------------



 Query = "Select Distinct \"U_FGSubItemGroup1\",\"U_Density\" from \"OITM\" Where \"U_Density\" is not null and \"U_Density\"<>1 and \"U_FGSubItemGroup1\"='MAGNUM' Order by \"U_FGSubItemGroup1\",\"U_Density\"";

                    ClsSBOAddOn.ExecuteSQL(ref oRecordset, Query);

                   

                    if (oRecordset.RecordCount > 0)

                    {

                        oRecordset.MoveFirst();

                        while (!oRecordset.EoF)

                        {

                            string FD = oRecordset.Fields.Item("U_FGSubItemGroup1").Value.ToString().Trim();

                            string fieldID = FD.Substring(0,3)+ Convert.ToString(oRecordset.Fields.Item("U_Density").Value);

                            string Descr = Convert.ToString(oRecordset.Fields.Item("U_FGSubItemGroup1").Value) + '-' + Convert.ToString(oRecordset.Fields.Item("U_Density").Value);

                            ClsDatabase.AddColumn("FPL1", fieldID, Descr, 50, SAPbobsCOM.BoFieldTypes.db_Float, SAPbobsCOM.BoFldSubTypes.st_Price, SAPbobsCOM.BoYesNoEnum.tNO, SAPbobsCOM.BoYesNoEnum.tNO);

                            

                            oRecordset.MoveNext();

                        }


                    }

--------------------------------------------------------------------------------------------

CREATE LOCAL TEMPORARY TABLE #FinalRecord(

             PartyCode Varchar(20),

             PartyName Varchar(200),

            PurcahseQty double,

            DebitQty double,

            OpnBal double,

            ItemAvgRate double,

            AmtPaid double

                     

);

Drop Table #FinalRecord;

------------------------------------------------------------------------------------------------

Update T0

Set T0."U_POEntry"=T1."U_POEntryT"

from "@CIN_OGAE" T0

Inner Join "@CIN_OGAE" T1 on T0."DocEntry"=T1."DocEntry"

-----------------------------------------------------------------------------------------------



------------------lOADING DATA IN MATRIX COLUMN ON FORM LOAD AT ADD MODE-----------------------

public void LoadDetails()

        {

            try 

            {

                if (State != "")

                {

                    this.oForm.Items.Item("etBEntry").Enabled = false;

                    ODBmaster.SetValue("U_BaseEntry", 0, BaseEntry);

                    int i = 1;

                    ORecordset = (SAPbobsCOM.Recordset)ClsSBOAddOn.SBOCompany.GetBusinessObject(SAPbobsCOM.BoObjectTypes.BoRecordset);

                    Query = "Select * from \"OITM\" where \"U_State\" = '" + State + "'";

                    ORecordset.DoQuery(Query);

                    ORecordset.MoveFirst();


                    if (ORecordset.RecordCount > 0)

                    {

                        ORecordset.MoveFirst();

                        while (!ORecordset.EoF)

                        {

                            oMatrix.AddRow();

                            oMatrix.Columns.Item("colBEntry").Cells.Item(i).Specific.Value = BaseEntry;

                            oMatrix.Columns.Item("SNO").Cells.Item(i).Specific.Value = i;

                            oMatrix.Columns.Item("ItemCode").Cells.Item(i).Specific.Value = ORecordset.Fields.Item("ItemCode").Value.ToString().Trim();

                            oMatrix.Columns.Item("Itmnm").Cells.Item(i).Specific.Value = ORecordset.Fields.Item("ItemName").Value.ToString().Trim();

                            oMatrix.Columns.Item("PCODE").Cells.Item(i).Specific.Value = PartyCode;

                            oMatrix.Columns.Item("STATE").Cells.Item(i).Specific.Value = State;

                            

                            i++;

                            ORecordset.MoveNext();

                        }

                    }

                    System.Runtime.InteropServices.Marshal.ReleaseComObject(ORecordset);

                }

            }

            catch (Exception ex)

            {

                oForm.Freeze(false);

                clsUIGeneric.CreateErrorlog(ClsSBOAddOn.SBOCompany.UserName.Trim(), "Namespace:SecondrySale,class:PartyMasterDetails,Function:LoadDetails,Error" + ex.Message, DateTime.Now, clsUIGeneric.strErrorLogFilePath);

            }

        }

-----------------------------------------------------------------------------------------------------------------

SAPbobsCOM.Recordset oReco = ClsSBOAddOn.SBOCompany.GetBusinessObject(SAPbobsCOM.BoObjectTypes.BoRecordset) as SAPbobsCOM.Recordset;

                       string Query_1 = "exec  CIN_BR_VMCVFT  '" + ((SAPbobsCOM.ICompany)ClsSBOAddOn.SBOApplication.Company.GetDICompany()).UserSignature + "','CINN_OSBS','E','0'";

                oReco.DoQuery(Query_1);

                if (oReco.RecordCount > 0)

                {

                    String list = oReco.Fields.Item(0).Value;

                    String[] separator = { ";" };

                    String[] strList = list.Split(separator,StringSplitOptions.RemoveEmptyEntries);

                    for (int i = 1; i < strList.Length; i++)

                    {

                        __mtrx.Columns.Item(strList[i]).Editable = false;

                       

                        string s = strList[i];

                       

                    }

                }

-------------------------------------------------------------------------------------------------------------------

 this.__form__.Mode = BoFormMode.fm_FIND_MODE;

                ((SAPbouiCOM.EditText)this.__form__.Items.Item("txtDocEt").Specific).Value = BarCodeEntry;

                this.__form__.Items.Item("1").Click(SAPbouiCOM.BoCellClickType.ct_Regular);

---------------------------------------------------------------------------------------------------------------------



        #region FillCombo

        private void FillCombo()

        {

            try

            {

               

                _sql = "Select \"SlpCode\",\"SlpName\" from \"OSLP\"";

                Utilities.FillCombo(ref _cmbDSCWise, _sql);

                //_cmbDSCWise.Select(0, SAPbouiCOM.BoSearchKey.psk_Index);


                _sql = "Select \"Code\",\"Name\" from \"@CIN_DROUTE\"";

                Utilities.FillCombo(ref _cmbDRoute, _sql);

                //_cmbDRoute.Select(0, SAPbouiCOM.BoSearchKey.psk_Index);


                _sql = "Select \"Code\",\"Name\" from \"@CIN_AREA\"";

                Utilities.FillCombo(ref _cmbAreaAA, _sql);

                // _cmbArea.Select(0, SAPbouiCOM.BoSearchKey.psk_Index);


           


                //_sql = @"select Series,SeriesName FROM NNM1 WHERE ObjectCode='CIN_UDO_QltyCheck' and Locked='N'";

                //Utilities.FillCombo(ref _cmbChanel, _sql);

                //_cmbChanel.Select(0, SAPbouiCOM.BoSearchKey.psk_Index);


                _sql = "Select \"BPLId\",\"BPLName\" from \"OBPL\" Where \"Disabled\"='N'";

                Utilities.FillCombo(ref _cmbBranch, _sql);

                //_cmbBranch.Select(0, SAPbouiCOM.BoSearchKey.psk_Index);


            }

            catch (Exception ex)

            {

                Utilities.ShowErrorMessage(ex.Message); 

               

            }


        }

---------------------------------------------------------------------------------------------------------


        #region Validation

        private bool Validation()

        {

            try

            {

                if (_Form.Mode == SAPbouiCOM.BoFormMode.fm_ADD_MODE)

                {

                    _mtMatrix.FlushToDataSource();


                    if (String.IsNullOrEmpty(_dbDataSourceMaster.GetValue("U_CWISE", 0).ToString().Trim()))

                    {

                        Utilities.ShowErrorMessage("Please enter Comapny Wise.");

                        return false;

                    }

                    if (String.IsNullOrEmpty(_dbDataSourceMaster.GetValue("U_PLCDATE", 0).ToString().Trim()))

                    {

                        Utilities.ShowErrorMessage("Please enter Pick List Create Date.");

                        return false;

                    }


                    if (String.IsNullOrEmpty(_dbDataSourceMaster.GetValue("U_PLDDATE", 0).ToString().Trim()))

                    {

                        Utilities.ShowErrorMessage("Please enter Pick List Delivery Date.");

                        return false;

                    }


                    if (String.IsNullOrEmpty(_dbDataSourceMaster.GetValue("U_CHANNEL", 0).ToString().Trim()))

                    {

                        Utilities.ShowErrorMessage("Please Select Channel.");

                        return false;

                    }


                    if (String.IsNullOrEmpty(_dbDataSourceMaster.GetValue("U_BPLID", 0).ToString().Trim()))

                    {

                        Utilities.ShowErrorMessage("Please select Branch.");

                        return false;

                    }


                    if (String.IsNullOrEmpty(_dbDataSourceMaster.GetValue("U_WAREHOUSE", 0).ToString().Trim()))

                    {

                        Utilities.ShowErrorMessage("Please select Warehouse.");

                        return false;

                    }


                    if (_dbDataSourceChild.Size == 0)

                    {

                        Utilities.ShowErrorMessage("Order Item details Not available, cannot add transaction.");

                        return false;

                    }


                    for (int i = 0; i <= _dbDataSourceChild.Size - 1; i++)

                    {

                        string SoDocEntry = _dbDataSourceChild.GetValue("U_SODOCENTRY", i).ToString().Trim();

                        string Itemcode=_dbDataSourceChild.GetValue("U_ItemCode",i).ToString().Trim();

                        string Quantity = _dbDataSourceChild.GetValue("U_QTY", i).ToString().Trim();

                        string SODocNum = _dbDataSourceChild.GetValue("U_SODOCNUM", i).ToString().Trim();

                        if (Constants.ServerType == SAPbobsCOM.BoDataServerTypes.dst_HANADB)

                        {

                            _sql = @"call TK_DIPL_GetValidate('" + SoDocEntry + "','" + Itemcode + "','" + Quantity + "')";

                        }

                        else

                        {

                            _sql = @"Exec TK_DIPL_GetValidate('" + SoDocEntry + "','" + Itemcode + "','" + Quantity + "')";

                          

                        }

                        Utilities.ExecuteSQL(ref _recordSet, _sql);

                        string status = String.Empty;

                        if (_recordSet.RecordCount >0)

                        {

                            Utilities.ShowErrorMessage("Pick List for SO DocNum:" + SODocNum + " ItemCode:" + Itemcode + " already created,Create invoice for it");

                            return false;

                        }


                    }

                    _mtMatrix.LoadFromDataSource();

                }

                return true;

            }

            catch (Exception ex)

            {


                return false;

            }


        }


        #endregion

=--------------------------------------------------------------------------------------------==========

        #region SetValue

        private void SetValue()

        {

            _flag = false;

            username = Utilities.Application.SBO_Application.Company.UserName;

            //DateTime dt = Utilities.TodayDate();

            //string sdate = dt.ToString("yyyyMMdd");


            _sql = "Select \"Series\",\"SeriesName\" FROM \"NNM1\" WHERE \"ObjectCode\"='CIN_OPKL' and \"Locked\"='N'";

            Utilities.ExecuteSQL(ref _recordSet, _sql);

            if (_recordSet.RecordCount > 0)

            {

                _Series = Convert.ToString(_recordSet.Fields.Item(0).Value);


            }

            _dbDataSourceMaster.SetValue("DocNum", 0, _Form.BusinessObject.GetNextSerialNumber(_Series, "CIN_OPKL").ToString());

        }

        #endregion

---------------------------------------------------------------------------------------------------------------------------------------

        #region EnableDisable


        private void EnableDisable(bool status)

        {

            

            _Form.Items.Item("etRemarks").Click(SAPbouiCOM.BoCellClickType.ct_Regular);

            if (_Form.Mode == SAPbouiCOM.BoFormMode.fm_ADD_MODE)

            {

                _Form.Items.Item("etCWise").Enabled = true;

                _Form.Items.Item("CmbDRoute").Enabled = true;

                _Form.Items.Item("Item_21").Enabled = true;

                _Form.Items.Item("TDATE").Enabled = true;

                _Form.Items.Item("FDATE").Enabled = true;

                _Form.Items.Item("cmbDSC").Enabled = true;

                _Form.Items.Item("CmbArea").Enabled = true;

                _Form.Items.Item("Item_18").Enabled = true;

                _Form.Items.Item("DocNum").Enabled = false;

                _Form.Items.Item("cmbBranch").Enabled = true;

                _Form.Items.Item("etWhs").Enabled = true;

                _Form.Items.Item("cmbChanel").Enabled = true;

                _Form.Items.Item("Item_12").Enabled = true;

                _Form.Items.Item("Item_6").Enabled = false;

                _Form.Items.Item("Item_10").Enabled = false;

             

            }

            if (_Form.Mode == SAPbouiCOM.BoFormMode.fm_UPDATE_MODE || _Form.Mode == SAPbouiCOM.BoFormMode.fm_OK_MODE)

            {

                _Form.Items.Item("etCWise").Enabled = false;

                _Form.Items.Item("CmbDRoute").Enabled = false;

                _Form.Items.Item("Item_21").Enabled = false;

                _Form.Items.Item("FDATE").Enabled = false;

                _Form.Items.Item("TDATE").Enabled = false;

                _Form.Items.Item("cmbDSC").Enabled = false;

                _Form.Items.Item("CmbArea").Enabled = false;

                _Form.Items.Item("Item_18").Enabled = false;

                _Form.Items.Item("DocNum").Enabled = false;

                _Form.Items.Item("cmbBranch").Enabled = false;

                _Form.Items.Item("etWhs").Enabled = false;

                _Form.Items.Item("cmbChanel").Enabled = false;

                _Form.Items.Item("Item_12").Enabled = false;

                _Form.Items.Item("Item_6").Enabled = false;

                _Form.Items.Item("Item_10").Enabled = false;

            }

            if (_Form.Mode == SAPbouiCOM.BoFormMode.fm_FIND_MODE && status == false)

            {

                _Form.Items.Item("etCWise").Enabled = true;

                _Form.Items.Item("CmbDRoute").Enabled = true;

                _Form.Items.Item("Item_21").Enabled = true;

                _Form.Items.Item("FDATE").Enabled = true;

                _Form.Items.Item("TDATE").Enabled = true;

                _Form.Items.Item("cmbDSC").Enabled = true;

                _Form.Items.Item("CmbArea").Enabled = true;

                _Form.Items.Item("Item_18").Enabled = true;

                _Form.Items.Item("DocNum").Enabled = true;

                _Form.Items.Item("cmbBranch").Enabled = true;

                _Form.Items.Item("etWhs").Enabled = true;

                _Form.Items.Item("cmbChanel").Enabled = true;

                _Form.Items.Item("Item_12").Enabled = true;

                _Form.Items.Item("Item_6").Enabled = false;

                _Form.Items.Item("Item_10").Enabled = false;

            }

            if (_Form.Mode == SAPbouiCOM.BoFormMode.fm_FIND_MODE && status==true)

            {

                _Form.Items.Item("etCWise").Enabled = false;

                _Form.Items.Item("CmbDRoute").Enabled = false;

                _Form.Items.Item("Item_21").Enabled = false;

                _Form.Items.Item("FDATE").Enabled = false;

                _Form.Items.Item("TDATE").Enabled = false;

                _Form.Items.Item("cmbDSC").Enabled = false;

                _Form.Items.Item("CmbArea").Enabled = false;

                _Form.Items.Item("Item_18").Enabled = false;

                _Form.Items.Item("DocNum").Enabled = false;

                _Form.Items.Item("cmbBranch").Enabled = false;

                _Form.Items.Item("etWhs").Enabled = false;

                _Form.Items.Item("cmbChanel").Enabled = false;

                _Form.Items.Item("Item_12").Enabled = false;

                _Form.Items.Item("Item_6").Enabled = false;

                _Form.Items.Item("Item_10").Enabled = false;

                _Form.Items.Item("etRemarks").Click(SAPbouiCOM.BoCellClickType.ct_Regular);

            }

        }

        #endregion

--------------------------------------------------------------------------------------------

// Get Invoice document 


SAPbobsCOM.Documents _mDoc;

AddressExtension m_AddrExtension; 


m_Doc = (SAPbobsCOM.Documents)m_Company.GetBusinessObject(BoObjectTypes.oInvoices); 

m_Doc.GetByKey(4); 

 

// Get the address sub object from the document object 

m_AddrExtension = (AddressExtension)m_Doc.AddressExtension; 

 

// Set bill to address properties 

m_AddrExtension.BillToBlock = "BillToBlockU"; 

m_AddrExtension.BillToBuilding = "BillToBuildingU"; 

m_AddrExtension.BillToCity = "BillToCityU"; 

m_AddrExtension.BillToCountry = "BCU"; 

m_AddrExtension.BillToCounty = "BUt"; 

m_AddrExtension.BillToState = "BSU"; 

m_AddrExtension.BillToStreet = "BillToStreetU"; 

m_AddrExtension.BillToStreetNo = "BillToStreetNoU"; 

m_AddrExtension.BillToZipCode = "BillToZipCodeU"; 

m_AddrExtension.BillToAddressType = "BillToAddressTypeU"; 

 

// Set ship to address properties 

m_AddrExtension.ShipToBlock = "ShipToBlockU"; 

m_AddrExtension.ShipToBuilding = "ShipToBuildingU"; 

m_AddrExtension.ShipToCity = "ShipToCityU"; 

m_AddrExtension.ShipToCountry = "SCU"; 

m_AddrExtension.ShipToCounty = "SUt"; 

m_AddrExtension.ShipToState = "SUt"; 

m_AddrExtension.ShipToStreet = "ShipToStreetU"; 

m_AddrExtension.ShipToStreetNo = "ShipToStreetNoU"; 

m_AddrExtension.ShipToZipCode = "ShipToZipCodeU"; 

 

// Update the document 

m_Doc.Update();