123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Windows;
- using System.Windows.Controls;
- using System.Windows.Media;
- using System.Windows.Media.Imaging;
- using Comal.Classes;
- using InABox.Clients;
- using InABox.Core;
- using InABox.DynamicGrid;
- using InABox.WPF;
- using Color = System.Drawing.Color;
- namespace PRSDesktop
- {
- internal class RequisitionGrid : DynamicDataGrid<Requisition>
- {
- //public Dictionary<Object, Object> _Employees = new Dictionary<object, object>();
- //public Dictionary<Object, Object> _Jobs = new Dictionary<object, object>();
- private readonly ComboBox _filter;
- private readonly BitmapImage barcode = PRSDesktop.Resources.barcode.AsBitmapImage();
- private bool bSplitting;
- private readonly BitmapImage docs = PRSDesktop.Resources.doc_png.AsBitmapImage();
- private readonly BitmapImage forklift = PRSDesktop.Resources.forklift.AsBitmapImage(Color.White);
- private readonly BitmapImage printer = PRSDesktop.Resources.printer.AsBitmapImage();
- private readonly BitmapImage tick = PRSDesktop.Resources.tick.AsBitmapImage(Color.White);
- private readonly BitmapImage truck = PRSDesktop.Resources.truck.AsBitmapImage();
- public RequisitionGrid()
- {
- var left = new Border
- {
- Height = 30,
- Width = 30,
- Margin = new Thickness(0, 0, 2, 2),
- BorderBrush = new SolidColorBrush(Colors.Gray),
- BorderThickness = new Thickness(0.75),
- Background = new SolidColorBrush(Colors.WhiteSmoke),
- CornerRadius = new CornerRadius(5, 0, 0, 0)
- };
- left.SetValue(DockPanel.DockProperty, Dock.Left);
- var right = new Border
- {
- Height = 30,
- Width = 30,
- Margin = new Thickness(2, 0, 0, 2),
- BorderBrush = new SolidColorBrush(Colors.Gray),
- BorderThickness = new Thickness(0.75),
- Background = new SolidColorBrush(Colors.WhiteSmoke),
- CornerRadius = new CornerRadius(0, 5, 0, 0)
- };
- right.SetValue(DockPanel.DockProperty, Dock.Right);
- _filter = new ComboBox
- {
- ItemsSource = new List<string>
- {
- "All Requisitions",
- "Unfilled Requisitions",
- "Requisitions needing Delivery",
- "Requisitions to be Archived"
- },
- Margin = new Thickness(0, 0, 0, 2),
- VerticalContentAlignment = VerticalAlignment.Center,
- HorizontalContentAlignment = HorizontalAlignment.Center,
- SelectedIndex = 2,
- Height = 30
- };
- _filter.SetValue(DockPanel.DockProperty, Dock.Left);
- _filter.SelectionChanged += (o, e) => Refresh(false, true);
- var header = new DockPanel();
- header.Children.Add(left);
- header.Children.Add(right);
- header.Children.Add(_filter);
- Header = header;
- Options.BeginUpdate();
- Options.AddRange(DynamicGridOption.SelectColumns, DynamicGridOption.AddRows, DynamicGridOption.EditRows, DynamicGridOption.FilterRows);
- if (Security.IsAllowed<CanDeleteStoresRequisitions>())
- Options.Add(DynamicGridOption.DeleteRows);
- Options.EndUpdate();
- ActionColumns.Add(new DynamicImageColumn(DocumentsImage, DocumentsClick) { Position = DynamicActionColumnPosition.Start });
- ActionColumns.Add(new DynamicImageColumn(FilledImage));
- ActionColumns.Add(new DynamicImageColumn(DeliveryImage));
- ActionColumns.Add(new DynamicImageColumn(StockImage));
- //ActionColumns.Add(new DynamicImageColumn() { Action = LabelClick, Image = GetLabelImage });
- //ActionColumns.Add(new DynamicImageColumn() { Action = DeliveryDocketClick, Image = GetPrinterImage });
- HiddenColumns.Add(x => x.JobLink.ID);
- HiddenColumns.Add(x => x.JobLink.JobNumber);
- HiddenColumns.Add(x => x.JobLink.Name);
- HiddenColumns.Add(x => x.Boxes);
- HiddenColumns.Add(x => x.Filled);
- HiddenColumns.Add(x => x.Title);
- HiddenColumns.Add(x => x.Request);
- HiddenColumns.Add(x => x.Notes);
- HiddenColumns.Add(x => x.Number);
- HiddenColumns.Add(x => x.Employee.ID);
- HiddenColumns.Add(x => x.Employee.Name);
- HiddenColumns.Add(x => x.Due);
- HiddenColumns.Add(x => x.RequestedBy.ID);
- HiddenColumns.Add(x => x.RequestedBy.Name);
- HiddenColumns.Add(x => x.Documents);
- HiddenColumns.Add(x => x.Archived);
- HiddenColumns.Add(x => x.TakenBy.ID);
- HiddenColumns.Add(x => x.TakenBy.Name);
- HiddenColumns.Add(x => x.TakenBy.Deleted);
- HiddenColumns.Add(x => x.Delivery.ID);
- HiddenColumns.Add(x => x.Delivery.Number);
- HiddenColumns.Add(x => x.Delivery.Completed);
- HiddenColumns.Add(x => x.Delivery.Deleted);
- HiddenColumns.Add(x => x.StockUpdated);
- //CoreTable employees = new Client<Employee>().Query(
- // null,
- // new Columns<Employee>(x => x.ID, x => x.Name),
- // new SortOrder<Employee>(x => x.Name)
- //);
- //foreach (CoreRow row in employees.Rows)
- // _Employees[row.Get<Employee, Guid>(x => x.ID)] = row.Get<Employee, String>(x => x.Name);
- //Job[] jobs = new Client<Job>().Load(null, new SortOrder<Job>(x => x.JobNumber));
- //foreach (Job job in jobs)
- //_Jobs[job] = job.ToString();
- AddButton("-", PRSDesktop.Resources.box.AsBitmapImage(Color.White), DelBoxClick);
- AddButton("+", PRSDesktop.Resources.box.AsBitmapImage(Color.White), AddBoxClick);
- AddButton("Split", PRSDesktop.Resources.split.AsBitmapImage(), SplitRequiClick);
- //AddButton("Labels", PRSDesktop.Resources.barcode.AsBitmapImage(System.Drawing.Color.White), LabelClick);
- //AddButton("Del Dkt", PRSDesktop.Resources.printer.AsBitmapImage(System.Drawing.Color.White), DeliveryDocketClick);
- //AddButton("Complete", PRSDesktop.Resources.tick.AsBitmapImage(System.Drawing.Color.White), FilledClick);
- OnCustomiseEditor += CustomiseEditor;
- }
- public CoreTable Requisitions { get; private set; }
- private void CustomiseEditor(IDynamicEditorForm sender, Requisition[]? items, DynamicGridColumn column, BaseEditor editor)
- {
- if (column.ColumnName.Equals("Notes"))
- {
- if (editor is NotesEditor notes)
- notes.AlwaysEnabled = bSplitting;
- }
- else if (column.ColumnName.Equals("Filled"))
- {
- editor.Editable = Security.IsAllowed<CanSkipRequisitionPhotos>() || (items != null && items.Any() && items.First().Documents > 0)
- ? Editable.Enabled
- : Editable.Hidden;
- }
- else if (column.ColumnName.Equals("TakenBy.ID"))
- {
- editor.Editable = items != null && items.Any() && !items.First().Filled.IsEmpty() ? Editable.Enabled : Editable.Disabled;
- }
- }
- protected override Dictionary<string, object?> EditorValueChanged(IDynamicEditorForm editor, Requisition[] items, string name, object value)
- {
- var result = base.EditorValueChanged(editor, items, name, value);
- if (name.Equals("TakenBy.ID") && (value == null || Equals(value, Guid.Empty)))
- editor.FindEditor("Archived").SetValue(DateTime.MinValue);
- return result;
- }
- private bool DocumentsClick(CoreRow? arg)
- {
- if (arg == null)
- return false;
- var docs = new List<IEntityDocument>();
- using (new WaitCursor())
- {
- var deliveryid = arg.Get<Requisition, Guid>(x => x.ID);
- var table = new Client<RequisitionDocument>().Query(
- new Filter<RequisitionDocument>(x => x.EntityLink.ID).IsEqualTo(deliveryid)
- );
- foreach (var row in table.Rows)
- docs.Add(row.ToObject<RequisitionDocument>());
- }
- if (docs.Any())
- {
- var editor = new DocumentEditor(docs.ToArray());
- //editor.PrintAllowed = Security.IsAllowed<CanPrintFactoryFloorDrawings>();
- editor.SaveAllowed = Security.IsAllowed<CanSaveFactoryFloorDrawings>();
- editor.ShowDialog();
- }
- else
- {
- MessageBox.Show("No Documents Available!");
- }
- return false;
- }
- private BitmapImage? DocumentsImage(CoreRow? arg)
- {
- if (arg is null)
- return docs;
- return arg.Get<Requisition, int>(x => x.Documents) > 0 ? docs : null;
- }
- private bool SplitRequiClick(Button sender, CoreRow[] rows)
- {
- if (rows == null || rows.Length != 1)
- {
- MessageBox.Show("Please select a single Requisition to Split!");
- return false;
- }
- var requi = rows.First().ToObject<Requisition>();
- requi.Number = 0;
- requi.ID = Guid.Empty;
- requi.Filled = DateTime.MinValue;
- requi.Notes = new[]
- {
- string.Format("Items unavailable on Requisition #{0}:\n{1}",
- rows.First().Get<Requisition, int>(x => x.Number),
- string.Join("\n\n==============================", requi.Notes)
- )
- };
- requi.CommitChanges();
- bSplitting = true;
- if (EditItems(new[] { requi }))
- {
- bSplitting = false;
- new Client<Requisition>().Save(requi, "Created by Splitting Requi #" + rows.First().Get<Requisition, int>(x => x.Number));
- var newrequi = requi.Number;
- var notes = requi.Notes.First();
- requi = rows.First().ToObject<Requisition>();
- var oldnotes = requi.Notes.ToList();
- oldnotes.Insert(0,
- string.Format("Created secondary Requisition #{0} for further action:\n{1}\n\nOriginal Requisition Notes:\n", newrequi, notes));
- requi.Notes = oldnotes.ToArray();
- new Client<Requisition>().Save(requi, "Split Requisition to #" + newrequi);
- return true;
- }
- bSplitting = false;
- return false;
- }
- private bool AddBoxClick(Button btn, CoreRow[] rows)
- {
- if (rows.Length != 1)
- {
- MessageBox.Show("Please select one row to process!");
- return false;
- }
- var row = rows.First();
- var id = row.Get<Requisition, Guid>(x => x.ID);
- var req = new Client<Requisition>().Load(
- new Filter<Requisition>(x => x.ID).IsEqualTo(id)
- ).FirstOrDefault();
- if (req != null)
- {
- req.Boxes++;
- new Client<Requisition>().Save(req, string.Format("Set Number of Boxes to {0}", req.Boxes));
- //OnRequisitionBoxesChanged?.Invoke(req.ID, req.Boxes);
- return true;
- }
- MessageBox.Show("Cannot locate Requisition");
- return true;
- }
- private bool DelBoxClick(Button btn, CoreRow[] rows)
- {
- if (rows.Length != 1)
- {
- MessageBox.Show("Please select one row to process!");
- return false;
- }
- var row = rows.First();
- var id = row.Get<Requisition, Guid>(x => x.ID);
- var req = new Client<Requisition>().Load(
- new Filter<Requisition>(x => x.ID).IsEqualTo(id)
- ).FirstOrDefault();
- if (req != null)
- {
- if (req.Boxes > 0)
- {
- req.Boxes--;
- new Client<Requisition>().Save(req, string.Format("Set Number of Boxes to {0}", req.Boxes));
- //OnRequisitionBoxesChanged?.Invoke(req.ID, req.Boxes);
- }
- return true;
- }
- MessageBox.Show("Cannot Locate Requisition!");
- return true;
- }
- protected override Requisition CreateItem()
- {
- var requi = base.CreateItem();
- var role = new Client<Role>().Load(new Filter<Role>(x => x.Code).IsEqualTo("STORES")).FirstOrDefault();
- if (role != null)
- {
- var emprole = new Client<EmployeeRole>().Load(new Filter<EmployeeRole>(x => x.RoleLink.ID).IsEqualTo(role.ID)).FirstOrDefault();
- if (emprole != null)
- requi.Employee.ID = emprole.EmployeeLink.ID;
- }
- return requi;
- }
- private BitmapImage? GetBitmapImage(CoreRow? row, BitmapImage image)
- {
- if (row == null)
- return image;
- var filled = row.Get<Requisition, DateTime>(x => x.Filled);
- return filled.IsEmpty() ? null : image;
- }
- private BitmapImage? GetLabelImage(CoreRow row)
- {
- return GetBitmapImage(row, barcode);
- }
- private BitmapImage? GetPrinterImage(CoreRow row)
- {
- return GetBitmapImage(row, printer);
- }
- private BitmapImage? FilledImage(CoreRow? row)
- {
- if (row == null)
- return tick;
- var filled = row.Get<Requisition, DateTime>(x => x.Filled);
- return filled.IsEmpty() ? null : tick;
- }
- private BitmapImage? StockImage(CoreRow? row)
- {
- if (row == null)
- return forklift;
- var stockupdated = row.Get<Requisition, DateTime>(x => x.StockUpdated);
- return stockupdated.IsEmpty() ? null : forklift;
- }
- private BitmapImage? DeliveryImage(CoreRow? row)
- {
- if (row == null)
- return truck;
- var archived = row.Get<Requisition, DateTime>(x => x.Archived);
- return archived.IsEmpty() ? null : truck;
- }
- private void SendNotifications(CoreRow row)
- {
- var updates = new List<Notification>();
- var roles = new Client<EmployeeRole>().Query(new Filter<EmployeeRole>(x => x.RoleLink.Code).IsEqualTo("DELIVERIES"));
- foreach (var role in roles.Rows)
- {
- var notification = new Notification
- {
- Title = string.Format("Requi #{0} is ready", row.Get<Requisition, int>(x => x.Number)),
- Description = "The requisition has been packed and labelled, and is ready to be assigned to a Delivery"
- };
- notification.Sender.ID = row.Get<Requisition, Guid>(x => x.Employee.ID);
- notification.Employee.ID = role.Get<EmployeeRole, Guid>(x => x.EmployeeLink.ID);
- notification.Job.ID = row.Get<Requisition, Guid>(x => x.JobLink.ID);
- updates.Add(notification);
- }
- new Client<Notification>().Save(updates, "Sent Notification");
- }
- protected override void Reload(Filters<Requisition> criteria, Columns<Requisition> columns, ref SortOrder<Requisition>? sort,
- Action<CoreTable?, Exception?> action)
- {
- // Unfilled
- if (_filter.SelectedIndex == 1)
- criteria.Add(new Filter<Requisition>(x => x.Filled).IsEqualTo(DateTime.MinValue));
- // Undelivered
- else if (_filter.SelectedIndex == 2)
- criteria.Add(new Filter<Requisition>(x => x.Archived).IsEqualTo(DateTime.MinValue).Or(x => x.Filled).IsEqualTo(DateTime.MinValue));
- // Unarchived
- else if (_filter.SelectedIndex == 3)
- criteria.Add(new Filter<Requisition>(x => x.StockUpdated).IsEqualTo(DateTime.MinValue).Or(x => x.Archived)
- .IsEqualTo(DateTime.MinValue)
- .Or(x => x.Filled).IsEqualTo(DateTime.MinValue));
- sort = new SortOrder<Requisition>(x => x.Number, SortDirection.Descending);
- base.Reload(criteria, columns, ref sort, action);
- }
- }
- }
|