f_tools.cs 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476
  1. using Newtonsoft.Json;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.Globalization;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Net;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Windows.Forms;
  14. using System.Xml.Linq;
  15. using System.Xml.Serialization;
  16. namespace Fuel01
  17. {
  18. public partial class f_tools : Form
  19. {
  20. int err = 0;
  21. bool ok = false;
  22. DataSet1.tb_venteDataTable tb_vente = new DataSet1.tb_venteDataTable();
  23. DataSet1.tb_prestaDataTable tb_presta = new DataSet1.tb_prestaDataTable();
  24. List<string> files2move = new List<string>();
  25. bool hasChanged = false;
  26. List<Produit> lproduit = new List<Produit>();
  27. List<Vente> Ventes = new List<Vente>();
  28. public f_tools()
  29. {
  30. InitializeComponent();
  31. Program.subfolder = Program.folder + @"\" + Program.key_ope;
  32. if (!Directory.Exists(Program.subfolder))
  33. Directory.CreateDirectory(Program.subfolder);
  34. if (File.Exists(Program.folder + @"\param\produit.xml"))
  35. {
  36. lproduit = DbUtil.GetProduits();
  37. }
  38. if (File.Exists(Program.subfolder + @"\presta.json"))
  39. {
  40. tb_presta = DbUtil.LoadPrestaFromJson(Program.subfolder + @"\presta.json", lproduit);
  41. }
  42. }
  43. /// <summary>
  44. /// Appelle le serveur pour récupérer les fichiers
  45. /// </summary>
  46. /// <param name="sender"></param>
  47. /// <param name="e"></param>
  48. private void bt_getdatas_Click(object sender, EventArgs e)
  49. {
  50. textResult.Text = "";
  51. line_res("Connexion au serveur");
  52. string url = Properties.Settings.Default.server_adress_datas;
  53. List<string> lines = readHttp_Dir(url);
  54. copyHttp(lines);
  55. line_res("F I N");
  56. }
  57. private void bt_trait_Click(object sender, EventArgs e)
  58. {
  59. this.Cursor = Cursors.WaitCursor;
  60. files2move.Clear();
  61. err = 0;
  62. textResult.Text = "";
  63. line_res("Début");
  64. string[] files = Directory.GetFiles(Program.folder + @"\in", "*.json ");
  65. List<Achats3> allAchats = new List<Achats3>();
  66. foreach (string file in files)
  67. {
  68. var content = File.ReadAllText(file);
  69. var achats = JsonConvert.DeserializeObject<List<Achats3>>(content);
  70. allAchats.AddRange(achats);
  71. }
  72. Ventes = ConvertAchatsToVentes(Ventes, allAchats);
  73. line_res("F I N");
  74. if (err == 0 && !ok)
  75. {
  76. if (MessageBox.Show("Voulez-vous enregister les achats", "Aucune erreur", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == System.Windows.Forms.DialogResult.Yes)
  77. {
  78. ok = true;
  79. load_vente();
  80. bt_trait_Click(sender, e);
  81. tb_vente.WriteXml(Program.subfolder + @"\vente.xml", XmlWriteMode.WriteSchema);
  82. //File.WriteAllText(Program.subfolder + @"\vente.json", JsonConvert.SerializeObject(allAchats));
  83. hasChanged = false;
  84. foreach (string file in files2move)
  85. File.Move(file, file.Replace(Program.folder + @"\in", Program.folder + @"\in\done"));
  86. foreach(var vente in Ventes)
  87. {
  88. traite(vente);
  89. }
  90. DbUtil.SaveToJson<DataSet1.tb_venteDataTable>(Program.subfolder + @"\vente.json", tb_vente);
  91. load_vente();
  92. }
  93. }
  94. else
  95. ok = false;
  96. this.Cursor = Cursors.Default;
  97. }
  98. private void load_vente()
  99. {
  100. tb_vente.Clear();
  101. if (File.Exists(Program.subfolder + @"\vente.json"))
  102. {
  103. tb_vente = DbUtil.LoadFromJson<DataSet1.tb_venteDataTable>(Program.subfolder + @"\vente.json", tb_vente);
  104. Ventes = JsonConvert.DeserializeObject<List<Vente>>(File.ReadAllText(Program.subfolder + @"\vente.json"));
  105. if (Ventes != null && Ventes.Count > 0)
  106. {
  107. tb_vente.AcceptChanges();
  108. tbventeBindingSource.DataSource = tb_vente;
  109. }
  110. }
  111. }
  112. private void save_vente()
  113. {
  114. File.WriteAllText(Program.subfolder + @"\vente.json", JsonConvert.SerializeObject(Ventes));
  115. }
  116. private List<Vente> ConvertAchatsToVentes(List<Vente> ventes, List<Achats3> achats)
  117. {
  118. foreach (var achat in achats)
  119. {
  120. var vente = new Vente
  121. {
  122. date_vt = DateTime.ParseExact(achat.moment, "yyyy-MM-ddTHH:mm:ss.ffffff", CultureInfo.InvariantCulture),
  123. epreuve_vt = Program.key_ope,
  124. ht_vt = 0,
  125. prod_vt = achat.libel,
  126. pu_vt = achat.pu,
  127. qtt_vt = achat.qtty,
  128. station_vt = achat.stationKey.ToString(),
  129. ttc_vt = achat.montantTTC,
  130. tva_vt = 0,
  131. vehi_vt = achat.bandeau
  132. };
  133. ventes.Add(vente);
  134. }
  135. return ventes;
  136. }
  137. /// <summary>
  138. /// Récupère les noms des fichiers à partir d'un repertoire listé en HTML
  139. /// </summary>
  140. /// <param name="url_txt">URL à lister</param>
  141. /// <returns>liste Urls des fichiers distants</returns>
  142. private List<string> readHttp_Dir(string url_txt)
  143. {
  144. Uri url = new Uri(url_txt);
  145. List<string> lines = new List<string>();
  146. try
  147. {
  148. HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
  149. HttpWebResponse response = (HttpWebResponse)request.GetResponse();
  150. Stream receiveStream = response.GetResponseStream();
  151. StreamReader readStream = new StreamReader(receiveStream, Encoding.UTF8);
  152. var block = readStream.ReadToEnd();
  153. response.Close();
  154. readStream.Close();
  155. var files = JsonConvert.DeserializeObject<List<string>>(block);
  156. foreach (var file in files.Where(x => x.EndsWith(".json", StringComparison.OrdinalIgnoreCase)))
  157. {
  158. try
  159. {
  160. var fileUrl = Path.Combine(url_txt, file);
  161. request = (HttpWebRequest)WebRequest.Create(fileUrl);
  162. response = (HttpWebResponse)request.GetResponse();
  163. receiveStream = response.GetResponseStream();
  164. readStream = new StreamReader(receiveStream, Encoding.UTF8);
  165. block = readStream.ReadToEnd();
  166. response.Close();
  167. readStream.Close();
  168. Console.WriteLine(block);
  169. var json = JsonConvert.DeserializeObject<string>(block);
  170. _ = JsonConvert.DeserializeObject<List<Achats3>>(json);
  171. lines.Add("http://" + response.ResponseUri.Host + "/Achats/" + file);
  172. }
  173. catch (Exception ex)
  174. {
  175. }
  176. }
  177. }
  178. catch (System.Net.WebException ex)
  179. {
  180. MessageBox.Show(ex.Message, "Err. Net");
  181. }
  182. catch (Exception ex)
  183. {
  184. MessageBox.Show(ex.Message, "Err. Autre");
  185. }
  186. line_res(lines.Count.ToString() + " Fichiers trouvés");
  187. return lines;
  188. }
  189. /// <summary>
  190. /// Copy localement (sous programmData/xxxx/xxxx) une liste de fichiers issue d"un répertoire HTML
  191. /// </summary>
  192. /// <param name="lines">liste des URL des fichiers distants</param>
  193. private void copyHttp(List<string> lines)
  194. {
  195. foreach (string line in lines)
  196. {
  197. Uri url = new Uri(line);
  198. HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
  199. // Set some reasonable limits on resources used by this request
  200. request.MaximumAutomaticRedirections = 4;
  201. request.MaximumResponseHeadersLength = 4;
  202. // Set credentials to use for this request.
  203. request.Credentials = CredentialCache.DefaultCredentials;
  204. HttpWebResponse response = (HttpWebResponse)request.GetResponse();
  205. if (!File.Exists(Program.folder + @"\in\" + response.ResponseUri.Segments[response.ResponseUri.Segments.Length - 1]) && !File.Exists(Program.folder + @"\in\done\" + response.ResponseUri.Segments[response.ResponseUri.Segments.Length - 1]))
  206. {
  207. text_res("Copie de " + response.ResponseUri.Segments[response.ResponseUri.Segments.Length - 1]);
  208. Stream receiveStream = response.GetResponseStream();
  209. StreamReader readStream = new StreamReader(receiveStream, Encoding.UTF8);
  210. StreamWriter writeStream = new StreamWriter(Program.folder + @"\in\" + response.ResponseUri.Segments[response.ResponseUri.Segments.Length - 1], false, Encoding.UTF8);
  211. writeStream.Write(readStream.ReadToEnd());
  212. writeStream.Close();
  213. readStream.Close();
  214. line_res(" . OK");
  215. }
  216. response.Close();
  217. }
  218. }
  219. //private void streamtolist_globXMLS(StreamReader readStream, string file)
  220. //{
  221. // XmlSerializer xs = new XmlSerializer(typeof(List<Achats>));
  222. // List<Achats> ListAchats = new List<Achats>();
  223. // try
  224. // {
  225. // using (readStream)
  226. // ListAchats = xs.Deserialize(readStream) as List<Achats>;
  227. // }
  228. // catch (Exception ex)
  229. // {
  230. // err++;
  231. // line_res("ERREUR Fichier : " + file);
  232. // MessageBox.Show(file + "\r\n" + ex.Message, "streamtolist_glob");
  233. // }
  234. // foreach (Achats ac in ListAchats)
  235. // {
  236. // line_res(string.Format("GLOBAL Date {0} Produit {1} PTTC {2}", ac.Date, ac.KindCarbu, ac.MontantCarbu));
  237. // if (ok)
  238. // {
  239. // traite(ac);
  240. // }
  241. // }
  242. // if (ok && err == 0) files2move.Add(file); // Normalement err toujours à zero pour autoriser le traitement cad ok=true;
  243. //}
  244. //private void streamtolist(StreamReader readStream, string file)
  245. //{
  246. //}
  247. //private void streamtolist_uniq(StreamReader readStream, string file)
  248. //{
  249. // XmlSerializer xs = new XmlSerializer(typeof(Achats));
  250. // Achats ac = null;
  251. // try
  252. // {
  253. // using (readStream)
  254. // ac = xs.Deserialize(readStream) as Achats;
  255. // line_res(string.Format("UNIQ Date {0} Produit {1} PTTC {2}", ac.Date, ac.KindCarbu, ac.MontantCarbu));
  256. // if (ok)
  257. // {
  258. // traite(ac);
  259. // files2move.Add(file);
  260. // }
  261. // }
  262. // catch (Exception ex)
  263. // {
  264. // err++;
  265. // line_res("ERREUR Fichier : " + file);
  266. // MessageBox.Show(file + "\r\n" + ex.Message, "streamtolist_uniq");
  267. // }
  268. //}
  269. //private void traite(Achats ac)
  270. //{
  271. // if (ac.Volume > 0)
  272. // {
  273. // tsLbl1.Text = string.Format("Date {0} Bandeau {1} Type {2} Volume {3} Total {4}", ac.Date, ac.Bandeau, ac.KindCarbu, ac.Volume, ac.MontantTotal);
  274. // Application.DoEvents();
  275. // if (tb_vente.FindByepreuve_vtstation_vtvehi_vtprod_vtdate_vt(Program.key_ope, ac.StationId.ToString(), ac.Bandeau, ac.KindCarbu, ac.Date) == null)
  276. // {
  277. // DataSet1.tb_venteRow myrow = tb_vente.NewRow() as DataSet1.tb_venteRow;
  278. // DataSet1.tb_prestaRow mydata = null;
  279. // mydata = tb_presta.FindBysta_prprod_pr(ac.StationId.ToString(), ac.KindCarbu);
  280. // if (mydata != null)
  281. // ac.TxTva = (float)mydata.tva_pr;
  282. // else
  283. // ac.TxTva = 0;
  284. // myrow["epreuve_vt"] = Program.key_ope;
  285. // myrow["station_vt"] = ac.StationId.ToString();
  286. // myrow["vehi_vt"] = ac.Bandeau;
  287. // myrow["prod_vt"] = ac.KindCarbu;
  288. // myrow["date_vt"] = ac.Date;
  289. // myrow["qtt_vt"] = Math.Round(ac.Volume, 2);
  290. // myrow["pu_vt"] = Math.Round(ac.PrixCarbu, 3);
  291. // myrow["tva_vt"] = ac.TxTva;
  292. // myrow["ttc_vt"] = Math.Round(ac.MontantCarbu, 2);
  293. // myrow["ht_vt"] = Math.Round(ac.MontantCarbu / (1 + (ac.TxTva / 100)), 2);
  294. // tb_vente.Addtb_venteRow(myrow);
  295. // hasChanged = true;
  296. // }
  297. // }
  298. // foreach (PrestasFournies pf in ac.Prestas)
  299. // {
  300. // if (pf.Name != null)
  301. // {
  302. // pf.TxTva = 0;
  303. // string newName = pf.Name.ToUpper().Contains("FREE") ? (pf.Libel == null ? "Produit inconnu" : pf.Libel) : pf.Name;
  304. // if (tb_vente.FindByepreuve_vtstation_vtvehi_vtprod_vtdate_vt(Program.key_ope, ac.StationId.ToString(), ac.Bandeau, newName, ac.Date) == null)
  305. // {
  306. // DataSet1.tb_venteRow myrow = tb_vente.NewRow() as DataSet1.tb_venteRow;
  307. // myrow["epreuve_vt"] = Program.key_ope;
  308. // myrow["station_vt"] = ac.StationId.ToString();
  309. // myrow["vehi_vt"] = ac.Bandeau;
  310. // myrow["prod_vt"] = newName;
  311. // myrow["date_vt"] = ac.Date;
  312. // myrow["qtt_vt"] = Math.Round(pf.Quantity, 2);
  313. // myrow["pu_vt"] = Math.Round(pf.PrixUnitaire, 2);
  314. // myrow["tva_vt"] = pf.TxTva; // pf.TxTva == 0 ? 20 : pf.TxTva; ;
  315. // myrow["ttc_vt"] = Math.Round(pf.Total, 2);
  316. // myrow["ht_vt"] = Math.Round(pf.Total, 2); // Math.Round(pf.Total / (1 + ( pf.TxTva / 100)), 2);
  317. // tb_vente.Addtb_venteRow(myrow);
  318. // hasChanged = true;
  319. // }
  320. // }
  321. // }
  322. // tsLbl1.Text = "";
  323. //}
  324. private void traite(Vente ac)
  325. {
  326. if (ac.qtt_vt > 0)
  327. {
  328. tsLbl1.Text = string.Format("Date {0} Bandeau {1} Type {2} Volume {3} Total {4}", ac.date_vt, ac.vehi_vt, ac.prod_vt, ac.qtt_vt, ac.ttc_vt);
  329. Application.DoEvents();
  330. if (tb_vente.FindByepreuve_vtstation_vtvehi_vtprod_vtdate_vt(Program.key_ope, ac.station_vt, ac.vehi_vt, ac.prod_vt, ac.date_vt) == null)
  331. {
  332. DataSet1.tb_venteRow myrow = tb_vente.NewRow() as DataSet1.tb_venteRow;
  333. DataSet1.tb_prestaRow mydata = null;
  334. mydata = tb_presta.FindBysta_prprod_pr(ac.station_vt, ac.prod_vt);
  335. if (mydata != null )
  336. ac.txtva_vt = (float)mydata.tva_pr;
  337. else
  338. ac.txtva_vt = 0;
  339. myrow["epreuve_vt"] = Program.key_ope;
  340. myrow["station_vt"] = ac.station_vt;
  341. myrow["vehi_vt"] = ac.vehi_vt;
  342. myrow["prod_vt"] = ac.prod_vt;
  343. myrow["date_vt"] = ac.date_vt;
  344. myrow["qtt_vt"] = Math.Round(ac.qtt_vt, 2);
  345. myrow["pu_vt"] = Math.Round(ac.pu_vt, 3);
  346. myrow["tva_vt"] = ac.txtva_vt;
  347. myrow["ttc_vt"] = Math.Round(ac.ttc_vt, 2);
  348. myrow["ht_vt"] = Math.Round(ac.ttc_vt / (1 + (ac.txtva_vt / 100)), 2);
  349. tb_vente.Addtb_venteRow(myrow);
  350. hasChanged = true;
  351. }
  352. }
  353. //foreach (PrestasFournies pf in ac.Prestas)
  354. //{
  355. // if (pf.Name != null)
  356. // {
  357. // pf.TxTva = 0;
  358. // string newName = pf.Name.ToUpper().Contains("FREE") ? (pf.Libel == null ? "Produit inconnu" : pf.Libel) : pf.Name;
  359. // if (tb_vente.FindByepreuve_vtstation_vtvehi_vtprod_vtdate_vt(Program.key_ope, ac.StationId.ToString(), ac.Bandeau, newName, ac.Date) == null)
  360. // {
  361. // DataSet1.tb_venteRow myrow = tb_vente.NewRow() as DataSet1.tb_venteRow;
  362. // myrow["epreuve_vt"] = Program.key_ope;
  363. // myrow["station_vt"] = ac.StationId.ToString();
  364. // myrow["vehi_vt"] = ac.Bandeau;
  365. // myrow["prod_vt"] = newName;
  366. // myrow["date_vt"] = ac.Date;
  367. // myrow["qtt_vt"] = Math.Round(pf.Quantity, 2);
  368. // myrow["pu_vt"] = Math.Round(pf.PrixUnitaire, 2);
  369. // myrow["tva_vt"] = pf.TxTva; // pf.TxTva == 0 ? 20 : pf.TxTva; ;
  370. // myrow["ttc_vt"] = Math.Round(pf.Total, 2);
  371. // myrow["ht_vt"] = Math.Round(pf.Total, 2); // Math.Round(pf.Total / (1 + ( pf.TxTva / 100)), 2);
  372. // tb_vente.Addtb_venteRow(myrow);
  373. // hasChanged = true;
  374. // }
  375. // }
  376. //}
  377. tsLbl1.Text = "";
  378. }
  379. private void text_res(string text)
  380. {
  381. textResult.Text += text;
  382. textResult.ScrollToCaret();
  383. Application.DoEvents();
  384. }
  385. private void line_res(string text)
  386. {
  387. textResult.Text += (text + "\r\n");
  388. textResult.SelectionStart = textResult.TextLength;
  389. textResult.ScrollToCaret();
  390. Application.DoEvents();
  391. }
  392. private void bt_loadVT_Click(object sender, EventArgs e)
  393. {
  394. load_vente();
  395. }
  396. private void check_modif_CheckedChanged(object sender, EventArgs e)
  397. {
  398. dg_vente.AllowUserToDeleteRows = check_modif.Checked;
  399. dg_vente.ReadOnly = !check_modif.Checked;
  400. }
  401. private void dg_vente_CellEndEdit(object sender, DataGridViewCellEventArgs e)
  402. {
  403. hasChanged = true;
  404. }
  405. private void f_tools_FormClosing(object sender, FormClosingEventArgs e)
  406. {
  407. if (hasChanged)
  408. if (MessageBox.Show("Voulez-vous sauvegarder les modifications ?", "Modifications non sauvegardées", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question) == System.Windows.Forms.DialogResult.Yes)
  409. DbUtil.SaveToJson<DataSet1.tb_venteDataTable>(Program.subfolder + @"\vente.json", tb_vente);
  410. e.Cancel = false;
  411. }
  412. private void f_tools_Load(object sender, EventArgs e)
  413. {
  414. }
  415. private void f_tools_MouseDoubleClick(object sender, MouseEventArgs e)
  416. {
  417. string input = "";
  418. if (Program.ShowInputDialog("Contrôle", "Entrez le mot de passe", ref input, true) == DialogResult.OK)
  419. splitContainer1.Enabled = (input == "fuel2016");
  420. }
  421. }
  422. }