/// <summary> /// Get Project Phase Tasks. /// </summary> /// <returns>Array of tasks</returns> public MProjectTask[] GetTasks() { List <MProjectTask> list = new List <MProjectTask>(); String sql = "SELECT * FROM C_ProjectTask WHERE C_ProjectPhase_ID=" + GetC_ProjectPhase_ID() + " ORDER BY SeqNo"; try { DataSet ds = DataBase.DB.ExecuteDataset(sql, null, Get_TrxName()); if (ds.Tables.Count > 0) { foreach (DataRow rs in ds.Tables[0].Rows) { list.Add(new MProjectTask(GetCtx(), rs, Get_TrxName())); } } } catch (Exception ex) { log.Log(Level.SEVERE, sql, ex); } // MProjectTask[] retValue = new MProjectTask[list.Count]; retValue = list.ToArray(); return(retValue); }
/// <summary> /// Copy Tasks from other Phase /// </summary> /// <param name="fromPhase">from phase</param> /// <returns>number of tasks copied</returns> public int CopyTasksFrom(MProjectTypePhase fromPhase) { if (fromPhase == null) { return(0); } int count = 0; int tasklinecount = 0; // Copy Type Tasks MProjectTypeTask[] fromTasks = fromPhase.GetTasks(); for (int i = 0; i < fromTasks.Length; i++) { MProjectTask toTask = new MProjectTask(this, fromTasks[i]); if (toTask.Save()) { // check if table exists then only it will copy the task lines if (PO.Get_Table_ID("C_TaskLine") > 0) { tasklinecount = CopyMTaskLines(fromTasks[i].GetC_Task_ID(), toTask.GetC_ProjectTask_ID()); } count++; } } log.Fine("#" + count + " - " + fromPhase + ", #" + tasklinecount); if (fromTasks.Length != count) { log.Log(Level.SEVERE, "Count difference - TypePhase=" + fromTasks.Length + " <> Saved=" + count); } return(count); }
/// <summary> /// Copy Tasks from other Phase /// </summary> /// <param name="fromPhase">from phase</param> /// <returns>number of tasks copied</returns> public int CopyTasksFrom(MProjectTypePhase fromPhase) { if (fromPhase == null) { return(0); } int count = 0; // Copy Type Tasks MProjectTypeTask[] fromTasks = fromPhase.GetTasks(); for (int i = 0; i < fromTasks.Length; i++) { MProjectTask toTask = new MProjectTask(this, fromTasks[i]); if (toTask.Save()) { count++; } } log.Fine("#" + count + " - " + fromPhase); if (fromTasks.Length != count) { log.Log(Level.SEVERE, "Count difference - TypePhase=" + fromTasks.Length + " <> Saved=" + count); } return(count); }
/// <summary> /// Copy Tasks from other Phase /// </summary> /// <param name="fromPhase">from phase</param> /// <returns>number of tasks copied</returns> public int CopyTasksFrom(MProjectPhase fromPhase) { if (fromPhase == null) { return(0); } int count = 0; // MProjectTask[] myTasks = GetTasks(); MProjectTask[] fromTasks = fromPhase.GetTasks(); // Copy Project Tasks for (int i = 0; i < fromTasks.Length; i++) { // Check if Task already exists int C_Task_ID = fromTasks[i].GetC_Task_ID(); bool exists = false; if (C_Task_ID == 0) { exists = false; } else { for (int ii = 0; ii < myTasks.Length; ii++) { if (myTasks[ii].GetC_Task_ID() == C_Task_ID) { exists = true; break; } } } // Phase exist if (exists) { log.Info("Task already exists here, ignored - " + fromTasks[i]); } else { MProjectTask toTask = new MProjectTask(GetCtx(), 0, Get_TrxName()); PO.CopyValues(fromTasks[i], toTask, GetAD_Client_ID(), GetAD_Org_ID()); toTask.SetC_ProjectPhase_ID(GetC_ProjectPhase_ID()); if (toTask.Save()) { count++; } } } if (fromTasks.Length != count) { log.Warning("Count difference - ProjectPhase=" + fromTasks.Length + " <> Saved=" + count); } return(count); }
/// <summary> /// Generate Appointments if Owner is selected at Task Tab. /// </summary> private void GenerateAppointment() { if (C_ProjectTask_ID != 0) { sql = "select name from c_campaign where c_campaign_id = (select c_campaign_id from c_project where c_project_id = (select c_project_id " + " from c_projectphase where c_projectphase_id = (select c_projectphase_id from c_projecttask where c_projecttask_id = " + C_ProjectTask_ID + ")))"; string name = Util.GetValueOfString(DB.ExecuteScalar(sql, null, Get_Trx())); VAdvantage.Model.MProjectTask task = new VAdvantage.Model.MProjectTask(GetCtx(), C_ProjectTask_ID, Get_Trx()); int AppointmentsInfo_ID = Util.GetValueOfInt(task.GetAppointmentsInfo_ID()); sql = "select count(*) from AppointmentsInfo where AppointmentsInfo_ID = " + AppointmentsInfo_ID; int res = Util.GetValueOfInt(DB.ExecuteScalar(sql, null, Get_Trx())); if (res == 0) { string subject = name + "_" + task.GetName(); string desc = task.GetDescription(); int AD_User_ID = task.GetSalesRep_ID(); //DateTime? sDate = task. if (AD_User_ID != 0) { VAdvantage.Model.X_AppointmentsInfo appoint = new VAdvantage.Model.X_AppointmentsInfo(GetCtx(), 0, Get_Trx()); appoint.SetAD_Client_ID(GetCtx().GetAD_Client_ID()); appoint.SetAD_Org_ID(GetCtx().GetAD_Org_ID()); appoint.SetSubject(subject); appoint.SetStartDate(task.GetStartDate()); appoint.SetEndDate(task.GetEndDate()); appoint.SetStatus(3); appoint.SetDescription(task.GetDescription()); appoint.SetAppointmentCategory_ID(1000000); appoint.SetIsRead(true); appoint.SetAD_User_ID(AD_User_ID); appoint.SetIsPrivate(false); appoint.SetPriorityKey(5); appoint.SetIsTask(true); if (!appoint.Save(Get_Trx())) { log.SaveError("AppointmentNotSaved", "AppointmentNotSaved"); msg = Msg.GetMsg(GetCtx(), "AppointmentNotSaved"); //return msg; } task.SetAppointmentsInfo_ID(appoint.GetAppointmentsInfo_ID()); if (!task.Save(Get_Trx())) { log.SaveError("TaskNotSaved", "TaskNotSaved"); } count = count++; msg = Msg.GetMsg(GetCtx(), "AppointmentSaved"); } else { msg = Msg.GetMsg(GetCtx(), "OwnerNotSelected"); // return msg; } } else { string subject = name + "_" + task.GetName(); string desc = task.GetDescription(); int AD_User_ID = task.GetSalesRep_ID(); //DateTime? sDate = task. if (AD_User_ID != 0) { VAdvantage.Model.X_AppointmentsInfo appoint = new VAdvantage.Model.X_AppointmentsInfo(GetCtx(), Util.GetValueOfInt(task.GetAppointmentsInfo_ID()), Get_Trx()); appoint.SetAD_Client_ID(GetCtx().GetAD_Client_ID()); appoint.SetAD_Org_ID(GetCtx().GetAD_Org_ID()); appoint.SetSubject(subject); appoint.SetStartDate(task.GetStartDate()); appoint.SetEndDate(task.GetEndDate()); appoint.SetStatus(3); appoint.SetDescription(task.GetDescription()); appoint.SetAppointmentCategory_ID(1000000); appoint.SetIsRead(true); appoint.SetAD_User_ID(AD_User_ID); appoint.SetIsPrivate(false); appoint.SetIsTask(true); if (!appoint.Save(Get_Trx())) { log.SaveError("AppointmentNotSaved", "AppointmentNotSaved"); msg = Msg.GetMsg(GetCtx(), "AppointmentNotSaved"); // return msg; } task.SetAppointmentsInfo_ID(appoint.GetAppointmentsInfo_ID()); if (!task.Save(Get_Trx())) { log.SaveError("TaskNotSaved", "TaskNotSaved"); } count = count + 1; msg = Msg.GetMsg(GetCtx(), "AppointmentSaved"); } else { msg = Msg.GetMsg(GetCtx(), "OwnerNotSelected"); // return msg; } } } }
/// <summary> /// Update Header /// </summary> private void UpdateHeader() { int id = GetC_ProjectTask_ID(); int projID = 0; if (id == 0) { projID = GetC_Project_ID(); // Marketing Campaign Window } else { //Used transaction because total was not updating on header string Sql = "SELECT C_Project_ID FROM C_ProjectPhase WHERE C_ProjectPhase_ID in(select C_ProjectPhase_ID FROM" + " C_ProjectTask WHERE C_ProjectTask_ID =" + id + ")"; projID = Util.GetValueOfInt(DB.ExecuteScalar(Sql, null, Get_TrxName())); } //Used transaction because total was not updating on header string sql = "SELECT IsOpportunity FROM C_Project WHERE C_Project_ID = " + projID; string isOpp = Util.GetValueOfString(DB.ExecuteScalar(sql, null, Get_TrxName())); //Amit string isCam = Util.GetValueOfString(DB.ExecuteScalar("SELECT IsCampaign FROM C_Project WHERE C_Project_ID = " + projID, null, Get_TrxName())); if (isOpp.Equals("N") && isCam.Equals("N") && id != 0) { // set sum of planned Amount from task line to task MProjectTask tsk = new MProjectTask(GetCtx(), id, Get_Trx()); //Used transaction because total was not updating on header decimal plannedAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_ProjectTask_ID = " + id, null, Get_TrxName())); tsk.SetPlannedAmt(plannedAmt); tsk.Save(); } //Amit else if (isOpp.Equals("N") && isCam.Equals("N") && id == 0 && GetC_ProjectPhase_ID() != 0) { //Used transaction because total was not updating on header MProjectPhase projectPhase = new MProjectPhase(GetCtx(), GetC_ProjectPhase_ID(), Get_TrxName()); decimal plnAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_ProjectPhase_ID = " + GetC_ProjectPhase_ID() + " AND pl.C_Project_ID = " + projID, null, Get_TrxName())); projectPhase.SetPlannedAmt(plnAmt); projectPhase.Save(); } else if (isOpp.Equals("Y")) // Opportunity Window { //Used transaction because total was not updating on header MProject prj = new MProject(GetCtx(), projID, Get_TrxName()); decimal plnAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + projID, null, Get_TrxName())); prj.SetPlannedAmt(plnAmt); prj.Save(); if (VAdvantage.Utility.Env.IsModuleInstalled("VA077_")) { sql = @"UPDATE C_Project SET VA077_TotalMarginAmt=(SELECT ROUND(Sum(VA077_MarginAmt),2) FROM C_ProjectLine WHERE C_PROJECT_ID=" + projID + @" AND IsActive='Y'), VA077_TotalPurchaseAmt=(SELECT ROUND(Sum(VA077_PurchaseAmt),2) FROM C_ProjectLine WHERE C_PROJECT_ID=" + projID + @" AND IsActive='Y'), VA077_MarginPercent=(SELECT CASE WHEN Sum(PlannedAmt) > 0 Then ROUND(((Sum(PlannedAmt)- Sum(NVL(VA077_PurchaseAmt,0)))/Sum(PlannedAmt)*100),2) ELSE 0 END FROM C_ProjectLine WHERE C_PROJECT_ID=" + projID + @" AND IsActive='Y') WHERE C_Project_ID=" + projID; int no = DB.ExecuteQuery(sql, null, Get_TrxName()); if (no != 1) { log.Log(Level.SEVERE, "updateHeader - #" + no); } } } else if (id != 0) { MProjectTask tsk = new MProjectTask(GetCtx(), id, Get_TrxName()); //Used transaction because total was not updating on header decimal plannedAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_ProjectTask_ID = " + id, null, Get_TrxName())); tsk.SetPlannedAmt(plannedAmt); tsk.Save(); } else { sql = "UPDATE C_Project p SET " + "PlannedAmt=(SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",PlannedQty=(SELECT COALESCE(SUM(pl.PlannedQty),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",PlannedMarginAmt=(SELECT COALESCE(SUM(pl.PlannedMarginAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",CommittedAmt=(SELECT COALESCE(SUM(pl.CommittedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",CommittedQty=(SELECT COALESCE(SUM(pl.CommittedQty),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",InvoicedAmt=(SELECT COALESCE(SUM(pl.InvoicedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ", InvoicedQty =(SELECT COALESCE(SUM(pl.InvoicedQty),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + " WHERE p.C_Project_ID=" + GetC_Project_ID(); int no = DB.ExecuteQuery(sql, null, Get_TrxName()); if (no != 1) { log.Log(Level.SEVERE, "updateHeader - #" + no); } } }
/// <summary> /// Before Save /// </summary> /// <param name="newRecord">new</param> /// <returns>true</returns> protected override bool BeforeSave(bool newRecord) { if (GetLine() == 0) { SetLine(); } // Work done for Purchase Price and Mergin calculation if (Env.IsModuleInstalled("VA077_") && Get_ColumnIndex("VA077_PurchasePrice") >= 0 && Util.GetValueOfDecimal(Get_Value("VA077_PurchasePrice")).Equals(0)) { if (GetProject() != null && _parent.IsOpportunity() && Util.GetValueOfInt(_parent.Get_Value("PO_PriceList_ID")) > 0) { Set_Value("VA077_PurchasePrice", GetPurchasePrice()); // Calculate Purchase Amount Decimal purchaseAmt = Decimal.Multiply(GetPlannedQty(), Util.GetValueOfDecimal(Get_Value("VA077_PurchasePrice"))); if (Env.Scale(purchaseAmt) > GetCurPrecision()) { purchaseAmt = Decimal.Round(purchaseAmt, GetCurPrecision(), MidpointRounding.AwayFromZero); } Set_Value("VA077_PurchaseAmt", purchaseAmt); } // Calculate Margin Amount Decimal marginEach = Decimal.Subtract(GetPlannedPrice(), Util.GetValueOfDecimal(Get_Value("VA077_PurchasePrice"))); Set_Value("VA077_MarginAmt", Decimal.Multiply(marginEach, GetPlannedQty())); // Calculate Margin Percentage Decimal marginPer = 0; if (GetPlannedPrice() > 0) { marginPer = Decimal.Round(Decimal.Multiply(Decimal.Divide(marginEach, GetPlannedPrice()) , Env.ONEHUNDRED), GetCurPrecision(), MidpointRounding.AwayFromZero); } Set_Value("VA077_MarginPercent", marginPer); } // Planned Amount - Currency Precision Decimal plannedAmt = Decimal.Multiply(GetPlannedQty(), GetPlannedPrice()); if (Env.Scale(plannedAmt) > GetCurPrecision()) { //plannedAmt.setScale(GetCurPrecision(), Decimal.ROUND_HALF_UP); Decimal.Round(plannedAmt, GetCurPrecision(), MidpointRounding.AwayFromZero); } SetPlannedAmt(plannedAmt); // Planned Margin if (Is_ValueChanged("M_Product_ID") || Is_ValueChanged("M_Product_Category_ID") || Is_ValueChanged("PlannedQty") || Is_ValueChanged("PlannedPrice")) { if (GetM_Product_ID() != 0) { Decimal marginEach = Decimal.Subtract(GetPlannedPrice(), GetLimitPrice()); SetPlannedMarginAmt(Decimal.Multiply(marginEach, GetPlannedQty())); } else if (GetM_Product_Category_ID() != 0) { MProductCategory category = MProductCategory.Get(GetCtx(), GetM_Product_Category_ID()); Decimal marginEach = category.GetPlannedMargin(); SetPlannedMarginAmt(Decimal.Multiply(marginEach, GetPlannedQty())); } } // Phase/Task if (Is_ValueChanged("C_ProjectTask_ID") && GetC_ProjectTask_ID() != 0) { MProjectTask pt = new MProjectTask(GetCtx(), GetC_ProjectTask_ID(), Get_TrxName()); if (pt == null || pt.Get_ID() == 0) { log.Warning("Project Task Not Found - ID=" + GetC_ProjectTask_ID()); return(false); } else { SetC_ProjectPhase_ID(pt.GetC_ProjectPhase_ID()); } } if (Is_ValueChanged("C_ProjectPhase_ID") && GetC_ProjectPhase_ID() != 0) { MProjectPhase pp = new MProjectPhase(GetCtx(), GetC_ProjectPhase_ID(), Get_TrxName()); if (pp == null || pp.Get_ID() == 0) { log.Warning("Project Phase Not Found - " + GetC_ProjectPhase_ID()); return(false); } else { SetC_Project_ID(pp.GetC_Project_ID()); } } return(true); }
/// <summary> /// Update Header /// </summary> private void UpdateHeader() { int id = GetC_ProjectTask_ID(); int projID = 0; if (id == 0) { projID = GetC_Project_ID(); // Marketing Campaign Window } else { string Sql = "SELECT C_Project_ID FROM C_ProjectPhase WHERE C_ProjectPhase_ID in(select C_ProjectPhase_ID FROM" + " C_ProjectTask WHERE C_ProjectTask_ID =" + id + ")"; projID = Util.GetValueOfInt(DB.ExecuteScalar(Sql, null, null)); } string sql = "SELECT IsOpportunity FROM C_Project WHERE C_Project_ID = " + projID; string isOpp = Util.GetValueOfString(DB.ExecuteScalar(sql, null, null)); //Amit string isCam = Util.GetValueOfString(DB.ExecuteScalar("SELECT IsCampaign FROM C_Project WHERE C_Project_ID = " + projID)); if (isOpp.Equals("N") && isCam.Equals("N") && id != 0) { // set sum of planned Amount from task line to task MProjectTask tsk = new MProjectTask(GetCtx(), id, Get_Trx()); decimal plannedAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_ProjectTask_ID = " + id)); tsk.SetPlannedAmt(plannedAmt); tsk.Save(); } //Amit else if (isOpp.Equals("N") && isCam.Equals("N") && id == 0 && GetC_ProjectPhase_ID() != 0) { MProjectPhase projectPhase = new MProjectPhase(GetCtx(), GetC_ProjectPhase_ID(), null); decimal plnAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_ProjectPhase_ID = " + GetC_ProjectPhase_ID() + " AND pl.C_Project_ID = " + projID)); projectPhase.SetPlannedAmt(plnAmt); projectPhase.Save(); } else if (isOpp.Equals("Y")) // Opportunity Window { MProject prj = new MProject(GetCtx(), projID, Get_TrxName()); decimal plnAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + projID)); prj.SetPlannedAmt(plnAmt); prj.Save(); } else if (id != 0) { MProjectTask tsk = new MProjectTask(GetCtx(), id, Get_TrxName()); decimal plannedAmt = Util.GetValueOfDecimal(DB.ExecuteScalar("SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_ProjectTask_ID = " + id)); tsk.SetPlannedAmt(plannedAmt); tsk.Save(); } else { sql = "UPDATE C_Project p SET " + "PlannedAmt=(SELECT COALESCE(SUM(pl.PlannedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",PlannedQty=(SELECT COALESCE(SUM(pl.PlannedQty),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",PlannedMarginAmt=(SELECT COALESCE(SUM(pl.PlannedMarginAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",CommittedAmt=(SELECT COALESCE(SUM(pl.CommittedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",CommittedQty=(SELECT COALESCE(SUM(pl.CommittedQty),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ",InvoicedAmt=(SELECT COALESCE(SUM(pl.InvoicedAmt),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + ", InvoicedQty =(SELECT COALESCE(SUM(pl.InvoicedQty),0) FROM C_ProjectLine pl WHERE pl.IsActive = 'Y' AND pl.C_Project_ID = " + GetC_Project_ID() + ")" + " WHERE p.C_Project_ID=" + GetC_Project_ID(); int no = DB.ExecuteQuery(sql, null, Get_TrxName()); if (no != 1) { log.Log(Level.SEVERE, "updateHeader - #" + no); } } }
/// <summary> /// Before Save /// </summary> /// <param name="newRecord">new</param> /// <returns>true</returns> protected override bool BeforeSave(bool newRecord) { if (GetLine() == 0) { SetLine(); } // Planned Amount - Currency Precision Decimal plannedAmt = Decimal.Multiply(GetPlannedQty(), GetPlannedPrice()); if (Env.Scale(plannedAmt) > GetCurPrecision()) { //plannedAmt.setScale(GetCurPrecision(), Decimal.ROUND_HALF_UP); Decimal.Round(plannedAmt, GetCurPrecision(), MidpointRounding.AwayFromZero); } SetPlannedAmt(plannedAmt); // Planned Margin if (Is_ValueChanged("M_Product_ID") || Is_ValueChanged("M_Product_Category_ID") || Is_ValueChanged("PlannedQty") || Is_ValueChanged("PlannedPrice")) { if (GetM_Product_ID() != 0) { Decimal marginEach = Decimal.Subtract(GetPlannedPrice(), GetLimitPrice()); SetPlannedMarginAmt(Decimal.Multiply(marginEach, GetPlannedQty())); } else if (GetM_Product_Category_ID() != 0) { MProductCategory category = MProductCategory.Get(GetCtx(), GetM_Product_Category_ID()); Decimal marginEach = category.GetPlannedMargin(); SetPlannedMarginAmt(Decimal.Multiply(marginEach, GetPlannedQty())); } } // Phase/Task if (Is_ValueChanged("C_ProjectTask_ID") && GetC_ProjectTask_ID() != 0) { MProjectTask pt = new MProjectTask(GetCtx(), GetC_ProjectTask_ID(), Get_TrxName()); if (pt == null || pt.Get_ID() == 0) { log.Warning("Project Task Not Found - ID=" + GetC_ProjectTask_ID()); return(false); } else { SetC_ProjectPhase_ID(pt.GetC_ProjectPhase_ID()); } } if (Is_ValueChanged("C_ProjectPhase_ID") && GetC_ProjectPhase_ID() != 0) { MProjectPhase pp = new MProjectPhase(GetCtx(), GetC_ProjectPhase_ID(), Get_TrxName()); if (pp == null || pp.Get_ID() == 0) { log.Warning("Project Phase Not Found - " + GetC_ProjectPhase_ID()); return(false); } else { SetC_Project_ID(pp.GetC_Project_ID()); } } return(true); }
/// <summary> /// To copy the task lines from project template Standard Task lines tab /// </summary> /// <param name="Task_ID">ID of tasks</param> /// <param name="C_ProjectTask_ID">Project task ID</param> /// <returns>No of lines created</returns> public int CopyMTaskLinesFromProjectTask(MProjectTask fromTask, MProjectTask toTask, int To_Project_ID) { ValueNamePair pp = null; int tasklinecount = 0; StringBuilder msg = new StringBuilder(); try { MProjectLine[] fromLines = null; List <MProjectLine> list = new List <MProjectLine>(); DataSet projDs = DB.ExecuteDataset(" SELECT C_ProjectLine_ID FROM C_ProjectLine WHERE " + " C_ProjectPhase_ID =" + fromTask.GetC_ProjectPhase_ID() + " AND C_ProjectTask_ID =" + fromTask.GetC_ProjectTask_ID() + " AND IsActive='Y' ORDER BY Line "); if (projDs != null && projDs.Tables[0].Rows.Count > 0) { for (int k = 0; k < projDs.Tables[0].Rows.Count; k++) { list.Add(new MProjectLine(GetCtx(), Util.GetValueOfInt(projDs.Tables[0].Rows[k]["C_ProjectLine_ID"]), Get_TrxName())); } fromLines = new MProjectLine[list.Count]; fromLines = list.ToArray(); } if (fromLines != null && fromLines.Length > 0) { for (int j = 0; j < fromLines.Length; j++) { MProjectLine line = new MProjectLine(GetCtx(), 0, Get_TrxName()); PO.CopyValues(fromLines[j], line, GetAD_Client_ID(), GetAD_Org_ID()); line.SetC_Project_ID(To_Project_ID); line.SetC_ProjectTask_ID(toTask.GetC_ProjectTask_ID()); line.SetC_ProjectPhase_ID(toTask.GetC_ProjectPhase_ID()); line.SetInvoicedAmt(Env.ZERO); line.SetInvoicedQty(Env.ZERO); line.SetC_OrderPO_ID(0); line.SetC_Order_ID(0); line.SetProcessed(false); if (line.Save()) { tasklinecount++; } else { pp = VLogger.RetrieveError(); if (pp != null) { msg.Append(pp.GetName()); //if GetName is Empty then it will check GetValue if (string.IsNullOrEmpty(msg.ToString())) { msg.Append(Msg.GetMsg("", pp.GetValue())); } } if (string.IsNullOrEmpty(msg.ToString())) { msg.Append(Msg.GetMsg(GetCtx(), "VIS_LineNotSaved")); } else { msg.Append(Msg.GetMsg(GetCtx(), "VIS_LineNotSaved") + "," + msg.ToString()); } } } } } catch (Exception ex) { log.Log(Level.SEVERE, "", ex); } // return(tasklinecount); }
/// <summary> /// To copy task from other phase to new phase /// </summary> /// <param name="fromPhase">From Phase</param> /// <param name="toPhase">To Phase</param> /// <returns></returns> public int CopyTasksFrom(MProjectPhase fromPhase, MProjectPhase toPhase) { if (fromPhase == null) { return(0); } int count = 0; ValueNamePair pp = null; StringBuilder msg = new StringBuilder(); MProjectTask[] myTasks = GetTasks(); MProjectTask[] fromTasks = fromPhase.GetTasks(); int C_Task_ID = 0; bool exists = false; // Copy Project Tasks for (int i = 0; i < fromTasks.Length; i++) { // Check if Task already exists C_Task_ID = fromTasks[i].GetC_ProjectTask_ID(); exists = false; if (C_Task_ID == 0) { exists = false; } else { for (int ii = 0; ii < myTasks.Length; ii++) { if (myTasks[ii].GetC_ProjectTask_ID() == C_Task_ID) { exists = true; break; } } } // Phase exist if (exists) { log.Info("Task already exists here, ignored - " + fromTasks[i]); } else { MProjectTask toTask = new MProjectTask(GetCtx(), 0, Get_TrxName()); PO.CopyValues(fromTasks[i], toTask, GetAD_Client_ID(), GetAD_Org_ID()); toTask.SetC_ProjectPhase_ID(toPhase.GetC_ProjectPhase_ID()); if (toTask.Save()) { count++; count += CopyMTaskLinesFromProjectTask(fromTasks[i], toTask, toPhase.GetC_Project_ID()); } else { pp = VLogger.RetrieveError(); if (pp != null) { msg.Append(pp.GetName()); //if GetName is Empty then it will check GetValue if (string.IsNullOrEmpty(msg.ToString())) { msg.Append(Msg.GetMsg("", pp.GetValue())); } } if (string.IsNullOrEmpty(msg.ToString())) { msg.Append(Msg.GetMsg(GetCtx(), "VIS_LineNotSaved")); } else { msg.Append(Msg.GetMsg(GetCtx(), "VIS_LineNotSaved") + "," + msg.ToString()); } } } } if (fromTasks.Length != count) { log.Warning("Count difference - ProjectPhase=" + fromTasks.Length + " <> Saved=" + count); } return(count); }