Ejemplo n.º 1
0
        public void GenerarXMLRecibidas(string _NombreFichero)
        {
            Recibidas funcion        = new Recibidas();
            string    _NomFicheroWrk = _NombreFichero;

            try
            {
                //APInvoicesBatch _LoteFactRecibidas = new APInvoicesBatch();
                Batch     _LoteFactRecibidas = new Batch(BatchActionKeys.LR, BatchActionPrefixes.SuministroLR, BatchTypes.FacturasRecibidas);
                APInvoice _FactRecibidaAct   = new APInvoice();
                Party     _Titular           = new Party();
                bool      _NuevaFact         = false;

                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":
                                _Titular = funcion.TratarRegCabecera(_CamposReg);
                                _LoteFactRecibidas.Titular = _Titular;
                                string _TipoComunicacion = _CamposReg[3];
                                switch (_TipoComunicacion)
                                {
                                case "A0":
                                    _LoteFactRecibidas.CommunicationType = CommunicationType.A0;
                                    break;

                                case "A1":
                                    _LoteFactRecibidas.CommunicationType = CommunicationType.A1;
                                    break;

                                case "A4":
                                    _LoteFactRecibidas.CommunicationType = CommunicationType.A4;
                                    break;
                                }
                                break;

                            case "FACT":
                                if (_NuevaFact)     // Si se trata de una nueva factura, añadiremos la 'antigua' al fichero
                                {
                                    _LoteFactRecibidas.BatchItems.Add(_FactRecibidaAct);
                                    _NuevaFact = false;
                                }
                                _FactRecibidaAct = new APInvoice();
                                _FactRecibidaAct = funcion.TratarFactRecibida(_CamposReg, _Titular);
                                break;

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

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

                            case "FINI":
                                // Tenemos que grabar la última factura tratada, ya que sino no se incluirá en el XML
                                _LoteFactRecibidas.BatchItems.Add(_FactRecibidaAct);

                                // Procedemos a generar el XML final.
                                DateTime _FechaActual  = DateTime.Today;    //Obtenemos la fecha actual sin la hora
                                string   nombrefichero = "SII_Recibidas_" + _Titular.TaxIdentificationNumber + "_" + _FechaActual.ToString("yyyyMMdd") + ".XML";
                                string   XmlResult     = "C:/Temp/" + nombrefichero;
                                _LoteFactRecibidas.GetXml(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);
            }
        }
Ejemplo n.º 2
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);
            }
        }