f_presta.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. using Fuel01.Models;
  2. using Newtonsoft.Json;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.ComponentModel;
  6. using System.Data;
  7. using System.Diagnostics;
  8. using System.Drawing;
  9. using System.IO;
  10. using System.Linq;
  11. using System.Security.Cryptography.X509Certificates;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. using System.Windows.Forms;
  15. using System.Xml.Linq;
  16. using Excel = Microsoft.Office.Interop.Excel;
  17. namespace Fuel01
  18. {
  19. public partial class f_presta : Form
  20. {
  21. DataSet1.tb_prestaDataTable tb_presta = new DataSet1.tb_prestaDataTable();
  22. DataSet1.tb_venteDataTable tb_vente = new DataSet1.tb_venteDataTable();
  23. DataSet1.tb_stationDataTable tb_station = new DataSet1.tb_stationDataTable();
  24. DataSet1.tb_stationRow current_sta = null;
  25. List<Produit> lproduit = new List<Produit>();
  26. DataGridViewRow myrow = null;
  27. float oldqtt = 0;
  28. string id_sta;
  29. public f_presta(TextBox key_sta)
  30. {
  31. InitializeComponent();
  32. if (File.Exists(Program.folder + @"\param\produit.xml"))
  33. init_list_produit();
  34. if (File.Exists(Program.subfolder + @"\presta.json"))
  35. {
  36. tb_presta = DbUtil.LoadPrestaFromJson(Program.subfolder + @"\presta.json", lproduit);
  37. tb_presta.AcceptChanges();
  38. }
  39. tbprestaBindingSource.DataSource = tb_presta;
  40. if (File.Exists(Program.subfolder + @"\vente.json"))
  41. tb_vente = DbUtil.LoadFromJson<DataSet1.tb_venteDataTable>(Program.subfolder + @"\vente.json", tb_vente);
  42. tb_vente.AcceptChanges();
  43. tbventeBindingSource.DataSource = tb_vente;
  44. id_sta = key_sta.Text;
  45. tbprestaBindingSource.Filter = " sta_pr='" + id_sta + "'";
  46. tbventeBindingSource.Filter = " station_vt='" + id_sta + "'";
  47. tbprestaBindingSource.Sort = "sta_pr,kind_pr,prod_pr";
  48. key_sta.TextChanged += key_sta_TextChanged;
  49. key_sta_TextChanged(key_sta, null);
  50. t_facture.Enabled = Program.isExcel;
  51. }
  52. void key_sta_TextChanged(object sender, EventArgs e)
  53. {
  54. TextBox mytxtb = sender as TextBox;
  55. id_sta = mytxtb.Text;
  56. tbprestaBindingSource.Filter = " sta_pr='" + id_sta + "'";
  57. tbventeBindingSource.Filter = " station_vt='" + id_sta + "'";
  58. current_sta = tb_station.FindBykey_sta(id_sta);
  59. }
  60. private void f_presta_FormClosing(object sender, FormClosingEventArgs e)
  61. {
  62. SavePresta();
  63. }
  64. private void init_list_produit()
  65. {
  66. lproduit=DbUtil.GetProduits();
  67. dg_presta_prod.Items.Clear();
  68. dg_presta_prod.DataSource = lproduit;
  69. dg_presta_prod.DisplayMember = "lib_prod";
  70. dg_presta_prod.ValueMember = "key_prod";
  71. }
  72. private void dg_presta_RowsAdded(object sender, DataGridViewRowsAddedEventArgs e)
  73. {
  74. if (e.RowIndex > 0)
  75. {
  76. if (dg_presta.Rows[e.RowIndex - 1].Cells[0].Value is System.DBNull)
  77. {
  78. dg_presta.Rows[e.RowIndex - 1].Cells[0].Value = id_sta;
  79. }
  80. if (dg_presta.Rows[e.RowIndex - 1].Cells[0].Value == null)
  81. {
  82. dg_presta.Rows[e.RowIndex - 1].Cells[0].Value = id_sta;
  83. }
  84. }
  85. }
  86. private void bt_ajCarbu_Click(object sender, EventArgs e)
  87. {
  88. foreach (Produit p in lproduit.Where(p => p.type_prod == "Carburant"))
  89. {
  90. bool ok = false;
  91. for (int i = 0; i < dg_presta.RowCount - 1 && !ok; i++)
  92. if (dg_presta.Rows[i].Cells[1].Value.ToString() == p.key_prod)
  93. ok = true;
  94. if (!ok)
  95. {
  96. DataSet1.tb_prestaRow myNewRow = tb_presta.Newtb_prestaRow();
  97. myNewRow["sta_pr"] = id_sta;
  98. myNewRow["prod_pr"] = p.key_prod;
  99. myNewRow["kind_pr"] = p.type_prod;
  100. myNewRow["unite_pr"] = "L";
  101. myNewRow["pu_pr"] = 1;
  102. myNewRow["tva_pr"] = 20;
  103. myNewRow["ttc_pr"] = 1.2;
  104. tb_presta.Addtb_prestaRow(myNewRow);
  105. }
  106. }
  107. }
  108. private void bt_ajProd_Click(object sender, EventArgs e)
  109. {
  110. foreach (Produit p in lproduit)
  111. {
  112. bool ok = false;
  113. for (int i = 0; i < dg_presta.RowCount - 1 && !ok; i++)
  114. if (dg_presta.Rows[i].Cells[1].Value.ToString() == p.key_prod)
  115. ok = true;
  116. if (!ok)
  117. {
  118. DataSet1.tb_prestaRow myNewRow = tb_presta.Newtb_prestaRow();
  119. myNewRow["sta_pr"] = id_sta;
  120. myNewRow["prod_pr"] = p.key_prod;
  121. myNewRow["kind_pr"] = p.type_prod;
  122. myNewRow["unite_pr"] = p.type_prod == "Carburant" ? "L" : "U";
  123. myNewRow["pu_pr"] = 1;
  124. myNewRow["tva_pr"] = 20;
  125. myNewRow["ttc_pr"] = 1.2;
  126. tb_presta.Addtb_prestaRow(myNewRow);
  127. }
  128. }
  129. }
  130. private void bt_calcHT_Click(object sender, EventArgs e)
  131. {
  132. foreach (DataSet1.tb_prestaRow p in tb_presta.Rows)
  133. {
  134. if (p["ttc_pr"].ToString() != "" && p["tva_pr"].ToString() != "")
  135. {
  136. Decimal ttc = (Decimal)p["ttc_pr"];
  137. Decimal tva = 1 + (Decimal)p["tva_pr"] / 100;
  138. Decimal ht = ttc / tva;
  139. ht = Math.Round(ht, 3);
  140. p["pu_pr"] = ht;
  141. }
  142. }
  143. }
  144. private void bt_calcTTC_Click(object sender, EventArgs e)
  145. {
  146. foreach (DataSet1.tb_prestaRow p in tb_presta.Rows)
  147. {
  148. Console.WriteLine(p["sta_pr"].ToString());
  149. Console.WriteLine(p["prod_pr"].ToString());
  150. Console.WriteLine(p["kind_pr"].ToString());
  151. Console.WriteLine(p["unite_pr"].ToString());
  152. Console.WriteLine(p["pu_pr"].ToString());
  153. Console.WriteLine(p["tva_pr"].ToString());
  154. Console.WriteLine(p["ttc_pr"].ToString());
  155. if (p["pu_pr"].ToString() != "" && p["tva_pr"].ToString() != "")
  156. {
  157. Decimal ht = (Decimal)p["pu_pr"];
  158. Decimal tva = 1 + (Decimal)p["tva_pr"] / 100;
  159. Decimal ttc = ht * tva;
  160. ttc = Math.Round(ttc, 3);
  161. p["ttc_pr"] = ttc;
  162. }
  163. }
  164. }
  165. private void dg_vente_RowsAdded(object sender, DataGridViewRowsAddedEventArgs e)
  166. {
  167. if (e.RowIndex > 0)
  168. {
  169. if (dg_vente.Rows[e.RowIndex - 1].Cells[0].Value is System.DBNull)
  170. {
  171. dg_vente.Rows[e.RowIndex - 1].Cells[0].Value = Program.key_ope;
  172. dg_vente.Rows[e.RowIndex - 1].Cells[1].Value = id_sta;
  173. }
  174. if (dg_vente.Rows[e.RowIndex - 1].Cells[0].Value == null)
  175. {
  176. dg_vente.Rows[e.RowIndex - 1].Cells[0].Value = Program.key_ope;
  177. dg_vente.Rows[e.RowIndex - 1].Cells[1].Value = id_sta;
  178. }
  179. }
  180. }
  181. private void dg_presta_CellEndEdit(object sender, DataGridViewCellEventArgs e)
  182. {
  183. if (e.ColumnIndex != 1) return;
  184. string typeProd = "";
  185. string prod = dg_presta.Rows[e.RowIndex].Cells[e.ColumnIndex].Value.ToString();
  186. if (lproduit.Exists(xx => xx.key_prod == prod))
  187. typeProd = lproduit.Find(xx => xx.key_prod == prod).type_prod;
  188. dg_presta.Rows[e.RowIndex].Cells[2].Value = typeProd;
  189. }
  190. private void SavePresta()
  191. {
  192. List<PrestaSta> prestaStas = new List<PrestaSta>();
  193. tb_presta.AcceptChanges();
  194. string filter = tbprestaBindingSource.Filter;
  195. tbprestaBindingSource.Filter = "";
  196. tbprestaBindingSource.Sort = "sta_pr,kind_pr,prod_pr";
  197. bool isEmpty = tb_presta.Count == 0;
  198. var result0 = isEmpty ? "[]" : JsonConvert.SerializeObject(tb_presta);
  199. var result1 = isEmpty ? new List<Presta>() : JsonConvert.DeserializeObject<List<Presta>>(result0);
  200. var oldPr = "*";
  201. Prod prod;
  202. PrestaSta newPresta=new PrestaSta() ;
  203. foreach (var presta in result1)
  204. {
  205. var l_pr = lproduit.FirstOrDefault(x => x.key_prod == presta.prod_pr);
  206. if (l_pr == null)
  207. {
  208. continue;
  209. }
  210. var idSta = presta.sta_pr;
  211. var kind = presta.kind_pr;
  212. if (idSta != oldPr)
  213. {
  214. newPresta = new PrestaSta();
  215. newPresta.sta_pr = presta.sta_pr ;
  216. prestaStas.Add(newPresta);
  217. oldPr = idSta;
  218. }
  219. prod = new Prod
  220. {
  221. lib_prod = l_pr.lib_prod,
  222. prod_pr = presta.prod_pr,
  223. unite_pr = presta.unite_pr,
  224. pu_pr = presta.pu_pr.ToString("0.000"),
  225. tva_pr = presta.tva_pr.ToString("0.000"),
  226. ttc_pr = presta.ttc_pr.ToString("0.000")
  227. };
  228. if (newPresta != null)
  229. {
  230. if (kind == "Carburant")
  231. {
  232. newPresta.carburants.Add(prod);
  233. }
  234. else
  235. {
  236. newPresta.autres.Add(prod);
  237. }
  238. }
  239. }
  240. tbprestaBindingSource.Filter = filter;
  241. DbUtil.SaveToJson<DataSet1.tb_prestaDataTable>(Program.subfolder + @"\prestalocal.json", tb_presta);
  242. DbUtil.SaveToJson(prestaStas, Program.subfolder + @"\presta.json");
  243. }
  244. private void button1_Click(object sender, EventArgs e)
  245. {
  246. SavePresta();
  247. }
  248. private void t_facture_Click(object sender, EventArgs e)
  249. {
  250. f_facture ffac = new f_facture(current_sta["key_sta"].ToString());
  251. ffac.ShowDialog();
  252. }
  253. private void dg_vente_CellEndEdit(object sender, DataGridViewCellEventArgs e)
  254. {
  255. Console.WriteLine("EN EDIT ");
  256. bool ok = true;
  257. if (myrow != null)
  258. {
  259. Console.WriteLine("EN EDIT OK1");
  260. float qtt = 0;
  261. float puttc = 0;
  262. float tva = 0;
  263. float ttc = 0;
  264. float ht = 0;
  265. ok = float.TryParse(myrow.Cells[5].Value.ToString(), out qtt);
  266. if (ok) ok = float.TryParse(myrow.Cells[6].Value.ToString(), out puttc);
  267. if (ok) ok = float.TryParse(myrow.Cells[7].Value.ToString(), out tva);
  268. if (ok) ok = float.TryParse(myrow.Cells[8].Value.ToString(), out ht);
  269. if (ok) ok = float.TryParse(myrow.Cells[9].Value.ToString(), out ttc);
  270. if (!ok)
  271. {
  272. MessageBox.Show("Erreur de saisie");
  273. dg_vente.Rows[e.RowIndex].Cells[5].Value = oldqtt;
  274. return;
  275. }
  276. dg_vente.Rows[e.RowIndex].Cells[9].Value = qtt * puttc;
  277. dg_vente.Rows[e.RowIndex].Cells[8].Value = (qtt * puttc) / (1 + (tva / 100));
  278. }
  279. myrow = null;
  280. oldqtt = 0;
  281. Console.WriteLine("ENd EDIT OUt");
  282. }
  283. private void dg_vente_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
  284. {
  285. Console.WriteLine("BEGIN EDIT");
  286. myrow = dg_vente.Rows[e.RowIndex];
  287. if (!float.TryParse(myrow.Cells[5].Value.ToString(), out oldqtt))
  288. e.Cancel = true;
  289. }
  290. private void dg_vente_DataError(object sender, DataGridViewDataErrorEventArgs e)
  291. {
  292. if (myrow != null)
  293. {
  294. MessageBox.Show("Appuyez sur la touche Echappe (ESC Escape) \r\n dans la grille de saisie pour Abndonner l'opération", "Erreur de saisie");
  295. dg_vente.Rows[e.RowIndex].Cells[5].Value = oldqtt;
  296. myrow = null;
  297. oldqtt = 0;
  298. }
  299. }
  300. private void chk_modif_CheckedChanged(object sender, EventArgs e)
  301. {
  302. dg_vt_qtt.ReadOnly = !chk_modif.Checked;
  303. for (int i = 0; i < dg_vente.ColumnCount; i++)
  304. {
  305. if (i == 5)
  306. dg_vente.Columns[i].DefaultCellStyle.BackColor = chk_modif.Checked ? Color.LimeGreen : Color.Empty;
  307. else
  308. dg_vente.Columns[i].DefaultCellStyle.BackColor = chk_modif.Checked ? Color.OrangeRed : Color.Empty;
  309. }
  310. }
  311. }
  312. }