void Books.Create_Sales_Order_in_Books(int soid) { //Getting authtoken and organisation id books_access = thisapp.Books.Get_Books_Access(); conn_tok = books_access.get("connection"); org_id = books_access.get("organisation_id"); //info auth_tok; //info org_id; //------------------------------------------------------------------------------ fetch_so = Sales_Order[ID == input.soid]; //info fetch_so; fetch_cust = Customers[ID == fetch_so.Customer_Name]; //info ("fetchcust" + fetch_cust) + " " + fetch_cust.Customer_Books_ID; fetch_delivery_method = Shipping_Mode[ID == fetch_so.Delivery_Mode].Shipping_Mode; fetch_warehouse = Warehouse[ID = fetch_so.Warehouse].Warehouse_Name; fettax = GST_Details[ID == fetch_so.Item_Details.Tax]; fetemp = Employee_Details[ID == fetch_so.Created_By].Employee_Name; fetch_payment_trms = Payment_Terms[ID == fetch_so.Payment_Terms].Stages; shipment_date = fetch_so.Expected_Shipment_Date.toString("yyyy-MM-dd"); so_date = zoho.currentdate.toString("yyyy-MM-dd"); curr_code = Currency_Code[ID == fetch_cust.Currency_Code]; curr_conv = Currency_Conversion[Convert_To == fetch_cust.Currency_Code]; plc_of_supply = Destination[Destination == fetch_so.Place_of_Supply.Destination].Short_Name; fet_gst_trmt = GST_Treatment[ID == fetch_cust.GST_Treatment]; mymap = Map(); mymap.put("customer_id",fetch_cust.Customer_Books_ID); mymap.put("customer_name",fetch_cust.Contact_Name); mymap.put("date",so_date); //mymap.put("billing_address",fetch_so.Billing_Address); //mymap.put("shipping_address",fetch_so.Shipping_Address); mymap.put("shipment_date",shipment_date); mymap.put("delivery_method",fetch_delivery_method); mymap.put("place_of_supply",plc_of_supply); mymap.put("gst_treatment",fet_gst_trmt.Link_name); mymap.put("salesorder_number",fetch_so.Sale_Order_No); mymap.put("salesperson_name",fetemp); mymap.put("currency_id",curr_code.Zoho_Books_ID); mymap.put("exchange_rate",curr_conv.Exchange_Rate); mymap.put("status","Open"); url_to_so = "https://creatorapp.zoho.in/carrierwheels/erp/#Page:SO_Print?ID=" + soid; custom_list = List(); custom_map = Map(); custom_map.put("api_name","cf_download_so_from_erp"); custom_map.put("value",url_to_so); custom_list.add(custom_map); mymap.put("custom_fields",custom_list); item_list = List(); tx_val = 0; totalqty = 0; for each rec in fetch_so.Item_Details { fetchitem = Materials[ID == rec.Part_Description]; line_item_map = Map(); line_item_map.put("name",rec.Part_Description.Part_Description); line_item_map.put("item_id",fetchitem.Zoho_Books_ID); // line_item_map.put("description",rec.Part_Description.Additional_Description); line_item_map.put("quantity",rec.Qty); totalqty = ifnull(totalqty,0.00) + ifnull(rec.Qty,0.00); line_item_map.put("rate",rec.Rate); line_item_map.put("warehouse_name",fetch_warehouse); //line_item_map.put("tax_type",fettax.Tax_Details.Tax_Type); line_item_map.put("tax_name",fettax.Tax_Name); line_item_map.put("tax_id",fettax.Zoho_Books_ID); line_item_map.put("tax_percentage",fettax.Total_Rate); item_list.add(line_item_map); tx_val = ifnull(tx_val,0.0) + ifnull(rec.Tax_Value,0.0); } if(fetch_so.Packing_Forwarding > 0) { fetchitem = Materials[Part_No == "900114"]; line_item_map = Map(); line_item_map.put("name",fetchitem.Part_Description); line_item_map.put("item_id",fetchitem.Zoho_Books_ID); //line_item_map.put("quantity",1); line_item_map.put("rate",fetch_so.Packing_Forwarding); line_item_map.put("warehouse_name",fetch_warehouse); line_item_map.put("tax_name",fettax.Tax_Name); line_item_map.put("tax_id",fettax.Zoho_Books_ID); line_item_map.put("tax_percentage",fettax.Total_Rate); item_list.add(line_item_map); tx_val = ifnull(tx_val,0.0) + ifnull(fetch_so.PF_Tax_value,0.0); } mymap.put("tax_total",tx_val); mymap.put("line_items",item_list); post_url = zoho.books.createRecord("salesorders",org_id,mymap,conn_tok); info post_url; res_code = post_url.get("code").toLong(); resp_Map = Map(); log_type = "Failure"; if(res_code == 0) { log_type = "Success"; books_id = post_url.toMap().get("salesorder").toMap().get("salesorder_id"); fetch_so.Zoho_Books_ID=books_id; test_map = Map(); mark_response = invokeurl [ url :"https://www.zohoapis.in/books/v3/salesorders/" + books_id + "/status/open?organization_id=" + org_id + "" type :POST parameters:test_map connection:"books_con" ]; } if(res_code == 0) { getzbook = zoho.books.getRecordsByID("salesorders",org_id,books_id); get_line_item = getzbook.toMap().get("salesorder").toMap().get("line_items"); for each lineitem in get_line_item { lineitemid = lineitem.getjson("line_item_id"); itemid = lineitem.getjson("item_id"); fetso = Sales_Order[Zoho_Books_ID == books_id]; fetsosf = Sale_Order_Subform[Sales_Order_Exis_ID == fetso.ID]; getmat = Materials[Zoho_Books_ID == itemid]; for each sosfrec in fetsosf { if(sosfrec.Part_No == getmat.ID) { sosfrec.zb_line_item_id=lineitemid; fetso.pack_forw_lineitemid=lineitemid; } } } } ins_log = insert into Log_Files [ Added_User=zoho.loginuser Log_Type=log_type Module_Name="Books" Form_Name="Sales Order" Log_Details=post_url Reference_NO=fetch_so.Sale_Order_No ]; //sending error log message if(log_type == "Failure") { resp_Map.put("Resp","Failure"); resp_Map.put("log_msg",post_url.get("message")); } //status to changed updtstatus = zoho.books.markStatus("salesorders",org_id,books_id,"open",conn_tok); }
for each rec in Calibration_Master[ID != null && Cal_Due_Date != null] { if(rec.Today != zoho.currentdate) { rec.Today=zoho.currentdate; //info rec.Today; info rec.Cal_Due_Date; daysleft = daysBetween(rec.Today,rec.Cal_Due_Date); rec.Days_Left=daysleft; info daysleft; if(rec.Days_Left.toNumber() <= 30 && rec.Days_Left.toNumber() > 0) { rec.Status1="Attention"; } else if(rec.Days_Left.toNumber() > 30) { rec.Status1="No Issue"; } else if(rec.Days_Left.toNumber() <= 0) { rec.Status1="Urgent"; } } }
for each rec in Calibration_Master[ID != null] { calhist = Calibration_History[Calibration_Master_ID == rec.ID]; if(calhist.Cal_Due_Date < zoho.currentdate && calhist.Status != "Completed") { calhist.Status="Overdue"; } if(calhist.Cal_Due_Date >= zoho.currentdate && calhist.Status != "Completed") { calhist.Status="Due"; } if(rec.Cal_Due_Date < zoho.currentdate) { rec.Status="Overdue"; } if(rec.Cal_Due_Date >= zoho.currentdate) { rec.Status="Due"; } }
getemail = Email_Template[Template_No == 9]; sub = getemail.Subject_field; body = getemail.Body; tab = "<html><style>th,td {padding: 5px;}</style><table border = 1> <th> S.No. </th> <th>Part No.</th> <th>Part Name <th>Minimum Quantity</th> <th>Available Quantity</th>"; count = 0; for each var in Materials[Material_Item_Type.Material_Type == "General Purchase" && Planning_Procedure == "Consumption-Based Planning"] { stock = Stock_Value[Part_No == var.ID].sum(Stock_Qty); if(var.Minimum_Stock != null) { if(var.Minimum_Stock >= stock) { count = count + 1; tab = tab + "<tr><td>" + count + "</td>"; tab = tab + "<td>" + var.Part_No + "</td>"; tab = tab + "<td>" + var.Part_Description + "</td>"; tab = tab + "<td>" + var.Minimum_Stock + "</td>"; tab = tab + "<td>" + stock + "</td></tr>"; } } } if(count > 1) { info "test"; tab = tab + "</table></html>"; body = body.replaceAll("{table}",tab,true); sub = sub.replaceAll("<partno>",var.Part_No,true); sendmail [ from :"CWPL ERP <erp@carrierwheels.com>" to :"pooja.s@synprosoft.com" subject :sub message :body ] }
alllist = List(); alllist = {"png","PNG","JPEG","jpeg","JPG","jpg","GIF","gif","BMP","bmp"}; var = ""; if(input.Attachment != null) { ext = input.Attachment.toList(".").get(input.Attachment.toList(".").size() - 1); } rpl = replaceAll(ext," border = \"0\"></img>",""); var = rpl.replaceAll("\"",""); if(!alllist.contains(var) && var != "") { alert "This file type is not accepted. Only PNG,JPG,JPEG,BMP file formats are allowed"; cancel submit; }
i = 0; for each rec in input.Item_Details1 { i = i + 1; rec.S_No=i; } itmname = ""; des = ""; for each sub in input.Item_Details1 { if(sub.S_No == 1) { itmname = sub.Item_Name; des = sub.Description; } } if(itmname != null) { for each sub1 in input.Item_Details1 { if(sub1.S_No > 1) { sub1.Item_Name=itmname; sub1.Description=des; } } } // itm = List(); // for each var in input.Item_Details1 // { // fetcal = Calibration_Master[Item_Name == var.Item_Name.Item_Name].ID.getAll(); // itm.add(fetcal); // itm = itm.distinct(); // var.Item_Name:ui.add(itm); // }
alllist = List(); alllist = {"png","PNG","JPEG","jpeg","JPG","jpg","GIF","gif","BMP","bmp"}; var = ""; if(input.Attachment != null) { ext = input.Attachment.toList(".").get(input.Attachment.toList(".").size() - 1); } rpl = replaceAll(ext," border = \"0\"></img>",""); var = rpl.replaceAll("\"",""); if(!alllist.contains(var) && var != "") { alert "This file type is not accepted. Only PNG,JPG,JPEG,BMP file formats are allowed"; }
if(input.Calibration_Master_ID != null) { fetcal = Calibration_Master[ID == input.Calibration_Master_ID]; input.Item_Name = fetcal.ID; input.Gauge_No = fetcal.ID; input.Description_Make = fetcal.Description_Make; input.Location = fetcal.Location; input.Range = fetcal.ID; input.Least_Count = fetcal.ID; input.Permissable_Error = fetcal.Permissable_Error; input.Usable_Range = fetcal.ID; input.Internal_External = fetcal.Internal_External; input.Calibration_Type = fetcal.Internal_External; input.Closed_Date = zoho.currentdate; input.Cal_Done_Date = zoho.currentdate; input.Cal_Due_Date = fetcal.Cal_Due_Date; input.Master_Instrument = fetcal.Master_Instruments; input.Checked_By = ifnull(Employee_Details[Employee_Email == "kapilsaini7890ks@gmail.com"].ID,""); input.Verification_By = ifnull(Employee_Details[Employee_Email = "manishchaudhary@carrierwheels.com"].ID,""); input.Approved_By = ifnull(Employee_Details[Employee_Email = "barkha@carrierwheels.com"].ID,""); input.Calibration_By = ifnull(Employee_Details[Employee_Email == zoho.loginuserid].ID,""); if(input.Internal_External == "Both") { enable Calibration_Type; } else { disable Calibration_Type; } } //Hide/Disable //disable Calibration_Type ; hide Checked_By; disable Internal_External; hide Vendor_Name; hide Vendor_Address; hide Calibration_Done; hide Closed_Date; disable Item_Details1.S_No; //disable Calibration_By; disable Permissable_Error; disable Usable_Range; disable Least_Count; //disable Internal_External; disable Cal_Due_Date; disable Item_Name; disable Gauge_No; disable Description_Make; disable Location; disable Range; disable Master_Instrument; //disable Master_Instrument; disable Vendor_Address; hide Shipping_Cost; hide Calibration_Master_ID; hide Status; hide Transportation_Details; hide Vehicle_Photo; hide Transport_Name; hide Transporter_Name; hide Driver_Name; hide Driver_Mobile; hide Driver_License_No; hide Vehicle_Type; hide Vehicle_No_dup; hide Vehicle_RC_No; hide Vehicle_No; hide GR_RR_No; hide Calibration_No; //disable Calibration_Type; //disable Closed_By; hide Calibration_History_ID; hide Approval; //hide Verification_By; hide Approved_By;
if(input.Start_Date != null && input.Frequency != null) { mon = input.Frequency; input.Cal_Due_Date = input.Start_Date.addDay(mon); input.Cal_Due_Date = input.Cal_Due_Date.subDay(1); startDate = input.Cal_Due_Date; endDate = input.Today.subDay(1); input.Days_Left = daysBetween(endDate,startDate); }
if(input.Start_Date != null && input.Frequency != null) { mon = input.Frequency; input.Cal_Due_Date = input.Start_Date.addDay(mon); input.Cal_Due_Date = input.Cal_Due_Date.subDay(1); startDate = input.Cal_Due_Date; endDate = input.Today.subDay(1); input.Days_Left = daysBetween(endDate,startDate); }
rec = 0; if(isBlank(input.Cal_Master_No.trim())) { rec = 1; str1 = thisapp.Common.Number_Function_New("Cal Master No"); input.Cal_Master_No = str1; } if(input.Calibration_Master_ID == null) { info "if"; input.Obsolete_Status = "Active"; var = 0; if(isBlank(input.Gauge_No.trim())) { var = 1; str = thisapp.Common.Number_Function_New("Gauge No"); input.Gauge_No = str; openUrl("#Form:Alert_Messages?Status=" + "cal" + "&Value=" + input.Gauge_No + "&zc_LoadIn=dialog","same window"); } } if(input.Calibration_Master_ID != null && Revision_Status == "Yes") { fetcal = Calibration_Master[ID == input.ID]; fetcal.Obsolete_Status="Inactive"; fetcal.Approval="Pending for Approval"; openUrl("#Report:All_Calibration_Masters","same window"); } thisapp.Calibration.CalibrationHistory(input.ID);
// GIN num generation try { input.Status = "Open"; for each rec in input.Item_Details { rec.Status=input.Status; } var = 0; if(input.GIN_Number.trim().len() < 1) { var = 1; str = thisapp.Common.Number_Function_New("Goods Issued Note"); input.GIN_Number = str; } //as per the advice from Mr.senthil dt 05/1/2024 in stock values form reduce the stockqty based on FIFO method(added time) for each itdrec in input.Item_Details { getstkvalue = Stock_Value[Part_No == itdrec.Part_No && Stock_Qty > 0] sort by Added_Time asc; if(getstkvalue.count() > 0) { svbalqty = 0; svi = 1; for each stokvalrec in getstkvalue { //Issued Quantiy is less total qty if(itdrec.Issued_Quantity <= stokvalrec.Stock_Qty && svi == 1) { stokvalrec.Stock_Qty=ifnull(itdrec.Qty_after_Issued,0.0); stokvalrec.Stock_Value=ifnull(itdrec.Rate,0.0) * ifnull(itdrec.Qty_after_Issued,0.0); stokvalrec.Inventory_Qty=ifnull(itdrec.Qty_after_Issued,0.0); } //Issued Quantity is more total qty else if(itdrec.Issued_Quantity > stokvalrec.Stock_Qty && svi == 1) { svbalqty = ifnull(itdrec.Issued_Quantity,0.0) - ifnull(stokvalrec.Stock_Qty,0.0); stokvalrec.Stock_Qty=0; stokvalrec.Stock_Value=0; stokvalrec.Inventory_Qty=0; } //for first time it should not get inside the loop if(svbalqty > 0 && svi > 1) { //Balance Qty is less if(svbalqty <= stokvalrec.Stock_Qty) { stokvalrec.Stock_Qty=ifnull(stokvalrec.Stock_Qty,0.0) - ifnull(svbalqty,0.0); stokvalrec.Stock_Value=ifnull(stokvalrec.Unit_Price,0.0) * ifnull(stokvalrec.Stock_Qty,0.0); stokvalrec.Inventory_Qty=ifnull(stokvalrec.Inventory_Qty,0.0) - ifnull(svbalqty,0.0); svbalqty = 0; } //Balance Qty is More else if(svbalqty >= stokvalrec.Stock_Qty) { svbalqty = ifnull(svbalqty,0.0) - ifnull(stokvalrec.Stock_Qty,0.0); stokvalrec.Stock_Qty=0; stokvalrec.Stock_Value=0; stokvalrec.Inventory_Qty=0; } } if(svbalqty == 0) { info "before break"; break; } svi = svi + 1; } } else if(getstkvalue.count() == 0) { insert into Stock_Value [ Added_User=zoho.loginuser Part_No=itdrec.Part_No Part_Description=itdrec.Part_Description Specification=itdrec.Specification Stock_Qty=ifnull(itdrec.Qty_after_Issued,0.0) Unit_Price=ifnull(itdrec.Rate,0.00) Stock_Value=ifnull(itdrec.Rate,0.00) * ifnull(itdrec.Qty_after_Issued,0.00) Inventory_Qty=ifnull(itdrec.Qty_after_Issued,0.0) ] } } // //insert the part no if not available in stock value form.the below comment and new code is above on 5/1/2024 /*for each stkvalrec in input.Item_Details { getinvent = Inventory[Part_No == stkvalrec.Part_No && Total_Qty > 0]; if(getinvent.count() > 0) { fet_stockvalue = Stock_Value[Part_No == stkvalrec.Part_No && Unit_Price == stkvalrec.Rate]; if(fet_stockvalue.count() == 0) { insert into Stock_Value [ Added_User=zoho.loginuser Part_No=stkvalrec.Part_No Part_Description=stkvalrec.Part_Description Specification=stkvalrec.Specification Location_Name=getinvent.Location_Name Sub_Location=getinvent.Sub_Location Rack_Number=getinvent.Rack_Number Warehouse=getinvent.Warehouse Stock_Qty=ifnull(stkvalrec.Qty_after_Issued,0.0) Unit_Price=ifnull(stkvalrec.Rate,0.00) Stock_Value=ifnull(stkvalrec.Rate,0.00) * ifnull(stkvalrec.Qty_after_Issued,0.00) Inventory_Qty=ifnull(stkvalrec.Qty_after_Issued,0.0) ] } else if(fet_stockvalue.count() > 0) { fet_stockvalue = Stock_Value[Part_No == stkvalrec.Part_No && Unit_Price == stkvalrec.Rate]; if(fet_stockvalue.Stock_Qty > 0) { fet_stockvalue.Stock_Qty=ifnull(fet_stockvalue.Stock_Qty,0.0) - ifnull(stkvalrec.Issued_Quantity,0.0); fet_stockvalue.Stock_Value=ifnull(stkvalrec.Rate,0.0) * ifnull(fet_stockvalue.Stock_Qty,0.0); fet_stockvalue.Inventory_Qty=ifnull(fet_stockvalue.Stock_Qty,0.0); } else { fet_stockvalue.Stock_Qty=ifnull(stkvalrec.Qty_after_Issued,0.0); fet_stockvalue.Stock_Value=ifnull(stkvalrec.Rate,0.0) * ifnull(stkvalrec.Qty_after_Issued,0.0); fet_stockvalue.Inventory_Qty=ifnull(stkvalrec.Qty_after_Issued,0.0); } } } }*/ // if(input.Form_Mode == "GIN against WO") { iss_qty = 0; ava_qty = 0; bal_qty = 0; for each wovar in input.Item_Details { getinv = Inventory[Part_No == wovar.Part_No && Location_Name.Location__Name == "Production WIP" && Sub_Location.Sub_Location == "Paint Shop"]; getin = Inventory[Part_No == wovar.Part_No && Location_Name.Location__Name != "Production WIP" && Total_Qty > 0] sort by Total_Qty desc; // sendmail // [ // from :zoho.loginuserid // to :"pooja.s@synprosoft.com","parthasarathy.m@synprosoft.com" // subject :"GIN Successful form submission - getinV" // message :"Part No " + getin.Part_No.Part_No + "PRD WIP TOT QTY-" + getinv.Total_Qty + "PRD WIP AVL QTY-" + getinv.Available_Qty + "PRD WIP BLK QTY-" + getinv.Block_Qty + "ID-" + getin.ID + "getinv insert Count-" + getinv.count() + "NOPRDWIP TQ " + getin.Total_Qty + "noprdwip aq " + getin.Available_Qty + "noprd blkqty " + getin.Block_Qty // ] if(getin.count() > 0) { //Block is greater than Issue qty if(getin.Block_Qty >= wovar.Issued_Quantity && getin.Block_Qty > 0) { getin.Block_Qty=ifnull(getin.Block_Qty,0) - ifnull(wovar.Issued_Quantity,0); getin.Total_Qty=ifnull(getin.Total_Qty,0) - ifnull(wovar.Issued_Quantity,0); } else if(getin.Block_Qty < wovar.Issued_Quantity && getin.Block_Qty > 0) { bal = ifnull(wovar.Issued_Quantity,0) - ifnull(wovar.Block_Qty,0); blk = ifnull(wovar.Block_Qty,0); getin.Available_Qty=ifnull(getin.Available_Qty,0) - bal; getin.Total_Qty=ifnull(getin.Total_Qty,0) - ifnull(wovar.Issued_Quantity,0); getin.Block_Qty=0; } else if(getin.Block_Qty == 0 || getin.Block_Qty == null) { if(getin.Available_Qty > 0 && getin.Available_Qty >= wovar.Issued_Quantity) { getin.Available_Qty=ifnull(getin.Available_Qty,0) - wovar.Issued_Quantity; getin.Total_Qty=ifnull(getin.Total_Qty,0) - ifnull(wovar.Issued_Quantity,0); } if(getin.Available_Qty > 0 && getin.Available_Qty < wovar.Issued_Quantity) { getin.Available_Qty=wovar.Issued_Quantity - ifnull(getin.Available_Qty,0); getin.Total_Qty=ifnull(wovar.Issued_Quantity,0) - ifnull(getin.Total_Qty,0); } } } if(getinv.count() == 0) { bal = 0; if(wovar.Issued_Quantity > wovar.Block_Qty && getin.Available_Qty > 0) { bal = ifnull(wovar.Issued_Quantity,0) - ifnull(wovar.Block_Qty,0); getin.Block_Qty=0; getin.Available_Qty=ifnull(getin.Available_Qty,0) - bal; getin.Total_Qty=ifnull(getin.Available_Qty,0); } if(wovar.Issued_Quantity > wovar.Required_Quantity) { blk = ifnull(wovar.Issued_Quantity,0) - ifnull(wovar.Required_Quantity,0); ins = insert into Inventory [ Part_Description=wovar.Part_Description Part_No=wovar.Part_No Total_Qty=wovar.Required_Quantity Available_Qty=wovar.Issued_Quantity Block_Qty=blk UOM=wovar.Unit_of_Measurement Location_Name=143536000004382382 Sub_Location=143536000004382454 Added_User=zoho.loginuser ]; } else if(wovar.Issued_Quantity == wovar.Required_Quantity) { ins1 = insert into Inventory [ Part_Description=wovar.Part_Description Part_No=wovar.Part_No Total_Qty=wovar.Required_Quantity Available_Qty=wovar.Issued_Quantity Block_Qty=0 UOM=wovar.Unit_of_Measurement Location_Name=143536000004382382 Sub_Location=143536000004382454 Added_User=zoho.loginuser ]; } else if(wovar.Issued_Quantity < wovar.Required_Quantity) { ins2 = insert into Inventory [ Part_Description=wovar.Part_Description Part_No=wovar.Part_No Total_Qty=wovar.Required_Quantity Available_Qty=wovar.Issued_Quantity Block_Qty=wovar.Balance_Quantity UOM=wovar.Unit_of_Measurement Location_Name=143536000004382382 Sub_Location=143536000004382454 Added_User=zoho.loginuser ]; } } else if(getinv.count() > 0) { sendmail [ from :zoho.loginuserid to :"pooja.s@synprosoft.com" subject :"GIN Successful form submission - getinV" message :"Part No " + getin.Part_No.Part_No + "PRD WIP TOT QTY-" + getinv.Total_Qty + "PRD WIP AVL QTY-" + getinv.Available_Qty + "PRD WIP BLK QTY-" + getinv.Block_Qty + "ID-" + getin.ID + "getinv insert Count-" + getinv.count() ] if(wovar.Required_Quantity == wovar.Issued_Quantity) { getinv.Available_Qty=ifnull(getinv.Available_Qty,0) + ifnull(wovar.Issued_Quantity,0); getinv.Total_Qty=ifnull(getinv.Total_Qty,0) + ifnull(wovar.Issued_Quantity,0); } //When Issued Qty is Greater than Reqquired Qty else if(wovar.Issued_Quantity > wovar.Required_Quantity) { // blk = ifnull(wovar.Issued_Quantity,0) - ifnull(wovar.Required_Quantity,0); // getinv.Total_Qty=ifnull(getinv.Total_Qty,0) + ifnull(wovar.Required_Quantity,0); // getinv.Available_Qty=ifnull(getinv.Available_Qty,0) + ifnull(wovar.Issued_Quantity,0); // getinv.Block_Qty=ifnull(getinv.Block_Qty,0) + blk; blk = ifnull(wovar.Issued_Quantity,0) + ifnull(wovar.Required_Quantity,0); getinv.Total_Qty=ifnull(getinv.Total_Qty,0) + blk; getinv.Available_Qty=ifnull(getinv.Available_Qty,0) + ifnull(wovar.Issued_Quantity,0); getinv.Block_Qty=ifnull(getinv.Block_Qty,0) + ifnull(wovar.Required_Quantity,0); } else if(wovar.Issued_Quantity < wovar.Required_Quantity) { getinv.Total_Qty=ifnull(getinv.Total_Qty,0) + ifnull(wovar.Required_Quantity,0); getinv.Available_Qty=ifnull(getinv.Available_Qty,0) + ifnull(wovar.Issued_Quantity,0); getinv.Block_Qty=ifnull(getinv.Block_Qty,0) + ifnull(wovar.Balance_Quantity,0); } } mat_isf_qty = ifnull(wovar.Issued_Quantity,0) + ifnull(wovar.Quantity_issued_so_far,0); fetch_mat_subform = Material_Request_Subform[ID == wovar.Material_Request_Subform_lu && Part_Description == wovar.Part_Description]; fetch_mat_subform.Quantity_issued_so_far=mat_isf_qty; blnc_qty = ifnull(wovar.Balance_Quantity,0.0); fetch_mat_subform.Balance_Qty=blnc_qty; bat_no_list = List(); iss_qty = wovar.Issued_Quantity; bat = Stock_Batch[Part_No == wovar.Part_No && Part_Description == wovar.Part_Description && Status != "Issued" && Location == wovar.Location && Warehouse == input.Warehouse && Sub_Location == wovar.Sub_Location && Racks_Bins == wovar.Racks_Bins]; for each i1 in bat { bat_no = Stock_Batch[ID == i1].Batch_No; bat_no_list.add(bat_no); } i = 0; for each no in bat_no_list { batching = Stock_Batch[Batch_No == no]; ava_qty = batching.Available_Quantity; i = i + 1; if(i == 1 && iss_qty > ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = iss_qty - ava_qty; } else if(i == 1 && iss_qty < ava_qty) { batching.Status="Partially Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=ava_qty - iss_qty; bal_qty = 0; } else if(i == 1 && iss_qty == ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = 0; } else if(i > 1 && bal_qty > ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = bal_qty - ava_qty; } else if(i > 1 && bal_qty < ava_qty) { batching.Status="Partially Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=ava_qty - bal_qty; bal_qty = 0; } else if(i > 1 && bal_qty == ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=bal_qty; batching.Available_Quantity=0; bal_qty = 0; } } // Updating Stock value temp_issued_qty = rec.Issued_Quantity; ival = 0; bal = 0; if(wovar.Balance_Quantity < 1) { fetch_mat_subform.Status="Issued"; } else { fetch_mat_subform.Status="Partially Issued"; } } } //above closing parenthesis is for gin from work order if contidion. emptylist = List(); if(Material_Request_RECID != emptylist || Material_Request_RECID != null && input.Form_Mode == "GIN against MRQ") { fet_Mrq_sts = Material_Request[ID == input.Material_Request_RECID]; //For GIN Validtaions for each rec in input.Item_Details { if(rec.Issued_Quantity != null || rec.Issued_Quantity != 0) { //Updating qty issued so far mat_isf_qty = ifnull(rec.Issued_Quantity,0) + ifnull(rec.Quantity_issued_so_far,0); //Updating Quantity_issued_so_far in Material Request Subform fetch_mat_subform = Material_Request_Subform[ID == rec.Material_Request_Subform_lu && Part_Description == rec.Part_Description]; fetch_mat_subform.Quantity_issued_so_far=mat_isf_qty; //Updating blnc qty blnc_qty = ifnull(rec.Balance_Quantity,0.0); fetch_mat_subform.Balance_Qty=blnc_qty; //below is new code to handle when items are in multiple times with different places. getinventory = Inventory[Part_No == rec.Part_No] sort by Total_Qty desc; info getinventory; if(getinventory.count() > 0) { balqty = 0; i = 1; for each inventrec in getinventory { info balqty; info i; //Issued Quantiy is less total qty if(rec.Issued_Quantity <= inventrec.Total_Qty && i == 1) { info "issued qty is less than total qty"; inventrec.Total_Qty=ifnull(inventrec.Total_Qty,0.0) - ifnull(rec.Issued_Quantity,0.0); inventrec.Available_Qty=ifnull(inventrec.Available_Qty,0.0) - ifnull(rec.Issued_Quantity,0.0); } //Issued Quantity is more total qty else if(rec.Issued_Quantity > inventrec.Total_Qty && i == 1) { info "issued qty is more than total qty"; balqty = ifnull(rec.Issued_Quantity,0.0) - ifnull(inventrec.Total_Qty,0.0); inventrec.Total_Qty=0; inventrec.Available_Qty=0; } //for first time it should not get inside the loop if(balqty > 0 && i > 1) { info "balaance qty is more than zero"; //Balance Qty is less if(balqty <= inventrec.Total_Qty) { info "balance qty is less than total qty"; inventrec.Total_Qty=ifnull(inventrec.Total_Qty,0.0) - ifnull(balqty,0.0); inventrec.Available_Qty=ifnull(inventrec.Available_Qty,0.0) - ifnull(balqty,0.0); balqty = 0; } //Balance Qty is More else if(balqty >= inventrec.Total_Qty) { info "balance qty is greater than total qty"; balqty = ifnull(balqty,0.0) - ifnull(inventrec.Total_Qty,0.0); inventrec.Total_Qty=0; inventrec.Available_Qty=0; } } if(balqty == 0) { info "before break"; break; } i = i + 1; } } //-- //Subracting stock-batch // Basic /*bat = Stock_Batch[Part_No == rec.Part_No && Part_Description == rec.Part_Description && Status != "Issued" && Batch_No == rec.Batch_No.Batch_No]; if(bat.Available_Quantity == rec.Issued_Quantity) { bat.Status="Issued"; } if(bat.Available_Quantity > rec.Issued_Quantity) { bat.Status="Partially Issued"; bat.Available_Quantity=bat.Available_Quantity - rec.Issued_Quantity; }*/ // Advanced iss_qty = 0; ava_qty = 0; bal_qty = 0; // if(rec.Specification == null || rec.Specification == "") // { bat = Stock_Batch[Part_No == rec.Part_No && Part_Description == rec.Part_Description && Status != "Issued" && Location == rec.Location && Warehouse == input.Warehouse && Sub_Location == rec.Sub_Location && Racks_Bins == rec.Racks_Bins]; // } // else // { // bat = Stock_Batch[Part_No == rec.Part_No && Part_Description == rec.Part_Description && Specification == rec.Specification && Status != "Issued" && Location == rec.Location && Warehouse == input.Warehouse && Sub_Location == rec.Sub_Location && Racks_Bins == rec.Racks_Bins]; // } bat_no_list = List(); iss_qty = rec.Issued_Quantity; for each i1 in bat { bat_no = Stock_Batch[ID == i1].Batch_No; bat_no_list.add(bat_no); } info bat_no_list; i = 0; for each no in bat_no_list { batching = Stock_Batch[Batch_No == no]; ava_qty = batching.Available_Quantity; i = i + 1; if(i == 1 && iss_qty > ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = iss_qty - ava_qty; } else if(i == 1 && iss_qty < ava_qty) { batching.Status="Partially Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=ava_qty - iss_qty; bal_qty = 0; } else if(i == 1 && iss_qty == ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = 0; } else if(i > 1 && bal_qty > ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = bal_qty - ava_qty; } else if(i > 1 && bal_qty < ava_qty) { batching.Status="Partially Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=ava_qty - bal_qty; bal_qty = 0; } else if(i > 1 && bal_qty == ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=bal_qty; batching.Available_Quantity=0; bal_qty = 0; } } // Updating Stock value temp_issued_qty = rec.Issued_Quantity; ival = 0; bal = 0; } if(rec.Balance_Quantity == null || rec.Balance_Quantity == 0) { fetch_mat_subform.Status="Issued"; } else { fetch_mat_subform.Status="Partially Issued"; } } } else if(input.Form_Mode == "Direct GIN" || input.Form_Mode == "") { str = thisapp.Common.Number_Function_New("Material Request"); gin_without_mrq = insert into Material_Request [ Request_Date=zoho.currentdate Added_User=zoho.loginuser Request_Raised_By=input.Issued_By Warehouse=input.Warehouse Material_Type=input.Material_Request_Type Material_Request_No=str MR_Status="MRQ from GIN" ]; input.Material_Request_RECID = gin_without_mrq; Statusw = ""; Balance_Qtyw = input.Item_Details.Balance_Quantity; if(Balance_Qtyw < 1) { Statusw = "Issued"; } else { Statusw = "Partially Issued"; } for each recmrsf in input.Item_Details { insert into Material_Request_Subform [ Part_Description=recmrsf.Part_No Part_No=recmrsf.Part_Description Added_User=zoho.loginuser Material_Type=recmrsf.Material_Type Department=input.Issued_Empolyee_Department UoM=recmrsf.Unit_of_Measurement Specification=recmrsf.Specification Stock_Qty=recmrsf.Stock_Quantity Required_Qty=recmrsf.Required_Quantity Balance_Qty=recmrsf.Balance_Quantity Status=Statusw Quantity_issued_so_far=recmrsf.Issued_Quantity Material_Req_Exis_ID=gin_without_mrq ] } //For GIN Validtaions for each rec in input.Item_Details { if(rec.Issued_Quantity != null || rec.Issued_Quantity != 0) { rec.Material_Request_No=str; //below is new code to handle when items are in multiple times with different places. getinventory = Inventory[Part_No == rec.Part_No] sort by Total_Qty desc; info getinventory; if(getinventory.count() > 0) { balqty = 0; i = 1; for each inventrec in getinventory { //Issued Quantiy is less total qty if(rec.Issued_Quantity <= inventrec.Total_Qty && i == 1) { inventrec.Total_Qty=ifnull(inventrec.Total_Qty,0.0) - ifnull(rec.Issued_Quantity,0.0); inventrec.Available_Qty=ifnull(inventrec.Available_Qty,0.0) - ifnull(rec.Issued_Quantity,0.0); } //Issued Quantity is more total qty else if(rec.Issued_Quantity > inventrec.Total_Qty && i == 1) { balqty = ifnull(rec.Issued_Quantity,0.0) - ifnull(inventrec.Total_Qty,0.0); inventrec.Total_Qty=0; inventrec.Available_Qty=0; } //for first time it should not get inside the loop if(balqty > 0 && i > 1) { info "balaance qty is more than zero"; //Balance Qty is less if(balqty <= inventrec.Total_Qty) { info "balance qty is less than total qty"; inventrec.Total_Qty=ifnull(inventrec.Total_Qty,0.0) - ifnull(balqty,0.0); inventrec.Available_Qty=ifnull(inventrec.Available_Qty,0.0) - ifnull(balqty,0.0); balqty = 0; } //Balance Qty is More else if(balqty >= inventrec.Total_Qty) { info "balance qty is greater than total qty"; balqty = ifnull(balqty,0.0) - ifnull(inventrec.Total_Qty,0.0); inventrec.Total_Qty=0; inventrec.Available_Qty=0; } } if(balqty == 0) { info "before break"; break; } i = i + 1; } iss_qty = 0; ava_qty = 0; bal_qty = 0; bat = Stock_Batch[Part_No == rec.Part_No && Part_Description == rec.Part_Description && Status != "Issued" && Warehouse == input.Warehouse && Location == rec.Location && Sub_Location == rec.Sub_Location && Racks_Bins == rec.Racks_Bins]; bat_no_list = List(); iss_qty = rec.Issued_Quantity; for each i1 in bat { bat_no = Stock_Batch[ID == i1].Batch_No; bat_no_list.add(bat_no); } info bat_no_list; i = 0; for each no in bat_no_list { batching = Stock_Batch[Batch_No == no]; ava_qty = batching.Available_Quantity; i = i + 1; if(i == 1 && iss_qty > ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = iss_qty - ava_qty; } else if(i == 1 && iss_qty < ava_qty) { batching.Status="Partially Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=ava_qty - iss_qty; bal_qty = 0; } else if(i == 1 && iss_qty == ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = 0; } else if(i > 1 && bal_qty > ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=0; bal_qty = bal_qty - ava_qty; } else if(i > 1 && bal_qty < ava_qty) { batching.Status="Partially Issued"; batching.Issued_Qty_So_far=iss_qty; batching.Available_Quantity=ava_qty - bal_qty; bal_qty = 0; } else if(i > 1 && bal_qty == ava_qty) { batching.Status="Issued"; batching.Issued_Qty_So_far=bal_qty; batching.Available_Quantity=0; bal_qty = 0; } } // Updating Stock value temp_issued_qty = rec.Issued_Quantity; ival = 0; bal = 0; if(temp_issued_qty != 0) { } } } } //Insert / Update the Issued Details for each Itemdetrec in input.Item_Details { insert into Inventory_Ageing [ Added_User=zoho.loginuser Part_No=Itemdetrec.Part_No Part_Description=Itemdetrec.Part_Description Specification=Itemdetrec.Specification Issued_Stock=Itemdetrec.Issued_Quantity Stock_Added_Issued_Date=zoho.currentdate ] } getdeptname = Department[ID == input.Issued_Empolyee_Department].Department_Name; //The code below is to get Project cost posum = 0; fc = 0; for each rec in input.Item_Details { fet_posub = Purchase_Order_Subform[Part_No == rec.Part_No]; if(rec.Part_No == fet_posub.Part_No) { posum = posum + ifnull(fet_posub.Rate,0.00); finalcost = fet_posub.Rate * rec.Issued_Quantity; } else { fet_venSub = Vendor_Contract_Subform[Part_Description == rec.Part_Description].maximum(Unit_Price); posum = posum + ifnull(fet_venSub,0.00); finalcost = ifnull(fet_posub.Rate,0.0) * ifnull(rec.Issued_Quantity,0.0); } fc = fc + finalcost; } input.Project_Cost = fc; input.Project_Rate = posum; //below code is to update in zoho project form if(input.Project_Name.Project_Title != null) { Fet_ZohoProject = Zoho_Projects_Data[ID == input.Project_Name]; if(Fet_ZohoProject.GIN_Item_Total_Amount == 0 || Fet_ZohoProject.GIN_Item_Total_Amount == null) { Fet_ZohoProject.GIN_Item_Total_Amount=ifnull(input.Project_Cost,0.00); } else { Fet_ZohoProject.GIN_Item_Total_Amount=ifnull(Fet_ZohoProject.GIN_Item_Total_Amount,0.00) + Ifnull(input.Project_Cost,0.00); } } //THE Below function write the record in stock ledger. thisapp.Stock_Ledger.Quantity_out_for_Stock_Ledger(input.ID); for each itemrec in input.Item_Details { //if(itemrec.Part_No.Part_No == "100166" || itemrec.Part_No.Part_No == "100044") if(itemrec.Part_No.Part_No == "100166") { //thisapp.Books.Adjust_Item_Inventory_in_zbooks(itemrec.ID); //thisapp.Inventory.update_books_stock_details(itemrec.ID); } } if(var == 1) { openUrl("#Form:Alert_Messages?Status=" + "GIN" + "&Value=" + input.GIN_Number + "&zc_LoadIn=dialog","same window"); } else { openUrl("#Form:GIN","same window"); } } catch (e) { sendmail [ from :"erp@carrierwheels.com" to :"parthasarathy.m@synprosoft.com" subject :"GIN Created Or Edited Successful Form Submission try & catch" + input.ID message :e ] }
emptylist = List(); //move the status into form mode to handle. if(input.Form_Mode == null || input.Form_Mode == "") { input.Form_Mode = "Direct GIN"; //info Form_Mode; } if(input.Status == "GIN against MRQ" && input.Material_Request_Subform_record_id != emptylist || input.Material_Request_Subform_record_id != null) { input.Form_Mode = "GIN against MRQ"; hide Item_Details.Available_Qty; hide Item_Details.Block_Qty; input.Status = ""; matreqsf = Material_Request_Subform[ID == input.Material_Request_Subform_record_id]; Material_Req_Exis_ID = matreqsf.Material_Req_Exis_ID; mat_req = Material_Request[ID == Material_Req_Exis_ID]; input.Material_Request_RECID = Material_Req_Exis_ID; input.Warehouse = matreqsf.Material_Req_Exis_ID.Warehouse; input.Work_Order_No = matreqsf.Material_Req_Exis_ID.Work_Order_No; input.Finished_Good = mat_req.FG_Part_Description; mrn = mat_req.Material_Request_No; input.Project_Name = Zoho_Projects_Data[ID == mat_req.Project_Name].ID; input.Machine_Name = Machine_Master[ID == mat_req.Machine_Name].ID; input.Status = "Draft"; input.Request_raised_By = mat_req.Request_Raised_By; //input.Department = Department[ID==mat_req.Department].Department_Name; input.Request_Date = mat_req.Request_Date; //info mat_req.Material_Type; input.Material_Request_Type = mat_req.Material_Type; //input.Project_Name = ifnull(mat_req.Project_Name,""); row1 = Goods_Issued_Note.Item_Details(); i = 0; grstot = 0; for each i1 in matreqsf { i = i + 1; //Store will issue Itmes from Satellite stores and engineering stores - erp channel - 14/12/2024 from user. //inv = Inventory[Part_No == i1.Part_No && Warehouse == input.Warehouse && Total_Qty > 0]; inv = Inventory[Part_No == i1.Part_No && Warehouse == input.Warehouse && Total_Qty > 0 && Location_Name.Location__Name == "Satellite Stores" || Location_Name.Location__Name == "Engineering Stores"]; //info inv; fet_stockvalue = Stock_Value[Part_No == i1.Part_No] sort by Unit_Price desc; row1.S_No=i; row1.Part_No=i1.Part_No; row1.Part_Description=i1.Part_Description; row1.Material_Type=i1.Material_Type; row1.Unit_of_Measurement=i1.UoM; row1.Required_Quantity=ifnull(i1.Required_Qty,0.00); row1.Quantity_issued_so_far=ifnull(i1.Quantity_issued_so_far,0); row1.Specification=i1.Specification; if(i1.Quantity_issued_so_far > 0 && i1.Required_Qty > 0) { if(i1.Quantity_issued_so_far > i1.Required_Qty) { row1.Issued_Quantity=ifnull(i1.Quantity_issued_so_far,0) - ifnull(i1.Required_Qty,0); } } else { row1.Issued_Quantity=ifnull(i1.Required_Qty,0); } //row1.Issued_Quantity=ifnull(i1.Required_Qty,0) - ifnull(i1.Quantity_issued_so_far,0); //row1.Sub_Total=row1.Issued_Quantity * row1.Rate; //new function is written to calculate the rate by Mr.Varun - dt 5/12/2023 - Mail on 5/12/2023 //row1.Rate=fet_stockvalue.Unit_Price; getrate = thisapp.Stock_Value.Average_Stock_Value(row1.Part_No,row1.Issued_Quantity); row1.Rate=ifnull(getrate,0); if(row1.Issued_Quantity > 0 && row1.Rate > 0) { sub = ifnull(row1.Issued_Quantity,0) * ifnull(row1.Rate,0); } grstot = ifnull(grstot,0) + ifnull(sub,0); //row1.Sub_Total=sub; row1.Value=sub; row1.Balance_Quantity=0.00; row1.Stock_Quantity=ifnull(inv.Total_Qty,0.00); row1.Available_Qty=ifnull(inv.Available_Qty,0.00); row1.Block_Qty=ifnull(inv.Block_Qty,0.00); row1.Work_Order_No=i1.Work_Order_No; row1.Sales_Order_No=i1.Sales_Order_No; row1.Material_Request_No=Material_Req_Exis_ID.Material_Request_No; row1.Material_Request_Subform_lu=i1.ID; row1.Material_type_from_mrq=Material_Req_Exis_ID.Material_Type; row1.Location=inv.Location_Name.getall(); row1.Sub_Location=inv.Sub_Location.getall(); row1.Racks_Bins=inv.Rack_Number.getall(); input.Item_Details.insert(row1); } input.Grand_Total1 = grstot; for each row2 in input.Item_Details { if(row2.Racks_Bins != null) { ava = 0; for each i1 in row2.Racks_Bins { inv2 = Inventory[Warehouse == input.Warehouse && Part_No == row2.Part_No && Location_Name == row2.Location && Sub_Location == row2.Sub_Location && Rack_Number == i1 && Total_Qty > 0]; //info inv2; ava = ava + ifnull(inv2.Available_Qty,0.0); } row2.Stock_Quantity=ifnull(ava,0.00); row2.Qty_after_Issued=ifnull(row2.Stock_Quantity,0.0) - ifnull(row2.Issued_Quantity,0.0); //info row2.Qty_after_Issued; } } disable Request_raised_By; disable Request_Date; disable Material_Request_Type; } else if(input.Form_Mode == "GIN against WO") { disable Item_Details.Available_Qty; disable Item_Details.Block_Qty; input.Status = ""; matreqsf = Material_Request_Subform[ID == input.Material_Request_Subform_record_id]; Material_Req_Exis_ID = matreqsf.Material_Req_Exis_ID; mat_req = Material_Request[ID == Material_Req_Exis_ID]; input.Material_Request_RECID = Material_Req_Exis_ID; input.Warehouse = matreqsf.Material_Req_Exis_ID.Warehouse; input.Work_Order_No = matreqsf.Material_Req_Exis_ID.Work_Order_No; input.Finished_Good = mat_req.FG_Part_Description; mrn = mat_req.Material_Request_No; input.Project_Name = Zoho_Projects_Data[ID == mat_req.Project_Name].ID; input.Machine_Name = Machine_Master[ID == mat_req.Machine_Name].ID; input.Status = "Draft"; input.Request_raised_By = mat_req.Request_Raised_By; input.Request_Date = mat_req.Request_Date; input.Material_Request_Type = mat_req.Material_Type; partno_list = List(); qtylist = List(); mymap = Map(); qtymap = Map(); for each bomrec in matreqsf { partno_list.add(bomrec.Part_No); qtyvar = ifnull(qtymap.get(bomrec.Part_No),0) + bomrec.Required_Qty; qtymap.put(bomrec.Part_No,qtyvar); //partno_list.add(bomrec.Required_Qty); } partno_list.sort(); i = 0; grstot = 0; for each recpartlist in partno_list.distinct() { row1 = Goods_Issued_Note.Item_Details(); mrqsflist = Material_Request_Subform[ID = input.Material_Request_Subform_record_id && Part_No == recpartlist]; mymap.put("Partno",recpartlist); mymap.put("partdesc",mrqsflist.Part_Description); i = i + 1; getinv = Inventory[Part_No == mrqsflist.Part_No && Warehouse == input.Warehouse && Total_Qty > 0]; getin = Inventory[Part_No == mrqsflist.Part_No && Location_Name.Location__Name != "Production WIP"].sum(Total_Qty); ////Store will issue Itemss from Satellite stores and engineering stores - erp channel - 14/12/2024 from user. getstokqty = Inventory[Part_No == mrqsflist.Part_No && Warehouse == input.Warehouse && Total_Qty > 0 && Location_Name.Location__Name == "Satellite Stores" || Location_Name.Location__Name == "Engineering Stores"].sum(Total_Qty); //info "getstokqty " + getstokqty; fet_stockvalue = Stock_Value[Part_No == mrqsflist.Part_No] sort by Unit_Price desc; row1.S_No=i; row1.Part_No=recpartlist; row1.Part_Description=mrqsflist.Part_Description; row1.Material_Type=mrqsflist.Material_Type; row1.Unit_of_Measurement=mrqsflist.UoM; qtv = qtymap.get(mrqsflist.Part_No); //info "line 155 qty " + qtv; row1.Required_Quantity=qtv; row1.Quantity_issued_so_far=ifnull(mrqsflist.Quantity_issued_so_far,0); row1.Specification=mrqsflist.Specification; if(mrqsflist.Quantity_issued_so_far > 0 && mrqsflist.Required_Qty > 0) { if(mrqsflist.Quantity_issued_so_far > qtv) { row1.Issued_Quantity=ifnull(mrqsflist.Quantity_issued_so_far,0) - ifnull(qtv,0); } else if(mrqsflist.Quantity_issued_so_far < qtv) { row1.Issued_Quantity=ifnull(qtv,0) - ifnull(mrqsflist.Quantity_issued_so_far,0); } } else { row1.Issued_Quantity=ifnull(qtv,0); } getrate = thisapp.Stock_Value.Average_Stock_Value(row1.Part_No,row1.Issued_Quantity); if(getrate == null) { getrate = Stock_Value[Part_No == row1.Part_No && Unit_Price > 0].Unit_Price sort by Added_Time asc; } if(getrate > 0 || getrate != null) { row1.Rate=ifnull(getrate,0); sub = ifnull(row1.Issued_Quantity,0) * ifnull(row1.Rate,0); } grstot = ifnull(grstot,0) + ifnull(sub,0); //row1.Sub_Total=sub; row1.Value=sub; row1.Balance_Quantity=0.00; //Stock Quantity should be from engineering and satellite locations only - 16/12/2024 //row1.Stock_Quantity=ifnull(getinv.Total_Qty,0.00); // row1.Stock_Quantity=ifnull(getin,0); row1.Stock_Quantity=ifnull(getstokqty,0); row1.Available_Qty=ifnull(getinv.Available_Qty,0.00); row1.Block_Qty=ifnull(getinv.Block_Qty,0.00); row1.Work_Order_No=mrqsflist.Work_Order_No; row1.Sales_Order_No=mrqsflist.Sales_Order_No; row1.Material_Request_No=Material_Req_Exis_ID.Material_Request_No; row1.Material_Request_Subform_lu=mrqsflist.ID; row1.Material_type_from_mrq=Material_Req_Exis_ID.Material_Type; // row1.Location=getinv.Location_Name.getall(); // row1.Sub_Location=getinv.Sub_Location.getall(); // row1.Racks_Bins=getinv.Rack_Number.getall(); input.Item_Details.insert(row1); } input.Grand_Total1 = grstot; for each row2 in input.Item_Details { if(row2.Racks_Bins != null) { ava = 0; for each mrqsflist in row2.Racks_Bins { ////Store will issue Itemss from Satellite stores and engineering stores - erp channel - 14/12/2024 from user. //inv2 = Inventory[Warehouse == input.Warehouse && Part_No == row2.Part_No && Location_Name == row2.Location && Sub_Location == row2.Sub_Location && Rack_Number == mrqsflist && Total_Qty > 0]; inv2 = Inventory[Warehouse == input.Warehouse && Part_No == row2.Part_No && Location_Name.Location__Name == "Satellite Stores" || Location_Name.Location__Name == "Engineering Stores" && Rack_Number == mrqsflist && Total_Qty > 0]; //info inv2; ava = ava + ifnull(inv2.Available_Qty,0.0); } row2.Stock_Quantity=ifnull(ava,0.00); row2.Qty_after_Issued=ifnull(row2.Stock_Quantity,0.0) - ifnull(row2.Issued_Quantity,0.0); //info row2.Qty_after_Issued; } } disable Request_raised_By; disable Request_Date; disable Material_Request_Type; }
getmrp = MRP[Work_Order_Subform_ID == input.ID]; getmrpsub = MRP_Subform_CWPL[MRP_Exis_ID == getmrp.ID]; fet_wosub = Work_Order_Subform[ID == input.ID]; fet_wo = Work_Order[ID == fet_wosub.Work_Order_Exis_ID]; fet_bom = Create_BOM[Part_No == fet_wosub.Part_No]; fetsubbom = BoM_FG_Subform[BOM_FG_Exis_ID == fet_bom.ID]; //info fetsubbom.count(); if(fetsubbom.count() == 0) { openUrl("#Form:Alert_Messages?Status=MRPbom_Alert&Value=BoM not created! Create BoM for this Material. &zc_LoadIn=dialog","same window"); } else if(getmrp.MRP_Status == null && fet_wosub.WO_Qty != 0) { openUrl("#Form:MRP?Work_Order_Subform_ID=" + input.ID,"same window"); } else if(getmrp.MRP_Status == "MRP Reverted") { openUrl("#Form:MRP?Work_Order_Subform_ID=" + input.ID,"same window"); } else if(fet_wosub.Work_Order_Status == "MRP Rejected") { openUrl("#Form:MRP?Work_Order_Subform_ID=" + input.ID,"same window"); } else if(getmrp.MRP_Status == "Draft") { openUrl("#Form:MRP?recLinkID=" + getmrp.ID + "&viewLinkName=MRP_Report&Form_Mode=DraftMRP","same window"); } else if(fet_wosub.WO_Qty <= 0) { openUrl("#Form:Alert_Messages?Status=MRP_Alert&Value=Stock available for this WorkOrder. <br>Not Required MRP! &zc_LoadIn=dialog","same window"); } else { openUrl("#Form:MRP?Work_Order_Subform_ID=" + input.ID,"same window"); }
void Dispatch_Note.Dispatch(int ID) { openUrl("#Form:Create_Dispatch_Note_Format?recLinkID=" + ID + "&viewLinkName=Dispatch_Note_Actual&Dispatch_Type=Actual","popup window"); }
for each deliv in input.Despatch_Schedule { if(deliv.Part_No == row.Part_No) { deliv.Full_Quantity=false; } } for each r in input.Despatch_Schedule { b = r.S_No - 1; r.S_No=b; if(r.S_No < row.S_No) { b = b + 1; r.S_No=b; } }
for each r in input.Item_Details { b = ifnull(r.S_No,0) - 1; r.S_No=b; if(r.S_No < row.S_No) { b = b + 1; r.S_No=b; } } input.Gross_Total = ifnull(input.Gross_Total,0.0) - ifnull(row.Sub_Total,0.0); input.Total_Quantity = ifnull(input.Total_Quantity,0.0) - ifnull(row.Qty,0.0); if(input.Gross_Total == 0) { input.Gross_Total = 0; input.Total_Quantity = null; input.Discount = null; input.Discount_Amount = 0; input.Discount_Amount = null; hide Discount_Amount; input.Discount_Percentage = null; hide Discount_Percentage; input.Final_Gross_Total = 0; input.Total_Taxes = null; input.Grand_Total = null; input.Gross_with_Discount = null; input.Gross_Value_Tax = null; input.Gross_Total_with_Discount = null; input.Packing_Forwarding = null; input.PF_Total_with_tax = null; input.PF_Tax_value = null; } for each rec in input.Despatch_Schedule { if(rec.Part_No == row.Part_No) { rec.Part_No=null; rec.Quantity=null; rec.Delivery_Date=null; } } itemlist = List(); qtyList = List(); dateList = List(); remarksList = List(); fullQtyList = List(); for each rec in input.Despatch_Schedule { if(rec.Part_No != null) { itemlist.add(rec.Part_No); qtyList.add(rec.Quantity); dateList.add(rec.Delivery_Date); remarksList.add(rec.Remarks); fullQtyList.add(rec.Full_Quantity); } } input.Despatch_Schedule.clear(); i = 0; s_no = 0; for each items in itemlist { s_no = s_no + 1; row1 = Sales_Order.Despatch_Schedule(); row1.S_No=s_no; row1.Part_No=items; row1.Quantity=qtyList.get(i); row1.Delivery_Date=dateList.get(i); row1.Remarks=remarksList.get(i); row1.Full_Quantity=fullQtyList.get(i); input.Despatch_Schedule.insert(row1); i = i + 1; } //Grand total adjustment input.Grand_Total = ifnull(input.Grand_Total,0.0) - ifnull(row.Total_Amount,0.0);
i = 0; for each rec_sn in input.Despatch_Schedule { i = i + 1; row.S_No=i; } //For Delivery Schedule clear row.Part_No; item_list = List(); deliv_list = List(); for each an_item in input.Item_Details { item_list.add(an_item.Part_Description); } for each deliv in input.Despatch_Schedule { if(deliv.Part_No != null && deliv.Full_Quantity == true) { deliv_list.add(deliv.Part_No); } } item_list.removeAll(deliv_list); row.Part_No:ui.add(item_list.sort(true)); if(item_list.size() > 0) { row.Part_No=item_list.get(0); //Setting Quantity for each rec in input.Item_Details { if(rec.Qty < 1) { alert "Please enter quantity for all the item(s) in Item Details "; row.Quantity=null; } else { tot = 0.0; for each rec1 in input.Despatch_Schedule { if(rec1.Part_No == rec.Part_Description) { tot = tot + ifnull(rec1.Quantity,0.0); } } if(rec.Part_Description == row.Part_No) { row.Quantity=if(tot > 0,rec.Qty - tot,rec.Qty); row.Delivery_Date=if(tot > 0,null,input.Expected_Shipment_Date); row.Specification=rec.Remarks_multiline; row.Full_Quantity=true; } } } }
i = 0; for each rec_sn in input.Item_Details { i = i + 1; row.S_No=i; } //item details part no should be loaded from customer pricing master based on customer selected as per user requirement-7/3/2023,if not in master then load asusal clear row.Part_No; clear row.Part_Description; if(input.Sales_Type != "Tooling" && input.Sales_Type != "Research & Development Charges") { getcust = Customer_Pricing_Master[Customer_Name == input.Customer_Name && Status == "Active"]; if(getcust.count() > 0) { //Remove the Part No available in Regular Item master for contract- User Requirement - MR.Senthil - 14/03/2024 - will open after production //if input.Sales_Type == "Contract" //{ //regularitem = Regular_Item_Master[ID != 0].Part_No.getAll(); //get_active = Customer_Pricing_subform[Customer_Pricing_Master_Recid == getcust.ID && sf_Status == "Active" && Part_No != regularitem].Part_No.getAll(); //} //else // { get_active = Customer_Pricing_subform[Customer_Pricing_Master_Recid == getcust.ID && sf_Status == "Active"].Part_No.getAll(); // } //info get_active; row.Part_No:ui.add(get_active); //To restrict choosing same items clear row.Part_Description; //Remove the Part No available in Regular Item master for contract- User Requirement - MR.Senthil - 14/03/2024 - will open after production //if input.Sales_Type == "Contract" //{ //regularitem = Regular_Item_Master[ID != 0].Part_No.getAll(); //get_active = Customer_Pricing_subform[Customer_Pricing_Master_Recid == getcust.ID && sf_Status == "Active" && Part_No != regularitem].Part_No.getAll(); //} //else // { prdcts = Customer_Pricing_subform[ID == getcust.ID && sf_Status == "Active"].Part_No.getAll(); // } addproduct = List(); addproduct.addAll(prdcts); remproduct = List(); for each prd in input.Item_Details { if(prd.Part_No != 0) { toadd = Materials[ID == prd.Part_Description].ID; remproduct.add(toadd); } } addproduct.removeAll(remproduct); row.Part_Description:ui.add(addproduct); clear row.Part_No; //Remove the Part No available in Regular Item master for contract- User Requirement - MR.Senthil - 14/03/2024 - will open after production //if input.Sales_Type == "Contract" //{ //regularitem = Regular_Item_Master[ID != 0].Part_No.getAll(); //get_active = Customer_Pricing_subform[Customer_Pricing_Master_Recid == getcust.ID && sf_Status == "Active" && Part_No != regularitem].Part_No.getAll(); //} //else // { prdcts = Customer_Pricing_subform[Customer_Pricing_Master_Recid == getcust.ID && sf_Status == "Active"].Part_No.getAll(); //} addproduct = List(); addproduct.addAll(prdcts); remproduct = List(); for each prd in input.Item_Details { if(prd.Part_No != 0) { toadd = Materials[ID == prd.Part_No].ID; remproduct.add(toadd); } } addproduct.removeAll(remproduct); row.Part_No:ui.add(addproduct); } } else { //New Sale type Research & Development Charges - Mail Dated 29/11/2023 -Parthasarathy if(input.Sales_Type == "Tooling") { prdcts = Materials[Category.Category == "Tooling" && Status == "Active"].ID.getAll(); } else if(input.Sales_Type == "Research & Development Charges") { prdcts = Materials[Category.Category == "R&D" && Status == "Active"].ID.getAll(); } addproduct = List(); addproduct.addAll(prdcts); remproduct = List(); for each prd in input.Item_Details { if(prd.Part_Description != 0) { toadd = Materials[ID == prd.Part_Description].ID; remproduct.add(toadd); } } addproduct.removeAll(remproduct); row.Part_Description:ui.add(addproduct); clear row.Part_No; if(input.Sales_Type == "Tooling") { prdcts = Materials[Category.Category == "Tooling" && Status == "Active"].ID.getAll(); } else if(input.Sales_Type == "Research & Development Charges") { prdcts = Materials[Category.Category == "R&D" && Status == "Active"].ID.getAll(); } addproduct = List(); addproduct.addAll(prdcts); remproduct = List(); for each prd in input.Item_Details { if(prd.Part_No != 0) { toadd = Materials[ID == prd.Part_No].ID; remproduct.add(toadd); } } addproduct.removeAll(remproduct); row.Part_No:ui.add(addproduct); } //below code is blocked as per user request - 01/04/2023 /*if(getcust.count() == 0) { clear row.Part_No; clear row.Part_Description; prdcts = Materials[ID != 0 && Material_Item_Type.Material_Type == "CWPL Products" && CRM_Sync == "Yes"].ID.getAll(); addproduct = List(); addproduct.addAll(prdcts); remproduct = List(); for each prd in input.Item_Details { if(prd.Part_Description != 0) { toadd = Materials[ID == prd.Part_Description].ID; remproduct.add(toadd); } } addproduct.removeAll(remproduct); row.Part_Description:ui.add(addproduct); clear row.Part_No; prdcts = Materials[ID != 0 && Material_Item_Type.Material_Type == "CWPL Products" && CRM_Sync == "Yes"].ID.getAll(); addproduct = List(); addproduct.addAll(prdcts); remproduct = List(); for each prd in input.Item_Details { if(prd.Part_No != 0) { toadd = Materials[ID == prd.Part_No].ID; remproduct.add(toadd); } } addproduct.removeAll(remproduct); row.Part_No:ui.add(addproduct); }*/
Created or Edited -> User input of Item Details.Part_Description -> ItemDeatils_PartDesc_Validations
if(row.Part_Description != null) { check_same_item = 0; for each rec in input.Item_Details { if(rec.Part_Description == row.Part_Description) { check_same_item = check_same_item + 1; } } if(check_same_item == 2) { alert "You have already entered the same item"; row.Part_Description=null; } else { mat_data = Materials[ID == row.Part_Description]; row.Rate=ifnull(mat_data.Selling_Price,0.0); row.Part_No=mat_data.ID; /*-------------------------Tax Showing----------------------------*/ if(input.Place_of_Supply.Inside_India == "Yes") { tax_det = if(input.Customer_Name.Destination.Short_Name == "" || input.Customer_Name.Destination.Short_Name == null,if(input.Place_of_Supply.Short_Name == "TN",mat_data.GST_Details,mat_data.IGST_Details),if(input.Customer_Name.Destination.Short_Name == "TN",mat_data.GST_Details,mat_data.IGST_Details)); } else { tax_det = GST_Details[Tax_Name == "IGST0"].ID; } /*-----------------------End-------------------------------------------------------------------------------*/ row.Tax=tax_det; row.UoM=row.Part_Description.Primary_UoM; row.Remarks_multiline=row.Part_Description.Specification; //Check Stock Summary row.Stock_FG_Qty=ifnull(Inventory[Part_No == row.Part_No && Part_Description == row.Part_Description].Available_Qty,0.0); } }
if(row.Part_No != null) { mat_data = Materials[ID == row.Part_No]; getcustdet = Customer_Pricing_subform[Part_No == row.Part_No && Customer_Name == input.Customer_Name && sf_Status == "Active"]; if(getcustdet.count() > 0) { getcustdet = Customer_Pricing_subform[Part_No == row.Part_No && Customer_Name == input.Customer_Name && sf_Status == "Active"]; row.Part_Description=getcustdet.Part_Description; row.UoM=Materials[ID == getcustdet.Part_No].Primary_UoM; // row.Rate=getcustdet.Price; row.Rate=getcustdet.Settled_Price; row.Tax=getcustdet.Tax; row.Packing_Std=getcustdet.Packaging; row.Customer_Part_Code=getcustdet.Customer_Part_Code; row.HSN_Code=mat_data.HSN_SAC; row.Classification=mat_data.Classification; } if(getcustdet.count() == 0 && input.Sales_Type == "Tooling" || input.Sales_Type == "Research & Development Charges") { row.Part_Description=mat_data.ID; if(input.Place_of_Supply.Inside_India == "Yes") { if(input.Place_of_Supply.Short_Name == "UP") { row.Tax=row.Part_No.GST_Details; } else { row.Tax=row.Part_No.IGST_Details; } } //row.Tax=tax_det; } row.UoM=row.Part_Description.Primary_UoM; row.Stock_FG_Qty=ifnull(Inventory[Part_No == row.Part_No].sum(Available_Qty),0.0); row.Stock_SFG_Qty=ifnull(Semi_Finished_Goods_Summary[Part_No == row.Part_No && Part_Description == row.Part_Description && Warehouse == input.Warehouse].Available_Qty,0.0); } else { row.Part_Description=null; row.Remarks_multiline=null; row.Rate=null; row.Stock_FG_Qty=0.0; row.Stock_SFG_Qty=0.0; } for each rec in input.Despatch_Schedule { if(rec.Part_No == row.Part_No) { rec.Part_No=null; } } for each var in input.Item_Details { row.Blocke_Qty=Inventory[Part_No == row.Part_No && Part_Description == row.Part_Description].Block_Qty; } if(input.Place_of_Supply.Short_Name != "UP") { if(row.Tax != null) { if(row.Tax.Tax_Name.startswith("G") == True) { alert "Tax should be IGST for this customer.Tax configured as " + row.Tax.Tax_Name + " Pls check"; row.Tax=null; } } } //set the tax percentage since its same for all the line items input.TaxP = row.Tax; if(row.Rate != null && row.Qty != null && row.Tax != null) { get_tax_value = GST_Details[ID == ifnull(row.Tax,"")].Total_Rate; Tax_calc = ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0) * ifnull(get_tax_value,0.0) / 100; amount_calc = ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0); row.Sub_Total=ifnull(amount_calc,0.00); row.Tax_Value=Tax_calc; row.Total_Amount=ifnull(amount_calc,0.0) + ifnull(Tax_calc,0.0); tot = 0.0; totqty = 0.0; subtot = 0.0; for each rec1 in Item_Details { tot = tot + ifnull(rec1.Total_Amount,0.0); totqty = totqty + ifnull(rec1.Qty,0.0); subtot = subtot + ifnull(rec1.Sub_Total,0.0); } input.Item_Total = tot; input.Overall_Total = ifnull(input.Item_Total,0.0) + ifnull(input.Extra_Charge_s_Total,0.0); //new field calculation starts here - 1/4/2023 input.Total_Quantity = ifnull(totqty,0.0); input.Gross_Total = ifnull(subtot,0.0); input.Gross_with_Discount = ifnull(input.Gross_Total,0.0); if(input.Discount_Amount > 0) { input.Gross_with_Discount = ifnull(input.Gross_Total,0.0) - ifnull(input.Discount_Amount,0.0); input.Overall_Total = ifnull(input.Overall_Total,0.0) - ifnull(input.Discount_Amount,0.0); } else { input.Gross_with_Discount = ifnull(input.Gross_with_Discount,0.0); } get_tax_value = GST_Details[ID == ifnull(input.TaxP,"")].Total_Rate; if(get_tax_value == 0) { input.Gross_Value_Tax = 0; } else { Tax_calc = ifnull(input.Gross_with_Discount,0.0) * ifnull(get_tax_value,0.0) / 100; input.Tax_Total = ifnull(Tax_calc,0.0); input.Gross_Value_Tax = ifnull(Tax_calc,0.0); input.Gross_Total_with_Discount = ifnull(input.Gross_with_Discount,0.0) + ifnull(input.Gross_Value_Tax,0.0); } if(input.Packing_Forwarding > 0) { Tax_calc1 = ifnull(input.Packing_Forwarding,0.0) * ifnull(get_tax_value,0.0) / 100; input.PF_Tax_value = ifnull(Tax_calc1,0.0); input.PF_Total_with_tax = ifnull(input.Packing_Forwarding,0.0) + ifnull(input.PF_Tax_value,0.0); } input.Grand_Total = ifnull(input.Gross_Total_with_Discount,0.0) + ifnull(input.PF_Total_with_tax,0.0); //new fields calculation ends }
if(row.Rate != null && row.Qty != null && row.Tax != null) { get_tax_value = GST_Details[ID == row.Tax].Total_Rate; Tax_calc = ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0) * ifnull(get_tax_value,0.0) / 100; amount_calc = row.Qty * row.Rate; row.Sub_Total=ifnull(amount_calc,0.00); row.Tax_Value=Tax_calc; row.Total_Amount=ifnull(amount_calc,0.0) + ifnull(Tax_calc,0.0); tot = 0.0; for each rec in Item_Details { tot = tot + ifnull(rec.Total_Amount,0.0); } input.Item_Total = tot; input.Overall_Total = ifnull(input.Item_Total,0.0) + ifnull(input.Extra_Charge_s_Total,0.0); // // new fields caluclation - 1/4/2023 - stats // input.Gross_Total = ifnull(input.Gross_Total,0.0) + ifnull(row.Sub_Total,0.0)+ifnull(input.Tax_Total,0.0); // input.Tax_Total = ifnull(input.Tax_Total,0.0)+ifnull(row.Tax_Value,0.0); // // new fields calculation ends } if(row.Tax == null) { row.Tax_Value=0.0; row.Total_Amount=ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0); tot1 = 0.0; for each rec in Item_Details { tot1 = tot1 + rec.Total_Amount; } input.Item_Total = tot1; input.Overall_Total = ifnull(input.Item_Total,0.0) + ifnull(input.Extra_Charge_s_Total,0.0); }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <h1> CHAI OR CODE </h1> <button id = "stop ">stop </button> </body> <script> ////////////////////***** 1 WAY ***////////////// setTimeout(function(){ consol.log("HITESH"); ///after 2 sec it will excute },2000) // only 1 time will excute ////////////////////***** 2 WAY ***////////////// const sayhitesh = function (){ console.log("tanishq"); } const changeText = function () { document.querySelector('h1').innerHTML = "best js course on yt"; // change the h1 }; const changeMe = setTimeout(changeText, 2000); // changeText will execute after 2 seconds document.querySelector('#stop'). //// function to stop the changetext option addEventListener('click', function () { // if we press stop button it will stop the excution of changing of h1 clearTimeout(changeMe) console.log("STOPPED") }) </script> </html>
//For Negative validation Check if(row.Rate < 0 && row.Rate != null) { alert "Please enter positive values"; row.Rate=null; } else { get_tax_value = GST_Details[ID == ifnull(row.Tax,"")].Total_Rate; Tax_calc = ifnull(row.Qty,0) * ifnull(row.Rate,0) * ifnull(get_tax_value,0) / 100; amount_calc = ifnull(row.Qty,0) * ifnull(row.Rate,0); row.Sub_Total=ifnull(amount_calc,0.00); row.Tax_Value=ifnull(Tax_calc,0); row.Total_Amount=ifnull(amount_calc,0) + ifnull(Tax_calc,0); //alert amount_calc + Tax_calc; tot = 0.0; subtot = 0.0; totqty = 0.0; for each rec in Item_Details { tot = tot + ifnull(rec.Total_Amount,0.0); totqty = totqty + ifnull(rec.Qty,0.0); subtot = subtot + ifnull(rec.Sub_Total,0.0); } input.Item_Total = tot; input.Overall_Total = tot + ifnull(input.Extra_Charge_s_Total,0.0); //new field calculation starts here - 1/4/2023 //input.Gross_Total = ifnull(input.Gross_Total,0.0) + ifnull(row.Sub_Total,0.0); //input.Grand_Total = ifnull(input.Gross_Total,0.0); input.Total_Quantity = ifnull(totqty,0.0); input.Gross_Total = ifnull(subtot,0.0); input.Gross_with_Discount = ifnull(input.Gross_Total,0.0); if(input.Discount_Amount > 0) { input.Gross_with_Discount = ifnull(input.Gross_Total,0.0) - ifnull(input.Discount_Amount,0.0); input.Overall_Total = ifnull(input.Overall_Total,0.0) - ifnull(input.Discount_Amount,0.0); } else { input.Gross_with_Discount = ifnull(input.Gross_with_Discount,0.0); } get_tax_value = GST_Details[ID == ifnull(input.TaxP,"")].Total_Rate; if(get_tax_value == 0) { input.Gross_Value_Tax = 0; // input.Grand_Total = ifnull(input.Gross_Total_after_Discount_PF,0.0); } else { Tax_calc = ifnull(input.Gross_with_Discount,0.0) * ifnull(get_tax_value,0.0) / 100; input.Tax_Total = ifnull(Tax_calc,0.0); input.Gross_Value_Tax = ifnull(Tax_calc,0.0); input.Gross_Total_with_Discount = ifnull(input.Gross_with_Discount,0.0) + ifnull(input.Gross_Value_Tax,0.0); // input.Grand_Total = ifnull(input.Gross_Total_after_Discount_PF,0.0) + ifnull(input.Tax_Total,0.0); } if(input.Packing_Forwarding > 0) { Tax_calc1 = ifnull(input.Packing_Forwarding,0.0) * ifnull(get_tax_value,0.0) / 100; input.PF_Tax_value = ifnull(Tax_calc1,0.0); input.PF_Total_with_tax = ifnull(input.Packing_Forwarding,0.0) + ifnull(input.PF_Tax_value,0.0); } input.Grand_Total = ifnull(input.Gross_Total_with_Discount,0.0) + ifnull(input.PF_Total_with_tax,0.0); //new fields calculation ends }
getsprice = Customer_Pricing_subform[Part_No == row.Part_No && Packaging == row.Packing_Std && Customer_Name == input.Customer_Name && sf_Status == "Active"]; row.Rate=getsprice.Settled_Price; if(row.Rate != null && row.Qty != null && row.Tax != null) { get_tax_value = GST_Details[ID == ifnull(row.Tax,"")].Total_Rate; Tax_calc = ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0) * ifnull(get_tax_value,0.0) / 100; amount_calc = ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0); row.Sub_Total=ifnull(amount_calc,0.00); row.Tax_Value=Tax_calc; row.Total_Amount=ifnull(amount_calc,0.0) + ifnull(Tax_calc,0.0); tot = 0.0; totqty = 0.0; subtot = 0.0; for each rec in Item_Details { tot = tot + ifnull(rec.Total_Amount,0.0); totqty = totqty + ifnull(rec.Qty,0.0); subtot = subtot + ifnull(rec.Sub_Total,0.0); } input.Item_Total = tot; input.Overall_Total = ifnull(input.Item_Total,0.0) + ifnull(input.Extra_Charge_s_Total,0.0); input.Total_Quantity = ifnull(totqty,0.0); //new field calculation starts here - 1/4/2023 input.Gross_Total = ifnull(subtot,0.0); if(input.Discount_Amount > 0) { input.Gross_with_Discount = ifnull(input.Gross_Total,0.0) - ifnull(input.Discount_Amount,0.0); } else { input.Gross_with_Discount = ifnull(input.Gross_Total,0.0); } get_tax_value = GST_Details[ID == ifnull(input.TaxP,"")].Total_Rate; if(get_tax_value == 0) { input.Gross_Value_Tax = 0; input.Gross_Total_with_Discount = ifnull(input.Gross_with_Discount,0.0); } else { Tax_calc = ifnull(input.Gross_with_Discount,0.0) * ifnull(get_tax_value,0.0) / 100; input.Tax_Total = ifnull(Tax_calc,0.0); input.Gross_Value_Tax = ifnull(Tax_calc,0.0); input.Gross_Total_with_Discount = ifnull(input.Gross_with_Discount,0.0) + ifnull(input.Gross_Value_Tax,0.0); } if(input.Packing_Forwarding > 0) { if(get_tax_value == 0) { Tax_calc1 = 0; } else { Tax_calc1 = ifnull(input.Packing_Forwarding,0.0) * ifnull(get_tax_value,0.0) / 100; } input.PF_Tax_value = ifnull(Tax_calc1,0.0); input.PF_Total_with_tax = ifnull(input.Packing_Forwarding,0.0) + ifnull(input.PF_Tax_value,0.0); } else { input.PF_Total_with_tax = 0; } input.Grand_Total = ifnull(input.Gross_Total_with_Discount,0.0) + ifnull(input.PF_Total_with_tax,0.0); //new fields calculation ends } //For Adding subtotal field if(row.Qty != null && row.Rate != null && row.Tax == null) { row.Sub_Total=row.Qty * row.Rate; } //rate is null if(row.Rate == null) { row.Sub_Total=null; row.Tax_Value=null; row.Total_Amount=null; }
//For Negative validation Check for each var in input.Item_Details { var.Balance_Qty=var.Qty; } if(row.Qty <= 0 && row.Qty != null) { alert "Please enter positive values"; row.Qty=null; } else { if(row.Rate != null && row.Qty != null && row.Tax != null) { get_tax_value = GST_Details[ID == ifnull(row.Tax,"")].Total_Rate; Tax_calc = ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0) * ifnull(get_tax_value,0.0) / 100; amount_calc = ifnull(row.Qty,0.0) * ifnull(row.Rate,0.0); row.Sub_Total=ifnull(amount_calc,0.00); row.Tax_Value=Tax_calc; row.Total_Amount=ifnull(amount_calc,0.0) + ifnull(Tax_calc,0.0); tot = 0.0; totqty = 0.0; subtot = 0.0; for each rec in Item_Details { tot = tot + ifnull(rec.Total_Amount,0.0); totqty = totqty + ifnull(rec.Qty,0.0); subtot = subtot + ifnull(rec.Sub_Total,0.0); } input.Item_Total = tot; input.Overall_Total = ifnull(input.Item_Total,0.0) + ifnull(input.Extra_Charge_s_Total,0.0); input.Total_Quantity = ifnull(totqty,0.0); //new field calculation starts here - 1/4/2023 input.Gross_Total = ifnull(subtot,0.0); if(input.Discount_Amount > 0) { input.Gross_with_Discount = ifnull(input.Gross_Total,0.0) - ifnull(input.Discount_Amount,0.0); } else { input.Gross_with_Discount = ifnull(input.Gross_Total,0.0); } get_tax_value = GST_Details[ID == ifnull(input.TaxP,"")].Total_Rate; if(get_tax_value == 0) { input.Gross_Value_Tax = 0; input.Gross_Total_with_Discount = ifnull(input.Gross_with_Discount,0.0); } else { Tax_calc = ifnull(input.Gross_with_Discount,0.0) * ifnull(get_tax_value,0.0) / 100; input.Tax_Total = ifnull(Tax_calc,0.0); input.Gross_Value_Tax = ifnull(Tax_calc,0.0); input.Gross_Total_with_Discount = ifnull(input.Gross_with_Discount,0.0) + ifnull(input.Gross_Value_Tax,0.0); } if(input.Packing_Forwarding > 0) { if(get_tax_value == 0) { Tax_calc1 = 0; } else { Tax_calc1 = ifnull(input.Packing_Forwarding,0.0) * ifnull(get_tax_value,0.0) / 100; } input.PF_Tax_value = ifnull(Tax_calc1,0.0); input.PF_Total_with_tax = ifnull(input.Packing_Forwarding,0.0) + ifnull(input.PF_Tax_value,0.0); } else { input.PF_Total_with_tax = 0; } input.Grand_Total = ifnull(input.Gross_Total_with_Discount,0.0) + ifnull(input.PF_Total_with_tax,0.0); //new fields calculation ends } //For Adding subtotal field if(row.Qty != null && row.Rate != null && row.Tax == null) { row.Sub_Total=row.Qty * row.Rate; } fet_deli = Delivery_Schedule[Part_No == row.Part_No]; if(fet_deli.count() >= 1) { if(row.Qty > fet_deli.sum(Quantity)) { fet_deli.Full_Quantity=false; } } }
if(row.Delivery_Date <= zoho.currentdate) { alert "Please enter future dates only"; row.Delivery_Date=null; } else if(row.Delivery_Date != null) { check_same_date = 0; coun = 1; for each rec in input.Despatch_Schedule { if(rec.Part_No == row.Part_No && rec.Delivery_Date == row.Delivery_Date) { check_same_date = check_same_date + 1; } } //alert check_same_date; if(check_same_date == 2) { alert "Already you have chosen the same date for the same item.Please Choose different delivery date"; row.Delivery_Date=null; } }
i = 0; for each rec in input.Product_Details { if(rec.S_NO != row.S_NO) { i = i + 1; rec.S_NO=i; } } //Another Deletion of row code for S_No below for each r in input.Returnable_Packing_Material { b = r.S_No - 1; r.S_No=b; if(r.S_No < row.S_No) { b = b + 1; r.S_No=b; } }
i = 0; for each rec in input.Returnable_Packing_Material { i = i + 1; row.S_No=i; }
if(input.Dispatch_Type == "Actual") { disp = 0; disp1 = 0; bal = 0; so = Sales_Order[ID == input.Sales_Order_ID]; wo = Work_Order[Sales_Order_Nos.Sale_Order_No == so.Sale_Order_No]; invmain = Invoice[ID == input.Invoice_ID]; invsub = Invoice_Subform[Invoice_Exist_ID == invmain.ID]; if(input.Sales_Type == "Direct Order" || input.Sales_Type == "Tooling") { if(so.CWPL_SO_Status == "Dispatch Note Partial") { so.CWPL_SO_Status="Invoice Created"; } } for each rec in input.Product_Details { invsub.Dispatch_Actual_Date_Time=rec.Disp_Actual_Date_Time; disp = ifNull(rec.Actual_Qty,0) + disp; rec.Ac_so_far=ifNull(rec.Actual_Qty_so_far,0) + ifNull(rec.Actual_Qty,0); rec.Balance_Qty=ifNull(rec.Balance_Qty,0) - ifNull(rec.Actual_Qty,0); rec.Edit_stk_qty=ifNull(rec.Actual_Qty,0); so = Sales_Order[ID == input.Sales_Order_ID]; bal = ifNull(rec.Balance_Qty,0) + bal; if(rec.Balance_Qty < 0 || rec.Balance_Qty == rec.Actual_Qty) { rec.Balance_Qty=0; } if(rec.Actual_Qty == rec.Planned_Qty) { rec.Sales_Lost_Qty=0.0; } getsosub = Sale_Order_Subform[Sales_Order_Exis_ID == so.ID && Part_No == rec.Product_Code]; if(so.count() > 0) { get_inven = Inventory[Part_No == rec.Product_Code && Location_Name.Location__Name == "FG Warehouse"]; getstk = Inventory[Part_No == rec.Product_Code && Location_Name.Location__Name == "FG Warehouse"]; fetwo = Work_Order[Sales_Order_Nos == input.Sales_Order_No]; blksosub = Sale_Order_Subform[Part_No == rec.Product_Code && Sales_Order_Exis_ID.Sale_Order_No == input.Sales_Order_No.Sale_Order_No]; wosub = Work_Order_Subform[Part_No == blksosub.Part_No]; getsoblk = Sales_Order[ID == input.Sales_Order_ID]; if(getsosub.Balance_Qty < 0 || getsosub.Balance_Qty == getsosub.Actual_Qty_So_far) { getsosub.Balance_Qty=0; } if(get_inven.count() > 0 && get_inven.Available_Qty > 0 && rec.Block_Qty == 0 && getsosub.DQR_Blk_Qty == null || getsosub.DQR_Blk_Qty <= 0 && getsosub.Logistics_Status != "Logistics Confirmed" || getsosub.Logistics_Status == "" || getsosub.Logistics_Status == null) { get_inven.Available_Qty=ifNull(get_inven.Available_Qty,0) - rec.Actual_Qty; get_inven.Total_Qty=ifNull(get_inven.Total_Qty,0) - rec.Actual_Qty; if(get_inven.Available_Qty < 0) { get_inven.Available_Qty=0; get_inven.Total_Qty=0; } } //Below code is to use the block qty for dispatch, only for the logistics confirmed Sale Order. ---Commented on 06/12/2024 if(getsoblk.count() > 0 && getsosub.DQR_Blk_Qty > 0 && getstk.Block_Qty > 0 && input.Sales_Order_No == fetwo.Sales_Order_Nos && getsosub.Logistics_Status == "Logistics Confirmed") { if(getstk.count() > 0 && rec.Product_Code == wosub.Part_No && rec.Actual_Qty <= rec.Block_Qty) { getstk.Block_Qty=ifNull(getstk.Block_Qty,0) - ifnull(rec.Actual_Qty,0); getstk.Total_Qty=ifNull(getstk.Total_Qty,0) - ifnull(rec.Actual_Qty,0); fetwo.WO_Status="Dispatched"; getsosub.WO_Status_in_sosub="Dispatched"; } else if(getstk.count() > 0 && rec.Product_Code == wosub.Part_No && rec.Actual_Qty > rec.Block_Qty) { balc = rec.Actual_Qty - getstk.Block_Qty; getstk.Block_Qty=0; getstk.Available_Qty=ifNull(getstk.Available_Qty,0) - ifnull(balc,0); getstk.Total_Qty=ifNull(getstk.Total_Qty,0) - ifnull(rec.Actual_Qty,0); fetwo.WO_Status="Dispatched"; getsosub.WO_Status_in_sosub="Dispatched"; } sendmail [ from :zoho.loginuserid to :"pooja.s@synprosoft.com" subject :"Dispatch Successful form submission - using Block" + input.Sales_Order_No.Sale_Order_No message :"Part No " + rec.Product_Code.Part_No + "TOT QTY-" + get_inven.Total_Qty + "AVL QTY-" + get_inven.Available_Qty + "BLK QTY-" + get_inven.Block_Qty + "ID-" + rec.ID + "Actual Qty=" + rec.Actual_Qty ] } getsosub.Actual_Qty_So_far=ifNull(getsosub.Actual_Qty_So_far,0) + ifNull(rec.Ac_so_far,0); if(getsosub.count() > 0) { getsosub.Create_Dispatch_Note_Plan_ID=input.ID; so.Create_Dispatch_Note_REC_ID=input.ID; getsosub.Balance_Qty=ifnull(getsosub.Balance_Qty,0) - ifnull(rec.Ac_so_far,0); if(getsosub.Balance_Qty > 0) { so.DP_Status=False; } getsosub.Planned_Qty_So_far=0; } input.Disptach_Status = "Approved"; } } //Below For-Each is for utilizing the Block Qty for dispatch if(rec.Actual_Weight != rec.Product_Weight || rec.Actual_Weight == rec.Product_Weight) { thisapp.Books.DispatchEmailTemplate(input.ID); } sasub = Sale_Order_Subform[Sales_Order_Exis_ID == so.ID]; solist = List(); solist.addAll(so.Dispatch_Note_No); solist.add(input.ID); so.Dispatch_Note_No=solist; so.Dispatch_Qty=sasub.sum(Actual_Qty_So_far); so.Balance_Qty=sasub.sum(Balance_Qty); //so.Dispatch_Qty=ifNull(so.Dispatch_Qty,0) + disp; so.Shipped_Qty=so.Dispatch_Qty; //so.Balance_Qty=bal; openUrl("#Report:Dispatch_Note_Actual","same window"); thisapp.Update_Salesorder_Books(input.Sales_Order_ID,input.Dispatch_Type); thisapp.DC.DCtoBooks(input.ID); for each var in input.Returnable_Packing_Material { insdc = insert into Create_DC_Subform [ Qty=var.Qty Part_Description=var.Part_Name Part_No=var.Part_No S_No=var.S_No Added_User=zoho.loginuser ]; } //thisapp.Books.Dispatch_Note_Actual_In_Books(input.ID); // thisapp.Books.Create_invoice_individual(input.ID); thisapp.Books.Create_Packages(input.ID); thisapp.Books.Create_Shipment(input.ID); con = true; for each sal in Sale_Order_Subform[Sales_Order_Exis_ID == so.ID] { if(sal.Balance_Qty > 0 && sal.Planned_Qty_So_far == null || sal.Planned_Qty_So_far == 0) { con = false; } } so.DP_Status=con; } else if(input.Dispatch_Type == "Actual Edit") { dispt = 0; balan = 0; for each rec1 in input.Product_Details { getso = Sales_Order[ID == input.Sales_Order_ID]; getsosub = Sale_Order_Subform[Sales_Order_Exis_ID == input.Sales_Order_ID && Part_No == rec1.Product_Code]; getsosub.Actual_Qty_So_far=ifNull(getsosub.Actual_Qty_So_far,0) + ifNull(rec1.Actual_Qty,0); getsosub.Balance_Qty=ifnull(getsosub.Balance_Qty,0) - ifnull(rec1.Actual_Qty,0); getso = Sales_Order[ID == input.Sales_Order_ID]; balan = ifNull(getsosub.Balance_Qty,0) + balan; dispt = ifNull(rec1.Actual_Qty,0) + dispt; if(getsosub.Balance_Qty > 0) { so = Sales_Order[ID == input.Sales_Order_ID]; so.DP_Status=False; } // get_invent = Inventory[Part_No == rec1.Product_Code]; // if(get_invent.count() > 0) // { // if(get_invent.Total_Qty < get_invent.Available_Qty) // { // //get_invent.Total_Qty=get_invent.Available_Qty; // } // // get_invent.Available_Qty=ifNull(get_invent.Available_Qty,0) - rec1.Actual_Qty; // // get_invent.Total_Qty=ifNull(get_invent.Total_Qty,0) - rec1.Actual_Qty; // sendmail // [ // from :zoho.loginuserid // to :"parthasarathy.m@synprosoft.com" // subject :"Edited>Successful form submission>OnSuccess_edited input.Dispatch_Type == Actual Edit" // message :"PartNo " + get_inven.Part_No.Part_No + "Total Qty is " + get_inven.Total_Qty + "Available Qty.. " + get_inven.Available_Qty // ] // } } if(rec1.Actual_Weight != rec1.Product_Weight || rec1.Actual_Weight == rec1.Product_Weight) { thisapp.Books.DispatchEmailTemplate(input.ID); } subsa = Sale_Order_Subform[Sales_Order_Exis_ID == getso.ID]; getso.Dispatch_Qty=subsa.sum(Actual_Qty_So_far); getso.Balance_Qty=subsa.sum(Balance_Qty); //getso.Dispatch_Qty=dispt; getso.Shipped_Qty=getso.Dispatch_Qty; // getso.Balance_Qty=balan; openUrl("#Report:Edit_Dispatch_Note_Actual","same window"); thisapp.Books.Edit_discpatch_note_actual_invoice(input.ID); } else { openUrl("#Report:Order_Gate_Process","same window"); } fet_dis = Create_Dispatch_Note_Format[ID == input.ID]; insrec = insert into Dispatch_Note_Actual_History [ Dispatch_Type=fet_dis.Dispatch_Type Added_User=zoho.loginuser CDNF_ID=fet_dis.CDNF_ID Currency_Code=fet_dis.Currency_Code Dispatch_Note_Date=fet_dis.Dispatch_Note_Date Customer_Address=fet_dis.Customer_Address Sales_Type=fet_dis.Sales_Type Sales_Order_No=fet_dis.Sales_Order_No Customer_Name=fet_dis.Customer_Name Incoterms=fet_dis.Incoterms Incoterms_Location=fet_dis.Incoterms_Location Product_List=fet_dis.Product_List Load_Products=fet_dis.Load_Products Transport_Type=fet_dis.Transport_Type Transporter_Name=fet_dis.Transporter_Name Vehicle_No_dup=fet_dis.Vehicle_No_dup GR_No=fet_dis.GR_No Driver_Name=fet_dis.Driver_Name Driver_Mobile_Number=fet_dis.Driver_Mobile_Number Vehicle_Type=fet_dis.Vehicle_Type Total_Qty=fet_dis.Total_Qty Total_Weight=fet_dis.Total_Weight ]; for each recsub in input.Product_Details { subins = insert into Dispatch_Note_Actual_History_Subform [ Added_User=zoho.loginuser Dispatch_Note_Actual_History_Exis_ID=insrec S_NO=recsub.S_NO Product_Code=recsub.Product_Code Product_Description=recsub.Product_Description Customer_Product_Code=recsub.Customer_Product_Code Packing_Details1=recsub.Packing_Details1 UoM=recsub.UoM Planned_Qty=recsub.Planned_Qty Plan_Qty_so_far=recsub.Plan_Qty_so_far Product_Weight=recsub.Product_Weight Actual_Qty=recsub.Actual_Qty Ac_so_far=recsub.Ac_so_far Actual_Qty_so_far=recsub.Actual_Qty_so_far Actual_Weight=recsub.Actual_Weight Remarks=recsub.Remarks Reason=recsub.Reason Individual=recsub.Individual Stock_Qty=recsub.Stock_Qty Ordered_Qty=recsub.Ordered_Qty Balance_Qty=recsub.Balance_Qty ]; } for each retmat in input.Returnable_Packing_Material { retins = insert into Returnable_Packing_Material_History [ Qty=retmat.Qty Part_No=retmat.Part_No Part_Name=retmat.Part_Name Added_User=zoho.loginuser ]; } if(input.Dispatch_Type == "Gate") { invmain = Invoice[ID == input.Invoice_ID]; invsub = Invoice_Subform[Invoice_Exist_ID == invmain.ID]; invsub.Vehicle_Gate_in_Time=input.In_Time; invsub.Vehicle_Gate_out_time=input.Out_Time; }
if(input.Dispatch_Type == "Plan") { input.Plan_Date_Time = zoho.currenttime; fetso = Sales_Order[ID == input.Sales_Order_ID]; invmain = Invoice[ID == input.Invoice_ID]; invsub = Invoice_Subform[Invoice_Exist_ID == invmain.ID]; if(input.Sales_Type == "Direct Order" || input.Sales_Type == "Tooling") { if(fetso.CWPL_SO_Status == "Active") { fetso.CWPL_SO_Status="Dispatch Note Partial"; } } var = True; polist = List(); for each rec in input.Product_Details { invsub.Dispatch_Plan_Date_time=rec.Disp_Plan_Date_Time; fetsosub = Sale_Order_Subform[Sales_Order_Exis_ID == fetso.ID && Part_No == rec.Product_Code]; polist.add(rec.Product_Code); fetsosub.Planned_Qty_So_far=ifNull(rec.Plan_Qty_so_far,0) + ifNull(rec.Planned_Qty,0); rec.Balance_Qty=ifNull(rec.Planned_Qty,0); bal = ifnull(fetsosub.Balance_Qty,0.0) - ifnull(rec.Planned_Qty,0.0); if(bal > 0) { var = False; } if(bal < 0) { fetsosub.Balance_Qty=0; } } for each sorec in Sale_Order_Subform[Sales_Order_Exis_ID == fetso.ID && Part_No not in polist] { sobal = ifnull(sorec.Balance_Qty,0.0) - ifnull(sorec.Planned_Qty_So_far,0.0); if(sobal > 0) { var = false; } if(sobal < 0) { sorec.Balance_Qty=0; } } fetso.DP_Status=var; if(fetso.DP_Status == True && fetso.CWPL_SO_Status == "Active" || fetso.CWPL_SO_Status == "Dispatch Note Partial") { fetso.CWPL_SO_Status="Dispatch Note Plan Completed"; } input.Disptach_Status = "Plan Closed"; fetci = Check_Inventory[ID == input.Check_Inventory_ID]; if(fetci.count() > 0) { fetci.Create_Dispatch_Note_RECID=input.ID; fetci.Status="Closed"; } so = Sales_Order[ID == input.Sales_Order_ID]; if(so.count() > 0) { getsosub = Sale_Order_Subform[Sales_Order_Exis_ID == so.ID]; if(getsosub.count() > 0) { getsosub.Create_Dispatch_Note_Plan_ID=input.ID; so.Create_Dispatch_Note_REC_ID=input.ID; } } } getmodule = Module_Master[Module_Name == "Dispatch Note"]; getauto = Auto_Generate_Numbers[Module_Name == getmodule.ID]; input.CDNF_ID = getauto.Module_Short_Name + "-" + getauto.Prefix + "-" + input.Auto_Number; openUrl("#Form:Alert_Messages?Status=" + "DN1" + "&Value=" + input.CDNF_ID + "&zc_LoadIn=dialog","same window");
// if(input.Sales_Type == "Contract") // { clear Product_Details; fet_so = Sales_Order[ID == input.Sales_Order_ID]; if(input.Load_Products == True) { show Product_Details; show Total_Qty; show Total_Weight; sno = 0; for each var in input.Product_List { a1 = Sale_Order_Subform[Sales_Order_Exis_ID == fet_so.ID && Part_No == var && Balance_Qty > 0]; planvar1 = ifNull(a1.Balance_Qty,0) - ifNull(a1.Planned_Qty_So_far,0); if(a1.count() > 0) { fetch_inven = Inventory[Part_No == a1.Part_No].sum(Available_Qty); row1 = Create_Dispatch_Note_Format.Product_Details(); row1.Sale_Order_Subform_ID=a1.ID; row1.Product_Description=a1.Part_Description; row1.Product_Code=a1.Part_No; row1.Customer_Product_Code=a1.Customer_Part_Code; row1.Remarks=a1.Remarks; row1.UoM=a1.UoM; row1.Packing_Details1=a1.Packing_Std; //row1.Planned_Qty=a1.Qty; row1.Ordered_Qty=a1.Qty; // row1.Stock_Qty=fetch_inven; row1.Plan_Qty_so_far=a1.Planned_Qty_So_far; if(a1.Balance_Qty > 0 && planvar1 > 0) { row1.S_NO=sno + 1; sno = sno + 1; input.Product_Details.insert(row1); } disable Sale_Order_Subform_RECID; disable Product_Details.S_NO; disable Product_Details.Product_Code; disable Product_Details.Product_Description; } } if(input.Dispatch_Type == "Plan") { Total1 = 0; wt = 0; for each rec in input.Product_Details { fet_item = Materials[ID = rec.Product_Code]; salesub = Sale_Order_Subform[Sales_Order_Exis_ID == input.Sales_Order_ID && Part_No == rec.Product_Code]; rec.Planned_Qty=ifNull(salesub.Balance_Qty,0) - ifNull(salesub.Planned_Qty_So_far,0); // rec.Stock_Qty=fetch_inven; Total1 = Total1 + rec.Planned_Qty; rec.Product_Weight=ifNull(fet_item.Final_Weight,0.0) * ifNull(rec.Planned_Qty,0.0); wt = wt + rec.Product_Weight; disable Total_Qty; disable Total_Weight; } input.Total_Qty = Total1; input.Total_Weight = wt; } } //}
disable Product_Details.Ordered_Qty; disable Product_Details.UoM; //hide Product_Details.Individual; hide CDNF_ID; hide Currency_Code; hide Actual_Date_Time; disable Plan_Date_Time; hide Export_Information_ID; //hide Disptach_Status; hide Sale_Order_Subform_RECID; disable Incoterms; hide Product_Details.Block_Qty; disable Incoterms_Location; hide DN_No; disable Product_Details.Packing_Details1; hide Product_Details.Export_Information_Exis_ID; hide Product_Details.Reason; hide Sales_Order_ID; hide Inventory_ID; hide Create_Dispatch_Note_Plan_ID; hide Check_Inventory_ID; hide Unblock_Inventory_ID; hide Product_Details.Actual_Qty_so_far; hide Product_Details.Plan_Qty_so_far; hide Product_Details.Ac_so_far; hide Product_Details.Stock_Qty; disable Product_Details.Customer_Product_Code; disable Product_Details.Product_Weight; disable Sales_Type; disable Product_Details.Remarks; //hide Product_Details.Actual_Qty; hide Product_Details.Create_Dispatch_Note_Plan_RECID; hide Disptach_Status; if(input.Dispatch_Type == "Plan") { input.Plan_Date_Time = zoho.currenttime; hide Transportation_Details; hide Returnable_Packing_Material; hide Product_Details.Ordered_Qty; hide Product_Details.Actual_Qty; hide Product_Details.Actual_Weight; } if(input.Dispatch_Type == "Actual") { hide Product_Details.Ordered_Qty; hide Out_Time; hide In_Time; disable Product_Details.Actual_Qty; } if(input.Sale_Order_Subform_RECID != null) { getSosub = Sale_Order_Subform[ID == input.Sale_Order_Subform_RECID]; input.Sales_Order_ID = getSosub.Sales_Order_Exis_ID; input.Sales_Order_No = getSosub.Sales_Order_Exis_ID; disable Sales_Order_No; so = Sales_Order[ID == getSosub.Sales_Order_Exis_ID]; input.Expected_Shipping_Date = so.Expected_Shipment_Date; //var = Check_Inventory[ID == input.ID]; fet_so = Sales_Order[ID == input.Sales_Order_ID]; getsosub = Sale_Order_Subform[Sales_Order_Exis_ID == fet_so.ID]; fet_chk = Check_Inventory[Sale_Order_Subform_ID == input.Sale_Order_Subform_RECID]; if(fet_chk.count() > 0) { input.Check_Inventory_ID = fet_chk.ID; } fet_pro = Proforma_Invoice[Customer_Name == fet_so.Customer_Name && Sales_Order_No == getsosub.Sales_Order_Exis_ID]; //fetch_inve = Inventory[Part_No == getsosub.Part_No]; input.Customer_Name = fet_so.Customer_Name; input.Customer_Address = fet_so.Shipping_Address; input.Incoterms = fet_so.Incoterms1; input.Incoterms_Location = fet_so.Incoterms_Location; input.Currency_Code = fet_so.Currency_Code; input.Sales_Type = fet_so.Sales_Type; input.Packing_Forwarding = fet_so.Packing_Forwarding; if(input.Sales_Type == "Direct Order" || input.Sales_Type == "Tooling" || input.Sales_Type == "Research & Development Charges") { input.Expected_Shipping_Date = so.Expected_Shipment_Date; hide Product_Details; hide Total_Qty; hide Total_Weight; sublistdo = List(); sosub1 = Sale_Order_Subform[Sales_Order_Exis_ID == fet_so.ID && Balance_Qty > 0]; for each recsodo in sosub1 { planvardo = ifNull(recsodo.Balance_Qty,0) - ifNull(recsodo.Planned_Qty_So_far,0); if(planvardo > 0) { sublistdo.add(recsodo.Part_No); } } input.Product_List:ui.add(sublistdo); if(fet_pro.Proforma_Invoice_Status == "Over Due") { alert "Proforma Invoice is in OverDue for this Customer"; } else if(fet_pro.Proforma_Invoice_Status == "Due") { alert "Proforma Invoice is in Due for this Customer"; } else if(fet_pro.Proforma_Invoice_Status == "Partially Paid") { alert "Proforma Invoice is in Partially Paid for this Customer"; } //input.Invoice_Address = fet_so.Billing_Address.state_province; // sno = 0; // for each a1 in fet_so.Item_Details // { // fetch_inven = Inventory[Part_No == a1.Part_No].sum(Available_Qty); // row1 = Create_Dispatch_Note_Format.Product_Details(); // row1.Product_Description=a1.Part_Description; // row1.Product_Code=a1.Part_No; // row1.Customer_Product_Code=a1.Customer_Part_Code; // row1.Remarks=a1.Remarks; // row1.UoM=a1.UoM; // row1.Packing_Details1=a1.Packing_Std; // //row1.Planned_Qty=a1.Qty; // row1.Ordered_Qty=a1.Qty; // // row1.Stock_Qty=fetch_inven; // row1.Plan_Qty_so_far=a1.Planned_Qty_So_far; // planvar = ifNull(a1.Balance_Qty,0) - ifNull(a1.Planned_Qty_So_far,0); // if(a1.Balance_Qty > 0 && planvar > 0) // { // row1.S_NO=sno + 1; // sno = sno + 1; // input.Product_Details.insert(row1); // } // disable Sale_Order_Subform_RECID; // disable Product_Details.S_NO; // disable Product_Details.Product_Code; // disable Product_Details.Product_Description; // } // if(input.Dispatch_Type == "Plan") // { // Tot = 0; // wt = 0; // for each rec in input.Product_Details // { // rec.Disp_Plan_Date_Time=zoho.currenttime; // fet_item = Materials[ID = rec.Product_Code]; // salesub = Sale_Order_Subform[Sales_Order_Exis_ID == input.Sales_Order_ID && Part_No == rec.Product_Code]; // rec.Planned_Qty=ifNull(salesub.Balance_Qty,0) - ifNull(salesub.Planned_Qty_So_far,0); // // rec.Stock_Qty=fetch_inven; // Tot = Tot + ifNull(rec.Planned_Qty,0); // rec.Product_Weight=ifNull(fet_item.Final_Weight,0.0) * ifNull(rec.Planned_Qty,0.0); // wt = wt + rec.Product_Weight; // disable Total_Qty; // disable Total_Weight; // } // input.Total_Qty = Tot; // input.Total_Weight = wt; // } } else if(input.Sales_Type == "Contract") { hide Product_Details; hide Total_Qty; hide Total_Weight; sublist = List(); sosub = Sale_Order_Subform[Sales_Order_Exis_ID == fet_so.ID && Balance_Qty > 0]; for each recso in sosub { planvar1 = ifNull(recso.Balance_Qty,0) - ifNull(recso.Planned_Qty_So_far,0); if(planvar1 > 0) { sublist.add(recso.Part_No); } } input.Product_List:ui.add(sublist); } }
/*----------------------------------------------------Level 1------------------------------------------------------------*/ //Checking if row.Level == 1, then run all the levels if(row.Level == "Level-1") { for each cwplrec in input.BoM_Details_CWPL { //LEVEL-1 if(cwplrec.Level == "Level-1") { for each lis1 in Create_BOM[Part_No == cwplrec.Part_No] { for each var in input.BoM_Details_CWPL { if(var.Part_No.Part_No == lis1.Material_Details.Part_No.Part_No) { var.BoM_Qty=cwplrec.Actual_Qty; var.Actual_Qty=ifnull(var.BoM_Qty,0.0) * ifnull(var.bom_stk_qty,0.0) - ifnull(var.Stock_Qty,0.0); var.Plan_Qty=var.Actual_Qty; } if(var.Stock_Qty > var.BoM_Qty) { var.Blocked_Qty=var.Actual_Qty; } if(var.Stock_Qty != 0 && var.Blocked_Qty > var.Stock_Qty || var.Stock_Qty < var.BoM_Qty) { var.Blocked_Qty=var.Stock_Qty; } //Below Foreach is for General Purchase calculation for each vargp in input.BoM_Details_General_Purchase { row.Tot_BoM_Qty=ifnull(input.MRP_Qty,0) * ifnull(row.bom_stk_qty,0.0); if(vargp.Part_No.Part_No.startswith("BT") == true || vargp.Part_No.Part_No.startswith("NT") == true || vargp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var.Part_No.Part_No.contains("_UP") == true) { //If RIM means, var.Actual_qty should be passed to this BOM_Qty vargp.BoM_Qty=ifnull(var.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(vargp.BoM_Qty,0) * ifnull(vargp.Org_BoM_Qty,0.0) - ifnull(vargp.Stock_Qty,0) >= 0) { vargp.Plan_Qty=ifnull(vargp.BoM_Qty,0) * ifnull(vargp.Org_BoM_Qty,0.0) - ifnull(vargp.Stock_Qty,0); } else { vargp.Plan_Qty=ifnull(vargp.Stock_Qty,0) - ifnull(vargp.BoM_Qty,0) * ifnull(vargp.Org_BoM_Qty,0.0); } //Above ifelse ends here vargp.Purchase_Qty=ifnull(vargp.Plan_Qty,0); } } else { if(vargp.Level == var.Level && vargp.Level == "Level-1") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); vargp.BoM_Qty=var.Actual_Qty; if(ifnull(vargp.BoM_Qty,0) * ifnull(vargp.Org_BoM_Qty,0.0) - ifnull(vargp.Stock_Qty,0) >= 0) { vargp.Plan_Qty=ifnull(vargp.BoM_Qty,0) * ifnull(vargp.Org_BoM_Qty,0.0) - ifnull(vargp.Stock_Qty,0); } else { vargp.Plan_Qty=ifnull(vargp.Stock_Qty,0) - ifnull(vargp.BoM_Qty,0) * ifnull(vargp.Org_BoM_Qty,0.0); } vargp.Purchase_Qty=vargp.Plan_Qty; } } } } } } //LEVEL-2 if(cwplrec.Level == "Level-2") { info "level2"; info cwplrec.Actual_Qty; for each lis2 in Create_BOM[Part_No == cwplrec.Part_No] { for each var2 in input.BoM_Details_CWPL { if(var2.Part_No.Part_No == lis2.Material_Details.Part_No.Part_No) { var2.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var2.BoM_Qty=cwplrec.Actual_Qty; var2.Actual_Qty=ifnull(var2.BoM_Qty,0.0) * ifnull(var2.bom_stk_qty,0.0) - ifnull(var2.Stock_Qty,0.0); var2.Plan_Qty=var2.Actual_Qty; } if(var2.Stock_Qty > var2.BoM_Qty) { var2.Blocked_Qty=var2.Actual_Qty; } if(var2.Stock_Qty != 0 && var2.Blocked_Qty > var2.Stock_Qty || var2.Stock_Qty < var2.BoM_Qty) { var2.Blocked_Qty=var2.Stock_Qty; } for each var2gp in input.BoM_Details_General_Purchase { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); if(var2gp.Part_No.Part_No.startswith("BT") == true || var2gp.Part_No.Part_No.startswith("NT") == true || var2gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var2.Part_No.Part_No.contains("_UP") == true) { //If RIM means, var.Actual_qty should be passed to this BOM_Qty var2gp.BoM_Qty=ifnull(var2.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0) >= 0) { var2gp.Plan_Qty=ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0); } else { var2gp.Plan_Qty=ifnull(var2gp.Stock_Qty,0) - ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var2gp.Purchase_Qty=ifnull(var2gp.Plan_Qty,0); } } else { if(var2gp.Level == var2.Level && var2gp.Level == "Level-2") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var2gp.BoM_Qty=var2.Actual_Qty; //var2gp.Plan_Qty=ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0) >= 0) { var2gp.Plan_Qty=ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0); } else { var2gp.Plan_Qty=ifnull(var2gp.Stock_Qty,0) - ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0); } var2gp.Purchase_Qty=var2gp.Plan_Qty; } } } } } //cwplrec.Plan_Qty=ifnull(cwplrec.BoM_Qty,0.0) * ifnull(cwplrec.bom_stk_qty,0.0) - ifnull(cwplrec.Stock_Qty,0.0); //cwplrec.Actual_Qty=cwplrec.Plan_Qty; } //LEVEL-3 if(cwplrec.Level == "Level-3") { for each lis3 in Create_BOM[Part_No == cwplrec.Part_No] { for each var3 in input.BoM_Details_CWPL { if(var3.Part_No.Part_No == lis3.Material_Details.Part_No.Part_No) { var3.Tot_BoM_Qty=ifnull(var3.BoM_Qty,0) * ifnull(var3.bom_stk_qty,0.0); var3.BoM_Qty=cwplrec.Actual_Qty; var3.Actual_Qty=ifnull(var3.BoM_Qty,0.0) * ifnull(var3.bom_stk_qty,0.0) - ifnull(var3.Stock_Qty,0.0); var3.Plan_Qty=var3.Actual_Qty; } if(var3.Stock_Qty > var3.BoM_Qty) { var3.Blocked_Qty=var3.Actual_Qty; } if(var3.Stock_Qty != 0 && var3.Blocked_Qty > var3.Stock_Qty || var3.Stock_Qty < var3.BoM_Qty) { var3.Blocked_Qty=var3.Stock_Qty; } for each var3gp in input.BoM_Details_General_Purchase { if(var3gp.Part_No.Part_No.startswith("BT") == true || var3gp.Part_No.Part_No.startswith("NT") == true || var3gp.Part_No.Part_No.startswith("WS") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var3.Part_No.Part_No.contains("_UP") == true) { //If RIM means, var.Actual_qty should be passed to this BOM_Qty var3gp.BoM_Qty=ifnull(var3.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0) >= 0) { var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); } else { var3gp.Plan_Qty=ifnull(var3gp.Stock_Qty,0) - ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var3gp.Purchase_Qty=ifnull(var3gp.Plan_Qty,0); } } else { if(var3gp.Level == var3.Level && var3gp.Level == "Level-3") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var3gp.BoM_Qty=var3.Actual_Qty; //var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0) >= 0) { var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); } else { var3gp.Plan_Qty=ifnull(var3gp.Stock_Qty,0) - ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var3gp.Purchase_Qty=var3gp.Plan_Qty; } } } } } //cwplrec.Plan_Qty=ifnull(cwplrec.BoM_Qty,0.0) * ifnull(cwplrec.bom_stk_qty,0.0) - ifnull(cwplrec.Stock_Qty,0.0); //cwplrec.Actual_Qty=cwplrec.Plan_Qty; } //LEVEL-4 if(cwplrec.Level == "Level-4") { for each lis4 in Create_BOM[Part_No == cwplrec.Part_No] { for each var4 in input.BoM_Details_CWPL { if(var4.Part_No.Part_No == lis4.Material_Details.Part_No.Part_No) { var4.Tot_BoM_Qty=ifnull(var4.Actual_Qty,0) * ifnull(var4.bom_stk_qty,0.0); var4.BoM_Qty=cwplrec.Actual_Qty; var4.Actual_Qty=ifnull(var4.BoM_Qty,0.0) * ifnull(var4.bom_stk_qty,0.0) - ifnull(var4.Stock_Qty,0.0); var4.Plan_Qty=var4.Actual_Qty; } if(var4.Stock_Qty > var4.BoM_Qty) { var4.Blocked_Qty=var4.Actual_Qty; } if(var4.Stock_Qty != 0 && var4.Blocked_Qty > var4.Stock_Qty || var4.Stock_Qty < var4.BoM_Qty) { var4.Blocked_Qty=var4.Stock_Qty; } for each var4gp in input.BoM_Details_General_Purchase { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); if(var4gp.Part_No.Part_No.startswith("BT") == true || var4gp.Part_No.Part_No.startswith("NT") == true || var4gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var4.Part_No.Part_No.contains("_UP") == true) { //If RIM means, var.Actual_qty should be passed to this BOM_Qty var4gp.BoM_Qty=ifnull(var4.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=ifnull(var4gp.Plan_Qty,0); } } else { if(var4gp.Level == var4.Level && var4gp.Level == "Level-4") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var4gp.BoM_Qty=var4.Actual_Qty; // var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=var4gp.Plan_Qty; } } } } } //cwplrec.Plan_Qty=ifnull(cwplrec.BoM_Qty,0.0) * ifnull(cwplrec.bom_stk_qty,0.0) - ifnull(cwplrec.Stock_Qty,0.0); //cwplrec.Actual_Qty=cwplrec.Plan_Qty; } //LEVEL-5 if(cwplrec.Level == "Level-5") { for each lis5 in Create_BOM[Part_No == cwplrec.Part_No] { for each var5 in input.BoM_Details_CWPL { if(var5.Part_No.Part_No == lis5.Material_Details.Part_No.Part_No) { var5.Tot_BoM_Qty=ifnull(var5.Actual_Qty,0) * ifnull(var5.bom_stk_qty,0.0); var5.BoM_Qty=cwplrec.Actual_Qty; var5.Actual_Qty=ifnull(var5.BoM_Qty,0.0) * ifnull(var5.bom_stk_qty,0.0) - ifnull(var5.Stock_Qty,0.0); var5.Plan_Qty=var5.Actual_Qty; } for each var5gp in input.BoM_Details_General_Purchase { if(var5gp.Level == var5.Level && var5gp.Level == "Level-5") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5gp.BoM_Qty=var5.Actual_Qty; // var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=var5gp.Plan_Qty; } } } } //cwplrec.Plan_Qty=ifnull(cwplrec.BoM_Qty,0.0) * ifnull(cwplrec.bom_stk_qty,0.0) - ifnull(cwplrec.Stock_Qty,0.0); //cwplrec.Actual_Qty=cwplrec.Plan_Qty; } } //Foreach Ends } //Level1 checking close /*----------------------------------------------------Level 2------------------------------------------------------------*/ //Checking if row.Level == 2, then run all the levels >=2 if(row.Level == "Level-2") { for each cwplrec2 in input.BoM_Details_CWPL { //LEVEL-2 if(cwplrec2.Level == "Level-2") { for each lis2 in Create_BOM[Part_No == cwplrec2.Part_No] { for each var2 in input.BoM_Details_CWPL { if(var2.Part_No.Part_No == lis2.Material_Details.Part_No.Part_No) { var2.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var2.BoM_Qty=cwplrec2.Actual_Qty; var2.Actual_Qty=ifnull(var2.BoM_Qty,0.0) * ifnull(var2.bom_stk_qty,0.0) - ifnull(var2.Stock_Qty,0.0); var2.Plan_Qty=var2.Actual_Qty; } for each var2gp in input.BoM_Details_General_Purchase { if(var2gp.Part_No.Part_No.startswith("BT") == true || var2gp.Part_No.Part_No.startswith("NT") == true || var2gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var2.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var2gp.BoM_Qty=ifnull(var2.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0) >= 0) { var2gp.Plan_Qty=ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0); } else { var2gp.Plan_Qty=ifnull(var2gp.Stock_Qty,0) - ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var2gp.Purchase_Qty=ifnull(var2gp.Plan_Qty,0); } } else { if(var2gp.Level == var2.Level && var2gp.Level == "Level-2") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var2gp.BoM_Qty=var2.Actual_Qty; //var2gp.Plan_Qty=ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0) >= 0) { var2gp.Plan_Qty=ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0) - ifnull(var2gp.Stock_Qty,0); } else { var2gp.Plan_Qty=ifnull(var2gp.Stock_Qty,0) - ifnull(var2gp.BoM_Qty,0) * ifnull(var2gp.Org_BoM_Qty,0.0); } var2gp.Purchase_Qty=var2gp.Plan_Qty; } } } } } //cwplrec2.Plan_Qty=ifnull(cwplrec2.BoM_Qty,0.0) * ifnull(cwplrec2.bom_stk_qty,0.0) - ifnull(cwplrec2.Stock_Qty,0.0); //cwplrec2.Actual_Qty=cwplrec2.Plan_Qty; } //LEVEL-3 if(cwplrec2.Level == "Level-3") { for each lis3 in Create_BOM[Part_No == cwplrec2.Part_No] { for each var3 in input.BoM_Details_CWPL { if(var3.Part_No.Part_No == lis3.Material_Details.Part_No.Part_No) { var3.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var3.BoM_Qty=cwplrec2.Actual_Qty; var3.Actual_Qty=ifnull(var3.BoM_Qty,0.0) * ifnull(var3.bom_stk_qty,0.0) - ifnull(var3.Stock_Qty,0.0); var3.Plan_Qty=var3.Actual_Qty; } for each var3gp in input.BoM_Details_General_Purchase { if(var3gp.Part_No.Part_No.startswith("BT") == true || var3gp.Part_No.Part_No.startswith("NT") == true || var3gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var3.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var3gp.BoM_Qty=ifnull(var3.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0) >= 0) { var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); } else { var3gp.Plan_Qty=ifnull(var3gp.Stock_Qty,0) - ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var3gp.Purchase_Qty=ifnull(var3gp.Plan_Qty,0); } } else { if(var3gp.Level == var3.Level && var3gp.Level == "Level-3") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var3gp.BoM_Qty=var3.Actual_Qty; //var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0) >= 0) { var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); } else { var3gp.Plan_Qty=ifnull(var3gp.Stock_Qty,0) - ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var3gp.Purchase_Qty=var3gp.Plan_Qty; } } } } } //cwplrec2.Plan_Qty=ifnull(cwplrec2.BoM_Qty,0.0) * ifnull(cwplrec2.bom_stk_qty,0.0) - ifnull(cwplrec2.Stock_Qty,0.0); //cwplrec2.Actual_Qty=cwplrec2.Plan_Qty; } //LEVEL-4 if(cwplrec2.Level == "Level-4") { for each lis4 in Create_BOM[Part_No == cwplrec2.Part_No] { for each var4 in input.BoM_Details_CWPL { if(var4.Part_No.Part_No == lis4.Material_Details.Part_No.Part_No) { var4.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var4.BoM_Qty=cwplrec2.Actual_Qty; var4.Actual_Qty=ifnull(var4.BoM_Qty,0.0) * ifnull(var4.bom_stk_qty,0.0) - ifnull(var4.Stock_Qty,0.0); var4.Plan_Qty=var4.Actual_Qty; } for each var4gp in input.BoM_Details_General_Purchase { if(var4gp.Part_No.Part_No.startswith("BT") == true || var4gp.Part_No.Part_No.startswith("NT") == true || var4gp.Part_No.Part_No.startswith("WS") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var4.Part_No.Part_No.contains("_UP") == true) { //If RIM means, var.Actual_qty should be passed to this BOM_Qty var4gp.BoM_Qty=ifnull(var4.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=ifnull(var4gp.Plan_Qty,0); } } else { if(var4gp.Level == var4.Level && var4gp.Level == "Level-4") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var4gp.BoM_Qty=var4.Actual_Qty; // var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=var4gp.Plan_Qty; } } } } } //cwplrec2.Plan_Qty=ifnull(cwplrec2.BoM_Qty,0.0) * ifnull(cwplrec2.bom_stk_qty,0.0) - ifnull(cwplrec2.Stock_Qty,0.0); //cwplrec2.Actual_Qty=cwplrec2.Plan_Qty; } //LEVEL-5 if(cwplrec2.Level == "Level-5") { for each lis5 in Create_BOM[Part_No == cwplrec2.Part_No] { for each var5 in input.BoM_Details_CWPL { if(var5.Part_No.Part_No == lis5.Material_Details.Part_No.Part_No) { var5.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5.BoM_Qty=cwplrec2.Actual_Qty; var5.Actual_Qty=ifnull(var5.BoM_Qty,0.0) * ifnull(var5.bom_stk_qty,0.0) - ifnull(var5.Stock_Qty,0.0); var5.Plan_Qty=var5.Actual_Qty; } for each var5gp in input.BoM_Details_General_Purchase { if(var5gp.Part_No.Part_No.startswith("BT") == true || var5gp.Part_No.Part_No.startswith("NT") == true || var5gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var5.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var5gp.BoM_Qty=ifnull(var5.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=ifnull(var5gp.Plan_Qty,0); } } else { if(var5gp.Level == var5.Level && var5gp.Level == "Level-5") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5gp.BoM_Qty=var5.Actual_Qty; // var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=var5gp.Plan_Qty; } } } } } //cwplrec2.Plan_Qty=ifnull(cwplrec2.BoM_Qty,0.0) * ifnull(cwplrec2.bom_stk_qty,0.0) - ifnull(cwplrec2.Stock_Qty,0.0); //cwplrec2.Actual_Qty=cwplrec2.Plan_Qty; } } } //Level 2 checking close /*----------------------------------------------------Level 3------------------------------------------------------------*/ ////Checking if row.Level == 3, then run all the levels >=3 if(row.Level == "Level-3") { for each cwplrec3 in input.BoM_Details_CWPL { //LEVEL-3 if(cwplrec3.Level == "Level-3") { for each lis3 in Create_BOM[Part_No == cwplrec3.Part_No] { for each var3 in input.BoM_Details_CWPL { if(var3.Part_No.Part_No == lis3.Material_Details.Part_No.Part_No) { var3.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var3.BoM_Qty=cwplrec3.Actual_Qty; var3.Actual_Qty=ifnull(var3.BoM_Qty,0.0) * ifnull(var3.bom_stk_qty,0.0) - ifnull(var3.Stock_Qty,0.0); var3.Plan_Qty=var3.Actual_Qty; } for each var3gp in input.BoM_Details_General_Purchase { if(var3gp.Part_No.Part_No.startswith("BT") == true || var3gp.Part_No.Part_No.startswith("NT") == true || var3gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var3.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var3gp.BoM_Qty=ifnull(var3.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0) >= 0) { var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); } else { var3gp.Plan_Qty=ifnull(var3gp.Stock_Qty,0) - ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var3gp.Purchase_Qty=ifnull(var3gp.Plan_Qty,0); } } else { if(var3gp.Level == var3.Level && var3gp.Level == "Level-3") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var3gp.BoM_Qty=var3.Actual_Qty; //var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0) >= 0) { var3gp.Plan_Qty=ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0) - ifnull(var3gp.Stock_Qty,0); } else { var3gp.Plan_Qty=ifnull(var3gp.Stock_Qty,0) - ifnull(var3gp.BoM_Qty,0) * ifnull(var3gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var3gp.Purchase_Qty=var3gp.Plan_Qty; } } } } } //cwplrec3.Plan_Qty=ifnull(cwplrec3.BoM_Qty,0.0) * ifnull(cwplrec3.bom_stk_qty,0.0) - ifnull(cwplrec3.Stock_Qty,0.0); //cwplrec3.Actual_Qty=cwplrec3.Plan_Qty; } //LEVEL-4 if(cwplrec3.Level == "Level-4") { for each lis4 in Create_BOM[Part_No == cwplrec3.Part_No] { for each var4 in input.BoM_Details_CWPL { if(var4.Part_No.Part_No == lis4.Material_Details.Part_No.Part_No) { var4.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var4.BoM_Qty=cwplrec3.Actual_Qty; var4.Actual_Qty=ifnull(var4.BoM_Qty,0.0) * ifnull(var4.bom_stk_qty,0.0) - ifnull(var4.Stock_Qty,0.0); var4.Plan_Qty=var4.Actual_Qty; } for each var4gp in input.BoM_Details_General_Purchase { if(var4gp.Part_No.Part_No.startswith("BT") == true || var4gp.Part_No.Part_No.startswith("NT") == true || var4gp.Part_No.Part_No.startswith("WS") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var4.Part_No.Part_No.contains("_UP") == true) { //If RIM means, var.Actual_qty should be passed to this BOM_Qty var4gp.BoM_Qty=ifnull(var4.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=ifnull(var4gp.Plan_Qty,0); } } else { if(var4gp.Level == var4.Level && var4gp.Level == "Level-4") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var4gp.BoM_Qty=var4.Actual_Qty; // var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=var4gp.Plan_Qty; } } } } } //cwplrec3.Plan_Qty=ifnull(cwplrec3.BoM_Qty,0.0) * ifnull(cwplrec3.bom_stk_qty,0.0) - ifnull(cwplrec3.Stock_Qty,0.0); //cwplrec3.Actual_Qty=cwplrec3.Plan_Qty; } //LEVEL-5 if(cwplrec3.Level == "Level-5") { for each lis5 in Create_BOM[Part_No == cwplrec3.Part_No] { for each var5 in input.BoM_Details_CWPL { if(var5.Part_No.Part_No == lis5.Material_Details.Part_No.Part_No) { var5.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5.BoM_Qty=cwplrec3.Actual_Qty; var5.Actual_Qty=ifnull(var5.BoM_Qty,0.0) * ifnull(var5.bom_stk_qty,0.0) - ifnull(var5.Stock_Qty,0.0); var5.Plan_Qty=var5.Actual_Qty; } for each var5gp in input.BoM_Details_General_Purchase { if(var5gp.Part_No.Part_No.startswith("BT") == true || var5gp.Part_No.Part_No.startswith("NT") == true || var5gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var5.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var5gp.BoM_Qty=ifnull(var5.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=ifnull(var5gp.Plan_Qty,0); } } else { if(var5gp.Level == var5.Level && var5gp.Level == "Level-5") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5gp.BoM_Qty=var5.Actual_Qty; // var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=var5gp.Plan_Qty; } } } } } //cwplrec3.Plan_Qty=ifnull(cwplrec3.BoM_Qty,0.0) * ifnull(cwplrec3.bom_stk_qty,0.0) - ifnull(cwplrec3.Stock_Qty,0.0); //cwplrec3.Actual_Qty=cwplrec3.Plan_Qty; } } } //Level 3 checking close /*----------------------------------------------------Level 4------------------------------------------------------------*/ //Checking if row.Level == 4, then run all the levels >=4 if(row.Level == "Level-4") { for each cwplrec4 in input.BoM_Details_CWPL { //LEVEL-4 if(cwplrec4.Level == "Level-4") { for each lis4 in Create_BOM[Part_No == cwplrec4.Part_No] { for each var4 in input.BoM_Details_CWPL { if(var4.Part_No.Part_No == lis4.Material_Details.Part_No.Part_No) { var4.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var4.BoM_Qty=cwplrec4.Actual_Qty; var4.Actual_Qty=ifnull(var4.BoM_Qty,0.0) * ifnull(var4.bom_stk_qty,0.0) - ifnull(var4.Stock_Qty,0.0); var4.Plan_Qty=var4.Actual_Qty; } for each var4gp in input.BoM_Details_General_Purchase { if(var4gp.Part_No.Part_No.startswith("BT") == true || var4gp.Part_No.Part_No.startswith("NT") == true || var4gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var4.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var4gp.BoM_Qty=ifnull(var4.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=ifnull(var4gp.Plan_Qty,0); } } else { if(var4gp.Level == var4.Level && var4gp.Level == "Level-4") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var4gp.BoM_Qty=var4.Actual_Qty; // var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0) >= 0) { var4gp.Plan_Qty=ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0) - ifnull(var4gp.Stock_Qty,0); } else { var4gp.Plan_Qty=ifnull(var4gp.Stock_Qty,0) - ifnull(var4gp.BoM_Qty,0) * ifnull(var4gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var4gp.Purchase_Qty=var4gp.Plan_Qty; } } } } } //cwplrec4.Plan_Qty=ifnull(cwplrec4.BoM_Qty,0.0) * ifnull(cwplrec4.bom_stk_qty,0.0) - ifnull(cwplrec4.Stock_Qty,0.0); //cwplrec4.Actual_Qty=cwplrec4.Plan_Qty; } //LEVEL-5 if(cwplrec4.Level == "Level-5") { for each lis5 in Create_BOM[Part_No == cwplrec4.Part_No] { for each var5 in input.BoM_Details_CWPL { if(var5.Part_No.Part_No == lis5.Material_Details.Part_No.Part_No) { var5.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5.BoM_Qty=cwplrec4.Actual_Qty; var5.Actual_Qty=ifnull(var5.BoM_Qty,0.0) * ifnull(var5.bom_stk_qty,0.0) - ifnull(var5.Stock_Qty,0.0); var5.Plan_Qty=var5.Actual_Qty; } for each var5gp in input.BoM_Details_General_Purchase { if(var5gp.Part_No.Part_No.startswith("BT") == true || var5gp.Part_No.Part_No.startswith("NT") == true || var5gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var5.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var5gp.BoM_Qty=ifnull(var5.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=ifnull(var5gp.Plan_Qty,0); } } else { if(var5gp.Level == var5.Level && var5gp.Level == "Level-5") { var5gp.BoM_Qty=var5.Actual_Qty; // var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=var5gp.Plan_Qty; } } } } } //cwplrec4.Plan_Qty=ifnull(cwplrec4.BoM_Qty,0.0) * ifnull(cwplrec4.bom_stk_qty,0.0) - ifnull(cwplrec4.Stock_Qty,0.0); //cwplrec4.Actual_Qty=cwplrec4.Plan_Qty; } } } //Level 4 checking close /*----------------------------------------------------Level 5------------------------------------------------------------*/ //Checking if row.Level == 5, then run all the levels >=5 if(row.Level == "Level-5") { for each cwplrec5 in input.BoM_Details_CWPL { //LEVEL-5 if(cwplrec5.Level == "Level-5") { for each lis5 in Create_BOM[Part_No == cwplrec5.Part_No] { for each var5 in input.BoM_Details_CWPL { if(var5.Part_No.Part_No == lis5.Material_Details.Part_No.Part_No) { var5.Tot_BoM_Qty=ifnull(row.Actual_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5.BoM_Qty=cwplrec5.Actual_Qty; var5.Actual_Qty=ifnull(var5.BoM_Qty,0.0) * ifnull(var5.bom_stk_qty,0.0) - ifnull(var5.Stock_Qty,0.0); var5.Plan_Qty=var5.Actual_Qty; } if(var5.Stock_Qty > var5.BoM_Qty) { var5.Blocked_Qty=var5.Actual_Qty; } if(var5.Stock_Qty != 0 && var5.Blocked_Qty > var5.Stock_Qty || var5.Stock_Qty < var5.BoM_Qty) { var5.Blocked_Qty=var5.Stock_Qty; } for each var5gp in input.BoM_Details_General_Purchase { if(var5gp.Part_No.Part_No.startswith("BT") == true || var5gp.Part_No.Part_No.startswith("NT") == true || var5gp.Part_No.Part_No.startswith("WS") == true) { //If the CWPL is RIM, Corresponding General Pruchase is BT,NT,WS -->So this line is written to check the General Purchase. if(var5.Part_No.Part_No.contains("_UP") == true) { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); //If RIM means, var.Actual_qty should be passed to this BOM_Qty var5gp.BoM_Qty=ifnull(var5.Actual_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=ifnull(var5gp.Plan_Qty,0); } } else { if(var5gp.Level == var5.Level && var5gp.Level == "Level-5") { row.Tot_BoM_Qty=ifnull(row.BoM_Qty,0) * ifnull(row.bom_stk_qty,0.0); var5gp.BoM_Qty=var5.Actual_Qty; // var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); //Below ifelse is to check negative value if(ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0) >= 0) { var5gp.Plan_Qty=ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0) - ifnull(var5gp.Stock_Qty,0); } else { var5gp.Plan_Qty=ifnull(var5gp.Stock_Qty,0) - ifnull(var5gp.BoM_Qty,0) * ifnull(var5gp.Org_BoM_Qty,0.0); } //Above ifelse ends here var5gp.Purchase_Qty=var5gp.Plan_Qty; } } } } } //cwplrec5.Plan_Qty=ifnull(cwplrec5.BoM_Qty,0.0) * ifnull(cwplrec5.bom_stk_qty,0.0) - ifnull(cwplrec5.Stock_Qty,0.0); //cwplrec5.Actual_Qty=cwplrec5.Plan_Qty; } } } //Level 5 checking close for each rec in input.BoM_Details_CWPL { if(rec.Actual_Qty < 0) { rec.Actual_Qty=0; rec.Plan_Qty=0; rec.BoM_Qty=0; } if(rec.Blocked_Qty < 0) { rec.Blocked_Qty=0; } if(rec.Stock_Qty > rec.BoM_Qty) { rec.Blocked_Qty=rec.Actual_Qty; } if(rec.Stock_Qty != 0 && rec.Blocked_Qty > rec.Stock_Qty || rec.Stock_Qty < rec.BoM_Qty) { rec.Blocked_Qty=rec.Stock_Qty; } } for each rec1 in input.BoM_Details_General_Purchase { if(rec1.Blocked_Qty < 0) { rec1.Blocked_Qty=0; } if(rec1.Purchase_Qty < 0 || rec1.BoM_Qty < 0) { rec1.Purchase_Qty=0; rec1.Plan_Qty=0; rec1.BoM_Qty=0; } if(rec1.Stock_Qty > rec1.BoM_Qty) { rec1.Blocked_Qty=rec1.Purchase_Qty; } if(rec1.Stock_Qty != 0 && rec1.Blocked_Qty > rec1.Stock_Qty || rec1.Stock_Qty < rec1.BoM_Qty) { rec1.Blocked_Qty=rec1.Stock_Qty; } }
try { var = 0; fet_wosub = Work_Order_Subform[ID == input.Work_Order_Subform_ID]; fet_wo = Work_Order[ID == fet_wosub.Work_Order_Exis_ID]; fetsosub = Sale_Order_Subform[Work_Order_RECID == fet_wo.ID]; fet_wosub.MRP_ID=input.ID; fet_wr = Warehouse[ID != null]; if(isBlank(input.MRP_No.trim())) { var = 1; input.MRP_No = thisapp.Common.Number_Function_New("Material Resource Planning"); } if(input.Process_to_Submit = "Draft") { input.MRP_Status = "Draft"; fet_wo.WO_Status="MRP Draft"; fet_wosub.Work_Order_Status="MRP Draft"; if(fetsosub.count() > 0) { fetsosub.WO_Status_in_sosub="MRP Draft"; } indnthead = "No"; indsno = 0; for each rec in input.BoM_Details_General_Purchase { if(rec.Draft_Indent == true && input.Process_to_Submit == "Draft" && rec.Purchase_Qty > 0) { indsno = indsno + 1; thisapp.routing.RoutingFunction(input.ID); str1 = thisapp.Common.Number_Function_New("Purchase Requisition"); if(indnthead == "No" && rec.Purchase_Qty > 0) { fet_emp = Employee_Details[Employee_Email == zoho.loginuserid]; //Check for the Part No is already exists in the Indent without generation the purchase order. chkpartno = Indent_Sub_Form[Part_No == rec.Part_No && Status == "Indent against WO" && Purpose_of_Indent == "For MRP"]; if(chkpartno.count() == 0) { insrec = insert into Indent [ Indent_Request_Date=zoho.currentdate Request_Raised_By=fet_emp.ID Indent_No=str1 Material_Type="Standard" Department=fet_emp.Department_Name Approval_Status="Approved" Indent_Type="System Generated - Planning" Status="Indent against WO" Remarks="For Production Process" MRP_ID=input.ID Added_User=zoho.loginuser ]; indnthead = "Yes"; } } if(chkpartno.count() == 0) { subins = insert into Indent_Sub_Form [ Added_User=zoho.loginuser Indent_Form_RECID=insrec S_No=indsno Part_No=rec.Part_No Part_Description=rec.Part_Name UoM=rec.UoM Required_Qty=rec.Purchase_Qty Purpose_of_Indent="For MRP" Indent_No=str1 Status="Indent against WO" Work_Order_No_ms=input.Work_Order_ID ]; } else { wonolist = List(); wonolist.addall(chkpartno.Work_Order_No_ms); wonolist.add(input.Work_Order_No1); chkpartno.Work_Order_No_ms=wonolist; chkpartno.Required_Qty=ifnull(rec.Purchase_Qty,0) + ifnull(chkpartno.Required_Qty,0); } thisapp.MRP.Indent_Email_MRP(input.ID); } } } else if(input.Process_to_Submit = "Send for Approval") { input.MRP_Status = "Waiting for Approval"; input.Approval = "Pending"; } else if(input.Process_to_Submit = "Submit") { input.Approval = "Approved"; input.MRP_Status = "MRP Done"; fet_wo.WO_Status="MRP Done"; if(fetsosub.count() > 0) { fetsosub.WO_Status_in_sosub="MRP Done"; } } if(fet_wosub.Work_Order_Status == "MRP Rejected") { fet_wosub.Work_Order_Status="WO Created"; } if(input.Auto_Approval == "Yes") { input.MRP_Status = "MRP Done"; fet_wo.MRP_Status="MRP Done"; fet_wosub.Work_Order_Status="MRP Done"; input.Approval = "Approved"; for each blk in input.BoM_Details_CWPL { fet_inv = Inventory[Part_No == blk.Part_No && Available_Qty > 0] sort by Available_Qty desc; if(fet_inv.count() > 0) { if(blk.Block_Qty = True) { balqty = 0; i = 1; for each invcwplrec in fet_inv { //blocked Quantiy is less inventory available qty if(blk.Blocked_Qty <= invcwplrec.Available_Qty && i == 1) { //info "issued qty is less than total qty"; invcwplrec.Available_Qty=ifnull(invcwplrec.Available_Qty,0.0) - ifnull(blk.Blocked_Qty,0.0); invcwplrec.Block_Qty=ifnull(blk.Blocked_Qty,0) + ifnull(invcwplrec.Block_Qty,0); } //blocked Quantiy is more than inventory available qty else if(blk.Blocked_Qty > invcwplrec.Available_Qty && i == 1) { //info "issued qty is more than total qty"; balqty = ifnull(blk.Blocked_Qty,0.0) - ifnull(invcwplrec.Available_Qty,0.0); invcwplrec.Available_Qty=0; invcwplrec.Block_Qty=ifnull(blk.Blocked_Qty,0) + ifnull(invcwplrec.Block_Qty,0); } //for first time it should not get inside the loop if(balqty > 0 && i > 1) { //info "balance qty is more than zero"; //Balance Qty is less if(balqty <= invcwplrec.Available_Qty) { //info "balance qty is less than total qty"; invcwplrec.Available_Qty=ifnull(invcwplrec.Available_Qty,0.0) - ifnull(balqty,0.0); invcwplrec.Block_Qty=ifnull(blk.Blocked_Qty,0) + ifnull(invcwplrec.Block_Qty,0); balqty = 0; } //----Balance Qty is More------ else if(balqty >= invcwplrec.Available_Qty) { //info "balance qty is greater than total qty"; balqty = ifnull(balqty,0.0) - ifnull(invcwplrec.Available_Qty,0.0); invcwplrec.Available_Qty=0; invcwplrec.Block_Qty=ifnull(balqty,0) + ifnull(invcwplrec.Block_Qty,0); } } if(balqty == 0) { break; } i = i + 1; } if(blk.Blocked_Qty > 0) { insblock = insert into Block_Quantity [ Part_No=blk.Part_No Part_Name=blk.Part_Name Form_Type="MRP" Block_Qty=blk.Blocked_Qty MRP_RECID=input.ID WO_No=fet_wo.ID Status="Blocked from MRP" Added_User=zoho.loginuser ]; } } } } for each blk1 in input.BoM_Details_General_Purchase { fet_virstk = Inventory[Part_No == blk1.Part_No && Available_Qty > 0] sort by Available_Qty desc; if(fet_virstk.count() > 0) { if(blk1.Block_Qty = True) { balqty = 0; i1 = 1; for each invgprec in fet_virstk { // info balqty; // info i1; //if(input.MRP_Qty >= fet_inv.Available_Qty && input.MRP_Qty >= fet_inv.Total_Qty) if(blk1.Blocked_Qty <= invgprec.Available_Qty && i1 == 1) { //info "blocked qty is less than total qty"; invgprec.Block_Qty=ifnull(blk1.Blocked_Qty,0) + ifnull(invgprec.Block_Qty,0); invgprec.Available_Qty=ifnull(invgprec.Available_Qty,0) - ifnull(blk1.Blocked_Qty,0); } else if(blk1.Blocked_Qty > invgprec.Available_Qty && i == 1) { //info "blocked qty is more than available qty"; balqty = ifnull(blk1.Blocked_Qty,0.0) - ifnull(invgprec.Available_Qty,0.0); invgprec.Available_Qty=0; invgprec.Block_Qty=ifnull(blk1.Blocked_Qty,0) + ifnull(invgprec.Block_Qty,0); } if(balqty > 0 && i > 1) { //info "balaance qty is more than zero"; //Balance Qty is less if(balqty <= invgprec.Available_Qty) { // info "balance qty is less than available qty"; invgprec.Available_Qty=ifnull(invgprec.Available_Qty,0.0) - ifnull(balqty,0.0); invgprec.Block_Qty=ifnull(blk1.Blocked_Qty,0) + ifnull(invgprec.Block_Qty,0); balqty = 0; } //Balance Qty is More else if(balqty >= invgprec.Available_Qty) { //info "balance qty is greater than available qty"; balqty = ifnull(balqty,0.0) - ifnull(invgprec.Available_Qty,0.0); invgprec.Available_Qty=0; invgprec.Block_Qty=ifnull(blk1.Blocked_Qty,0) + ifnull(invgprec.Block_Qty,0); } } if(balqty == 0) { //info "before break"; break; } i = i + 1; } } } if(blk1.Blocked_Qty > 0) { insblock = insert into Block_Quantity [ Part_No=blk1.Part_No Part_Name=blk1.Part_Name Form_Type="MRP" Block_Qty=blk1.Blocked_Qty MRP_RECID=input.ID MRP_No=input.MRP_No WO_No=fet_wo.ID Status="Blocked from MRP" Added_User=zoho.loginuser ]; } } } else if(input.Process_to_Submit == "Submit" && input.Auto_Approval == "Yes" || input.Auto_Approval == "No") { input.MRP_Status = "MRP Done"; fet_wo.MRP_Status="MRP Done"; fet_wosub.Work_Order_Status="MRP Done"; input.Approval = "Approved"; if(fetsosub.count() > 0) { fetsosub.WO_Status_in_sosub="MRP Done"; } for each blkcwpl in input.BoM_Details_CWPL { fet_inve = Inventory[Part_No == blkcwpl.Part_No && Available_Qty > 0] sort by Available_Qty desc; if(fet_inve.count() > 0) { if(blkcwpl.Block_Qty = True) { balqty = 0; i = 1; for each invcwplrec1 in fet_inve { //blocked Quantiy is less inventory available qty if(blkcwpl.Blocked_Qty <= invcwplrec1.Available_Qty && i == 1) { // info "issued qty is less than total qty"; invcwplrec1.Available_Qty=ifnull(invcwplrec1.Available_Qty,0.0) - ifnull(blkcwpl.Blocked_Qty,0.0); invcwplrec1.Block_Qty=ifnull(blkcwpl.Blocked_Qty,0) + ifnull(invcwplrec1.Block_Qty,0); } //blocked Quantiy is more than inventory available qty else if(blkcwpl.Blocked_Qty > invcwplrec1.Available_Qty && i == 1) { //info "issued qty is more than total qty"; balqty = ifnull(blkcwpl.Blocked_Qty,0.0) - ifnull(invcwplrec1.Available_Qty,0.0); invcwplrec1.Available_Qty=0; invcwplrec1.Block_Qty=ifnull(blkcwpl.Blocked_Qty,0) + ifnull(invcwplrec1.Block_Qty,0); } //for first time it should not get inside the loop if(balqty > 0 && i > 1) { //info "balance qty is more than zero"; //Balance Qty is less if(balqty <= invcwplrec1.Available_Qty) { //info "balance qty is less than total qty"; invcwplrec1.Available_Qty=ifnull(invcwplrec1.Available_Qty,0.0) - ifnull(balqty,0.0); invcwplrec1.Block_Qty=ifnull(blkcwpl.Blocked_Qty,0) + ifnull(invcwplrec1.Block_Qty,0); balqty = 0; } //----Balance Qty is More------ else if(balqty >= invcwplrec1.Available_Qty) { //info "balance qty is greater than total qty"; balqty = ifnull(balqty,0.0) - ifnull(invcwplrec1.Available_Qty,0.0); invcwplrec1.Available_Qty=0; invcwplrec1.Block_Qty=ifnull(balqty,0) + ifnull(invcwplrec1.Block_Qty,0); } } if(balqty == 0) { break; } i = i + 1; } if(blkcwpl.Blocked_Qty > 0) { insblock = insert into Block_Quantity [ Part_No=blkcwpl.Part_No Part_Name=blkcwpl.Part_Name Form_Type="MRP" Block_Qty=blkcwpl.Blocked_Qty WO_No=fet_wo.ID MRP_RECID=input.ID Status="Blocked from MRP" Added_User=zoho.loginuser ]; } } } } for each blkgp in input.BoM_Details_General_Purchase { fet_virstk1 = Inventory[Part_No == blkgp.Part_No && Available_Qty > 0] sort by Available_Qty desc; if(fet_virstk1.count() > 0) { if(blkgp.Block_Qty = True) { balqty = 0; i1 = 1; for each invgprec1 in fet_virstk1 { // info balqty; // info i1; //if(input.MRP_Qty >= fet_inve.Available_Qty && input.MRP_Qty >= fet_inv.Total_Qty) if(blkgp.Blocked_Qty <= invgprec1.Available_Qty && i1 == 1) { //info "blocked qty is less than total qty"; invgprec1.Block_Qty=ifnull(blkgp.Blocked_Qty,0) + ifnull(invgprec1.Block_Qty,0); invgprec1.Available_Qty=ifnull(invgprec1.Available_Qty,0) - ifnull(blkgp.Blocked_Qty,0); } else if(blkgp.Blocked_Qty > invgprec1.Available_Qty && i1 == 1) { //info "blocked qty is more than available qty"; balqty = ifnull(blkgp.Blocked_Qty,0.0) - ifnull(invgprec1.Available_Qty,0.0); invgprec1.Available_Qty=0; invgprec1.Block_Qty=ifnull(blkgp.Blocked_Qty,0) + ifnull(invgprec1.Block_Qty,0); } if(balqty > 0 && i1 > 1) { //info "balaance qty is more than zero"; //Balance Qty is less if(balqty <= invgprec1.Available_Qty) { // info "balance qty is less than available qty"; invgprec1.Available_Qty=ifnull(invgprec1.Available_Qty,0.0) - ifnull(balqty,0.0); invgprec1.Block_Qty=ifnull(blkgp.Blocked_Qty,0) + ifnull(invgprec1.Block_Qty,0); balqty = 0; } //Balance Qty is More else if(balqty >= invgprec1.Available_Qty) { // info "balance qty is greater than available qty"; balqty = ifnull(balqty,0.0) - ifnull(invgprec1.Available_Qty,0.0); invgprec1.Available_Qty=0; invgprec1.Block_Qty=ifnull(blkgp.Blocked_Qty,0) + ifnull(invgprec1.Block_Qty,0); } } if(balqty == 0) { //info "before break"; break; } i1 = i1 + 1; } } } if(blkgp.Blocked_Qty > 0) { insblock = insert into Block_Quantity [ Part_No=blkgp.Part_No Part_Name=blkgp.Part_Name Form_Type="MRP" Block_Qty=blkgp.Blocked_Qty MRP_RECID=input.ID WO_No=fet_wo.ID Status="Blocked from MRP" Added_User=zoho.loginuser ]; } } } openUrl("#Form:Alert_Messages?Status=" + "MATRES" + "&Value=" + input.MRP_No + "&zc_LoadIn=dialog","same window"); } catch (e) { sendmail [ from :"erp@carrierwheels.com" to :"parthasarathy.m@synprosoft.com" subject :"MRP Created Or Edited Successful Form Submission try & catch" + input.MRP_No message :e ] }
//Last Corectly Made changes in ->Check the below version //Version 73.7 //01-Jul-2024 18:25:55 hide Reset1; hide MRP_No; fet_pref = Preferences[Module_Name = "MRP"]; input.Auto_Approval = fet_pref.Auto_Approval; if(input.Work_Order_Subform_ID != null) { fet_wosub = Work_Order_Subform[ID == input.Work_Order_Subform_ID]; fet_wo = Work_Order[ID == fet_wosub.Work_Order_Exis_ID]; if(fet_wo.Form_Mode == "Direct WO") { hide Sales_Order_No; hide Customer_Name; } input.Sales_Order_No = fet_wo.Sales_Order_Nos; input.Customer_Name = fet_wo.Customer_Name; input.Work_Order_Date = fet_wo.Work_Order_Date; input.Part_No = fet_wosub.Part_No; input.Part_Name = fet_wosub.Part_Description; input.Category = fet_wo.Category; input.Sub_Category = fet_wo.Sub_Category; input.MRP_Qty = fet_wosub.WO_Qty; input.Work_Order_No1 = fet_wo.ID; fet_bom = Create_BOM[Part_No == input.Work_Order_Subform_ID.Part_No && Status == "Active"]; level1 = BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == input.Part_No && BOM_FG_Exis_ID.Status == "Active"]; inside_gplevel1 = 0; inside_gplevel2 = 0; inside_gplevel3 = 0; inside_gplevel4 = 0; inside_gplevel5 = 0; for each levellist1 in level1 { level2 = BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist1.Part_No && BOM_FG_Exis_ID.Status == "Active"]; if(levellist1.Material_Item_Type.Material_Type == "CWPL Products" || levellist1.Material_Item_Type.Material_Type == "HR Coils and Sheets") { cwplrow = MRP.BoM_Details_CWPL(); inven1 = Inventory[Part_No == levellist1.Part_No].sum(Available_Qty); cwplrow.Part_No=levellist1.Part_No; cwplrow.Part_Name=levellist1.Part_Description; cwplrow.UoM=levellist1.UoM; cwplrow.Work_Order_No=fet_wo.ID; cwplrow.Stock_Qty=inven1.round(0); cwplrow.Material_Item_Type=levellist1.Material_Item_Type; cwplrow.bom_stk_qty=ifnull(levellist1.Qty,0.0); cwplrow.Level="Level-1"; cwplrow.test_level="Level-1"; cwplrow.Create_BoM_RECID=fet_bom.ID; cwplrow.Tot_BoM_Qty=ifnull(input.MRP_Qty,0) * ifnull(cwplrow.bom_stk_qty,0.0); //CALCULATION PART if(cwplrow.Stock_Qty >= input.MRP_Qty) { cwplrow.Actual_Qty=0; cwplrow.Plan_Qty=0; cwplrow.BoM_Qty=ifnull(input.MRP_Qty,0); //cwplrow.BoM_Qty=0; } else if(cwplrow.Stock_Qty < input.MRP_Qty) { cwplrow.Actual_Qty=ifnull(input.MRP_Qty,0) * ifnull(cwplrow.bom_stk_qty,0.0) - ifnull(cwplrow.Stock_Qty,0); cwplrow.BoM_Qty=ifnull(input.MRP_Qty,0); cwplrow.Plan_Qty=ifnull(input.MRP_Qty,0) * ifnull(cwplrow.bom_stk_qty,0.0) - ifnull(cwplrow.Stock_Qty,0); } else if(cwplrow.Stock_Qty > input.MRP_Qty) { cwplrow.BoM_Qty=ifnull(input.MRP_Qty,0); cwplrow.Actual_Qty=0; cwplrow.Plan_Qty=0; } input.BoM_Details_CWPL.insert(cwplrow); } for each abc in BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == input.Part_No && BOM_FG_Exis_ID.Status == "Active" && Material_Item_Type.Material_Type == "General Purchase"] { if(inside_gplevel1 == 0) { if(abc.Material_Item_Type.Material_Type == "General Purchase") { fetind = Indent_Sub_Form[Part_No == abc.Part_No].sum(Required_Qty); dprsub = DPR_General_Purchase_Stock_Qty[Part_No == abc.Part_No]; gprow = MRP.BoM_Details_General_Purchase(); inven = Inventory[Part_No == abc.Part_No].sum(Available_Qty); gprow.Part_No=abc.Part_No; gprow.Part_Name=abc.Part_Description; gprow.UoM=abc.UoM; gprow.Work_Order_No=fet_wo.ID; gprow.Material_Item_Type=abc.Material_Item_Type; gprow.Org_BoM_Qty=ifnull(abc.Qty,0.0); gprow.Stock_Qty=inven.round(0); gprow.Indent_Qty=fetind; gprow.Level="Level"; gprow.test_level="Level-1"; gprow.Create_BoM_RECID=fet_bom.ID; gprow.BoM_Qty=ifnull(input.MRP_Qty,0); gprow.Material_Center_Qty=ifnull(dprsub.GP_Balance_Qty,0); //CALCULATION PART //Below ifelse is to check negative value if(gprow.Material_Center_Qty == 0) { if(ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0) - ifnull(gprow.Stock_Qty,0) >= 0) { gprow.Tot_BoM_Qty=ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0); gprow.Plan_Qty=ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0) - ifnull(gprow.Stock_Qty,0); } else if(ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0) - ifnull(gprow.Stock_Qty,0) < 0) { gprow.Tot_BoM_Qty=ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0); gprow.Plan_Qty=ifnull(gprow.Stock_Qty,0) - ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0); } gprow.Purchase_Qty=ifnull(gprow.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow); } else if(gprow.Material_Center_Qty > 0) { if(ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0) - ifnull(gprow.Material_Center_Qty,0) >= 0) { gprow.Tot_BoM_Qty=ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0); gprow.Plan_Qty=ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0) - ifnull(gprow.Material_Center_Qty,0); } else if(ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0) - ifnull(gprow.Material_Center_Qty,0) < 0) { gprow.Tot_BoM_Qty=ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0); gprow.Plan_Qty=ifnull(gprow.Material_Center_Qty,0) - ifnull(gprow.BoM_Qty,0) * ifnull(gprow.Org_BoM_Qty,0.0); } gprow.Purchase_Qty=ifnull(gprow.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow); } } } } inside_gplevel1 = 1; cnt = 0; for each levellist2 in level2 { crtbom = Create_BOM[BoM_FG_Subform_ID == levellist2.ID && Status == "Active"]; cnt = cnt + 1; level3 = BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist2.Part_No && BOM_FG_Exis_ID.Status == "Active"]; if(levellist2.Material_Item_Type.Material_Type == "CWPL Products" || levellist2.Material_Item_Type.Material_Type == "HR Coils and Sheets") { cwplrow2 = MRP.BoM_Details_CWPL(); inven1 = Inventory[Part_No == levellist2.Part_No].sum(Available_Qty); cwplrow2.Part_No=levellist2.Part_No; cwplrow2.Part_Name=levellist2.Part_Description; cwplrow2.UoM=levellist2.UoM; cwplrow2.Work_Order_No=fet_wo.ID; cwplrow2.Stock_Qty=inven1.round(0); cwplrow2.Material_Item_Type=levellist2.Material_Item_Type; cwplrow2.bom_stk_qty=ifnull(levellist2.Qty,0.0); cwplrow2.Level="Level-2"; cwplrow2.test_level="Level1." + cnt; cwplrow2.Create_BoM_RECID=crtbom.ID; cwplrow2.BoM_Qty=cwplrow.Actual_Qty; cwplrow2.Tot_BoM_Qty=ifnull(cwplrow2.BoM_Qty,0.0) * ifnull(cwplrow2.bom_stk_qty,0.0); //CALCULATION PART planqty = 0.0; stkqty = 0.0; if(cwplrow2.Stock_Qty >= cwplrow2.Tot_BoM_Qty) { cwplrow2.Actual_Qty=0; //cwplrow2.BoM_Qty=0; cwplrow2.Plan_Qty=0; } if(cwplrow2.Stock_Qty < cwplrow2.Tot_BoM_Qty && cwplrow2.BoM_Qty != null) { planqty = ifnull(cwplrow2.BoM_Qty,0.0) * ifnull(cwplrow2.bom_stk_qty,0.0); stkqty = planqty - ifnull(cwplrow2.Stock_Qty,0.0); cwplrow2.Actual_Qty=stkqty; cwplrow2.Plan_Qty=stkqty; } input.BoM_Details_CWPL.insert(cwplrow2); } for each abc2 in BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist1.Part_No && Material_Item_Type.Material_Type == "General Purchase" && BOM_FG_Exis_ID.Status == "Active"] { if(inside_gplevel2 == 0) { if(abc2.Material_Item_Type.Material_Type == "General Purchase") { fetind = Indent_Sub_Form[Part_No == abc2.Part_No].sum(Required_Qty); dprsub = DPR_General_Purchase_Stock_Qty[Part_No == abc2.Part_No]; gprow2 = MRP.BoM_Details_General_Purchase(); inven = Inventory[Part_No == abc2.Part_No].sum(Available_Qty); gprow2.Part_No=abc2.Part_No; gprow2.Part_Name=abc2.Part_Description; gprow2.UoM=abc2.UoM; gprow2.Work_Order_No=fet_wo.ID; gprow2.Material_Item_Type=abc2.Material_Item_Type; gprow2.Org_BoM_Qty=ifnull(abc2.Qty,0.0); gprow2.Stock_Qty=inven.round(0); gprow2.Indent_Qty=fetind; gprow2.Level="Level-1"; gprow2.test_level="Level1." + cnt; gprow2.Create_BoM_RECID=crtbom.ID; //CALCULATION PART gprow2.BoM_Qty=ifnull(cwplrow.Actual_Qty,0); gprow2.Tot_BoM_Qty=ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0); gprow2.Material_Center_Qty=ifnull(dprsub.GP_Balance_Qty,0); //Below ifelse is to check negative value if(gprow2.Material_Center_Qty == 0) { if(ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0) - ifnull(gprow2.Stock_Qty,0) >= 0) { gprow2.Plan_Qty=ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0) - ifnull(gprow2.Stock_Qty,0); } else { gprow2.Plan_Qty=ifnull(gprow2.Stock_Qty,0) - ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0); } gprow2.Purchase_Qty=ifnull(gprow2.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow2); } else if(gprow2.Material_Center_Qty > 0) { if(ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0) - ifnull(gprow2.Material_Center_Qty,0) >= 0) { gprow2.Tot_BoM_Qty=ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0); gprow2.Plan_Qty=ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0) - ifnull(gprow2.Material_Center_Qty,0); } else if(ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0) - ifnull(gprow2.Material_Center_Qty,0) < 0) { gprow2.Tot_BoM_Qty=ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0); gprow2.Plan_Qty=ifnull(gprow2.Material_Center_Qty,0) - ifnull(gprow2.BoM_Qty,0) * ifnull(gprow2.Org_BoM_Qty,0.0); } gprow2.Purchase_Qty=ifnull(gprow2.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow2); } } } } inside_gplevel2 = 1; cnt1 = 0; for each levellist3 in level3 { crtbom1 = Create_BOM[BoM_FG_Subform_ID == levellist3.ID && Status == "Active"]; cnt1 = cnt1 + 1; level4 = BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist3.Part_No && BOM_FG_Exis_ID.Status == "Active"]; if(levellist3.Material_Item_Type.Material_Type == "CWPL Products" || levellist3.Material_Item_Type.Material_Type == "HR Coils and Sheets") { cwplrow3 = MRP.BoM_Details_CWPL(); inven1 = Inventory[Part_No == levellist3.Part_No].sum(Available_Qty); cwplrow3.Part_No=levellist3.Part_No; cwplrow3.Part_Name=levellist3.Part_Description; cwplrow3.UoM=levellist3.UoM; cwplrow3.Work_Order_No=fet_wo.ID; cwplrow3.Stock_Qty=inven1.round(0); cwplrow3.Material_Item_Type=levellist3.Material_Item_Type; cwplrow3.bom_stk_qty=ifnull(levellist3.Qty,0.0); cwplrow3.Level="Level-3"; cwplrow3.test_level="Level-1.1" + "." + cnt1; cwplrow3.Create_BoM_RECID=crtbom1.ID; cwplrow3.BoM_Qty=cwplrow2.Actual_Qty; cwplrow3.Tot_BoM_Qty=ifnull(cwplrow3.BoM_Qty,0.0) * ifnull(cwplrow3.bom_stk_qty,0.0); //CALCULATION PART planqty = 0.0; stkqty = 0.0; if(cwplrow3.Stock_Qty >= cwplrow3.Tot_BoM_Qty) { cwplrow3.Actual_Qty=0; // cwplrow3.BoM_Qty=0; cwplrow3.Plan_Qty=0; } if(cwplrow3.Stock_Qty < cwplrow3.Tot_BoM_Qty && cwplrow3.Tot_BoM_Qty != null) { planqty = ifnull(cwplrow3.BoM_Qty,0.0) * ifnull(cwplrow3.bom_stk_qty,0.0); stkqty = planqty - ifnull(cwplrow3.Stock_Qty,0.0); cwplrow3.Actual_Qty=stkqty; cwplrow3.Plan_Qty=stkqty; } input.BoM_Details_CWPL.insert(cwplrow3); } for each abc3 in BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist2.Part_No && Material_Item_Type.Material_Type == "General Purchase" && BOM_FG_Exis_ID.Status == "Active"] { if(inside_gplevel3 == 0) { if(abc3.Material_Item_Type.Material_Type == "General Purchase") { fetind = Indent_Sub_Form[Part_No == abc3.Part_No].sum(Required_Qty); dprsub = DPR_General_Purchase_Stock_Qty[Part_No == abc3.Part_No]; gprow3 = MRP.BoM_Details_General_Purchase(); inven = Inventory[Part_No == abc3.Part_No].sum(Available_Qty); gprow3.Part_No=abc3.Part_No; gprow3.Part_Name=abc3.Part_Description; gprow3.UoM=abc3.UoM; gprow3.Work_Order_No=fet_wo.ID; gprow3.Material_Item_Type=abc3.Material_Item_Type; gprow3.Org_BoM_Qty=ifnull(abc3.Qty,0.0); gprow3.Stock_Qty=inven.round(0); gprow3.Indent_Qty=fetind; gprow3.Level="Level-2"; gprow3.test_level="Level-1.1" + "." + cnt1; gprow3.Create_BoM_RECID=crtbom1.ID; gprow3.Material_Center_Qty=ifnull(dprsub.GP_Balance_Qty,0); //CALCULATION PART gprow3.BoM_Qty=ifnull(cwplrow2.Actual_Qty,0); gprow3.Tot_BoM_Qty=ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0); gprow3.Material_Center_Qty=ifnull(dprsub.GP_Balance_Qty,0); //Below ifelse is to check negative value if(gprow3.Material_Center_Qty == 0) { if(ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0) - ifnull(gprow3.Stock_Qty,0) >= 0) { gprow3.Plan_Qty=ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0) - ifnull(gprow3.Stock_Qty,0); } else { gprow3.Plan_Qty=ifnull(gprow3.Stock_Qty,0) - ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0); } gprow3.Purchase_Qty=ifnull(gprow3.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow3); } else if(gprow3.Material_Center_Qty > 0) { if(ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0) - ifnull(gprow3.Material_Center_Qty,0) >= 0) { gprow3.Tot_BoM_Qty=ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0); gprow3.Plan_Qty=ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0) - ifnull(gprow3.Material_Center_Qty,0); } else if(ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0) - ifnull(gprow3.Material_Center_Qty,0) < 0) { gprow3.Tot_BoM_Qty=ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0); gprow3.Plan_Qty=ifnull(gprow3.Material_Center_Qty,0) - ifnull(gprow3.BoM_Qty,0) * ifnull(gprow3.Org_BoM_Qty,0.0); } gprow3.Purchase_Qty=ifnull(gprow3.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow3); } } } } inside_gplevel3 = 1; cnt2 = 0; for each levellist4 in level4 { crtbom2 = Create_BOM[BoM_FG_Subform_ID == levellist4.ID && Status == "Active"]; level5 = BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist4.Part_No && BOM_FG_Exis_ID.Status == "Active"]; cnt2 = cnt2 + 1; if(levellist4.Material_Item_Type.Material_Type == "CWPL Products" || levellist4.Material_Item_Type.Material_Type == "HR Coils and Sheets") { cwplrow4 = MRP.BoM_Details_CWPL(); inven1 = Inventory[Part_No == levellist4.Part_No].sum(Available_Qty); cwplrow4.Part_No=levellist4.Part_No; cwplrow4.Part_Name=levellist4.Part_Description; cwplrow4.UoM=levellist4.UoM; cwplrow4.Work_Order_No=fet_wo.ID; cwplrow4.Stock_Qty=inven1.round(0); cwplrow4.Material_Item_Type=levellist4.Material_Item_Type; cwplrow4.bom_stk_qty=ifnull(levellist4.Qty,0.0); cwplrow4.Level="Level-4"; cwplrow4.test_level="Level-1.1" + "." + cnt1 + "." + cnt2; cwplrow4.Create_BoM_RECID=crtbom2.ID; cwplrow4.BoM_Qty=cwplrow3.Actual_Qty; cwplrow4.Tot_BoM_Qty=ifnull(cwplrow4.bom_stk_qty,0.0) * ifnull(cwplrow4.BoM_Qty,0.0); //CALCULATION PART planqty = 0.0; stkqty = 0.0; if(cwplrow4.Stock_Qty >= cwplrow4.Tot_BoM_Qty) { cwplrow4.Actual_Qty=0; //cwplrow4.BoM_Qty=0; cwplrow4.Plan_Qty=0; } if(cwplrow4.Stock_Qty < cwplrow4.Tot_BoM_Qty && cwplrow4.Tot_BoM_Qty != null) { planqty = ifnull(cwplrow4.BoM_Qty,0.0) * ifnull(cwplrow4.bom_stk_qty,0.0); stkqty = planqty - ifnull(cwplrow4.Stock_Qty,0.0); cwplrow4.Actual_Qty=stkqty; cwplrow4.Plan_Qty=stkqty; } input.BoM_Details_CWPL.insert(cwplrow4); } for each abc4 in BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist3.Part_No && Material_Item_Type.Material_Type == "General Purchase" && BOM_FG_Exis_ID.Status == "Active"] { if(inside_gplevel4 == 0) { if(abc4.Material_Item_Type.Material_Type == "General Purchase") { fetind = Indent_Sub_Form[Part_No == abc4.Part_No].sum(Required_Qty); dprsub = DPR_General_Purchase_Stock_Qty[Part_No == abc4.Part_No]; gprow4 = MRP.BoM_Details_General_Purchase(); inven = Inventory[Part_No == abc4.Part_No].sum(Available_Qty); gprow4.Part_No=abc4.Part_No; gprow4.Part_Name=abc4.Part_Description; gprow4.UoM=abc4.UoM; gprow4.Work_Order_No=fet_wo.ID; gprow4.Material_Item_Type=abc4.Material_Item_Type; gprow4.Org_BoM_Qty=ifnull(abc4.Qty,0.0); gprow4.Stock_Qty=inven.round(0); gprow4.Indent_Qty=fetind; gprow4.Level="Level-3"; gprow4.test_level="Level-1.1" + "." + cnt1 + "." + cnt2; gprow4.Create_BoM_RECID=crtbom2.ID; gprow4.Material_Center_Qty=ifnull(dprsub.GP_Balance_Qty,0); //CALCULATION PART gprow4.BoM_Qty=ifnull(cwplrow3.Actual_Qty,0); gprow4.Tot_BoM_Qty=ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0); //Below ifelse is to check negative value if(gprow4.Material_Center_Qty == 0) { if(ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0) - ifnull(gprow4.Stock_Qty,0) >= 0) { gprow4.Plan_Qty=ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0) - ifnull(gprow4.Stock_Qty,0); } else { gprow4.Plan_Qty=ifnull(gprow4.Stock_Qty,0) - ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0); } gprow4.Purchase_Qty=ifnull(gprow4.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow4); } else if(gprow4.Material_Center_Qty > 0) { if(ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0) - ifnull(gprow4.Material_Center_Qty,0) >= 0) { gprow4.Tot_BoM_Qty=ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0); gprow4.Plan_Qty=ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0) - ifnull(gprow4.Material_Center_Qty,0); } else if(ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0) - ifnull(gprow4.Material_Center_Qty,0) < 0) { gprow4.Tot_BoM_Qty=ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0); gprow4.Plan_Qty=ifnull(gprow4.Material_Center_Qty,0) - ifnull(gprow4.BoM_Qty,0) * ifnull(gprow4.Org_BoM_Qty,0.0); } gprow4.Purchase_Qty=ifnull(gprow4.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow4); } } } } inside_gplevel4 = 1; cnt3 = 0; for each levellist5 in level5 { crtbom3 = Create_BOM[BoM_FG_Subform_ID == levellist5.ID && Status == "Active"]; cnt3 = cnt3 + 1; if(levellist5.Material_Item_Type.Material_Type == "CWPL Products" || levellist5.Material_Item_Type.Material_Type == "HR Coils and Sheets") { cwplrow5 = MRP.BoM_Details_CWPL(); inven1 = Inventory[Part_No == levellist5.Part_No].sum(Available_Qty); cwplrow5.Part_No=levellist5.Part_No; cwplrow5.Part_Name=levellist5.Part_Description; cwplrow5.UoM=levellist5.UoM; cwplrow5.Work_Order_No=fet_wo.ID; cwplrow5.Stock_Qty=inven1.round(0); cwplrow5.Material_Item_Type=levellist5.Material_Item_Type; cwplrow5.bom_stk_qty=ifnull(levellist5.Qty,0.0); cwplrow5.Level="Level-5"; cwplrow5.test_level="Level1.1" + "." + cnt1 + "." + cnt2 + "." + cnt3; cwplrow5.Create_BoM_RECID=crtbom3.ID; cwplrow5.BoM_Qty=cwplrow4.Actual_Qty; cwplrow5.Tot_BoM_Qty=ifnull(cwplrow5.BoM_Qty,0.0) * ifnull(cwplrow5.bom_stk_qty,0.0); //CALCULATION PART planqty = 0.0; stkqty = 0.0; if(cwplrow5.Stock_Qty >= cwplrow5.Tot_BoM_Qty) { cwplrow5.Actual_Qty=0; //cwplrow5.BoM_Qty=0; cwplrow5.Plan_Qty=0; } if(cwplrow5.Stock_Qty < cwplrow5.BoM_Qty && cwplrow5.Tot_BoM_Qty != null) { planqty = ifnull(cwplrow5.BoM_Qty,0.0) * ifnull(cwplrow5.bom_stk_qty,0.0); stkqty = planqty - ifnull(cwplrow5.Stock_Qty,0.0); cwplrow5.Actual_Qty=stkqty; cwplrow5.Plan_Qty=stkqty; } input.BoM_Details_CWPL.insert(cwplrow5); } for each abc5 in BoM_FG_Subform[BOM_FG_Exis_ID.Part_No == levellist4.Part_No && Material_Item_Type.Material_Type == "General Purchase" && BOM_FG_Exis_ID.Status == "Active"] { if(inside_gplevel5 == 0) { if(abc5.Material_Item_Type.Material_Type == "General Purchase") { fetind = Indent_Sub_Form[Part_No == abc5.Part_No].sum(Required_Qty); dprsub = DPR_General_Purchase_Stock_Qty[Part_No == abc5.Part_No]; gprow5 = MRP.BoM_Details_General_Purchase(); inven = Inventory[Part_No == abc5.Part_No].sum(Available_Qty); gprow5.Part_No=abc5.Part_No; gprow5.Part_Name=abc5.Part_Description; gprow5.UoM=abc5.UoM; gprow5.Work_Order_No=fet_wo.ID; gprow5.Material_Item_Type=abc5.Material_Item_Type; gprow5.Org_BoM_Qty=ifnull(abc5.Qty,0.0); gprow5.Stock_Qty=inven.round(0); gprow5.Indent_Qty=fetind; gprow5.Level="Level-4"; gprow5.test_level="Level1.1" + "." + cnt1 + "." + cnt2 + "." + cnt3; gprow5.Create_BoM_RECID=crtbom3.ID; //CALCULATION PART gprow5.BoM_Qty=ifnull(cwplrow4.Actual_Qty,0); gprow5.Tot_BoM_Qty=ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0); gprow5.Material_Center_Qty=ifnull(dprsub.GP_Balance_Qty,0); //Below ifelse is to check negative value if(gprow5.Material_Center_Qty == 0) { if(ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0) - ifnull(gprow5.Stock_Qty,0) >= 0) { gprow5.Plan_Qty=ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0) - ifnull(gprow5.Stock_Qty,0); } else { gprow5.Plan_Qty=ifnull(gprow5.Stock_Qty,0) - ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0); } gprow5.Purchase_Qty=ifnull(gprow5.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow5); } else if(gprow5.Material_Center_Qty > 0) { if(ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0) - ifnull(gprow5.Material_Center_Qty,0) >= 0) { gprow5.Tot_BoM_Qty=ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0); gprow5.Plan_Qty=ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0) - ifnull(gprow5.Material_Center_Qty,0); } else if(ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0) - ifnull(gprow5.Material_Center_Qty,0) < 0) { gprow5.Tot_BoM_Qty=ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0); gprow5.Plan_Qty=ifnull(gprow5.Material_Center_Qty,0) - ifnull(gprow5.BoM_Qty,0) * ifnull(gprow5.Org_BoM_Qty,0.0); } gprow5.Purchase_Qty=ifnull(gprow5.Plan_Qty,0); input.BoM_Details_General_Purchase.insert(gprow5); } } } } inside_gplevel5 = 1; } } } } } //Test for each testrec in input.BoM_Details_General_Purchase { // if(testrec.S_No == 1) // { // testrec.Stock_Qty=1; // } // if(testrec.S_No == 2) // { // testrec.Stock_Qty=8; // } // if(testrec.S_No == 3) // { // testrec.bom_stk_qty=5; // } // if(testrec.S_No == 4) // { // testrec.Stock_Qty=50; // } // if(testrec.S_No == 5) // { // testrec.Stock_Qty=1; // } // if(testrec.S_No == 6) // { // testrec.Stock_Qty=4; // } // if(testrec.S_No == 7) // { // testrec.Stock_Qty=200; // } // if(testrec.S_No == 8) // { // testrec.Stock_Qty=50; // } } for each cwplrec in input.BoM_Details_CWPL { if(cwplrec.Stock_Qty < cwplrec.Tot_BoM_Qty) { cwplrec.Blocked_Qty=cwplrec.Stock_Qty; } if(cwplrec.Tot_BoM_Qty < cwplrec.Stock_Qty) { cwplrec.Blocked_Qty=cwplrec.Tot_BoM_Qty; } if(cwplrec.Tot_BoM_Qty == cwplrec.Stock_Qty) { cwplrec.Blocked_Qty=cwplrec.Stock_Qty; } if(cwplrec.Stock_Qty <= 0) { cwplrec.Blocked_Qty=0; } if(cwplrec.Blocked_Qty > 0) { cwplrec.Block_Qty=true; } } for each gprec in input.BoM_Details_General_Purchase { if(gprec.Stock_Qty < gprec.Tot_BoM_Qty) { gprec.Blocked_Qty=gprec.Stock_Qty; } else if(gprec.Tot_BoM_Qty <= gprec.Stock_Qty) { gprec.Plan_Qty=0; gprec.Purchase_Qty=0; gprec.Blocked_Qty=gprec.Tot_BoM_Qty; //info "if2"; } // else if(gprec.Tot_BoM_Qty > gprec.Stock_Qty) // { // gprec.Purchase_Qty=gprec.Plan_Qty; // } else if(gprec.Stock_Qty <= 0) { gprec.Blocked_Qty=0; //info "if3"; } else if(gprec.Tot_BoM_Qty == gprec.Stock_Qty) { gprec.Blocked_Qty=gprec.Stock_Qty; } if(gprec.Blocked_Qty > 0) { gprec.Block_Qty=true; } if(gprec.Purchase_Qty > 0) { gprec.Draft_Indent=true; } } //SNo for MRP-Subforms slno = 0; for each snrec in input.BoM_Details_CWPL { slno = slno + 1; if(snrec.Part_No != null) { snrec.S_No=slno; } } gslno = 0; for each snrecgp in input.BoM_Details_General_Purchase { gslno = gslno + 1; if(snrecgp.Part_No != null) { snrecgp.S_No=gslno; } } } //End
check the url below sudo apt update sudo apt install -y zsh it will ask a question for config opt 2 zsh --version which zsh whereis zsh sudo chsh -s /usr/bin/zsh sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" git clone https://github.com/zsh-users/zsh-autosuggestions ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-autosuggestions git clone https://github.com/zsh-users/zsh-syntax-highlighting.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting plugins=(git zsh-autosuggestions zsh-syntax-highlighting jsontools dirhistory)
SELECT columnname as 'Original_Value', LEN(LTRIM(columnname)) as 'Orig_Val_Char_Count', N'['+columnname+']' as 'UnicodeStr_Value', LEN(N'['+columnname+']')-2 as 'True_Char_Count' FROM mytable
bool _showLoading = true; @override void initState() { super.initState(); Timer(const Duration(seconds: 90), () { if (mounted) { setState(() { _showLoading = false; }); } }); } if (pipes.isEmpty) { if (_showLoading) { return const Padding( padding: EdgeInsets.all(16.0), child: Center( child: Loader(), ), ); } else { return const Padding( padding: EdgeInsets.all(16.0), child: Center( child: Text("No pipes found in enquiry"), ), ); } } else { error: (error, st) { return Center( child: Text(error.toString()), ); }, loading: () { return const Loader(); }, child: (salesStock.isEmpty) ? (_showLoading ? const Padding( padding: EdgeInsets.all(16.0), child: Center( child: CircularProgressIndicator(), ), ) : const Padding( padding: EdgeInsets.all(16.0), child: Center( child: Text("No Enquiry Found"), ), ))
{ "blocks": [ { "type": "header", "text": { "type": "plain_text", "text": " :mirror_ball::star: Boost Days - What's on this week! :star::mirror_ball:" } }, { "type": "section", "text": { "type": "mrkdwn", "text": "Happy Monday! See below for what's in store for our Boost Days this week:" } }, { "type": "divider" }, { "type": "header", "text": { "type": "plain_text", "text": ":calendar-date-21: Tuesday, 21st January", "emoji": true } }, { "type": "section", "text": { "type": "mrkdwn", "text": "\n:coffee: *Xero Café*: Café-style beverages and sweet treats \n\n:meow-coffee-intensifies-and-shakes: *Barista Special*: _Caramel Macchiato_ \n\n:pancakes: *Breakfast*: Provided by *Catroux* from *8:30am - 10:30am* \n " } }, { "type": "header", "text": { "type": "plain_text", "text": ":calendar-date-22: Wednesday, 22nd January", "emoji": true } }, { "type": "section", "text": { "type": "mrkdwn", "text": ":hands: *January Global All Hands:* 10am - 11am in the All Hands Space" } }, { "type": "header", "text": { "type": "plain_text", "text": ":calendar-date-23: Thursday, 23rd January", "emoji": true } }, { "type": "section", "text": { "type": "mrkdwn", "text": ":coffee: *Xero Café*: Café-style beverages and sweet treats \n\n :meow-coffee-intensifies-and-shakes: *Barista Special*: _Caramel Macchiato_ \n\n :sandwich: *Light Lunch*: Provided by *Catroux* from *12pm - 1pm* \n\n :massage: *Wellness* Massage therapy in the gym, treat yourself <https://corporate-massage.co.nz/bookable/make/appt/booking.php?c=lytgoz|*here.*> \n\n :cupcake: * New Brand Activation Platform Video:* Join us from 2pm in the All Hands Space to celebrate our new Brand Platform Activation _Your Business Supercharged_ we'll have some delicious cupcakes to enjoy while we watch the video! \n\n :clinking_glasses: *Social Happy Hour* from 4pm - 5:30pm in our All Hands Space" } }, { "type": "divider" }, { "type": "section", "text": { "type": "mrkdwn", "text": "Stay tuned to this channel for more details, check out the <https://calendar.google.com/calendar/u/0?cid=eGVyby5jb21fMXM4M3NiZzc1dnY0aThpY2FiZDZvZ2xncW9AZ3JvdXAuY2FsZW5kYXIuZ29vZ2xlLmNvbQ|*Auckland Social Calendar*>, and get ready to Boost your workdays!\n\nLove,\nWX :wx:" } } ] }
{ "blocks": [ { "type": "header", "text": { "type": "plain_text", "text": " :mirror_ball::star: Boost Days - What's on this week! :star::mirror_ball:" } }, { "type": "section", "text": { "type": "mrkdwn", "text": "Happy Monday! See below for what's in store for our Boost Days this week:" } }, { "type": "divider" }, { "type": "header", "text": { "type": "plain_text", "text": ":calendar-date-14: Tuesday, 14th January", "emoji": true } }, { "type": "section", "text": { "type": "mrkdwn", "text": "\n:coffee: *Xero Café*: Café-style beverages and sweet treats\n:meow-coffee-intensifies-and-shakes: *Barista Special*: Iced Vanilla Long Black \n:pancakes: *Breakfast*: Provided by *Catroux* from *8:30am - 10:30am* \n " } }, { "type": "header", "text": { "type": "plain_text", "text": ":calendar-date-16: Thursday, 16th January", "emoji": true } }, { "type": "section", "text": { "type": "mrkdwn", "text": ":coffee: *Xero Café*: Café-style beverages and sweet treats \n :meow-coffee-intensifies-and-shakes: *Barista Special*: White Chocolate Matcha \n :sandwich: *Light Lunch*: Provided by *Catroux* from *12pm - 1pm*" } }, { "type": "divider" }, { "type": "section", "text": { "type": "mrkdwn", "text": "Stay tuned to this channel for more details, check out the <https://calendar.google.com/calendar/u/0?cid=eGVyby5jb21fMXM4M3NiZzc1dnY0aThpY2FiZDZvZ2xncW9AZ3JvdXAuY2FsZW5kYXIuZ29vZ2xlLmNvbQ|*Auckland Social Calendar*>, and get ready to Boost your workdays!\n\nLove,\nWX :wx:" } } ] }
public class ValidationBehavior<TRequest, TResponse>(IValidator<TRequest>? validator = null) : IPipelineBehavior<TRequest, TResponse> where TRequest : IRequest<TResponse> where TResponse : IErrorOr { private readonly IValidator<TRequest>? _validator = validator; public async Task<TResponse> Handle( TRequest request, RequestHandlerDelegate<TResponse> next, CancellationToken cancellationToken) { if (_validator is null) { return await next(); } var validationResult = await _validator.ValidateAsync(request, cancellationToken); if (validationResult.IsValid) { return await next(); } var errors = validationResult.Errors .ConvertAll(error => Error.Validation( code: error.PropertyName, description: error.ErrorMessage)); return (dynamic)errors; } }
const deliveryMode = { online: true, inperson: false, hybrid: true }; const result = Object.keys(deliveryMode).filter(key => { return typeof deliveryMode[key] === "boolean" && deliveryMode[key] === true; console.log(result); // Output: ["online", "hybrid"] });
import random name = input("What is your name? ") print("Good Luck ! ", name) words = ['rainbow', 'computer', 'science', 'programming', 'python', 'mathematics', 'player', 'condition', 'reverse', 'water', 'board', 'geeks'] word = random.choice(words) print("Guess the characters") guesses = '' turns = 12 while turns > 0: failed = 0 for char in word: if char in guesses: print(char, end=" ") else: print("_") failed += 1 if failed == 0: print("You Win") print("The word is: ", word) break print() guess = input("guess a character:") guesses += guess if guess not in word: turns -= 1 print("Wrong") print("You have", + turns, 'more guesses') if turns == 0: print("You Loose")
graph = { 'A': ['B', 'C'], 'B': ['D', 'E'], 'C': ['F', 'G'], 'D': [], 'E': [], 'F': [], 'G': [] } def bfs(graph, start, goal): visited = [] # List to keep track of visited nodes queue = [] # Queue for BFS visited.append(start) queue.append(start) while queue: s = queue.pop(0) # Dequeue a node if s == goal: # Stop as soon as the goal is found print(s) return print(s) # Print the current node for neighbor in graph[s]: if neighbor not in visited: visited.append(neighbor) queue.append(neighbor) # Call the function bfs(graph, 'A', 'F')
Rows =int(input(Enter number of rows:)) K=o For I in range (1,rows+1): For space in in range (,(rows-i)+1
"use client"; import {useState} from "react"; const usePostData = () => { const [loading, setLoading] = useState(false); const [error, setError] = useState(null); const postData = async (url, payload) => { setLoading(true); setError(null); return fetch(url, { method: "POST", body: payload, }) .then((response) => { if (!response.ok) { return response.json().then((errorData) => { throw new Error(errorData.message || "Failed to post data"); }); } return response.json(); }) .catch((err) => { setError(err.message); throw err; // Re-throw the error to allow the component to handle it }) .finally(() => { setLoading(false); }); }; return { postData, loading, error }; }; export default usePostData;
use Illuminate\Http\Request; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; ->withExceptions(function (Exceptions $exceptions) { $exceptions->render(function (NotFoundHttpException $e, Request $request) { if ($request->is('api/*')) { return response()->json([ 'message' => 'Record not found.' ], 404); } }); })
Created or Edited -> User input of Item Details.Part_Description -> ItemDeatils_PartDesc_Validations
Tue Jan 07 2025 14:24:34 GMT+0000 (Coordinated Universal Time)
star
photo_camera
Tue Jan 07 2025 10:48:23 GMT+0000 (Coordinated Universal Time) https://bluevps.com/blog/how-to-install-oh-my-zsh-on-ubuntu-2204
star
photo_camera
Tue Jan 07 2025 10:46:25 GMT+0000 (Coordinated Universal Time) https://stackoverflow.com/questions/14255236/count-number-of-characters-in-nvarchar-column
star
Tue Jan 07 2025 09:14:52 GMT+0000 (Coordinated Universal Time) https://maticz.com/rarible-clone-script
star
photo_camera
Mon Jan 06 2025 21:42:52 GMT+0000 (Coordinated Universal Time) https://github.com/amantinband/error-or?form
star
photo_camera
Mon Jan 06 2025 06:23:59 GMT+0000 (Coordinated Universal Time) https://laravel.com/docs/11.x/errors