示例#1
0
 CGroup_solution GetGroup_solution(int?p_idgroup_solution)
 {
     if (p_idgroup_solution != null)
     {
         CGroup_solution oGroup_solution = new CGroup_solutionFactory().GetByPrimaryKey(new CGroup_solutionKeys(Convert.ToInt32(p_idgroup_solution)));
         return(oGroup_solution);
     }
     return(null);
 }
示例#2
0
        void InitTree()
        {
            treeStdCalib = treeSolution.Nodes[0];
            treeSolInterm1 = treeSolution.Nodes[1];
            treeSolInterm2 = treeSolution.Nodes[2];
            treeStdVerif = treeSolution.Nodes[3];
            treeSolTitration = treeSolution.Nodes[4];

            // --- solutions
            treeStdCalib.Tag = 1;
            treeSolInterm1.Tag = 2;
            treeSolInterm2.Tag = 3;
            treeStdVerif.Tag = 4;
            treeSolTitration.Tag = 5;

            TypeSolution = Convert.ToInt32(treeStdCalib.Tag);

            // --- limpiar nodos constantes
            treeStdCalib.Nodes.Clear();
            treeSolInterm1.Nodes.Clear();
            treeSolInterm2.Nodes.Clear();
            treeStdVerif.Nodes.Clear();
            treeSolTitration.Nodes.Clear();

            ModSolution oModSolution = new ModSolution();
            CGroup_solutionFactory faGroup_solution = new CGroup_solutionFactory();
            List<CGroup_solution> lstGroup_solution = faGroup_solution.GetAll();

            // 1:SC, 2:SI-1, 3:SI-2, 4:EV, 5:ST
            foreach (var item in lstGroup_solution)
            {
                // solución de calibracion (SC)
                if (item.Type_solution == 1)
                {
                    object[] obj = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail /*, item.Idsolution_pattern*/ };
                    TreeListNode node = treeSolution.AppendNode(obj, treeStdCalib);
                    node.Tag = treeStdCalib.Tag;
                    node.ImageIndex = 1;
                    node.SelectImageIndex = 1;
                }
                // solución intermedia 1, 2 y estandar de verificación
                if (item.Type_solution == 2 || item.Type_solution == 3 || item.Type_solution == 4) // --- agregar filas de la tabla de soluciones (intermedias)
                {
                    // --- agregar soluciones intermedia-1
                    List<CSolution> lstSolInterm1 = oModSolution.GetLstSolInterm1ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm1)
                    {
                        object[] obj = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm1);
                        node.Tag = treeSolInterm1.Tag;
                        node.ImageIndex = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar soluciones intermedia-2
                    List<CSolution> lstSolInterm2 = oModSolution.GetLstSolInterm2ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm2)
                    {
                        object[] obj = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm2);
                        node.Tag = treeSolInterm2.Tag;
                        node.ImageIndex = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar estandares de verificación
                    List<CSolution> lstStdVerif = oModSolution.GetLstStdVerifByGroup(item.Idgroup_solution);

                    foreach (CSolution solution in lstStdVerif)
                    {
                        object[] obj = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeStdVerif);
                        node.Tag = treeStdVerif.Tag;
                        node.ImageIndex = 2;
                        node.SelectImageIndex = 2;
                    }
                }
                if (item.Type_solution == 5)
                {
                    object[] obj = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail /*, item.Idsolution_pattern*/ };
                    TreeListNode node = treeSolution.AppendNode(obj, treeSolTitration);
                    node.Tag = treeSolTitration.Tag;
                    node.ImageIndex = 1;
                    node.SelectImageIndex = 1;
                }
            }

            treeSolution.ExpandAll();
        }
示例#3
0
 CGroup_solution GetGroup_solution(int? p_idgroup_solution)
 {
     if (p_idgroup_solution != null)
     {
         CGroup_solution oGroup_solution = new CGroup_solutionFactory().GetByPrimaryKey(new CGroup_solutionKeys(Convert.ToInt32(p_idgroup_solution)));
         return oGroup_solution;
     }
     return null;
 }
示例#4
0
        public void InitTree(typeSolution[] typeSol)
        {
            treeStdCalib = treeSolution.Nodes[0].Clone() as TreeListNode;
            treeSolInterm1 = treeSolution.Nodes[1].Clone() as TreeListNode;
            treeSolInterm2 = treeSolution.Nodes[2].Clone() as TreeListNode;
            treeStdVerif = treeSolution.Nodes[3].Clone() as TreeListNode;
            treeSolTitration = treeSolution.Nodes[4].Clone() as TreeListNode;

            // --- solutions
            treeStdCalib.Tag = Convert.ToInt32(typeSolution.StdCalib);
            treeSolInterm1.Tag = Convert.ToInt32(typeSolution.SolInterm1);
            treeSolInterm2.Tag = Convert.ToInt32(typeSolution.SolInterm2);
            treeStdVerif.Tag = Convert.ToInt32(typeSolution.StdVerif);
            treeSolTitration.Tag = Convert.ToInt32(typeSolution.SolTitration);

            treeSolution.Nodes.Clear();

            for (int i = 0; i < typeSol.Length; i++)
            {
                if (typeSol[i] == typeSolution.StdCalib)
                    treeSolution.Nodes.Add(treeStdCalib);
                else if (typeSol[i] == typeSolution.SolInterm1)
                    treeSolution.Nodes.Add(treeSolInterm1);
                else if (typeSol[i] == typeSolution.SolInterm2)
                    treeSolution.Nodes.Add(treeSolInterm2);
                else if (typeSol[i] == typeSolution.StdVerif)
                    treeSolution.Nodes.Add(treeStdVerif);
                else if (typeSol[i] == typeSolution.SolTitration)
                    treeSolution.Nodes.Add(treeSolTitration);
            }

            treeStdCalib["Nombre"] = "Estandar de Calibración";
            treeSolInterm1["Nombre"] = "Solución Intermedia 1";
            treeSolInterm2["Nombre"] = "Solución Intermedia 2";
            treeStdVerif["Nombre"] = "Estandar de Verificación";
            treeSolTitration["Nombre"] = "Soluciones Titulantes";

            // --- limpiar nodos constantes
            //treeStdCalib.Nodes.Clear();
            //treeSolInterm1.Nodes.Clear();
            //treeSolInterm2.Nodes.Clear();
            //treeStdVerif.Nodes.Clear();
            //treeSolTitration.Nodes.Clear();

            ModSolution oModSolution = new ModSolution();
            CGroup_solutionFactory faGroup_solution = new CGroup_solutionFactory();
            List<CGroup_solution> lstGroup_solution =
                faGroup_solution
                .GetAll()
                .Where(x => x.Type_solution == Convert.ToInt32(typeSolution.StdCalib)
                    || x.Type_solution == Convert.ToInt32(typeSolution.SolInterm1)
                    || x.Type_solution == Convert.ToInt32(typeSolution.SolInterm2)
                    || x.Type_solution == Convert.ToInt32(typeSolution.StdVerif)
                    || x.Type_solution == Convert.ToInt32(typeSolution.SolTitration)).ToList();

            // 1:SC, 2:SI-1, 3:SI-2, 4:EV, 5:ST
            foreach (var item in lstGroup_solution)
            {
                // solución de calibracion (SC)
                if (item.Type_solution == 1)
                {
                    object[] obj = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail /*, item.Idsolution_pattern*/ };
                    TreeListNode node = treeSolution.AppendNode(obj, treeStdCalib);
                    node.Tag = treeStdCalib.Tag;
                    node.ImageIndex = 1;
                    node.SelectImageIndex = 1;
                }
                // solución intermedia 1, 2 y estandar de verificación
                if (item.Type_solution == 2 || item.Type_solution == 3 || item.Type_solution == 4) // --- agregar filas de la tabla de soluciones (intermedias)
                {
                    // --- agregar soluciones intermedia-1
                    List<CSolution> lstSolInterm1 = oModSolution.GetLstSolInterm1ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm1)
                    {
                        object[] obj = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm1);
                        node.Tag = treeSolInterm1.Tag;
                        node.ImageIndex = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar soluciones intermedia-2
                    List<CSolution> lstSolInterm2 = oModSolution.GetLstSolInterm2ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm2)
                    {
                        object[] obj = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm2);
                        node.Tag = treeSolInterm2.Tag;
                        node.ImageIndex = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar estandares de verificación
                    List<CSolution> lstStdVerif = oModSolution.GetLstStdVerifByGroup(item.Idgroup_solution);

                    foreach (CSolution solution in lstStdVerif)
                    {
                        object[] obj = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeStdVerif);
                        node.Tag = treeStdVerif.Tag;
                        node.ImageIndex = 2;
                        node.SelectImageIndex = 2;
                    }
                }
                if (item.Type_solution == 5)
                {
                    object[] obj = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail };
                    TreeListNode node = treeSolution.AppendNode(obj, treeSolTitration);
                    node.Tag = treeSolTitration.Tag;
                    node.ImageIndex = 1;
                    node.SelectImageIndex = 1;
                }
            }

            treeSolution.ExpandAll();
        }
示例#5
0
        private void ucSign1_OnSign(bool login)
        {
            if (login)
            {
                if (nodeSolutionInProcess != null)
                {
                    ///si el nuevo nodo seleccionado es un estandar de verificación
                    ///reasignar el tipo de solucion intermedia de su solución padre
                    int type_sol = Convert.ToInt32(nodeSolutionInProcess["Type_sol"]);

                    if (type_sol == 3 || type_sol == 4)
                    {
                        if (nodeSolutionInProcess.Level == 1)
                        {
                            type_sol = 1;
                        }
                        if (nodeSolutionInProcess.Level == 2)
                        {
                            type_sol = 2;
                        }
                    }

                    FormSelMethods fmSelMethods = new FormSelMethods(group_solution, type_sol);

                    if (fmSelMethods.ShowDialog() == DialogResult.OK)
                    {
                        // --- guardar grupo de solución
                        CGroup_solutionFactory fagroup_solution = new CGroup_solutionFactory();
                        bool result = false;

                        if (!(result = fagroup_solution.Update(group_solution)))
                        {
                            result = fagroup_solution.Insert(group_solution);
                        }

                        // --- guardando soluciones
                        if (result)
                        {
                            // --- guardar los cambios en las soluciones
                            CSolutionFactory faSolution      = new CSolutionFactory();
                            bool             result_solution = false;
                            for (int i = 0; i < lstSolution.Count; i++)
                            {
                                result_solution = false;

                                if (lstSolution[i].Idsolution == 0)
                                {
                                    #region Grabar metodos a nueva solución ingresada

                                    lstSolution[i].Idgroup_solution = group_solution.Idgroup_solution;
                                    lstSolution[i].Cod_solution     = null;

                                    if (!(result_solution = faSolution.Update(lstSolution[i])))
                                    {
                                        result_solution = faSolution.Insert(lstSolution[i]);
                                    }

                                    // --- asignar un correlativo dependiendo del tipo de solución
                                    // 1:solución intermedia1, 2:solución intermedia 2, 3:estandar de verificación
                                    if (result_solution)
                                    {
                                        ModCorrelatives oModCorrelatives = new ModCorrelatives();
                                        if (lstSolution[i].Type_sol == 1 || lstSolution[i].Type_sol == 2)
                                        {
                                            lstSolution[i].Cod_solution = oModCorrelatives.GetCorrelative(ModCorrelatives.Correlative.SolucionIntermedia);
                                        }
                                        else if (lstSolution[i].Type_sol == 3 || lstSolution[i].Type_sol == 4)
                                        {
                                            lstSolution[i].Cod_solution = oModCorrelatives.GetCorrelative(ModCorrelatives.Correlative.EstandarVerificacion);
                                        }

                                        faSolution.Update(lstSolution[i]);
                                    }

                                    if (result_solution)
                                    {
                                        // --- grabar métodos de la solución
                                        CSolution_methodsFactory faSolution_methods = new CSolution_methodsFactory();
                                        CSolution_methods        oSolution_methods  = new CSolution_methods();
                                        string concatMethods          = "";
                                        bool   result_solution_method = false;

                                        // --- grabar linkeo de solución y métodos
                                        foreach (CMethodMini item in fmSelMethods.LstMethodMini)
                                        {
                                            if (item.Sel)
                                            {
                                                // indexar método a la solución
                                                oSolution_methods                   = new CSolution_methods();
                                                oSolution_methods.Idsolution        = lstSolution[i].Idsolution;
                                                oSolution_methods.Idtemplate_method = item.Idtemplate_method;
                                                oSolution_methods.Status            = true;

                                                if (!(result_solution_method = faSolution_methods.Update(oSolution_methods)))
                                                {
                                                    result_solution_method = faSolution_methods.Insert(oSolution_methods);
                                                }

                                                // concatenar método
                                                concatMethods += concatMethods.Trim().Length == 0 ? item.Cod_template_method : ", " + item.Cod_template_method;
                                            }
                                        }

                                        // asignar concatenado de métodos seleccionados al campo de la solucion[i]
                                        lstSolution[i].Concat_cod_methods = concatMethods;
                                        faSolution.Update(lstSolution[i]);
                                    }
                                    #endregion
                                }
                            }

                            treeSolInterm.DataSource = lstSolution;
                            FlagSolutionInProcess    = false;

                            ShowStatusButtons();

                            new FormMessage("Guardado", "Guardado correctamente.", true, false).ShowDialog();

                            ucSign1.Clear();
                            treeSolInterm.ExpandAll();
                        }

                        onSignSolInterm(group_solution);
                    }
                }
                else
                {
                    ///No existe ningún nodo en proceso, entonces los cambios
                    ///fueron sobre el estado de las soluciones
                    ///
                    CSolutionFactory faSolution = new CSolutionFactory();
                    for (int i = 0; i < lstSolution.Count; i++)
                    {
                        faSolution.Update(lstSolution[i]);
                    }

                    treeSolInterm.DataSource = lstSolution;

                    ShowStatusButtons();
                    new FormMessage("Guardado", "Guardado correctamente.", true, false).ShowDialog();
                    ucSign1.Clear();
                    treeSolInterm.ExpandAll();

                    onSignSolInterm(group_solution);
                }
            }
            else
            {
                new FormMessage("Error", "Contraseña incorrecta.", true, false).ShowDialog();
            }
        }
示例#6
0
        void InitTree()
        {
            treeStdCalib     = treeSolution.Nodes[0];
            treeSolInterm1   = treeSolution.Nodes[1];
            treeSolInterm2   = treeSolution.Nodes[2];
            treeStdVerif     = treeSolution.Nodes[3];
            treeSolTitration = treeSolution.Nodes[4];

            // --- solutions
            treeStdCalib.Tag     = 1;
            treeSolInterm1.Tag   = 2;
            treeSolInterm2.Tag   = 3;
            treeStdVerif.Tag     = 4;
            treeSolTitration.Tag = 5;

            TypeSolution = Convert.ToInt32(treeStdCalib.Tag);

            // --- limpiar nodos constantes
            treeStdCalib.Nodes.Clear();
            treeSolInterm1.Nodes.Clear();
            treeSolInterm2.Nodes.Clear();
            treeStdVerif.Nodes.Clear();
            treeSolTitration.Nodes.Clear();

            ModSolution            oModSolution      = new ModSolution();
            CGroup_solutionFactory faGroup_solution  = new CGroup_solutionFactory();
            List <CGroup_solution> lstGroup_solution = faGroup_solution.GetAll();

            // 1:SC, 2:SI-1, 3:SI-2, 4:EV, 5:ST
            foreach (var item in lstGroup_solution)
            {
                // solución de calibracion (SC)
                if (item.Type_solution == 1)
                {
                    object[]     obj  = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail /*, item.Idsolution_pattern*/ };
                    TreeListNode node = treeSolution.AppendNode(obj, treeStdCalib);
                    node.Tag              = treeStdCalib.Tag;
                    node.ImageIndex       = 1;
                    node.SelectImageIndex = 1;
                }
                // solución intermedia 1, 2 y estandar de verificación
                if (item.Type_solution == 2 || item.Type_solution == 3 || item.Type_solution == 4) // --- agregar filas de la tabla de soluciones (intermedias)
                {
                    // --- agregar soluciones intermedia-1
                    List <CSolution> lstSolInterm1 = oModSolution.GetLstSolInterm1ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm1)
                    {
                        object[]     obj  = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm1);
                        node.Tag              = treeSolInterm1.Tag;
                        node.ImageIndex       = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar soluciones intermedia-2
                    List <CSolution> lstSolInterm2 = oModSolution.GetLstSolInterm2ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm2)
                    {
                        object[]     obj  = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm2);
                        node.Tag              = treeSolInterm2.Tag;
                        node.ImageIndex       = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar estandares de verificación
                    List <CSolution> lstStdVerif = oModSolution.GetLstStdVerifByGroup(item.Idgroup_solution);

                    foreach (CSolution solution in lstStdVerif)
                    {
                        object[]     obj  = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeStdVerif);
                        node.Tag              = treeStdVerif.Tag;
                        node.ImageIndex       = 2;
                        node.SelectImageIndex = 2;
                    }
                }
                if (item.Type_solution == 5)
                {
                    object[]     obj  = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail /*, item.Idsolution_pattern*/ };
                    TreeListNode node = treeSolution.AppendNode(obj, treeSolTitration);
                    node.Tag              = treeSolTitration.Tag;
                    node.ImageIndex       = 1;
                    node.SelectImageIndex = 1;
                }
            }

            treeSolution.ExpandAll();
        }
示例#7
0
        private void ucSign1_OnSign(bool login)
        {
            if (login)
            {
                if (nodeSolutionInProcess != null)
                {
                    ///si el nuevo nodo seleccionado es un estandar de verificación
                    ///reasignar el tipo de solucion intermedia de su solución padre
                    int type_sol = Convert.ToInt32(nodeSolutionInProcess["Type_sol"]);

                    if (type_sol == 3 || type_sol == 4)
                    {
                        if (nodeSolutionInProcess.Level == 1)
                            type_sol = 1;
                        if (nodeSolutionInProcess.Level == 2)
                            type_sol = 2;
                    }

                    FormSelMethods fmSelMethods = new FormSelMethods(group_solution, type_sol);

                    if (fmSelMethods.ShowDialog() == DialogResult.OK)
                    {
                        // --- guardar grupo de solución
                        CGroup_solutionFactory fagroup_solution = new CGroup_solutionFactory();
                        bool result = false;

                        if (!(result = fagroup_solution.Update(group_solution)))
                            result = fagroup_solution.Insert(group_solution);

                        // --- guardando soluciones
                        if (result)
                        {
                            // --- guardar los cambios en las soluciones
                            CSolutionFactory faSolution = new CSolutionFactory();
                            bool result_solution = false;
                            for (int i = 0; i < lstSolution.Count; i++)
                            {
                                result_solution = false;

                                if (lstSolution[i].Idsolution == 0)
                                {
                                    #region Grabar metodos a nueva solución ingresada

                                    lstSolution[i].Idgroup_solution = group_solution.Idgroup_solution;
                                    lstSolution[i].Cod_solution = null;

                                    if (!(result_solution = faSolution.Update(lstSolution[i])))
                                        result_solution = faSolution.Insert(lstSolution[i]);

                                    // --- asignar un correlativo dependiendo del tipo de solución
                                    // 1:solución intermedia1, 2:solución intermedia 2, 3:estandar de verificación
                                    if (result_solution)
                                    {
                                        ModCorrelatives oModCorrelatives = new ModCorrelatives();
                                        if (lstSolution[i].Type_sol == 1 || lstSolution[i].Type_sol == 2)
                                            lstSolution[i].Cod_solution = oModCorrelatives.GetCorrelative(ModCorrelatives.Correlative.SolucionIntermedia);
                                        else if (lstSolution[i].Type_sol == 3 || lstSolution[i].Type_sol == 4)
                                            lstSolution[i].Cod_solution = oModCorrelatives.GetCorrelative(ModCorrelatives.Correlative.EstandarVerificacion);

                                        faSolution.Update(lstSolution[i]);
                                    }

                                    if (result_solution)
                                    {
                                        // --- grabar métodos de la solución
                                        CSolution_methodsFactory faSolution_methods = new CSolution_methodsFactory();
                                        CSolution_methods oSolution_methods = new CSolution_methods();
                                        string concatMethods = "";
                                        bool result_solution_method = false;

                                        // --- grabar linkeo de solución y métodos
                                        foreach (CMethodMini item in fmSelMethods.LstMethodMini)
                                        {
                                            if (item.Sel)
                                            {
                                                // indexar método a la solución
                                                oSolution_methods = new CSolution_methods();
                                                oSolution_methods.Idsolution = lstSolution[i].Idsolution;
                                                oSolution_methods.Idtemplate_method = item.Idtemplate_method;
                                                oSolution_methods.Status = true;

                                                if (!(result_solution_method = faSolution_methods.Update(oSolution_methods)))
                                                    result_solution_method = faSolution_methods.Insert(oSolution_methods);

                                                // concatenar método
                                                concatMethods += concatMethods.Trim().Length == 0 ? item.Cod_template_method : ", " + item.Cod_template_method;
                                            }
                                        }

                                        // asignar concatenado de métodos seleccionados al campo de la solucion[i]
                                        lstSolution[i].Concat_cod_methods = concatMethods;
                                        faSolution.Update(lstSolution[i]);
                                    }
                                    #endregion
                                }
                            }

                            treeSolInterm.DataSource = lstSolution;
                            FlagSolutionInProcess = false;

                            ShowStatusButtons();

                            new FormMessage("Guardado", "Guardado correctamente.", true, false).ShowDialog();

                            ucSign1.Clear();
                            treeSolInterm.ExpandAll();
                        }

                        onSignSolInterm(group_solution);
                    }
                }
                else
                {
                    ///No existe ningún nodo en proceso, entonces los cambios
                    ///fueron sobre el estado de las soluciones
                    ///
                    CSolutionFactory faSolution = new CSolutionFactory();
                    for (int i = 0; i < lstSolution.Count; i++)
                        faSolution.Update(lstSolution[i]);

                    treeSolInterm.DataSource = lstSolution;

                    ShowStatusButtons();
                    new FormMessage("Guardado", "Guardado correctamente.", true, false).ShowDialog();
                    ucSign1.Clear();
                    treeSolInterm.ExpandAll();

                    onSignSolInterm(group_solution);
                }
            }
            else
                new FormMessage("Error", "Contraseña incorrecta.", true, false).ShowDialog();
        }
示例#8
0
        public void InitTree(typeSolution[] typeSol)
        {
            treeStdCalib     = treeSolution.Nodes[0].Clone() as TreeListNode;
            treeSolInterm1   = treeSolution.Nodes[1].Clone() as TreeListNode;
            treeSolInterm2   = treeSolution.Nodes[2].Clone() as TreeListNode;
            treeStdVerif     = treeSolution.Nodes[3].Clone() as TreeListNode;
            treeSolTitration = treeSolution.Nodes[4].Clone() as TreeListNode;

            // --- solutions
            treeStdCalib.Tag     = Convert.ToInt32(typeSolution.StdCalib);
            treeSolInterm1.Tag   = Convert.ToInt32(typeSolution.SolInterm1);
            treeSolInterm2.Tag   = Convert.ToInt32(typeSolution.SolInterm2);
            treeStdVerif.Tag     = Convert.ToInt32(typeSolution.StdVerif);
            treeSolTitration.Tag = Convert.ToInt32(typeSolution.SolTitration);

            treeSolution.Nodes.Clear();

            for (int i = 0; i < typeSol.Length; i++)
            {
                if (typeSol[i] == typeSolution.StdCalib)
                {
                    treeSolution.Nodes.Add(treeStdCalib);
                }
                else if (typeSol[i] == typeSolution.SolInterm1)
                {
                    treeSolution.Nodes.Add(treeSolInterm1);
                }
                else if (typeSol[i] == typeSolution.SolInterm2)
                {
                    treeSolution.Nodes.Add(treeSolInterm2);
                }
                else if (typeSol[i] == typeSolution.StdVerif)
                {
                    treeSolution.Nodes.Add(treeStdVerif);
                }
                else if (typeSol[i] == typeSolution.SolTitration)
                {
                    treeSolution.Nodes.Add(treeSolTitration);
                }
            }


            treeStdCalib["Nombre"]     = "Estandar de Calibración";
            treeSolInterm1["Nombre"]   = "Solución Intermedia 1";
            treeSolInterm2["Nombre"]   = "Solución Intermedia 2";
            treeStdVerif["Nombre"]     = "Estandar de Verificación";
            treeSolTitration["Nombre"] = "Soluciones Titulantes";


            // --- limpiar nodos constantes
            //treeStdCalib.Nodes.Clear();
            //treeSolInterm1.Nodes.Clear();
            //treeSolInterm2.Nodes.Clear();
            //treeStdVerif.Nodes.Clear();
            //treeSolTitration.Nodes.Clear();

            ModSolution            oModSolution      = new ModSolution();
            CGroup_solutionFactory faGroup_solution  = new CGroup_solutionFactory();
            List <CGroup_solution> lstGroup_solution =
                faGroup_solution
                .GetAll()
                .Where(x => x.Type_solution == Convert.ToInt32(typeSolution.StdCalib) ||
                       x.Type_solution == Convert.ToInt32(typeSolution.SolInterm1) ||
                       x.Type_solution == Convert.ToInt32(typeSolution.SolInterm2) ||
                       x.Type_solution == Convert.ToInt32(typeSolution.StdVerif) ||
                       x.Type_solution == Convert.ToInt32(typeSolution.SolTitration)).ToList();

            // 1:SC, 2:SI-1, 3:SI-2, 4:EV, 5:ST
            foreach (var item in lstGroup_solution)
            {
                // solución de calibracion (SC)
                if (item.Type_solution == 1)
                {
                    object[]     obj  = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail /*, item.Idsolution_pattern*/ };
                    TreeListNode node = treeSolution.AppendNode(obj, treeStdCalib);
                    node.Tag              = treeStdCalib.Tag;
                    node.ImageIndex       = 1;
                    node.SelectImageIndex = 1;
                }
                // solución intermedia 1, 2 y estandar de verificación
                if (item.Type_solution == 2 || item.Type_solution == 3 || item.Type_solution == 4) // --- agregar filas de la tabla de soluciones (intermedias)
                {
                    // --- agregar soluciones intermedia-1
                    List <CSolution> lstSolInterm1 = oModSolution.GetLstSolInterm1ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm1)
                    {
                        object[]     obj  = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm1);
                        node.Tag              = treeSolInterm1.Tag;
                        node.ImageIndex       = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar soluciones intermedia-2
                    List <CSolution> lstSolInterm2 = oModSolution.GetLstSolInterm2ByGroup(item.Idgroup_solution);
                    foreach (CSolution solution in lstSolInterm2)
                    {
                        object[]     obj  = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeSolInterm2);
                        node.Tag              = treeSolInterm2.Tag;
                        node.ImageIndex       = 1;
                        node.SelectImageIndex = 1;
                    }

                    // --- agregar estandares de verificación
                    List <CSolution> lstStdVerif = oModSolution.GetLstStdVerifByGroup(item.Idgroup_solution);

                    foreach (CSolution solution in lstStdVerif)
                    {
                        object[]     obj  = { solution.Cod_solution, solution.Idgroup_solution, item.Idmr_detail };
                        TreeListNode node = treeSolution.AppendNode(obj, treeStdVerif);
                        node.Tag              = treeStdVerif.Tag;
                        node.ImageIndex       = 2;
                        node.SelectImageIndex = 2;
                    }
                }
                if (item.Type_solution == 5)
                {
                    object[]     obj  = { item.Cod_solution, item.Idgroup_solution, item.Idmr_detail };
                    TreeListNode node = treeSolution.AppendNode(obj, treeSolTitration);
                    node.Tag              = treeSolTitration.Tag;
                    node.ImageIndex       = 1;
                    node.SelectImageIndex = 1;
                }
            }

            treeSolution.ExpandAll();
        }