Пример #1
0
        public override void Commit()
        {
            _data.tpu_AgrupProveedores.Clear();
            _dataJerarquias.tpu_ProveedoresJerarquias.Clear();
            if (this.Elementos != null)
            {
                foreach (ProveedorView prov in this.Elementos)
                {
                    tpu_AgrupProveedoresDataset.tpu_AgrupProveedoresRow row = _data.tpu_AgrupProveedores.Newtpu_AgrupProveedoresRow();
                    row.IdProveedor                  = prov.IdProveedor;
                    row.Jerarquia                    = Jerarquia;
                    row.FechaCreacion                = mz.erp.businessrules.Sistema.DateTime.Now;
                    row.IdConexionCreacion           = Security.IdConexion;
                    row.IdConexionUltimaModificacion = Security.IdConexion;
                    row.IdReservado                  = 0;
                    row.RowId     = Guid.Empty;
                    row.IdEmpresa = Security.IdEmpresa;
                    _data.tpu_AgrupProveedores.Addtpu_AgrupProveedoresRow(row);

                    tpu_ProveedoresJerarquiasDataset.tpu_ProveedoresJerarquiasRow rowPJ = businessrules.tpu_ProveedoresJerarquias.GetByPk(prov.IdProveedor);
                    if (rowPJ == null)
                    {
                        rowPJ = _dataJerarquias.tpu_ProveedoresJerarquias.Newtpu_ProveedoresJerarquiasRow();
                        rowPJ["IdProveedor"] = prov.IdProveedor;
                        ProveedoresJerarquiaAuxiliar p = new ProveedoresJerarquiaAuxiliar();
                        ArrayList aux          = mz.erp.systemframework.Util.Parse(Jerarquia, 20);
                        string    nomenclatura = p.nomenclaturaReal(Jerarquia);
                        rowPJ[nomenclatura + "a"] = (aux.Count > 0 && aux[0] != null)? Convert.ToString(aux[0]) : string.Empty;
                        rowPJ[nomenclatura + "b"] = (aux.Count > 1 && aux[1] != null)? Convert.ToString(aux[1]) : string.Empty;
                        rowPJ[nomenclatura + "c"] = (aux.Count > 2 && aux[2] != null)? Convert.ToString(aux[2]) : string.Empty;
                        rowPJ[nomenclatura + "d"] = (aux.Count > 3 && aux[3] != null)? Convert.ToString(aux[3]) : string.Empty;
                        _dataJerarquias.tpu_ProveedoresJerarquias.Addtpu_ProveedoresJerarquiasRow(rowPJ);
                    }
                    else
                    {
                        ProveedoresJerarquiaAuxiliar p = new ProveedoresJerarquiaAuxiliar();
                        ArrayList aux          = mz.erp.systemframework.Util.Parse(Jerarquia, 20);
                        string    nomenclatura = p.nomenclaturaReal(Jerarquia);
                        rowPJ[nomenclatura + "a"] = (aux.Count > 0 && aux[0] != null)? Convert.ToString(aux[0]) : string.Empty;
                        rowPJ[nomenclatura + "b"] = (aux.Count > 1 && aux[1] != null)? Convert.ToString(aux[1]) : string.Empty;
                        rowPJ[nomenclatura + "c"] = (aux.Count > 2 && aux[2] != null)? Convert.ToString(aux[2]) : string.Empty;
                        rowPJ[nomenclatura + "d"] = (aux.Count > 3 && aux[3] != null)? Convert.ToString(aux[3]) : string.Empty;
                        _dataJerarquias.tpu_ProveedoresJerarquias.ImportRow(rowPJ);
                    }
                }
            }
        }
Пример #2
0
        public override void DeleteAgrupamientos(string Hierarchy)
        {
            if (this.Elementos != null)
            {
                foreach (ProveedorView pv in this.Elementos)
                {
                    string IdProveedor = pv.IdProveedor;
                    tpu_AgrupProveedoresDataset.tpu_AgrupProveedoresRow row = businessrules.tpu_AgrupProveedores.NewRow();
                    row = businessrules.tpu_AgrupProveedores.GetByPk(IdProveedor, Hierarchy);
                    if (row != null)
                    {
                        row.Delete();
                        businessrules.tpu_AgrupProveedores.Update(row);

                        //Si hay otra agrupproveedores no hay q eliminarla solo actualizarla, si no hay otra directamente borro la de proveedor jerarquia
                        DataSet dataset = businessrules.tpu_AgrupProveedores.GetList(IdProveedor);
                        if (dataset.Tables[0].Rows.Count == 0)
                        {
                            tpu_ProveedoresJerarquiasDataset.tpu_ProveedoresJerarquiasRow rowPJ = businessrules.tpu_ProveedoresJerarquias.GetByPk(IdProveedor);
                            rowPJ.Delete();
                            businessrules.tpu_ProveedoresJerarquias.Update(rowPJ);
                        }
                        //Else hay q actualizar la q jerarquia q corresponde = ""
                        else
                        {
                            ProveedoresJerarquiaAuxiliar p = new ProveedoresJerarquiaAuxiliar();
                            string    nomenclatura         = p.nomenclaturaReal(Jerarquia);
                            ArrayList aux = mz.erp.systemframework.Util.Parse(Jerarquia, 20);
                            tpu_ProveedoresJerarquiasDataset.tpu_ProveedoresJerarquiasRow rowPJ = AddTpu_ProveedoresJerarquias(IdProveedor);
                            rowPJ[nomenclatura + "a"] = string.Empty;
                            rowPJ[nomenclatura + "b"] = string.Empty;
                            rowPJ[nomenclatura + "c"] = string.Empty;
                            rowPJ[nomenclatura + "d"] = string.Empty;
                            businessrules.tpu_ProveedoresJerarquias.Update(rowPJ);
                        }
                    }
                }
            }
        }