Exemplo n.º 1
0
        public void GeneraFicheros(string _NomFichero)
        {
            if (File.Exists(_NomFichero))
            {
                string _TrabajarCon = "CORE";
                //string _TrabajarCon = "BUSI";

                // Leeremos la primera línea del fichero, en la que hay un campo que indica el tipo
                // de facturas que contiene. Posteriormente, llamaremos a la función correspondiente
                // para generar el XML correcto.
                StreamReader _Lector   = new StreamReader(_NomFichero);
                string       _Cabecera = _Lector.ReadLine();
                _Lector.Close();

                string[] _CamposReg   = _Cabecera.Split(';');
                string   _TipoFichero = _CamposReg[4];

                switch (_TipoFichero)
                {
                case "EMI":
                {
                    if (_TrabajarCon == "CORE")
                    {
                        EmitidasEnvel FuncionesEmiEnvel = new EmitidasEnvel();
                        FuncionesEmiEnvel.GenerarXMLEmitidasEnvel(_NomFichero);
                    }
                    else
                    {
                        Emitidas FuncionesEmi = new Emitidas();
                        FuncionesEmi.GenerarXMLEmitidas(_NomFichero);
                    }
                    break;
                }

                case "REC":
                {
                    if (_TrabajarCon == "CORE")
                    {
                        RecibidasEnvel FuncionesRecEnvel = new RecibidasEnvel();
                        FuncionesRecEnvel.GenerarXMLRecibidasEnvel(_NomFichero);
                    }
                    else
                    {
                        Recibidas FuncionesRec = new Recibidas();
                        FuncionesRec.GenerarXMLRecibidas(_NomFichero);
                    }
                    break;
                }

                case "INT":
                {
                    if (_TrabajarCon == "CORE")
                    {
                        IntracomEnvel FuncionesIntEnvel = new IntracomEnvel();
                        FuncionesIntEnvel.GenerarXMLIntracomEnvel(_NomFichero);
                    }
                    else
                    {
                        Intracom FuncionesInt = new Intracom();
                        FuncionesInt.GenerarXMLIntracom(_NomFichero);
                    }
                    break;
                }

                default:
                {
                    string _msg = "Este fichero no se puede tratar en este programa";
                    MessageBox.Show(_msg, "AVISO", MessageBoxButtons.OK, MessageBoxIcon.Warning);
                    break;
                }
                }
            }
            else
            {
                string _msg = "El fichero indicado no existe";
                MessageBox.Show(_msg, "ERROR", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }
Exemplo n.º 2
0
        public void GenerarXMLEmitidasEnvel(string _NombreFichero)
        {
            EmitidasEnvel funcion        = new EmitidasEnvel();
            string        _NomFicheroWrk = _NombreFichero;

            try
            {
                Envelope _EnvelWrk = new Envelope();
                SuministroLRFacturasEmitidas _SumLRFactEmit = new SuministroLRFacturasEmitidas();
                RegistroLRFacturasEmitidas   _RegLRFactEmit = new RegistroLRFacturasEmitidas();

                Cabecera _Cabecera = new Cabecera();

                using (StreamReader _Lector = new StreamReader(_NomFicheroWrk))
                {
                    while (_Lector.Peek() > -1)
                    {
                        string _RegFichero = _Lector.ReadLine();
                        if (!String.IsNullOrEmpty(_RegFichero))
                        {
                            // Con creamos un Array con los distintos campos que contiene el registro separados por ";"
                            string[] _CamposReg = _RegFichero.Split(';');
                            string   _TipoReg   = _CamposReg[0];

                            switch (_TipoReg)
                            {
                            case "CABE":
                                _Cabecera = funcion.TratarRegCabecera(_CamposReg);
                                _SumLRFactEmit.Cabecera = _Cabecera;
                                break;

                            case "FACT":
                                if (_NuevaFact)     // Si se trata de una nueva factura, añadiremos la 'antigua' al fichero
                                {
                                    _SumLRFactEmit.RegistroLRFacturasEmitidas.Add(_RegLRFactEmit);
                                    _NuevaFact = false;
                                }

                                // Se trata de una factura no Sujeta, de manera que no tendrá registros 'FISC' y se tendrá que añadir a
                                // la lista correspondiente.
                                if (!string.IsNullOrWhiteSpace(_CamposReg[19]) || !string.IsNullOrWhiteSpace(_CamposReg[20]))
                                {
                                    _NuevaFact = true;
                                }

                                _RegLRFactEmit = new RegistroLRFacturasEmitidas();
                                _RegLRFactEmit = funcion.TratarFactEmitida(_CamposReg);
                                break;

                            case "RECT":
                                _RegLRFactEmit = funcion.AgregarFactRectifica(_CamposReg, _RegLRFactEmit);
                                break;

                            case "FISC":
                                _NuevaFact     = true;
                                _RegLRFactEmit = funcion.AgregarDesgloseIVA(_CamposReg, _RegLRFactEmit);
                                break;

                            case "FINI":
                                // Incluimos la última factura que hemos tratado.
                                _SumLRFactEmit.RegistroLRFacturasEmitidas.Add(_RegLRFactEmit);

                                // Incluimos todas las facturas tratadas en el Envelope.
                                _EnvelWrk.Body.SuministroLRFacturasEmitidas = _SumLRFactEmit;

                                //Obtenemos la fecha actual sin la hora y procedemos a crear la ruta/nombre del fichero resultante
                                DateTime _FechaActual  = DateTime.Today;
                                string   nombrefichero = "SII_Emitidas_" + _Cabecera.Titular.NIF + "_" + _FechaActual.ToString("yyyyMMdd") + ".XML";
                                string   XmlResult     = "C:/Temp/" + nombrefichero;

                                // Con la siguiente instruccion se genera el XML en la direccion anteriormente indicada.
                                XmlDocument tmpXML = SIIParser.GetXml(_EnvelWrk, XmlResult);

                                string _msg = "Fichero XML generado: " + XmlResult;
                                MessageBox.Show(_msg, "Información", MessageBoxButtons.OK, MessageBoxIcon.Information);
                                break;

                            default:
                                string _msgAviso = "Tipo Registro incorrecto: " + _TipoReg;
                                MessageBox.Show(_msgAviso, "Aviso", MessageBoxButtons.OK, MessageBoxIcon.Warning);
                                break;
                            }
                        }
                    }
                }
            }
            catch (Exception ex)
            {
                string _msgError = "Error: " + ex.Message;
                MessageBox.Show(_msgError, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }