123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629 |
- using JPK_VDEK.Core;
- using Microsoft.Win32;
- using System;
- using System.Collections.Generic;
- using System.IO;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Windows;
- using System.Windows.Controls;
- using System.Windows.Data;
- using System.Windows.Documents;
- using System.Windows.Input;
- using System.Windows.Media;
- using System.Windows.Media.Imaging;
- using System.Windows.Navigation;
- using System.Windows.Shapes;
- using Path = System.IO.Path;
-
- namespace JPK_VDEK
- {
- /// <summary>
- /// Logika interakcji dla klasy Ogolne.xaml
- /// </summary>
- public partial class Ogolne : UserControl
- {
- public MainWindow win { get; set; }
- public Ogolne()
- {
- InitializeComponent();
- }
-
- private void Button_Click(object sender, RoutedEventArgs e)
- {
- OpenFileDialog openFileDialog = new OpenFileDialog();
- openFileDialog.Multiselect = false;
- openFileDialog.Title = "Podaj plik do przetworzenia IB";
- openFileDialog.Filter = "XML|*.xml";
- if (openFileDialog.ShowDialog() == true )
- {
- tigl.Text = openFileDialog.FileName;
- }
-
- }
-
- private void Button_Click_1(object sender, RoutedEventArgs e)
- {
- OpenFileDialog openFileDialog = new OpenFileDialog();
- openFileDialog.Multiselect = false;
- openFileDialog.Title = "Podaj plik do przetworzenia GL";
- openFileDialog.Filter = "CSV|*.csv";
- if (openFileDialog.ShowDialog() == true)
- {
- tgl.Text = openFileDialog.FileName;
- JpkData.initJpk();
- // wczytywanie pliku csv i wypełnianie struktur
- string path = tgl.Text;
- string file = Path.GetFileNameWithoutExtension(tgl.Text);
- file = file + ".xml";
- file = Path.GetDirectoryName(tgl.Text) + "\\" + file;
-
- JpkData.getJpk().outScalony = file;
- this.DataContext = JpkData.getJpk();
- }
- }
-
- private void Button_Click_2(object sender, RoutedEventArgs e)
- {
- OpenFileDialog openFileDialog = new OpenFileDialog();
- openFileDialog.Multiselect = false;
- openFileDialog.Title = "Podaj plik do przetworzenia IB";
- openFileDialog.Filter = "XML|*.xml";
- if (openFileDialog.ShowDialog() == true)
- {
- tscal.Text = openFileDialog.FileName;
- }
- }
-
- private void Button_Click_3(object sender, RoutedEventArgs e)
- {
-
- }
-
- private void Button_Click_4(object sender, RoutedEventArgs e)
- {
-
- }
-
- private void Button_Click_5(object sender, RoutedEventArgs e)
- {
-
- }
-
- private void Button_Click_6(object sender, RoutedEventArgs e)
- {
-
- }
-
- private void bgen_Click(object sender, RoutedEventArgs e)
- {
- string path = tgl.Text;
- string[] atr;
- if(tgl.Text.Length == 0)
- {
- return;
- }
- try
- {
- using (StreamReader sr = new StreamReader(path))
- {
- string line = sr.ReadLine();
- atr = line.Split('|');
-
- JpkData.getJpk().Naglowek.KodUrzedu = TKodUS.Item0271;
- JpkData.getJpk().UsNazwa = "DOLNOŚLĄSKI URZĄD SKARBOWY WE WROCŁAWJU";
-
- JpkData.getJpk().Naglowek.Rok = atr[1].Substring(0, 4);
- JpkData.getJpk().Naglowek.Miesiac = Convert.ToSByte(atr[1].Substring(4, 2));
- JpkData.getJpk().Naglowek.DataWytworzeniaJPK = new DateTime(Convert.ToInt16(atr[3].Substring(0, 4)), Convert.ToInt16(atr[3].Substring(4, 2)), Convert.ToInt16(atr[3].Substring(6, 2)));
- JpkData.getJpk().Naglowek.CelZlozenia.Value = 1;
-
- TPodmiotDowolnyBezAdresuOsobaNiefizyczna fir = new TPodmiotDowolnyBezAdresuOsobaNiefizyczna();
- JG jgos = new JG();
- SpName sp = (SpName)jgos.Lista.FirstOrDefault(s => s.Kod == atr[0]);
- fir.NIP = sp.NIP;
- fir.PelnaNazwa = sp.Describe;
- fir.Telefon = sp.telefon;
- fir.Email = sp.email;
- JpkData.getJpk().Podmiot1.Item = fir;
-
- int liczbaWSp = 0;
- Decimal podNal = 0;
- int liczbaWZp = 0;
- Decimal podNali = 0;
- while (!sr.EndOfStream)
- {
- line = sr.ReadLine();
- atr = line.Split('|');
- if (atr[1].Equals("D"))
- {
- JpkData.getJpk().Deklaracja.PozycjeSzczegolowe = new PozycjeSzczegolowe();
- PozycjeSzczegolowe d1 = JpkData.getJpk().Deklaracja.PozycjeSzczegolowe;
- d1.P_10 = atr[2] ;
- d1.P_11 = atr[3];
- d1.P_12 = atr[4];
- d1.P_13 = atr[5];
- d1.P_14 = atr[6];
- d1.P_15 = atr[7];
- d1.P_16 = atr[8];
- d1.P_17 = atr[9];
- d1.P_18 = atr[10];
- d1.P_19 = atr[11];
- d1.P_20 = atr[12];
- d1.P_21 = atr[13];
- d1.P_22 = atr[14];
- d1.P_23 = atr[15];
- d1.P_24 = atr[16];
- d1.P_25 = atr[17];
- d1.P_26 = atr[18];
- d1.P_27 = atr[19];
- d1.P_28 = atr[20];
- d1.P_29 = atr[21];
- d1.P_30 = atr[22];
- d1.P_31 = atr[23];
- d1.P_32 = atr[24];
- d1.P_33 = atr[25];
- d1.P_34 = atr[26];
- d1.P_35 = atr[27];
- d1.P_36 = atr[28];
- d1.P_37 = atr[29];
- d1.P_38 = atr[30];
- d1.P_39 = atr[31];
- d1.P_40 = atr[32];
- d1.P_41 = atr[33];
- d1.P_42 = atr[34];
- d1.P_43 = atr[35];
- d1.P_44 = atr[36];
- d1.P_45 = atr[37];
- d1.P_46 = atr[38];
- d1.P_47 = atr[39];
- d1.P_48 = atr[40];
- d1.P_49 = atr[41];
- d1.P_50 = atr[42];
- d1.P_51 = atr[43];
- d1.P_52 = atr[44];
- d1.P_53 = atr[45];
- d1.P_54 = atr[46];
- if(atr[47].Equals("X"))
- {
- d1.ItemElementName = ItemChoiceType.P_55;
- d1.Item = 1;
- JpkData.getJpk().P55 = true;
- }
- if (atr[48].Equals("X"))
- {
- d1.ItemElementName = ItemChoiceType.P_56;
- d1.Item = 1;
- JpkData.getJpk().P56 = true;
- }
- if (atr[49].Equals("X"))
- {
- d1.ItemElementName = ItemChoiceType.P_57;
- d1.Item = 1;
- JpkData.getJpk().P57 = true;
- }
- if (atr[50].Equals("X"))
- {
- d1.ItemElementName = ItemChoiceType.P_58;
- d1.Item = 1;
- JpkData.getJpk().P58 = true;
- }
- if(atr[51].Equals("X"))
- {
- d1.P_59 = 1;
- JpkData.getJpk().P59 = true;
- }
- else
- {
- d1.P_59 = 0;
- JpkData.getJpk().P59 = false;
- }
- d1.P_60 = atr[52];
- d1.P_61 = atr[53];
- d1.P_62 = atr[54];
- if (atr[55].Equals("X"))
- {
- d1.P_63 = 1;
- JpkData.getJpk().P63 = true;
- }
- else
- {
- d1.P_63 = 0;
- JpkData.getJpk().P63 = false;
- }
- if (atr[56].Equals("X"))
- {
- d1.P_64 = 1;
- JpkData.getJpk().P64 = true;
- }
- else
- {
- d1.P_64 = 0;
- JpkData.getJpk().P64 = false;
- }
- if (atr[57].Equals("X"))
- {
- d1.P_65 = 1;
- JpkData.getJpk().P65 = true;
- }
- else
- {
- d1.P_65 = 0;
- JpkData.getJpk().P65 = false;
- }
- if (atr[58].Equals("X"))
- {
- d1.P_66 = 1;
- JpkData.getJpk().P66 = true;
- }
- else
- {
- d1.P_66 = 0;
- JpkData.getJpk().P66 = false;
- }
- if (atr[59].Equals("X"))
- {
- d1.P_67 = 1;
- JpkData.getJpk().P67 = true;
- }
- else
- {
- d1.P_67 = 0;
- JpkData.getJpk().P67 = false;
- }
- d1.P_68 = atr[60];
- d1.P_69 = atr[61];
- d1.P_ORDZU = atr[62];
- JpkData.getJpk().Deklaracja.Pouczenia = Convert.ToDecimal(atr[63].Replace('.', ','));
- }
-
- if (atr[1].Equals("S"))
- {
- liczbaWSp++;
- JPKSprzedazWiersz spw = new JPKSprzedazWiersz();
- spw.LpSprzedazy = atr[0];
- spw.DataSprzedazy = new DateTime(Convert.ToInt16(atr[3].Substring(0, 4)), Convert.ToInt16(atr[3].Substring(4, 2)), Convert.ToInt16(atr[3].Substring(6, 2)));
- spw.DataWystawienia = new DateTime(Convert.ToInt16(atr[4].Substring(0, 4)), Convert.ToInt16(atr[4].Substring(4, 2)), Convert.ToInt16(atr[4].Substring(6, 2)));
- spw.DowodSprzedazy = atr[5];
- spw.NazwaKontrahenta = atr[6];
-
- spw.K_10 = Convert.ToDecimal(atr[8].Replace('.', ','));
- spw.K_11 = Convert.ToDecimal(atr[9].Replace('.', ','));
- spw.K_12 = Convert.ToDecimal(atr[10].Replace('.', ','));
- spw.K_13 = Convert.ToDecimal(atr[11].Replace('.', ','));
- spw.K_14 = Convert.ToDecimal(atr[12].Replace('.', ','));
- spw.K_15 = Convert.ToDecimal(atr[13].Replace('.', ','));
- spw.K_16 = Convert.ToDecimal(atr[14].Replace('.', ','));
- spw.K_17 = Convert.ToDecimal(atr[15].Replace('.', ','));
- spw.K_18 = Convert.ToDecimal(atr[16].Replace('.', ','));
- spw.K_19 = Convert.ToDecimal(atr[17].Replace('.', ','));
- spw.K_20 = Convert.ToDecimal(atr[18].Replace('.', ','));
- spw.K_21 = Convert.ToDecimal(atr[19].Replace('.', ','));
- spw.K_22 = Convert.ToDecimal(atr[20].Replace('.', ','));
- spw.K_23 = Convert.ToDecimal(atr[21].Replace('.', ','));
- spw.K_24 = Convert.ToDecimal(atr[22].Replace('.', ','));
- spw.K_25 = Convert.ToDecimal(atr[23].Replace('.', ','));
- spw.K_26 = Convert.ToDecimal(atr[24].Replace('.', ','));
- spw.K_27 = Convert.ToDecimal(atr[25].Replace('.', ','));
- spw.K_28 = Convert.ToDecimal(atr[26].Replace('.', ','));
- spw.K_29 = Convert.ToDecimal(atr[27].Replace('.', ','));
- spw.K_30 = Convert.ToDecimal(atr[28].Replace('.', ','));
- spw.K_31 = Convert.ToDecimal(atr[29].Replace('.', ','));
- spw.K_32 = Convert.ToDecimal(atr[30].Replace('.', ','));
- spw.K_33 = Convert.ToDecimal(atr[31].Replace('.', ','));
- spw.K_34 = Convert.ToDecimal(atr[32].Replace('.', ','));
- spw.K_35 = Convert.ToDecimal(atr[33].Replace('.', ','));
- spw.K_36 = Convert.ToDecimal(atr[34].Replace('.', ','));
-
- podNal = podNal + spw.K_16 + spw.K_18 + spw.K_20 + spw.K_24 + spw.K_26 + spw.K_28 + spw.K_30 + spw.K_32 + spw.K_33 + spw.K_34 - spw.K_35 - spw.K_36;
-
- spw.SprzedazVAT_Marza = Convert.ToDecimal(atr[35].Replace('.', ','));
-
- JpkData.getJpk().Sumy.K_10 += spw.K_10;
- JpkData.getJpk().Sumy.K_11 += spw.K_11;
- JpkData.getJpk().Sumy.K_12 += spw.K_12;
- JpkData.getJpk().Sumy.K_13 += spw.K_13;
- JpkData.getJpk().Sumy.K_14 += spw.K_14;
- JpkData.getJpk().Sumy.K_15 += spw.K_15;
- JpkData.getJpk().Sumy.K_16 += spw.K_16;
- JpkData.getJpk().Sumy.K_17 += spw.K_17;
- JpkData.getJpk().Sumy.K_18 += spw.K_18;
- JpkData.getJpk().Sumy.K_19 += spw.K_19;
- JpkData.getJpk().Sumy.K_20 += spw.K_20;
- JpkData.getJpk().Sumy.K_21 += spw.K_21;
- JpkData.getJpk().Sumy.K_22 += spw.K_22;
- JpkData.getJpk().Sumy.K_23 += spw.K_23;
- JpkData.getJpk().Sumy.K_24 += spw.K_24;
- JpkData.getJpk().Sumy.K_25 += spw.K_25;
- JpkData.getJpk().Sumy.K_26 += spw.K_26;
- JpkData.getJpk().Sumy.K_27 += spw.K_27;
- JpkData.getJpk().Sumy.K_28 += spw.K_28;
- JpkData.getJpk().Sumy.K_29 += spw.K_29;
- JpkData.getJpk().Sumy.K_30 += spw.K_30;
- JpkData.getJpk().Sumy.K_31 += spw.K_31;
- JpkData.getJpk().Sumy.K_32 += spw.K_32;
- JpkData.getJpk().Sumy.K_33 += spw.K_33;
- JpkData.getJpk().Sumy.K_34 += spw.K_34;
- JpkData.getJpk().Sumy.K_35 += spw.K_35;
- JpkData.getJpk().Sumy.K_36 += spw.K_36;
- JpkData.getJpk().Sumy.SprzedazVAT_Marza += spw.SprzedazVAT_Marza;
-
-
- spw.NrKontrahenta = atr[46];
-
- spw.KodKrajuNadaniaTIN = atr[48];
- if (atr[49].Equals("WEW"))
- {
- spw.TypDokumentu = TDowoduSprzedazy.WEW;
- }
- if (atr[49].Equals("RO"))
- {
- spw.TypDokumentu = TDowoduSprzedazy.RO;
- }
- if (atr[49].Equals("FP"))
- {
- spw.TypDokumentu = TDowoduSprzedazy.FP;
- }
-
- spw.GTU_01 = 0;
- spw.GTU_02 = 0;
- if (atr[50].Equals("X"))
- {
- spw.GTU_03 = 1;
- }
- else
- {
- spw.GTU_03 = 0;
- }
- spw.GTU_04 = 0;
- if (atr[51].Equals("X"))
- {
- spw.GTU_05 = 1;
- }
- else
- {
- spw.GTU_05 = 0;
- }
- if (atr[52].Equals("X"))
- {
- spw.GTU_06 = 1;
- }
- else
- {
- spw.GTU_06 = 0;
- }
- if (atr[53].Equals("X"))
- {
- spw.GTU_07 = 1;
- }
- else
- {
- spw.GTU_07 = 0;
- }
- spw.GTU_08 = 0;
- spw.GTU_09 = 0;
- if (atr[54].Equals("X"))
- {
- spw.GTU_10 = 1;
- }
- else
- {
- spw.GTU_10 = 0;
- }
- spw.GTU_11 = 0;
- if (atr[55].Equals("X"))
- {
- spw.GTU_12 = 1;
- }
- else
- {
- spw.GTU_12 = 0;
- }
- if (atr[56].Equals("X"))
- {
- spw.GTU_13 = 1;
- }
- else
- {
- spw.GTU_13 = 0;
- }
- if (atr[57].Equals("X"))
- {
- spw.SW = 1;
- }
- else
- {
- spw.SW = 0;
- }
- if (atr[58].Equals("X"))
- {
- spw.EE = 1;
- }
- else
- {
- spw.EE = 0;
- }
- if (atr[59].Equals("X"))
- {
- spw.TP = 1;
- }
- else
- {
- spw.TP = 0;
- }
- if (atr[60].Equals("X"))
- {
- spw.TT_WNT = 1;
- }
- else
- {
- spw.TT_WNT = 0;
- }
- if (atr[61].Equals("X"))
- {
- spw.TT_D = 1;
- }
- else
- {
- spw.TT_D = 0;
- }
- if (atr[62].Equals("X"))
- {
- spw.MR_T = 1;
- }
- else
- {
- spw.MR_T = 0;
- }
- if (atr[63].Equals("X"))
- {
- spw.MR_UZ = 1;
- }
- else
- {
- spw.MR_UZ = 0;
- }
- if (atr[64].Equals("X"))
- {
- spw.I_42 = 1;
- }
- else
- {
- spw.I_42 = 0;
- }
- if (atr[65].Equals("X"))
- {
- spw.I_63 = 1;
- }
- else
- {
- spw.I_63 = 0;
- }
- if (atr[65].Equals("X"))
- {
- spw.B_SPV = 1;
- }
- else
- {
- spw.B_SPV = 0;
- }
- if (atr[66].Equals("X"))
- {
- spw.B_SPV_DOSTAWA = 1;
- }
- else
- {
- spw.B_SPV_DOSTAWA = 0;
- }
- if (atr[67].Equals("X"))
- {
- spw.B_MPV_PROWIZJA = 1;
- }
- else
- {
- spw.B_MPV_PROWIZJA = 0;
- }
- if (atr[68].Equals("X"))
- {
- spw.MPP = 1;
- }
- else
- {
- spw.MPP = 0;
- }
- if (atr[69].Equals("X"))
- {
- spw.KorektaPodstawyOpodt = 1;
- }
- else
- {
- spw.KorektaPodstawyOpodt = 0;
- }
- JpkData.getJpk().SprzedazWiersz.Add(spw);
- JpkData.getJpk().ViewSP.Add(spw);
- }
- if (atr[1].Equals("Z"))
- {
- liczbaWZp++;
- JPKZakupWiersz zaw = new JPKZakupWiersz();
- zaw.LpZakupu = atr[0];
-
- zaw.DowodZakupu = atr[5];
- zaw.NazwaDostawcy = atr[6];
- zaw.NrDostawcy = atr[46];
- zaw.DataWplywu = new DateTime(Convert.ToInt16(atr[3].Substring(0, 4)), Convert.ToInt16(atr[3].Substring(4, 2)), Convert.ToInt16(atr[3].Substring(6, 2)));
- zaw.DataZakupu = new DateTime(Convert.ToInt16(atr[4].Substring(0, 4)), Convert.ToInt16(atr[4].Substring(4, 2)), Convert.ToInt16(atr[4].Substring(6, 2)));
-
- zaw.K_40 = Convert.ToDecimal(atr[38].Replace('.', ','));
- zaw.K_41 = Convert.ToDecimal(atr[39].Replace('.', ','));
- zaw.K_42 = Convert.ToDecimal(atr[40].Replace('.', ','));
- zaw.K_43 = Convert.ToDecimal(atr[41].Replace('.', ','));
-
- zaw.K_44 = Convert.ToDecimal(atr[42].Replace('.', ','));
- zaw.K_45 = Convert.ToDecimal(atr[43].Replace('.', ','));
- zaw.K_46 = Convert.ToDecimal(atr[44].Replace('.', ','));
- zaw.K_47 = Convert.ToDecimal(atr[45].Replace('.', ','));
-
- zaw.KodKrajuNadaniaTIN = atr[48];
-
- if (atr[49].Equals("MK"))
- {
- zaw.DokumentZakupu = TDowoduZakupu.MK;
- }
- if (atr[49].Equals("VAT_RR"))
- {
- zaw.DokumentZakupu = TDowoduZakupu.VAT_RR;
- }
- if (atr[49].Equals("WEW"))
- {
- zaw.DokumentZakupu = TDowoduZakupu.WEW;
- }
- if (atr[68].Equals("X"))
- {
- zaw.MPP = 1;
- }
- else
- {
- zaw.MPP = 0;
- }
- if (atr[70].Equals("X"))
- {
- zaw.IMP = 1;
- }
- else
- {
- zaw.IMP = 0;
- }
- zaw.ZakupVAT_Marza = Convert.ToDecimal(atr[71].Replace('.', ','));
-
- JpkData.getJpk().Sumy.K_40 += zaw.K_40;
- JpkData.getJpk().Sumy.K_41 += zaw.K_41;
- JpkData.getJpk().Sumy.K_42 += zaw.K_42;
- JpkData.getJpk().Sumy.K_43 += zaw.K_43;
- JpkData.getJpk().Sumy.K_44 += zaw.K_44;
- JpkData.getJpk().Sumy.K_45 += zaw.K_45;
- JpkData.getJpk().Sumy.K_46 += zaw.K_46;
- JpkData.getJpk().Sumy.K_47 += zaw.K_47;
- JpkData.getJpk().Sumy.ZakupVAT_Marza += zaw.ZakupVAT_Marza;
-
- podNali = podNali + zaw.K_41 + zaw.K_43 + zaw.K_44 + zaw.K_45 + zaw.K_46 + zaw.K_47;
- JpkData.getJpk().ZakupWiersz.Add(zaw);
- JpkData.getJpk().ViewZA.Add(zaw);
- }
- }
- JpkData.getJpk().SprzedazCtrl.LiczbaWierszySprzedazy = liczbaWSp.ToString();
- JpkData.getJpk().SprzedazCtrl.PodatekNalezny = podNal;
- JpkData.getJpk().ZakupCtrl.LiczbaWierszyZakupow = liczbaWZp.ToString();
- JpkData.getJpk().ZakupCtrl.PodatekNaliczony = podNali;
- }
- JpkData.getJpk().wczytalemGL = true;
- win.DataContext = JpkData.getJpk();
- }
- catch (FileNotFoundException ex)
- {
-
- }
- }
- }
- }
|