| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 | 
							- using System;
 
- using System.Collections.Generic;
 
- using System.Linq;
 
- using System.Reactive.Linq;
 
- using System.Windows;
 
- using System.Windows.Controls;
 
- using Comal.Classes;
 
- using InABox.Clients;
 
- using InABox.Core;
 
- using InABox.DynamicGrid;
 
- using InABox.Wpf;
 
- using InABox.WPF;
 
- namespace PRSDesktop;
 
- internal class JobRequisitionItemGrid : DynamicDataGrid<JobRequisitionItem>
 
- {
 
-     private Button CancelItemsButton;
 
-     public JobRequisitionItemGrid()
 
-     {
 
-         CancelItemsButton = AddButton("Cancel Items", PRSDesktop.Resources.disabled.AsBitmapImage(), CancelItems);
 
-         CancelItemsButton.Visibility = Security.CanEdit<JobRequisition>() && Security.CanEdit<JobRequisitionItem>()
 
-             ? System.Windows.Visibility.Visible
 
-             : System.Windows.Visibility.Hidden;
 
-     }
 
-     protected override void SelectItems(CoreRow[]? rows)
 
-     {
 
-         base.SelectItems(rows);
 
-         CancelItemsButton.IsEnabled = rows is not null && rows.Length > 0;
 
-     }
 
-     private bool CancelItems(Button button, CoreRow[] rows)
 
-     {
 
-         if(rows.Length == 0)
 
-         {
 
-             MessageWindow.ShowMessage("Please select at least one item to cancel.", "Select items");
 
-             return false;
 
-         }
 
-         // Reloading so I can ensure the correct columns without having to add hidden columns to JobRequisitionGrid.
 
-         var oldRequi = Client.Query(
 
-             new Filter<JobRequisition>(x => x.ID).IsEqualTo(Requisition.ID),
 
-             new Columns<JobRequisition>(x => x.Description)
 
- 					.Add(x => x.Number)
 
-                 .Add(x => x.DueDate))
 
-             .ToObjects<JobRequisition>()
 
-             .First();
 
-         var oldRequiItems = Client.Query(
 
-             new Filter<JobRequisitionItem>(x => x.ID).InList(rows.Select(x => x.Get<JobRequisitionItem, Guid>(x => x.ID)).ToArray()),
 
-             new Columns<JobRequisitionItem>(x => x.Qty)
 
-                 .Add(x => x.Sequence)
 
-                 .Add(x => x.Job.ID)
 
-                 .Add(x => x.Product.ID)
 
-                 .Add(x => x.Product.Code)
 
-                 .Add(x => x.Style.ID)
 
-                 .Add(x => x.Style.Code)
 
-                 .Add(x => x.Style.Description)
 
-                 .Add(x => x.Dimensions.Unit.ID)
 
-                 .Add(x => x.Dimensions.Quantity)
 
-                 .Add(x => x.Dimensions.Length)
 
-                 .Add(x => x.Dimensions.Width)
 
-                 .Add(x => x.Dimensions.Height)
 
-                 .Add(x => x.Dimensions.Weight)
 
-                 .Add(x => x.Dimensions.UnitSize)
 
-                 .Add(x => x.Supplier.ID));
 
-         var requisition = new JobRequisition
 
-         {
 
-             Description = $"Adjustment Requisition for Requisition {oldRequi.Number}",
 
-             DueDate = oldRequi.DueDate
 
-         };
 
-         requisition.Job.ID = Requisition.Job.ID;
 
-         requisition.Job.Synchronise(Requisition.Job);
 
-         var requiItems = new List<JobRequisitionItem>();
 
-         foreach(var oldItem in oldRequiItems.ToObjects<JobRequisitionItem>())
 
-         {
 
-             var newItem = new JobRequisitionItem
 
-             {
 
-                 Notes = "Adjustment Requisition item",
 
-                 Qty = -oldItem.Qty,
 
-                 Sequence = oldItem.Sequence
 
-             };
 
-             newItem.Job.ID = requisition.Job.ID;
 
-             newItem.Job.Synchronise(requisition.Job);
 
-             newItem.Product.ID = oldItem.Product.ID;
 
-             newItem.Product.Synchronise(oldItem.Product);
 
-             newItem.Style.ID = oldItem.Style.ID;
 
-             newItem.Style.Synchronise(oldItem.Style);
 
-             newItem.Dimensions.CopyFrom(oldItem.Dimensions);
 
-             newItem.Supplier.ID = oldItem.Supplier.ID;
 
-             newItem.Supplier.Synchronise(oldItem.Supplier);
 
-             requiItems.Add(newItem);
 
-         }
 
-         var grid = DynamicGridUtils.CreateDynamicGrid(typeof(DynamicGrid<>), typeof(JobRequisition));
 
-         if (grid.EditItems(new JobRequisition[] { requisition }, t =>
 
-         {
 
-             if (t == typeof(JobRequisitionItem))
 
-             {
 
-                 var table = new CoreTable();
 
-                 table.LoadColumns(typeof(JobRequisitionItem));
 
-                 table.LoadRows(requiItems);
 
-                 return table;
 
-             }
 
-             return null;
 
-         }))
 
-         {
 
-             MessageWindow.ShowMessage($"Created requisition {requisition.Number}", "Created Requisition");
 
-             return true;
 
-         }
 
-         else
 
-         {
 
-             return false;
 
-         }
 
-     }
 
-     protected override void DoReconfigure(FluentList<DynamicGridOption> options)
 
-     {
 
-         base.DoReconfigure(options);
 
-         options.AddRange(
 
-             DynamicGridOption.RecordCount,
 
-             DynamicGridOption.SelectColumns,
 
-             DynamicGridOption.FilterRows,
 
-             DynamicGridOption.MultiSelect
 
-             );
 
-     }
 
-     
 
-     public JobRequisition Requisition { get; set; }
 
-     protected override void Reload(Filters<JobRequisitionItem> criteria, Columns<JobRequisitionItem> columns,
 
-         ref SortOrder<JobRequisitionItem>? sort,
 
-         Action<CoreTable?, Exception?> action)
 
-     {
 
-         if(Requisition.ID == Guid.Empty)
 
-         {
 
-             criteria.Add(new Filter<JobRequisitionItem>().None());
 
-         }
 
-         else
 
-         {
 
-             criteria.Add(new Filter<JobRequisitionItem>(x => x.Requisition.ID).IsEqualTo(Requisition.ID));
 
-         }
 
-         base.Reload(criteria, columns, ref sort, action);
 
-     }
 
-     protected override bool CanCreateItems()
 
-     {
 
-         return Requisition.ID != Guid.Empty && base.CanCreateItems();
 
-     }
 
-     protected override JobRequisitionItem CreateItem()
 
-     {
 
-         var result = base.CreateItem();
 
-         result.Requisition.ID = Requisition.ID;
 
-         result.Requisition.Synchronise(Requisition);
 
-         result.Job.ID = Requisition.Job.ID;
 
-         result.Job.Synchronise(Requisition.Job);
 
-         result.Qty = 1;
 
-         return result;
 
-     }
 
-     
 
-     protected override void OnAfterEditorValueChanged(DynamicEditorGrid? grid, JobRequisitionItem[] items, AfterEditorValueChangedArgs args, Dictionary<string, object?> changes)
 
-     {
 
-         base.OnAfterEditorValueChanged(grid, items, args, changes);
 
-         if (args.ColumnName.Equals("Product.ID") || args.ColumnName.Equals("Dimensions") || args.ColumnName.StartsWith("Dimensions.") || args.ColumnName.Equals("Style.ID") || args.ColumnName.Equals("Supplier.ID"))
 
-         {
 
-             JobRequisitionItem.UpdateCosts(
 
-                 items, 
 
-                 changes
 
-             );
 
-         }
 
-     }
 
-     public override DynamicGridColumns GenerateColumns()
 
-     {
 
-         var columns = new DynamicGridColumns();
 
-         columns.Add<JobRequisitionItem, DateTime>(x => x.Created, 80, "Date", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, string>(x => x.Requisition.Job.JobNumber, 70, "Job", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, int>(x => x.Requisition.Number, 50, "NO.", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, string>(x => x.Product.Code, 70, "Code", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, string>(x => x.Product.Name, 200, "Product Name", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, string>(x => x.Style.Description, 150, "Style", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, double>(x => x.Qty, 50, "Qty", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, string>(x => x.Dimensions.UnitSize, 50, "Size", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, string>(x => x.PurchaseOrderNumbers, 80, "PO Numbers", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, JobRequisitionItemStatus>(x => x.Status, 80, "Status", "", Alignment.MiddleLeft);
 
-         columns.Add<JobRequisitionItem, string>(x => x.Notes, 300, "Notes", "", Alignment.MiddleLeft);
 
-         columns.AddRange(base.GenerateColumns());
 
-         return columns;
 
-     }
 
- }
 
 
  |