RequisitionItemGrid.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Windows;
  5. using Comal.Classes;
  6. using InABox.Clients;
  7. using InABox.Core;
  8. using InABox.DynamicGrid;
  9. using InABox.WPF;
  10. using Microsoft.Office.Interop.Outlook;
  11. using Syncfusion.Windows.Tools.Controls;
  12. using Exception = System.Exception;
  13. namespace PRSDesktop
  14. {
  15. public class RequisitionItemGrid : DynamicDataGrid<RequisitionItem>
  16. {
  17. //public int Boxes { get; set; }
  18. public bool Picked = true;
  19. public RequisitionItemGrid()
  20. {
  21. HiddenColumns.Add(x => x.Code);
  22. HiddenColumns.Add(x => x.BarCode);
  23. HiddenColumns.Add(x => x.RequisitionLink.ID);
  24. HiddenColumns.Add(x => x.RequisitionLink.JobLink.ID);
  25. HiddenColumns.Add(x => x.RequisitionLink.JobScope.ID);
  26. HiddenColumns.Add(x => x.RequisitionLink.Filled);
  27. HiddenColumns.Add(x => x.RequisitionLink.Archived);
  28. HiddenColumns.Add(x => x.Product.ID);
  29. HiddenColumns.Add(x => x.Product.Deleted);
  30. HiddenColumns.Add(x => x.Product.DefaultStyle.ID);
  31. HiddenColumns.Add(x => x.Product.Dimensions.Unit.ID);
  32. HiddenColumns.Add(x => x.Product.Dimensions.Length);
  33. HiddenColumns.Add(x => x.Product.Dimensions.Width);
  34. HiddenColumns.Add(x => x.Product.Dimensions.Height);
  35. HiddenColumns.Add(x => x.Product.Dimensions.Weight);
  36. HiddenColumns.Add(x => x.Product.Dimensions.UnitSize);
  37. HiddenColumns.Add(x => x.Product.Dimensions.Value);
  38. HiddenColumns.Add(x => x.Product.Dimensions.Unit.HasQuantity);
  39. HiddenColumns.Add(x => x.Product.Dimensions.Unit.HasLength);
  40. HiddenColumns.Add(x => x.Product.Dimensions.Unit.HasWidth);
  41. HiddenColumns.Add(x => x.Product.Dimensions.Unit.HasWeight);
  42. HiddenColumns.Add(x => x.Product.Dimensions.Unit.HasHeight);
  43. HiddenColumns.Add(x => x.Product.Dimensions.Unit.Formula);
  44. HiddenColumns.Add(x => x.Product.Dimensions.Unit.Format);
  45. //HiddenColumns.Add(x => x.Product.Units.ID);
  46. HiddenColumns.Add(x => x.Product.NonStock);
  47. HiddenColumns.Add(x => x.Location.ID);
  48. HiddenColumns.Add(x => x.Location.Code);
  49. HiddenColumns.Add(x => x.Location.Description);
  50. HiddenColumns.Add(x => x.Location.Deleted);
  51. HiddenColumns.Add(x => x.Style.ID);
  52. HiddenColumns.Add(x => x.Style.Code);
  53. HiddenColumns.Add(x => x.Picked);
  54. ActionColumns.Add(new DynamicMenuColumn(SelectHolding,
  55. (row) => (row.Get<RequisitionItem, Guid>(c => c.Product.ID) == Guid.Empty) || row.Get<RequisitionItem, bool>(c => c.Product.NonStock) == true
  56. ? DynamicMenuStatus.Hidden
  57. : DynamicMenuStatus.Enabled)
  58. );
  59. }
  60. protected override void DoReconfigure(FluentList<DynamicGridOption> options)
  61. {
  62. base.DoReconfigure(options);
  63. options.BeginUpdate()
  64. .Add(DynamicGridOption.RecordCount)
  65. .Add(DynamicGridOption.SelectColumns)
  66. .Add(DynamicGridOption.AddRows)
  67. .Add(DynamicGridOption.EditRows)
  68. .Add(DynamicGridOption.DeleteRows)
  69. .Add(DynamicGridOption.FilterRows)
  70. .Add(DynamicGridOption.MultiSelect)
  71. .Add(DynamicGridOption.DragTarget)
  72. .EndUpdate();
  73. }
  74. protected override void DoBeforeSave(IDynamicEditorForm editor, RequisitionItem[] items)
  75. {
  76. base.DoBeforeSave(editor, items);
  77. foreach (var item in items)
  78. item.Picked = Picked ? DateTime.Now : DateTime.MinValue;
  79. }
  80. private bool CanAddItems() =>
  81. Requisition is not null && Requisition.ID != Guid.Empty && Requisition.Filled.IsEmpty() && Security.CanEdit<Requisition>() && Security.CanEdit<RequisitionItem>();
  82. protected override void HandleDragOver(object sender, DragEventArgs e)
  83. {
  84. base.HandleDragOver(sender, e);
  85. if (e.Data.GetDataPresent(typeof(Product)))
  86. {
  87. if (e.Data.GetData(typeof(Product)) is Product product)
  88. {
  89. if (!CanAddItems())
  90. {
  91. e.Effects = DragDropEffects.None;
  92. }
  93. }
  94. }
  95. }
  96. protected override void HandleDragDrop(object sender, DragEventArgs e)
  97. {
  98. base.HandleDragDrop(sender, e);
  99. if (e.Data.GetDataPresent(typeof(Product)))
  100. {
  101. if(e.Data.GetData(typeof(Product)) is Product product)
  102. {
  103. if(CanAddItems())
  104. {
  105. int quantity = 1;
  106. if (NumberEdit.Execute("Enter Quantity:", 1, int.MaxValue, ref quantity))
  107. {
  108. var item = CreateItem();
  109. item.Product.ID = product.ID;
  110. item.Product.Synchronise(product);
  111. item.Quantity = quantity;
  112. item.Picked = Picked ? DateTime.Now : DateTime.MinValue;
  113. SaveItem(item);
  114. Refresh(false, true);
  115. }
  116. }
  117. }
  118. }
  119. }
  120. private void SelectHolding(DynamicMenuColumn column, CoreRow? row)
  121. {
  122. List<Guid> locations = new List<Guid>();
  123. var holdings = new Client<StockHolding>().Query(
  124. new Filter<StockHolding>(x => x.Product.ID).IsEqualTo(row.Get<RequisitionItem, Guid>(c => c.Product.ID)),
  125. new Columns<StockHolding>(x => x.Location.ID)
  126. .Add(x => x.Units));
  127. foreach (var holding in holdings.Rows)
  128. {
  129. var qty = holding.Get<StockHolding, double>(c => c.Units);
  130. if (!CoreUtils.IsEffectivelyEqual(qty, 0.0F) && qty > 0)
  131. locations.Add(holding.Get<StockHolding, Guid>(x => x.Location.ID));
  132. }
  133. if (locations.Count == 0)
  134. {
  135. MessageBox.Show("No valid holdings found for product");
  136. return;
  137. }
  138. var selection = new MultiSelectDialog<StockHolding>
  139. (
  140. new Filter<StockHolding>(x => x.Product.ID).IsEqualTo(row.Get<RequisitionItem, Guid>(c => c.Product.ID))
  141. .And(x => x.Location.ID).InList(locations.ToArray())
  142. ,
  143. new Columns<StockHolding>(
  144. x => x.Job.Name,
  145. x => x.Job.JobNumber,
  146. x => x.Units,
  147. x => x.Dimensions.UnitSize,
  148. x => x.Dimensions.Height,
  149. x => x.Dimensions.Width,
  150. x => x.Dimensions.Weight,
  151. x => x.Dimensions.Quantity,
  152. x => x.Dimensions.Length,
  153. x => x.Dimensions.Unit.ID,
  154. x => x.Dimensions.Unit.Format,
  155. x => x.Dimensions.Unit.Formula,
  156. x => x.Dimensions.Unit.HasHeight,
  157. x => x.Dimensions.Unit.HasWeight,
  158. x => x.Dimensions.Unit.HasWidth,
  159. x => x.Dimensions.Unit.HasQuantity,
  160. x => x.Dimensions.Unit.HasLength,
  161. x => x.Style.ID,
  162. x => x.Style.Code,
  163. x => x.Style.Description,
  164. x => x.Location.ID,
  165. x => x.Location.Code,
  166. x => x.Location.Description,
  167. x => x.Location.Area.Code,
  168. x => x.Location.Area.Description
  169. ), false);
  170. if (selection.ShowDialog("Units", "0", Syncfusion.Data.FilterType.GreaterThan) == true)
  171. SelectLocation(selection.Data().Rows.FirstOrDefault(), row);
  172. }
  173. private void SelectLocation(CoreRow holdingrow, CoreRow itemrow)
  174. {
  175. var item = itemrow.ToObject<RequisitionItem>();
  176. var holding = holdingrow.ToObject<StockHolding>();
  177. item.Location.ID = holding.Location.ID;
  178. item.Location.Code = holding.Location.Code;
  179. item.Dimensions.CopyFrom(holding.Dimensions, true);
  180. item.Style.ID = holding.Style.ID;
  181. item.Style.Code = holding.Style.Code;
  182. new Client<RequisitionItem>().Save(item, "Changed due to stock holding selection");
  183. Data.LoadRow(itemrow, item);
  184. InvalidateRow(itemrow);
  185. }
  186. public Requisition? Requisition { get; set; }
  187. protected override void Reload(Filters<RequisitionItem> criteria, Columns<RequisitionItem> columns, ref SortOrder<RequisitionItem>? sort,
  188. Action<CoreTable?, Exception?> action)
  189. {
  190. criteria.Add(
  191. new Filter<RequisitionItem>(x => x.RequisitionLink.ID).IsEqualTo(Requisition != null ? Requisition.ID : CoreUtils.FullGuid));
  192. if (Picked)
  193. criteria.Add(new Filter<RequisitionItem>(x => x.Picked).IsNotEqualTo(DateTime.MinValue));
  194. else
  195. criteria.Add(new Filter<RequisitionItem>(x => x.Picked).IsEqualTo(DateTime.MinValue));
  196. sort = new SortOrder<RequisitionItem>(x => x.Created);
  197. base.Reload(
  198. criteria,
  199. columns,
  200. ref sort,
  201. (o, e) =>
  202. {
  203. // Update Buttons Here
  204. action.Invoke(o, e);
  205. }
  206. );
  207. }
  208. protected override bool CanDeleteItems(CoreRow[] rows)
  209. {
  210. if (Requisition == null || Requisition.ID.Equals(Guid.Empty))
  211. {
  212. MessageBox.Show("Please select a Requisition first!");
  213. return false;
  214. }
  215. if (!Requisition.Filled.IsEmpty())
  216. {
  217. MessageBox.Show("Cannot Modify a Completed Requisition");
  218. return false;
  219. }
  220. return base.CanDeleteItems(rows);
  221. }
  222. public override bool EditItems(RequisitionItem[] items, Func<Type, CoreTable?>? PageDataHandler, bool PreloadPages = false)
  223. {
  224. if (Requisition == null || Requisition.ID.Equals(Guid.Empty))
  225. {
  226. MessageBox.Show("Please select a Requisition first!");
  227. return false;
  228. }
  229. if (!Requisition.StockUpdated.IsEmpty())
  230. {
  231. MessageBox.Show("Cannot Edit Items after Stock Holdings have been updated!");
  232. return false;
  233. }
  234. return base.EditItems(items, PageDataHandler, PreloadPages);
  235. }
  236. protected override RequisitionItem CreateItem()
  237. {
  238. var item = base.CreateItem();
  239. item.RequisitionLink.ID = Requisition?.ID ?? Guid.Empty;
  240. item.RequisitionLink.Synchronise(Requisition);
  241. item.Quantity = 1;
  242. return item;
  243. }
  244. protected override void DoAdd(bool OpenEditorOnDirectEdit = false)
  245. {
  246. if (Requisition == null || Requisition.ID.Equals(Guid.Empty))
  247. {
  248. MessageBox.Show("Please select a Requisition first!");
  249. return;
  250. }
  251. if (!Requisition.Filled.IsEmpty())
  252. {
  253. MessageBox.Show("Cannot Add Items to a Completed Requisition");
  254. return;
  255. }
  256. base.DoAdd();
  257. }
  258. }
  259. }