FactoryPanel.xaml.cs 115 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Collections.ObjectModel;
  4. using System.Drawing;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using System.Windows;
  9. using System.Windows.Controls;
  10. using System.Windows.Controls.Primitives;
  11. using System.Windows.Input;
  12. using System.Windows.Media;
  13. using System.Windows.Media.Imaging;
  14. using Comal.Classes;
  15. using InABox.Clients;
  16. using InABox.Configuration;
  17. using InABox.Core;
  18. using InABox.DynamicGrid;
  19. using InABox.Reports;
  20. using InABox.Reports.Common;
  21. using InABox.WPF;
  22. using Motorola.Snapi;
  23. using Motorola.Snapi.Constants.Enums;
  24. using Motorola.Snapi.EventArguments;
  25. using org.apache.commons.io.comparator;
  26. using BarcodeType = Comal.Classes.BarcodeType;
  27. using Color = System.Drawing.Color;
  28. using Image = System.Windows.Controls.Image;
  29. namespace PRSDesktop
  30. {
  31. /// <summary>
  32. /// Interaction logic for FactoryPanel.xaml
  33. /// </summary>
  34. public partial class FactoryPanel : UserControl, IPanel<ManufacturingPacket>
  35. {
  36. private Button _currentButton;
  37. private readonly BitmapImage barcode = PRSDesktop.Resources.barcode.AsBitmapImage();
  38. private readonly BitmapImage disabled = PRSDesktop.Resources.disabled.AsBitmapImage();
  39. //private Document document = null;
  40. private SetoutDocument[] documents = { };
  41. private readonly BitmapImage grouped = PRSDesktop.Resources.grouped.AsBitmapImage();
  42. private readonly string NEARLYDUE_COLOR = "Orange";
  43. private readonly string NOTYETDUE_COLOR = "PaleGreen";
  44. private readonly string OVERDUE_COLOR = "Salmon";
  45. private PDFEditorControl PDFEditor;
  46. private readonly string PRIORITY_COLOR = "Red";
  47. private readonly string QA_COLOR = "Silver";
  48. private QAGrid QAGrid;
  49. public List<IMotorolaBarcodeScanner> Scanners = new();
  50. private readonly string SELECTED_COLOR = "Yellow";
  51. private FactoryFloorLocalSettings settings;
  52. private readonly string SHARED_COLOR = "Lime";
  53. private readonly BitmapImage speechbubble = PRSDesktop.Resources.speechbubble.AsBitmapImage();
  54. private readonly BitmapImage starred = PRSDesktop.Resources.report.AsBitmapImage(48, 48);
  55. private readonly string TREATED_COLOR = "DarkOrchid";
  56. public FactoryPanel()
  57. {
  58. InitializeComponent();
  59. var CanConfigure = Security.IsAllowed<CanConfigureFactoryFloor>();
  60. Section.IsEnabled = CanConfigure;
  61. Station.IsEnabled = CanConfigure;
  62. PendingVisible = Security.IsAllowed<CanManagePendingPackets>();
  63. Kanbans = new ObservableCollection<ManufacturingKanban>();
  64. RackContents.ItemsSource = rackcontents;
  65. }
  66. public bool IsReady { get; set; }
  67. public void Setup()
  68. {
  69. settings = new LocalConfiguration<FactoryFloorLocalSettings>().Load();
  70. if (settings.Section.Equals(CoreUtils.FullGuid) && settings.Station.Equals(-1))
  71. {
  72. var user = new UserConfiguration<FactoryFloorSettings>().Load();
  73. settings.Section = user.Section;
  74. settings.Station = user.Station;
  75. settings.LineColor = ColorTranslator.ToHtml(Color.Red);
  76. settings.FontSize = 16;
  77. new LocalConfiguration<FactoryFloorLocalSettings>().Save(settings);
  78. }
  79. var setups = Client.QueryMultiple(
  80. new KeyedQueryDef<ManufacturingFactory>(),
  81. new KeyedQueryDef<ManufacturingSection>(
  82. new Filter<ManufacturingSection>(x => x.Hidden).IsEqualTo(false),
  83. null,
  84. new SortOrder<ManufacturingSection>(x => x.Factory.Sequence).ThenBy(x => x.Sequence)),
  85. new KeyedQueryDef<ManufacturingTrolley>(),
  86. new KeyedQueryDef<Employee>(
  87. LookupFactory.DefineFilter<Employee>(),
  88. new Columns<Employee>(x => x.ID, x => x.Name, x => x.UserLink.ID),
  89. new SortOrder<Employee>(x => x.Name)),
  90. new KeyedQueryDef<Shipment>(
  91. LookupFactory.DefineFilter<Shipment>(),
  92. new Columns<Shipment>(x => x.ID, x => x.Code, x => x.Description, x => x.BarCode),
  93. null));
  94. Factories = setups[nameof(ManufacturingFactory)].Rows.Select(x => x.ToObject<ManufacturingFactory>()).ToArray();
  95. Sections = setups[nameof(ManufacturingSection)].Rows.Select(x => x.ToObject<ManufacturingSection>()).ToArray();
  96. Trolleys = setups[nameof(ManufacturingTrolley)].Rows.Select(x => x.ToObject<ManufacturingTrolley>()).ToArray();
  97. Employees = setups[nameof(Employee)].ToDictionary<Employee, Guid, string>(x => x.ID, x => x.Name);
  98. var myRow = setups[nameof(Employee)].Rows.FirstOrDefault(r => r.Get<Employee, Guid>(c => c.UserLink.ID).Equals(ClientFactory.UserGuid));
  99. myID = myRow != null ? myRow.Get<Employee, Guid>(c => c.ID) : Guid.Empty;
  100. myName = myRow != null ? myRow.Get<Employee, string>(c => c.Name) : "(Unknown Employee)";
  101. Shipments = setups[nameof(Shipment)];
  102. CurrentSection = Sections.FirstOrDefault(x => x.ID.Equals(settings.Section));
  103. if (CurrentSection == null)
  104. CurrentSection = Sections.FirstOrDefault();
  105. var iSection = 0;
  106. var iCount = 0;
  107. foreach (var section in Sections)
  108. {
  109. if (section == CurrentSection)
  110. {
  111. iSection = Section.Items.Count;
  112. iCount = section.Stations; //Sections[id].Item2;
  113. }
  114. Section.Items.Add(string.Format("{0}: {1}", section.Factory.Name, section.Name));
  115. }
  116. Section.SelectedIndex = iSection;
  117. Station.Items.Clear();
  118. for (var i = 1; i <= (CurrentSection != null ? CurrentSection.Stations : 0); i++)
  119. Station.Items.Add(string.Format("Station #{0}", i));
  120. CurrentStation = settings.Station + 1;
  121. if (CurrentStation < 1)
  122. CurrentStation = 1;
  123. if (CurrentStation > iCount)
  124. CurrentStation = iCount;
  125. Station.SelectedIndex = CurrentStation - 1;
  126. SetupScanner();
  127. }
  128. public void Shutdown()
  129. {
  130. ShutdownScanner();
  131. //UpdateTimeTracking(true);
  132. LoadDrawing(null);
  133. }
  134. public void CreateToolbarButtons(IPanelHost host)
  135. {
  136. //if (Security.IsAllowed<CanViewManufacturingSelfAssessment>())
  137. // host.CreatePanelAction(new PanelAction() { Caption = "Self Assessment", Image = PRSDesktop.Resources.star, OnExecute = DoSelfAssessment });
  138. host.CreatePanelAction(new PanelAction { Caption = "Lost Time", Image = PRSDesktop.Resources.smiley, OnExecute = DoSelectLostTime });
  139. host.CreatePanelAction(new PanelAction
  140. { Caption = "Treament PO", Image = PRSDesktop.Resources.purchase, OnExecute = DoCreatePurchaseOrder });
  141. host.CreatePanelAction(new PanelAction
  142. { Caption = "Treatment Delivery", Image = PRSDesktop.Resources.barcode, OnExecute = DoScanDeliveryItems });
  143. host.CreatePanelAction(new PanelAction { Caption = "Select Rack", Image = PRSDesktop.Resources.forklift, OnExecute = DoSelectRack });
  144. host.CreatePanelAction(new PanelAction { Caption = "Close Rack", Image = PRSDesktop.Resources.forklift, OnExecute = DoCloseRack });
  145. host.CreatePanelAction(new PanelAction { Caption = "Scan Barcode", Image = PRSDesktop.Resources.product, OnExecute = DoScanBarcode });
  146. }
  147. public Dictionary<string, object[]> Selected()
  148. {
  149. var rows = Packets.Rows.Where(p => Kanbans.Any(k => k.Checked && p.Get<ManufacturingPacket, Guid>(c => c.ID).ToString().Equals(k.ID)));
  150. var pkts = rows.ToArray().Select(r => r.ToObject<ManufacturingPacket>());
  151. return new Dictionary<string, object[]> { { typeof(ManufacturingPacket).EntityName(), pkts.ToArray() } };
  152. }
  153. public string SectionName => "Factory";
  154. public DataModel DataModel(Selection selection)
  155. {
  156. var rows = selection == Selection.None
  157. ? new CoreRow[] { }
  158. : selection == Selection.Selected
  159. ? Packets.Rows.Where(p => Kanbans.Any(k => k.Checked && p.Get<ManufacturingPacket, Guid>(c => c.ID).ToString().Equals(k.ID)))
  160. : Packets.Rows;
  161. var ids = rows.Any() ? rows.Select(r => r.Get<ManufacturingPacket, Guid>(x => x.ID)).ToArray() : new[] { CoreUtils.FullGuid };
  162. return new ManufacturingPacketDataModel(new Filter<ManufacturingPacket>(x => x.ID).InList(ids));
  163. }
  164. public event DataModelUpdateEvent OnUpdateDataModel;
  165. public void Heartbeat(TimeSpan time)
  166. {
  167. // Security Descriptor should be disabled for non-manufacturing staff
  168. if (!Security.IsAllowed<CanTrackManufacturingHistory>() || CurrentSection == null)
  169. return;
  170. // If Lost Time is Active, let's record that
  171. if (LostTime != null)
  172. {
  173. var history = new ManufacturingHistory();
  174. history.Date = DateTime.Today;
  175. history.Employee.ID = myID;
  176. history.Packet.ID = Guid.Empty;
  177. history.LostTime.ID = LostTime.ID;
  178. history.Description = LostTime.Description;
  179. //history.Setout.ID = CheckedPackets[id].Item3;
  180. //history.Job.ID = CheckedPackets[id].Item4;
  181. history.Section.ID = CurrentSection.ID;
  182. history.Station = CurrentStation;
  183. history.Activity.ID = LostTime.Activity.ID;
  184. history.WorkDuration = new TimeSpan(time.Ticks);
  185. history.QACompleted = 0;
  186. history.WorkCompleted = 0;
  187. history.Window = time;
  188. new Client<ManufacturingHistory>().Save(history, "", (o, e) => { });
  189. }
  190. else
  191. {
  192. var CheckedPackets = new Dictionary<Guid, Tuple<DateTime, DateTime, Guid, Guid, string>>();
  193. foreach (var kanban in Kanbans.Where(x => x.Checked))
  194. {
  195. var packet = KanbanToPacket(kanban);
  196. if (packet != null)
  197. {
  198. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(packet.ID)
  199. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  200. .Equals(settings.Section));
  201. if (stagerow != null)
  202. {
  203. var stage = stagerow.ToObject<ManufacturingPacketStage>();
  204. if (stage.Station != 0)
  205. CheckedPackets[packet.ID] = new Tuple<DateTime, DateTime, Guid, Guid, string>(stage.Started, stage.Completed,
  206. packet.SetoutLink.ID, packet.SetoutLink.JobLink.ID, packet.Serial);
  207. }
  208. }
  209. }
  210. if (!CheckedPackets.Any())
  211. CheckedPackets[Guid.Empty] =
  212. new Tuple<DateTime, DateTime, Guid, Guid, string>(DateTime.MinValue, DateTime.MinValue, Guid.Empty, Guid.Empty, "No Packet");
  213. var updates = new List<ManufacturingHistory>();
  214. var slice = time.Ticks / CheckedPackets.Count;
  215. foreach (var id in CheckedPackets.Keys)
  216. {
  217. var history = new ManufacturingHistory();
  218. history.Date = DateTime.Today;
  219. history.Employee.ID = myID;
  220. history.Packet.ID = id;
  221. history.Description = CheckedPackets[id].Item5;
  222. //history.Setout.ID = CheckedPackets[id].Item3;
  223. //history.Job.ID = CheckedPackets[id].Item4;
  224. history.Section.ID = CurrentSection.ID;
  225. history.Activity.ID = CurrentSection.Activity.ID;
  226. history.Station = CurrentStation;
  227. if (CheckedPackets[id].Item1.Equals(DateTime.MinValue))
  228. history.QADuration = new TimeSpan(slice);
  229. else
  230. history.WorkDuration = new TimeSpan(slice);
  231. history.QACompleted = CheckedPackets[id].Item1.Equals(DateTime.MinValue) ? 0 : 0;
  232. history.WorkCompleted = CheckedPackets[id].Item2.Equals(DateTime.MinValue) ? 0 : 1;
  233. history.Window = time;
  234. updates.Add(history);
  235. }
  236. if (updates.Any())
  237. new Client<ManufacturingHistory>().Save(updates, "", (o, e) => { });
  238. }
  239. }
  240. public static IEnumerable<T> FindVisualChildren<T>(DependencyObject depObj) where T : DependencyObject
  241. {
  242. if (depObj != null)
  243. for (var i = 0; i < VisualTreeHelper.GetChildrenCount(depObj); i++)
  244. {
  245. var child = VisualTreeHelper.GetChild(depObj, i);
  246. if (child != null && child is T) yield return (T)child;
  247. foreach (var childOfChild in FindVisualChildren<T>(child)) yield return childOfChild;
  248. }
  249. }
  250. private void ShutdownScanner()
  251. {
  252. try
  253. {
  254. foreach (var scanner in Scanners) scanner.Actions.ToggleLed(LedMode.GreenOff);
  255. BarcodeScannerManager.Instance.DataReceived -= Instance_DataReceived;
  256. BarcodeScannerManager.Instance.Close();
  257. }
  258. catch (Exception e)
  259. {
  260. MessageBox.Show("Error Shutting down Scanner!\n\n" + e.Message);
  261. }
  262. }
  263. private void SetupScanner()
  264. {
  265. Scanners.Clear();
  266. BarcodeScannerManager.Instance.Open();
  267. BarcodeScannerManager.Instance.RegisterForEvents(EventType.Barcode, EventType.Pnp, EventType.Image, EventType.Other, EventType.Rmd);
  268. BarcodeScannerManager.Instance.GetDevices();
  269. foreach (var scanner in BarcodeScannerManager.Instance.GetDevices())
  270. {
  271. Scanners.Add(scanner);
  272. scanner.Actions.ToggleLed(LedMode.RedOn);
  273. scanner.Actions.SoundBeeper(BeepPattern.FastWarble);
  274. }
  275. BarcodeScannerManager.Instance.DataReceived += Instance_DataReceived;
  276. }
  277. private void Instance_DataReceived(object sender, BarcodeScanEventArgs e)
  278. {
  279. Dispatcher.Invoke(() => { ProcessCode(Scanners[(int)e.ScannerId], e.Data); });
  280. }
  281. private void ProcessCode(IMotorolaBarcodeScanner scanner, string code)
  282. {
  283. try
  284. {
  285. var isGuid = Guid.TryParse(code, out var guid);
  286. if (isGuid)
  287. {
  288. if (Sections.Any(x => x.ID.Equals(guid)))
  289. {
  290. IsReady = false;
  291. CurrentSection = Sections.First(x => x.ID.Equals(guid));
  292. Section.SelectedIndex = Array.IndexOf(Sections, CurrentSection);
  293. IsReady = true;
  294. Progress.Show("Changing Sections");
  295. DoRefresh(true);
  296. Progress.Close();
  297. if (scanner != null)
  298. scanner.Actions.SoundBeeper(BeepPattern.FastWarble);
  299. }
  300. else if (Trolleys.Any(x => x.ID.Equals(guid)))
  301. {
  302. var trolley = Trolleys.First().Code;
  303. var updates = new List<ManufacturingPacket>();
  304. foreach (var kanban in Kanbans.Where(x => x.Checked))
  305. {
  306. var packet = KanbanToPacket(kanban);
  307. packet.Trolleys = trolley;
  308. updates.Add(packet);
  309. var pktrow = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(Guid.Parse(kanban.ID)));
  310. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(packet.ID)
  311. && r.Get<ManufacturingPacketStage, Guid>(
  312. c => c.ManufacturingSectionLink.ID)
  313. .Equals(settings.Section));
  314. pktrow.Set<ManufacturingPacket, string>(x => x.Trolleys, packet.Trolleys);
  315. LoadModel(kanban, pktrow, stagerow, true);
  316. UpdateSelectedKanban(false);
  317. }
  318. if (updates.Any())
  319. new Client<ManufacturingPacket>().Save(updates, "Set Trolley to " + trolley, (o, e) => { });
  320. if (scanner != null)
  321. scanner.Actions.SoundBeeper(BeepPattern.LowHigh);
  322. }
  323. else
  324. {
  325. if (scanner != null)
  326. scanner.Actions.SoundBeeper(BeepPattern.FourLowShort);
  327. }
  328. }
  329. else
  330. {
  331. var shiprow = Shipments.Rows.FirstOrDefault(r => r.Get<Shipment, string>(c => c.BarCode).Equals(code));
  332. if (shiprow != null)
  333. {
  334. if (string.Equals(code, rackbarcode))
  335. {
  336. RackPanel.Visibility = Visibility.Collapsed;
  337. RackContents.ItemsSource = null;
  338. rackid = Guid.Empty;
  339. rackbarcode = "";
  340. if (scanner != null)
  341. scanner.Actions.SoundBeeper(BeepPattern.ThreeLowShort);
  342. }
  343. else
  344. {
  345. RackContents.ItemsSource = null;
  346. rackid = shiprow.Get<Shipment, Guid>(c => c.ID);
  347. rackbarcode = code;
  348. var rows = DeliveryItems.Rows.Where(r => r.Get<DeliveryItem, Guid>(c => c.ShipmentLink.ID).Equals(rackid)).ToArray();
  349. rackcontents.Clear();
  350. rackcontents.AddRange(rows.Select(x => x.ToObject<DeliveryItem>()));
  351. RackContents.ItemsSource = rackcontents;
  352. RackName.Content = string.Format("Rack {0}", shiprow.Get<Shipment, string>(c => c.Code));
  353. RackCount.Content = rows.Length.ToString();
  354. RackPanel.Visibility = Visibility.Visible;
  355. if (scanner != null)
  356. scanner.Actions.SoundBeeper(BeepPattern.ThreeHighShort);
  357. }
  358. }
  359. else
  360. {
  361. if (RackPanel.Visibility == Visibility.Visible)
  362. {
  363. var row = DeliveryItems.Rows.FirstOrDefault(r => r.Get<DeliveryItem, string>(c => c.Barcode).Equals(code));
  364. if (row != null)
  365. {
  366. var delitem = rackcontents.FirstOrDefault(x => string.Equals(x.Barcode, code));
  367. if (delitem != null)
  368. {
  369. rackcontents.Remove(delitem);
  370. delitem.ShipmentLink.ID = Guid.Empty;
  371. new Client<DeliveryItem>().Save(delitem, "Item Removed From Rack", (o, e) => { });
  372. row.Set<DeliveryItem, Guid>(x => x.ShipmentLink.ID, Guid.Empty);
  373. if (scanner != null)
  374. scanner.Actions.SoundBeeper(BeepPattern.HighLow);
  375. }
  376. else
  377. {
  378. delitem = row.ToObject<DeliveryItem>();
  379. delitem.ShipmentLink.ID = rackid;
  380. rackcontents.Add(delitem);
  381. new Client<DeliveryItem>().Save(delitem, "Item Added to " + RackName.Content, (o, e) => { });
  382. row.Set<DeliveryItem, Guid>(x => x.ShipmentLink.ID, rackid);
  383. if (Kanbans.Any(x => string.Equals(x.ID, delitem.ManufacturingPacketLink.ID.ToString())))
  384. ReloadPackets(true);
  385. if (scanner != null)
  386. scanner.Actions.SoundBeeper(BeepPattern.LowHigh);
  387. }
  388. RackContents.ItemsSource = null;
  389. RackContents.ItemsSource = rackcontents;
  390. RackCount.Content = rackcontents.Count.ToString();
  391. }
  392. }
  393. else
  394. {
  395. var id = new Client<DeliveryItem>().Query(
  396. new Filter<DeliveryItem>(x => x.Barcode).IsEqualTo(code),
  397. new Columns<DeliveryItem>(x => x.ManufacturingPacketLink.ID)
  398. ).Rows.FirstOrDefault()?.Get<DeliveryItem, Guid>(x => x.ManufacturingPacketLink.ID);
  399. if (!id.HasValue)
  400. {
  401. if (scanner != null)
  402. scanner.Actions.SoundBeeper(BeepPattern.FourLowShort);
  403. return;
  404. }
  405. var kanban = Kanbans.FirstOrDefault(x => string.Equals(x.ID, id.Value.ToString()));
  406. if (kanban == null)
  407. {
  408. // Error - packet not visible from this station
  409. if (scanner != null)
  410. scanner.Actions.SoundBeeper(BeepPattern.FourLowShort);
  411. return;
  412. }
  413. var stage = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(id)
  414. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  415. .Equals(settings.Section))?.ToObject<ManufacturingPacketStage>();
  416. if (stage == null)
  417. if (scanner != null)
  418. scanner.Actions.SoundBeeper(BeepPattern.FourHighShort);
  419. if (stage.Station == 0) AddPacketToCurrentWorkload(stage);
  420. if (kanban != CurrentKanban)
  421. {
  422. CurrentKanban = kanban;
  423. UpdateSelectedKanban(false);
  424. }
  425. if (scanner != null)
  426. scanner.Actions.SoundBeeper(BeepPattern.LowHigh);
  427. }
  428. }
  429. }
  430. }
  431. catch (Exception e)
  432. {
  433. if (scanner != null)
  434. scanner.Actions.SoundBeeper(BeepPattern.FourLowShort);
  435. }
  436. }
  437. private void LoadDrawing(Guid? id)
  438. {
  439. if (PDFEditor != null)
  440. {
  441. PDFEditor.Document = null;
  442. // Unload PDF Annotations
  443. PDFEditor = null;
  444. }
  445. else if (QAGrid != null)
  446. {
  447. Editor.Content = null;
  448. // Unload QA Answers
  449. QAGrid = null;
  450. }
  451. if (id.HasValue)
  452. {
  453. var pktid = CurrentKanban != null ? Guid.Parse(CurrentKanban.ID) : Guid.Empty;
  454. var row = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(pktid));
  455. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(pktid)
  456. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  457. .Equals(settings.Section));
  458. var packet = row.ToObject<ManufacturingPacket>();
  459. if (id.Value == Guid.Empty)
  460. {
  461. QAGrid = new QAGrid();
  462. var qadata = stagerow != null ? stagerow.Get<ManufacturingPacketStage, string>(c => c.FormData) : "";
  463. var values = string.IsNullOrWhiteSpace(qadata)
  464. ? new Dictionary<Guid, object>()
  465. : Serialization.Deserialize<Dictionary<Guid, object>>(qadata);
  466. if (CurrentSection != null && row != null)
  467. {
  468. var genquestions = LoadQAQuestions(packet, true, false);
  469. QAGrid.LoadChecks("Global Checks for " + CurrentSection.Name, genquestions, values);
  470. //var specquestions = LoadQAQuestions(packet, false, true);
  471. //QAGrid.LoadChecks(String.Format("Specific Checks for {0} [{1}] template", packet.ManufacturingTemplateLink.Name, packet.ManufacturingTemplateLink.Code), specquestions, values);
  472. }
  473. QAGrid.OnChanged += QAGridChanged;
  474. Editor.Content = QAGrid;
  475. }
  476. else
  477. {
  478. PDFEditor = new PDFEditorControl();
  479. PDFEditor.LineColor = settings.LineColor;
  480. PDFEditor.TextSize = settings.FontSize;
  481. PDFEditor.PrintAllowed = Security.IsAllowed<CanPrintFactoryFloorDrawings>();
  482. PDFEditor.SaveAllowed = Security.IsAllowed<CanSaveFactoryFloorDrawings>();
  483. var document = documents.FirstOrDefault(x => x.DocumentLink.ID.Equals(id));
  484. PDFEditor.Watermark = packet.WaterMark;
  485. PDFEditor.Document = document;
  486. PDFEditor.PDFSettingsChanged += PDFEditorSettingsChanged;
  487. Editor.Content = PDFEditor;
  488. }
  489. }
  490. }
  491. private void DoSelectRack(PanelAction obj)
  492. {
  493. var dlg = new MultiSelectDialog<Shipment>(
  494. null,
  495. new Columns<Shipment>(x => x.ID, x => x.Code, x => x.Description, x => x.BarCode),
  496. false
  497. );
  498. if (dlg.ShowDialog())
  499. {
  500. var id = dlg.IDs().FirstOrDefault();
  501. var barcode = dlg.Data().Rows.FirstOrDefault(r => r.Get<Shipment, Guid>(c => c.ID).Equals(id))?.Get<Shipment, string>(x => x.BarCode);
  502. ProcessCode(Scanners.FirstOrDefault(), barcode);
  503. }
  504. }
  505. private void DoCloseRack(PanelAction obj)
  506. {
  507. if (!string.IsNullOrWhiteSpace(rackbarcode))
  508. ProcessCode(Scanners.FirstOrDefault(), rackbarcode);
  509. }
  510. private void DoScanBarcode(PanelAction obj)
  511. {
  512. var dlg = new MultiSelectDialog<DeliveryItem>(
  513. new Filter<DeliveryItem>(x => x.DeliveredDate).IsEqualTo(DateTime.MinValue)
  514. .And(x => x.ManufacturingPacketLink).LinkValid(),
  515. new Columns<DeliveryItem>(x => x.ID, x => x.Barcode, x => x.Description),
  516. false
  517. );
  518. if (dlg.ShowDialog())
  519. {
  520. var id = dlg.IDs().FirstOrDefault();
  521. var barcode = dlg.Data().Rows.FirstOrDefault(r => r.Get<DeliveryItem, Guid>(c => c.ID).Equals(id))
  522. ?.Get<DeliveryItem, string>(x => x.Barcode);
  523. ProcessCode(Scanners.FirstOrDefault(), barcode);
  524. }
  525. }
  526. private void DoScanDeliveryItems(PanelAction obj)
  527. {
  528. new DeliveryBuilder(Guid.Empty, Guid.Empty).ShowDialog();
  529. }
  530. private void DoCreatePurchaseOrder(PanelAction obj)
  531. {
  532. //Guid section = CurrentSection != null ? CurrentSection.ID : CoreUtils.FullGuid;
  533. //var stages = Stages.Rows.Where(row => row.Get<ManufacturingPacketStage, Guid>(col => col.ManufacturingSectionLink.ID).Equals(section) && row.Get<ManufacturingPacketStage, int>(col => col.Station).Equals(CurrentStation));
  534. //var ids = stages.Select(row => row.Get<ManufacturingPacketStage, Guid>(col => col.ManufacturingPacketLink.ID)).ToArray();
  535. var ids = Kanbans.Where(x => !x.ColorKey.Equals(QA_COLOR)).Select(x => Guid.Parse(x.ID)).ToArray();
  536. var treatments = new Client<ManufacturingTreatment>().Query(new Filter<ManufacturingTreatment>(x => x.Packet.ID).InList(ids));
  537. var window = new ManufacturingTreatmentWindow(treatments);
  538. if (window.ShowDialog() != true)
  539. return;
  540. Progress.Show("Creating Purchase Order");
  541. var order = new PurchaseOrder();
  542. //Supplier supplier = new Client<Supplier>().Query(
  543. // new Filter<Supplier>(x => x.ID).IsEqualTo(window.SupplierID),
  544. // new Columns<Supplier>(x=>x.ID
  545. //).Rows.FirstOrDefault()?.ToObject<Supplier>());
  546. order.SupplierLink.ID = window.SupplierID;
  547. order.SupplierLink.Name = window.SupplierName; //supplier != null ? supplier.Name : "Unknown Supplier";
  548. order.Notes = string.Format("Materials Processing Request raised by {0} from Factory Floor", Employees[myID]);
  549. order.RaisedBy.ID = myID;
  550. order.IssuedBy.ID = myID;
  551. order.IssuedDate = DateTime.Today;
  552. order.DueDate = DateTime.Today.AddDays(7);
  553. new Client<PurchaseOrder>().Save(order, "Created Treatment Purchase Order");
  554. Progress.SetMessage("Creating Consignment");
  555. var consignment = new Consignment();
  556. consignment.Number = string.Format("MFG PO {0}", order.PONumber);
  557. consignment.Supplier.ID = order.SupplierLink.ID;
  558. consignment.EstimatedDispatchDate = order.IssuedDate;
  559. consignment.EstimatedWarehouseArrival = order.DueDate;
  560. consignment.Description = string.Format("{0} #{1} - {2}", CurrentSection.Name, CurrentStation,
  561. Employees.ContainsKey(myID) ? Employees[myID] : "(unknown)");
  562. new Client<Consignment>().Save(consignment, "Created by Factory Floor Purchase");
  563. Progress.SetMessage("Processing Order");
  564. var orderitems = new List<PurchaseOrderItem>();
  565. var packetupdates = new List<ManufacturingPacket>();
  566. var query = new MultiQuery();
  567. query.Add(
  568. new Filter<SupplierProduct>(x => x.ProductLink.ID).IsEqualTo(window.ProductID).And(x => x.SupplierLink.ID)
  569. .IsEqualTo(window.SupplierID),
  570. new Columns<SupplierProduct>(x => x.Job.ID).Add(x => x.CostPrice).Add(x => x.ProductLink.NettCost)
  571. );
  572. query.Add(
  573. new Filter<Product>(x => x.ID).IsEqualTo(window.ProductID),
  574. new Columns<Product>(x => x.NettCost)
  575. );
  576. query.Query();
  577. var supprods = query.Get<SupplierProduct>().Rows.Select(x => x.ToObject<SupplierProduct>()).ToArray();
  578. var supprice = supprods.FirstOrDefault(x => Equals(x.Job.ID, Guid.Empty));
  579. var prodprice = query.Get<Product>().Rows.FirstOrDefault()?.ToObject<Product>();
  580. var stdcost = supprice != null
  581. ? supprice.CostPrice
  582. : prodprice != null
  583. ? prodprice.NettCost
  584. : 0.0F;
  585. foreach (var row in window.Selected)
  586. {
  587. var treatment = row.ToObject<ManufacturingTreatment>();
  588. var packet = Packets.Rows.First(p => p.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(treatment.Packet.ID))
  589. .ToObject<ManufacturingPacket>();
  590. packetupdates.Add(packet);
  591. var item = new PurchaseOrderItem();
  592. item.PurchaseOrderLink.ID = order.ID;
  593. item.Job.ID = treatment.Packet.SetoutLink.JobLink.ID;
  594. item.Packet.ID = packet.ID;
  595. item.Consignment.ID = consignment.ID;
  596. item.Product.ID = window.ProductID;
  597. item.Qty = packet.BarcodeQty;
  598. item.Dimensions.Length = treatment.Parameter == 0.0F ? 1.0F : treatment.Parameter;
  599. var jobprice = supprods.FirstOrDefault(x => x.Job.ID.Equals(item.Job.ID));
  600. item.Cost = jobprice != null ? jobprice.CostPrice : stdcost;
  601. var description = new List<string>();
  602. description.Add(string.Format("{0} x {1} - {2}", packet.BarcodeQty, packet.Serial, packet.Title));
  603. var dimensions = new List<string>();
  604. if (packet.Height > 0.0F)
  605. dimensions.Add(string.Format("H:{0:F2}mm", packet.Height));
  606. if (packet.Width > 0.0F)
  607. dimensions.Add(string.Format("W:{0:F2}mm", packet.Width));
  608. if (packet.Length > 0.0F)
  609. dimensions.Add(string.Format("L:{0:F2}mm", packet.Length));
  610. dimensions.Add(string.Format("Param:{0:F4}", treatment.Parameter));
  611. if (dimensions.Any())
  612. description.Add(string.Format("Dimensions: {0}", string.Join(" ", dimensions)));
  613. item.Description = string.Join("\n", description);
  614. orderitems.Add(item);
  615. }
  616. new Client<PurchaseOrderItem>().Save(orderitems, "Created by Factory Floor Purchase");
  617. Progress.SetMessage("Updating Packets");
  618. foreach (var orderitem in orderitems)
  619. {
  620. var packet = packetupdates.FirstOrDefault(x => x.ID.Equals(orderitem.Packet.ID));
  621. if (packet != null)
  622. packet.OrderItem.ID = orderitem.ID;
  623. }
  624. new Client<ManufacturingPacket>().Save(packetupdates.Where(x => x.IsChanged()), "");
  625. Progress.SetMessage("Creating Delivery");
  626. var delivery = new Delivery();
  627. delivery.Date = DateTime.Today;
  628. delivery.Due = DateTime.Today;
  629. delivery.Employee.ID = myID;
  630. var sb = new StringBuilder();
  631. sb.Append("Serial # ");
  632. sb.AppendLine();
  633. if (Employees.ContainsKey(myID))
  634. sb.AppendLine();
  635. delivery.Notes = string.Format("Delivery of Items for processing to {0}\nOrder #{1} (raised on {2:dd MMM yy} by {3})\nItems: {4}",
  636. order.SupplierLink.Name,
  637. order.PONumber,
  638. delivery.Date,
  639. myName,
  640. string.Join(", ",
  641. orderitems.Select(x =>
  642. string.Format("{0}{1}", x.Description.Split('\n').FirstOrDefault(), x.Qty > 1 ? " (x" + x.Qty.ToString("F0") + ")" : "")))
  643. );
  644. new Client<Delivery>().Save(delivery, "Created by Factory Floor Purchase");
  645. Progress.Close();
  646. PrintDeliveryBarcode(delivery, order, consignment);
  647. PrintOrderItemBarcodes(delivery, order, consignment);
  648. SendPurchaseNotification(order.PONumber);
  649. MessageBox.Show("All Done");
  650. new DeliveryBuilder(delivery.ID, order.ID).ShowDialog();
  651. Refresh();
  652. }
  653. private void SendPurchaseNotification(string PONumber)
  654. {
  655. var updates = new List<Notification>();
  656. var roles = new Client<EmployeeRole>().Query(new Filter<EmployeeRole>(x => x.RoleLink.Code).IsEqualTo("PURCHASES"));
  657. foreach (var role in roles.Rows)
  658. {
  659. var notification = new Notification
  660. {
  661. Title = string.Format("Treatment PO #{0} has been raised", PONumber),
  662. Description = "The above Purchase Order has been created, and is ready to be checked and issued to the relevant supplier."
  663. };
  664. notification.Sender.ID = myID;
  665. notification.Employee.ID = role.Get<EmployeeRole, Guid>(x => x.EmployeeLink.ID);
  666. updates.Add(notification);
  667. }
  668. new Client<Notification>().Save(updates, "Sent Notification");
  669. }
  670. private void PrintDeliveryBarcode(Delivery delivery, PurchaseOrder order, Consignment consignment)
  671. {
  672. var model = new ManufacturingTreatmentDataModel(order, delivery, consignment);
  673. var templatename = "Print Treatment Delivery Bar Code";
  674. var sectionName = "Treatment Delivery Bar Code";
  675. var template = new Client<ReportTemplate>()
  676. .Load(
  677. new Filter<ReportTemplate>(x => x.Name).IsEqualTo(templatename)
  678. .And(x => x.DataModel).IsEqualTo(model.Name)
  679. .And(x => x.Section).IsEqualTo(sectionName)
  680. ).FirstOrDefault();
  681. if (template == null)
  682. {
  683. template = new ReportTemplate
  684. {
  685. DataModel = model.Name,
  686. Section = sectionName,
  687. Name = templatename
  688. };
  689. new Client<ReportTemplate>().Save(template, "Auto Created Report Template");
  690. }
  691. ReportUtils.PreviewReport(template, model, !Security.IsAllowed<CanDesignReports>(), Security.IsAllowed<CanDesignReports>());
  692. }
  693. private void PrintOrderItemBarcodes(Delivery delivery, PurchaseOrder order, Consignment consignment)
  694. {
  695. var model = new ManufacturingTreatmentDataModel(order, delivery, consignment);
  696. var templatename = "Print Treatment Item Bar Codes";
  697. var sectionName = "Treatment Item Bar Code";
  698. var template = new Client<ReportTemplate>()
  699. .Load(
  700. new Filter<ReportTemplate>(x => x.Name).IsEqualTo(templatename)
  701. .And(x => x.DataModel).IsEqualTo(model.Name)
  702. .And(x => x.Section).IsEqualTo(sectionName)
  703. ).FirstOrDefault();
  704. if (template == null)
  705. {
  706. template = new ReportTemplate
  707. {
  708. DataModel = model.Name,
  709. Section = sectionName,
  710. Name = templatename
  711. };
  712. new Client<ReportTemplate>().Save(template, "Auto Created Report Template");
  713. }
  714. ReportUtils.PreviewReport(template, model, !Security.IsAllowed<CanDesignReports>(), Security.IsAllowed<CanDesignReports>());
  715. }
  716. private CoreTable POItemTable(IEnumerable<PurchaseOrderItem> items)
  717. {
  718. var result = new CoreTable();
  719. result.LoadColumns(typeof(PurchaseOrderItem));
  720. result.LoadRows(items);
  721. return result;
  722. }
  723. private void DoSelectLostTime(PanelAction obj)
  724. {
  725. var chooser = new FactoryLostTimeChooser();
  726. if (chooser.ShowDialog() == true)
  727. {
  728. LostTime = chooser.SelectedLostTime;
  729. LostTimeDescription.Content = LostTime.Description;
  730. LostTimeActive.Visibility = Visibility.Visible;
  731. }
  732. }
  733. private void CancelLostTime_Click(object sender, RoutedEventArgs e)
  734. {
  735. LostTime = null;
  736. LostTimeActive.Visibility = Visibility.Collapsed;
  737. }
  738. //private void Current_DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e)
  739. //{
  740. // MessageBox.Show("Exception!\n\n" + e.Exception.Message + "\n\n" + e.Exception.StackTrace);
  741. // e.Handled = true;
  742. //}
  743. private void Section_SelectionChanged(object sender, SelectionChangedEventArgs e)
  744. {
  745. if (!IsReady)
  746. return;
  747. CurrentSection = Sections[Section.SelectedIndex];
  748. //Kanban.Columns.Clear();
  749. //Kanban.Columns.Add(new KanbanColumn() { Title = CurrentSection, Categories = CurrentSection.ID.ToString() });
  750. //Kanban.Columns[0].AllowDrag = false;
  751. //Kanban.Columns[0].PreviewMouseWheel += CardBorder_PreviewMouseWheel;
  752. IsReady = false;
  753. Station.Items.Clear();
  754. for (var i = 1; i <= CurrentSection.Stations; i++)
  755. Station.Items.Add(string.Format("Station #{0}", i));
  756. IsReady = true;
  757. Station.SelectedIndex = 0;
  758. }
  759. private void Station_SelectionChanged(object sender, SelectionChangedEventArgs e)
  760. {
  761. if (!IsReady)
  762. return;
  763. SelectSectionAndStation(CurrentSection.ID, Station.SelectedIndex + 1);
  764. }
  765. private void SelectSectionAndStation(Guid section, int station)
  766. {
  767. CurrentKanban = null;
  768. CurrentStation = station;
  769. settings.Section = section;
  770. settings.Station = CurrentStation - 1;
  771. new LocalConfiguration<FactoryFloorLocalSettings>().Save(settings);
  772. DoRefresh(true);
  773. }
  774. private void LoadKanban()
  775. {
  776. using (new WaitCursor())
  777. {
  778. if (CurrentKanban == null)
  779. {
  780. ButtonStack.Children.Clear();
  781. LoadDrawing(null);
  782. }
  783. else if (true) // Kanban has changed - how do we figure this out
  784. {
  785. var packet = KanbanToPacket(CurrentKanban);
  786. //SetoutStage stage = packet.GetCurrentStage();
  787. var row = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(packet.ID)
  788. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  789. .Equals(settings.Section));
  790. var station = row != null ? row.Get<ManufacturingPacketStage, int>(c => c.Station) : 0;
  791. var quality = row != null ? row.Get<ManufacturingPacketStage, QualityStatus>(c => c.QualityStatus) : QualityStatus.NotChecked;
  792. var percentage = row != null ? row.Get<ManufacturingPacketStage, double>(c => c.PercentageComplete) : 0.00F;
  793. var Pending = station == 0; //packet.StageLink.Station == 0;
  794. // Set the Proper Button Set for this type of Packet
  795. MfgRow.Height = Pending ? new GridLength(00) : new GridLength(50);
  796. foreach (var btn in FindVisualChildren<Button>(ButtonGrid))
  797. btn.IsEnabled = CurrentKanban != null;
  798. var idle = CompleteButton.Background;
  799. var current = new SolidColorBrush(Colors.SteelBlue);
  800. Update100Button.Background = percentage >= 100.0F ? current : idle;
  801. Update075Button.Background = percentage >= 75.0F ? current : idle;
  802. Update050Button.Background = percentage >= 50.0F ? current : idle;
  803. Update025Button.Background = percentage >= 25.0F ? current : idle;
  804. Update000Button.Background = percentage >= 00.0F ? current : idle;
  805. Button firstbutton = null;
  806. //LoadDrawing(Guid.Empty);
  807. ButtonStack.Children.Clear();
  808. // If we are quality checking, add the QA Check button
  809. if (!Pending)
  810. {
  811. var qabtn = new Button();
  812. qabtn.Content = "Quality Checks";
  813. qabtn.Tag = null;
  814. qabtn.Style = Resources["UnselectedButton"] as Style;
  815. qabtn.Click += ViewQualityChecks;
  816. ButtonStack.Children.Add(qabtn);
  817. if (packet.Drawing.IsValid())
  818. {
  819. var pdfbtn = new Button();
  820. pdfbtn.Content = packet.Drawing.FileName.ToLower();
  821. pdfbtn.Tag = packet.Drawing;
  822. pdfbtn.Style = Resources["UnselectedButton"] as Style;
  823. pdfbtn.Click += ViewDrawing;
  824. ButtonStack.Children.Add(pdfbtn);
  825. firstbutton = pdfbtn;
  826. }
  827. // List all available PDFs for this Setout
  828. documents = new Client<SetoutDocument>().Load(
  829. new Filter<SetoutDocument>(x => x.EntityLink.ID).IsEqualTo(CurrentKanban.SetoutID));
  830. foreach (var document in documents)
  831. if (document.DocumentLink != null && document.DocumentLink.FileName != null)
  832. if (document.DocumentLink.FileName.ToLower().EndsWith(".pdf") ||
  833. document.DocumentLink.FileName.ToLower().EndsWith(".png") ||
  834. document.DocumentLink.FileName.ToLower().EndsWith(".bmp") ||
  835. document.DocumentLink.FileName.ToLower().EndsWith(".jpg"))
  836. {
  837. var pdfbtn = new Button();
  838. pdfbtn.Content = document.DocumentLink.FileName.ToLower() +
  839. (!document.Superceded.IsEmpty() ? " (SUPERCEDED)" : "");
  840. pdfbtn.Tag = document.DocumentLink;
  841. pdfbtn.Style = Resources["UnselectedButton"] as Style;
  842. pdfbtn.Click += ViewDrawing;
  843. ButtonStack.Children.Add(pdfbtn);
  844. if (document.Superceded.IsEmpty())
  845. if ((PDFEditor != null && PDFEditor.Document.ID.Equals(document.ID)) || firstbutton == null)
  846. firstbutton = pdfbtn;
  847. }
  848. if (firstbutton == null)
  849. firstbutton = qabtn;
  850. }
  851. if (firstbutton != null)
  852. //SetCurrentButton(firstbutton);
  853. firstbutton.RaiseEvent(new RoutedEventArgs(ButtonBase.ClickEvent));
  854. else
  855. LoadDrawing(null);
  856. } // Kanban has not changed - do nothing
  857. }
  858. }
  859. private void SetCurrentButton(Button button)
  860. {
  861. if (_currentButton != null)
  862. _currentButton.Style = Resources["UnselectedButton"] as Style;
  863. _currentButton = button;
  864. button.Style = Resources["SelectedButton"] as Style;
  865. }
  866. private void SwimLaneSelected(object sender, MouseButtonEventArgs e)
  867. {
  868. }
  869. private void CardSelected(object sender, MouseButtonEventArgs e)
  870. {
  871. var border = (Border)sender;
  872. CurrentKanban = (ManufacturingKanban)border.Tag;
  873. UpdateSelectedKanban();
  874. }
  875. private bool CheckedPacketsChanged(Dictionary<Guid, Tuple<DateTime, DateTime>> lastCheckedPackets,
  876. Dictionary<Guid, Tuple<DateTime, DateTime>> newCheckedPackets)
  877. {
  878. if (lastCheckedPackets.Count != newCheckedPackets.Count)
  879. return true;
  880. foreach (var key in lastCheckedPackets.Keys)
  881. {
  882. if (!newCheckedPackets.ContainsKey(key))
  883. return true;
  884. if (!newCheckedPackets[key].Item1.Equals(lastCheckedPackets[key].Item1))
  885. return true;
  886. if (!newCheckedPackets[key].Item2.Equals(lastCheckedPackets[key].Item2))
  887. return true;
  888. }
  889. return false;
  890. }
  891. private void UpdateSelectedKanban(bool uncheckothers = true)
  892. {
  893. if (CurrentKanban != null)
  894. {
  895. var others = Kanbans.Where(x => x.Checked && x.Assignee != CurrentKanban.Assignee).ToArray();
  896. foreach (var other in others)
  897. other.Checked = false;
  898. others = Kanbans.Where(x => x.Checked).ToArray();
  899. if (others.Length == 1)
  900. others[0].Checked = false;
  901. others = Kanbans.Where(x => x.IsSelected).ToArray();
  902. foreach (var other in others)
  903. {
  904. other.IsSelected = false;
  905. var pkt = KanbanToPacket(other);
  906. if (pkt != null)
  907. //var stg = Stages.FirstOrDefault(x => x.ManufacturingPacketLink.ID.Equals(pkt.ID));
  908. other.SelectedColor = other.ColorKey;
  909. else
  910. other.SelectedColor = other.ColorKey;
  911. }
  912. CurrentKanban.Checked = true;
  913. CurrentKanban.IsSelected = true;
  914. CurrentKanban.SelectedColor = SELECTED_COLOR;
  915. }
  916. //UpdateTimeTracking();
  917. Kanban.ItemsSource = null;
  918. Kanban.ItemsSource = Kanbans.OrderBy(x => x.Assignee).ThenByDescending(x => x.Tags.Length).ThenBy(x => x.DueDate).ThenBy(x => x.JobName);
  919. LoadKanban();
  920. }
  921. private void CardChecked(object sender, RoutedEventArgs e)
  922. {
  923. //UpdateTimeTracking();
  924. try
  925. {
  926. var chk = sender as CheckBox;
  927. var border = (chk.Parent as Grid).Parent as Border;
  928. var kanban = border.Tag as ManufacturingKanban;
  929. kanban.Checked = chk.IsChecked == true;
  930. if (kanban.Checked)
  931. foreach (var other in Kanbans.Where(x => x.Assignee != kanban.Assignee))
  932. other.Checked = false;
  933. }
  934. catch (Exception err)
  935. {
  936. Logger.Send(LogType.Error, "", string.Format("*** Unknown Error: {0}\n{1}", err.Message, err.StackTrace));
  937. }
  938. //Kanban.ItemsSource = null;
  939. //Kanban.ItemsSource = Kanbans.OrderBy(x => x.Assignee).ThenByDescending(x => x.Tags.Length).ThenBy(x => x.DueDate).ThenBy(x => x.JobName);
  940. }
  941. private void CompleteButton_Click(object sender, RoutedEventArgs e)
  942. {
  943. var packets = new List<ManufacturingPacket>();
  944. foreach (var kanban in Kanbans.Where(x => x.Checked || x.IsSelected))
  945. {
  946. var packet = KanbanToPacket(kanban);
  947. if (packet.StageLink.SectionID != CurrentSection.ID)
  948. {
  949. MessageBox.Show("You cannot complete a distributed packet that is not yet progressed to your station!");
  950. return;
  951. }
  952. var qacomplete = true;
  953. var stage = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(packet.ID)
  954. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  955. .Equals(settings.Section));
  956. if (stage != null)
  957. {
  958. var qadata = stage.Get<ManufacturingPacketStage, string>(c => c.FormData);
  959. var questions = LoadQAQuestions(packet, true, true);
  960. var answers = string.IsNullOrWhiteSpace(qadata)
  961. ? new Dictionary<Guid, object>()
  962. : Serialization.Deserialize<Dictionary<Guid, object>>(qadata);
  963. foreach (var question in questions)
  964. {
  965. var parameters = question.ParseParameters();
  966. var bAnswerRequired = question.Answer != QAAnswer.Comment &&
  967. (!parameters.ContainsKey("Default") || string.IsNullOrWhiteSpace(parameters["Default"]));
  968. if (bAnswerRequired && (!answers.ContainsKey(question.ID) || answers[question.ID] == null))
  969. {
  970. qacomplete = false;
  971. break;
  972. }
  973. }
  974. }
  975. if (!qacomplete)
  976. {
  977. MessageBox.Show("You must complete the required QA checks before completing these items!");
  978. return;
  979. }
  980. packets.Add(packet);
  981. }
  982. Progress.Show("Scanning Packets");
  983. //Filter<ManufacturingPacketStage> stgflt = new Filter<ManufacturingPacketStage>(x => x.ID).IsEqualTo(CoreUtils.FullGuid);
  984. //foreach (var pkt in packets)
  985. // stgflt = stgflt.Or(x => x.ManufacturingPacketLink.ID).IsEqualTo(pkt.ID);
  986. //ManufacturingPacketStage[] stgs = new Client<ManufacturingPacketStage>().Load(stgflt, new SortOrder<ManufacturingPacketStage>(x => x.Sequence));
  987. var stage_updates = new List<ManufacturingPacketStage>();
  988. for (var i = 0; i < packets.Count; i++)
  989. {
  990. var packet = packets[i];
  991. var stagerows = Stages.Rows.Where(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(packet.ID));
  992. var stages = stagerows.Select(r => r.ToObject<ManufacturingPacketStage>());
  993. //var stages = stgs.Where(x => x.ManufacturingPacketLink.ID.Equals(packet.ID));
  994. long sequence = 0;
  995. // Send the update to the server
  996. var stage = stages.FirstOrDefault(x => x.ID.Equals(packet.StageLink.ID));
  997. if (stage != null)
  998. {
  999. stage.Completed = DateTime.Now;
  1000. stage.FormCompleted = DateTime.Now;
  1001. stage.FormCompletedBy.ID = ClientFactory.UserGuid;
  1002. stage.PercentageComplete = 100.0F;
  1003. if (!stage_updates.Contains(stage))
  1004. stage_updates.Add(stage);
  1005. sequence = stage.Sequence;
  1006. }
  1007. // Also update the local copy (hacky hacky)
  1008. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.ID).Equals(packet.StageLink.ID));
  1009. if (stagerow != null)
  1010. {
  1011. stagerow.Set<ManufacturingPacketStage, DateTime>(x => x.Completed, DateTime.Now);
  1012. stagerow.Set<ManufacturingPacketStage, DateTime>(x => x.FormCompleted, DateTime.Now);
  1013. stagerow.Set<ManufacturingPacketStage, Guid>(x => x.FormCompletedBy.ID, ClientFactory.UserGuid);
  1014. stagerow.Set<ManufacturingPacketStage, double>(x => x.PercentageComplete, 100.0F);
  1015. }
  1016. // Update the pointer to the next stage
  1017. // But only if it's at your station already
  1018. // This takes into account distributed packets that may not be completed elsewhere
  1019. if (packet.StageLink.SectionID == CurrentSection.ID)
  1020. {
  1021. stage = stages.Where(x => x.Sequence > sequence).FirstOrDefault();
  1022. // If this is a distributed packet, then it may already have data allocated to it
  1023. // We on;y want to reset the next stage if it's not distributed
  1024. if (!packet.Distributed)
  1025. if (stage != null)
  1026. {
  1027. stage.QualityStatus = QualityStatus.NotChecked;
  1028. stage.QualityNotes = "";
  1029. stage.Station = 0;
  1030. stage.Started = DateTime.MinValue;
  1031. stage.Completed = DateTime.MinValue;
  1032. stage.PercentageComplete = 0.0F;
  1033. if (!stage_updates.Contains(stage))
  1034. stage_updates.Add(stage);
  1035. }
  1036. }
  1037. packet.StageLink.ID = stage == null ? CoreUtils.FullGuid : stage.ID;
  1038. packet.Issued = !packet.StageLink.IsValid() ? DateTime.MinValue : packet.Issued.IsEmpty() ? DateTime.Now : packet.Issued;
  1039. packet.Completed = packet.StageLink.ID.Equals(CoreUtils.FullGuid)
  1040. ? packet.Completed.IsEmpty() ? DateTime.Now : packet.Completed
  1041. : DateTime.MinValue;
  1042. }
  1043. Progress.SetMessage("Progressing Items");
  1044. new Client<ManufacturingPacketStage>().Save(stage_updates, "ManufacturingPacket Progressed from Factory Floor");
  1045. new Client<ManufacturingPacket>().Save(packets, "ManufacturingPacket Progressed From Fatory Floor");
  1046. //UpdateTimeTracking();
  1047. Heartbeat(new TimeSpan(0L));
  1048. CurrentKanban = null;
  1049. Refresh();
  1050. Progress.Close();
  1051. }
  1052. private void UpdateButtonClick(object sender, RoutedEventArgs e)
  1053. {
  1054. Progress.Show("");
  1055. double percent = 0.0F;
  1056. if (double.TryParse(((Button)sender).Tag.ToString(), out percent))
  1057. {
  1058. var selected = new List<ManufacturingPacket>();
  1059. var stages = new List<ManufacturingPacketStage>();
  1060. foreach (var kanban in Kanbans.Where(x => x.Checked || x.IsSelected))
  1061. {
  1062. selected.Add(KanbanToPacket(kanban));
  1063. var pktid = Guid.Parse(kanban.ID);
  1064. var stagerows = Stages.Rows.Where(r =>
  1065. r.Get<ManufacturingPacketStage, Guid>(c => c.SectionID).Equals(CurrentSection.ID) &&
  1066. r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(pktid));
  1067. stages.AddRange(stagerows.Select(r => r.ToObject<ManufacturingPacketStage>()));
  1068. }
  1069. var updates = new List<ManufacturingPacketStage>();
  1070. foreach (var stage in stages)
  1071. {
  1072. var bChanged = false;
  1073. if (stage.Started == DateTime.MinValue)
  1074. {
  1075. stage.Started = DateTime.Now;
  1076. bChanged = true;
  1077. }
  1078. if (stage.PercentageComplete != percent)
  1079. {
  1080. stage.PercentageComplete = percent;
  1081. bChanged = true;
  1082. }
  1083. if (stage.Station != -1 && stage.Station != CurrentStation)
  1084. {
  1085. stage.Station = CurrentStation;
  1086. bChanged = true;
  1087. }
  1088. if (bChanged)
  1089. updates.Add(stage);
  1090. }
  1091. new Client<ManufacturingPacketStage>().Save(updates, "Progress Updated from Factory Floor");
  1092. DoRefresh(true);
  1093. }
  1094. Progress.Close();
  1095. }
  1096. private void BarcodesButton_Click(object sender, RoutedEventArgs e)
  1097. {
  1098. //List<ManufacturingPacket> updates = new List<ManufacturingPacket>();
  1099. var checkedpackets =
  1100. Packets.Rows.Where(p => Kanbans.Any(k => k.Checked && p.Get<ManufacturingPacket, Guid>(c => c.ID).ToString().Equals(k.ID)));
  1101. if (!checkedpackets.Any())
  1102. {
  1103. MessageBox.Show("Please select a packet before continuing");
  1104. return;
  1105. }
  1106. Progress.Show("");
  1107. Filter<ManufacturingPacket> pktflt = null;
  1108. foreach (var row in checkedpackets)
  1109. pktflt = pktflt == null
  1110. ? new Filter<ManufacturingPacket>(x => x.ID).IsEqualTo(row.Get<ManufacturingPacket, Guid>(c => c.ID))
  1111. : pktflt.Or(x => x.ID).IsEqualTo(row.Get<ManufacturingPacket, Guid>(c => c.ID));
  1112. var pkts = new Client<ManufacturingPacket>().Load(pktflt);
  1113. foreach (var pkt in pkts)
  1114. //var pkt = row.ToObject<ManufacturingPacket>();
  1115. if (pkt.BarcodePrinted == DateTime.MinValue)
  1116. pkt.BarcodePrinted = DateTime.Now;
  1117. //updates.Add(pkt);
  1118. //if (updates.Any())
  1119. //{
  1120. Progress.SetMessage("Creating Barcodes");
  1121. new Client<ManufacturingPacket>().Save(pkts, "Delivery Barcodes created");
  1122. //}
  1123. Filter<DeliveryItem> filter = null;
  1124. foreach (var row in checkedpackets)
  1125. {
  1126. var pktid = row.Get<ManufacturingPacket, Guid>(c => c.ID);
  1127. if (filter == null)
  1128. filter = new Filter<DeliveryItem>(x => x.ManufacturingPacketLink.ID).IsEqualTo(pktid);
  1129. else
  1130. filter = filter.Or(x => x.ManufacturingPacketLink.ID).IsEqualTo(pktid);
  1131. }
  1132. var dataenvironment = new Dictionary<Type, CoreTable>();
  1133. var model = new DeliveryItemDataModel(filter);
  1134. var Group = Packets.Rows.Select(r => r.Get<ManufacturingPacket, string>(c => c.Group)).FirstOrDefault();
  1135. var BaseReportName = "Print Bar Codes";
  1136. var sectionName = "Delivery Items";
  1137. var repflt = new Filter<ReportTemplate>(x => x.Name).IsEqualTo(BaseReportName);
  1138. var DesiredReportName = BaseReportName + (!string.IsNullOrWhiteSpace(Group) ? " - " + Group : "");
  1139. if (DesiredReportName != BaseReportName)
  1140. repflt = repflt.Or(x => x.Name).IsEqualTo(DesiredReportName);
  1141. var repflt2 = new Filter<ReportTemplate>(x => x.DataModel).IsEqualTo(model.Name).And(x => x.Section).IsEqualTo(sectionName);
  1142. repflt2.Ands.Add(repflt);
  1143. var templates = new Client<ReportTemplate>().Load(repflt2);
  1144. var report = templates.FirstOrDefault(x => x.Name == DesiredReportName);
  1145. if (report == null)
  1146. report = templates.FirstOrDefault(x => x.Name == BaseReportName);
  1147. if (report == null)
  1148. {
  1149. Progress.Close();
  1150. MessageBox.Show("Ready To Go -> [Print Bar Codes] report does not exist!");
  1151. Refresh();
  1152. }
  1153. Progress.Close();
  1154. ReportUtils.PreviewReport(report, model, false, Security.IsAllowed<CanDesignReports>());
  1155. Refresh();
  1156. }
  1157. private void ViewDrawing(object sender, RoutedEventArgs e)
  1158. {
  1159. var button = (Button)sender;
  1160. SetCurrentButton(button);
  1161. var doc = button.Tag as IEntityLink;
  1162. LoadDrawing(doc.ID);
  1163. }
  1164. private void Search_KeyUp(object sender, KeyEventArgs e)
  1165. {
  1166. SearchFilter = Search.Text;
  1167. if (e.Key == Key.Enter || string.IsNullOrEmpty(Search.Text))
  1168. {
  1169. ClearAllSelections();
  1170. ReloadPackets(true);
  1171. }
  1172. }
  1173. //private void SwimlaneCheckBox_Checked(object sender, RoutedEventArgs e)
  1174. //{
  1175. // CheckBox chk = sender as CheckBox;
  1176. // String tag = chk.Tag as String;
  1177. // foreach (var packet in Kanbans)
  1178. // packet.Checked = (packet.Assignee == tag) ? !packet.Checked : false;
  1179. // Kanban.ItemsSource = null;
  1180. // Kanban.ItemsSource = Kanbans.OrderBy(x => x.Assignee).ThenByDescending(x => x.Tags.Length).ThenBy(x => x.DueDate).ThenBy(x => x.JobName);
  1181. //}
  1182. //private void CardBorder_PreviewMouseWheel(object sender, MouseWheelEventArgs e)
  1183. //{
  1184. // e.Handled = true;
  1185. // var eventArg = new MouseWheelEventArgs(e.MouseDevice, e.Timestamp, e.Delta);
  1186. // eventArg.RoutedEvent = UIElement.MouseWheelEvent;
  1187. // eventArg.Source = sender;
  1188. // var tgts = FindVisualChildren<UIElement>(Kanban.Columns[0]);
  1189. // foreach (var tgt in tgts)
  1190. // tgt.RaiseEvent(eventArg);
  1191. //}
  1192. private void PacketMenu_Opened(object sender, RoutedEventArgs e)
  1193. {
  1194. var menu = sender as ContextMenu;
  1195. var setcurrent = menu.Items[0] as MenuItem;
  1196. var setpending = menu.Items[1] as MenuItem;
  1197. var actionseparator = menu.Items[2] as Separator;
  1198. var settrolley = menu.Items[3] as MenuItem;
  1199. var cleartrolley = menu.Items[4] as MenuItem;
  1200. var trolleyseparator = menu.Items[5] as Separator;
  1201. var setpriority = menu.Items[6] as MenuItem;
  1202. var clearpriority = menu.Items[7] as MenuItem;
  1203. var editissues = menu.Items[8] as MenuItem;
  1204. var sethold = menu.Items[9] as MenuItem;
  1205. var clearhold = menu.Items[10] as MenuItem;
  1206. var setdistributed = menu.Items[11] as MenuItem;
  1207. var cleardistributed = menu.Items[12] as MenuItem;
  1208. var distseparator = menu.Items[13] as Separator;
  1209. var setshared = menu.Items[14] as MenuItem;
  1210. var clearshared = menu.Items[15] as MenuItem;
  1211. var movepacket = menu.Items[16] as MenuItem;
  1212. var model = menu.Tag as ManufacturingKanban;
  1213. if (!model.Checked)
  1214. {
  1215. foreach (var kanban in Kanbans.Where(x => x.Checked).ToArray())
  1216. kanban.Checked = false;
  1217. model.Checked = true;
  1218. //Kanban.ItemsSource = null;
  1219. //Kanban.ItemsSource = Kanbans.OrderBy(x => x.Assignee).ThenByDescending(x => x.Tags.Length).ThenBy(x => x.DueDate).ThenBy(x => x.JobName);
  1220. }
  1221. var checkedkanbans = Kanbans.Where(k => k.Checked).Select(x => Guid.Parse(x.ID));
  1222. var checkedpackets = Packets.Rows.Where(r => checkedkanbans.Contains(r.Get<ManufacturingPacket, Guid>(c => c.ID)));
  1223. var checkedstages = Stages.Rows.Where(r => checkedkanbans.Contains(r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID))
  1224. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  1225. .Equals(settings.Section));
  1226. // Only if we right-click on a checked packet??
  1227. if (checkedpackets.Any() && checkedstages.Any())
  1228. {
  1229. var iStation = checkedstages.First().Get<ManufacturingPacketStage, int>(c => c.Station);
  1230. setcurrent.Visibility = iStation == 0 ? Visibility.Visible : Visibility.Collapsed;
  1231. setpending.Visibility = iStation > 0 ? Visibility.Visible : Visibility.Collapsed;
  1232. actionseparator.Visibility = Visibility.Collapsed;
  1233. settrolley.Visibility = Visibility.Visible;
  1234. cleartrolley.Visibility =
  1235. checkedpackets.Select(r => r.Get<ManufacturingPacket, string>(x => x.Trolleys)).Any(x => !string.IsNullOrWhiteSpace(x))
  1236. ? Visibility.Visible
  1237. : Visibility.Collapsed;
  1238. setpriority.Visibility = Visibility.Collapsed; // (packet != null) && packet.Priority ? Visibility.Collapsed : Visibility.Visible;
  1239. clearpriority.Visibility = Visibility.Collapsed; // (packet != null) && packet.Priority ? Visibility.Visible : Visibility.Collapsed;
  1240. editissues.Visibility = Visibility.Visible;
  1241. sethold.Visibility =
  1242. false //Security.IsAllowed<CanManagePacketHolds>() && checkedpackets.Any(r => !r.Get<ManufacturingPacket, bool>(c => c.OnHold))
  1243. ? Visibility.Visible
  1244. : Visibility.Collapsed;
  1245. clearhold.Visibility =
  1246. false //Security.IsAllowed<CanManagePacketHolds>() && checkedpackets.Any(r => r.Get<ManufacturingPacket, bool>(c => c.OnHold))
  1247. ? Visibility.Visible
  1248. : Visibility.Collapsed;
  1249. setdistributed.Visibility = Security.IsAllowed<CanDistributePackets>() &&
  1250. checkedpackets.Any(r => r.Get<ManufacturingPacket, bool>(c => c.Distributed) == false)
  1251. ? Visibility.Visible
  1252. : Visibility.Collapsed;
  1253. cleardistributed.Visibility = Security.IsAllowed<CanDistributePackets>() &&
  1254. checkedpackets.Any(r => r.Get<ManufacturingPacket, bool>(c => c.Distributed))
  1255. ? Visibility.Visible
  1256. : Visibility.Collapsed;
  1257. distseparator.Visibility = setdistributed.Visibility == Visibility.Visible || cleardistributed.Visibility == Visibility.Visible
  1258. ? Visibility.Visible
  1259. : Visibility.Collapsed;
  1260. setshared.Visibility = iStation > 0 ? Visibility.Visible : Visibility.Collapsed;
  1261. clearshared.Visibility = iStation < 0 ? Visibility.Visible : Visibility.Collapsed;
  1262. movepacket.Visibility = iStation > 0 ? Visibility.Visible : Visibility.Collapsed;
  1263. setcurrent.Tag = checkedstages;
  1264. setpending.Tag = checkedstages;
  1265. setpriority.Tag = checkedpackets;
  1266. clearpriority.Tag = checkedpackets;
  1267. editissues.Tag = checkedpackets;
  1268. sethold.Tag = checkedpackets;
  1269. clearhold.Tag = checkedpackets;
  1270. setdistributed.Tag = checkedpackets;
  1271. cleardistributed.Tag = checkedpackets;
  1272. setshared.Tag = checkedstages;
  1273. clearshared.Tag = checkedstages;
  1274. movepacket.Tag = checkedstages;
  1275. if (movepacket.Visibility == Visibility.Visible)
  1276. {
  1277. movepacket.Items.Clear();
  1278. foreach (var station in Station.Items)
  1279. {
  1280. var sub = new MenuItem { Header = station, Tag = checkedstages };
  1281. sub.Click += MovePacketClick;
  1282. movepacket.Items.Add(sub);
  1283. sub.Visibility = movepacket.Items.Count == CurrentStation ? Visibility.Collapsed : Visibility.Visible;
  1284. }
  1285. }
  1286. settrolley.Tag = Kanbans.Where(k => k.Checked);
  1287. cleartrolley.Tag = Kanbans.Where(k => k.Checked);
  1288. //if (Trolleys == null)
  1289. //{
  1290. // Trolleys = new Client<ManufacturingTrolley>().Query(
  1291. // LookupFactory.DefineFilter<ManufacturingTrolley>(),
  1292. // LookupFactory.DefineColumns<ManufacturingTrolley>(),
  1293. // LookupFactory.DefineSort<ManufacturingTrolley>()
  1294. // );
  1295. //}
  1296. //if (Trolleys.Rows.Any())
  1297. //{
  1298. // settrolley.Visibility = Visibility.Visible;
  1299. // settrolley.Items.Clear();
  1300. // foreach (var row in Trolleys.Rows)
  1301. // {
  1302. // MenuItem sub = new MenuItem() { Header = row.Get<ManufacturingTrolley,String>(x=>x.Code) + ": "+ row.Get<ManufacturingTrolley, String>(x => x.Description), Tag = row.Get<ManufacturingTrolley,Guid>(x=>x.ID) };
  1303. // sub.Click += SetTrolleyClick;
  1304. // settrolley.Items.Add(sub);
  1305. // }
  1306. //}
  1307. //else
  1308. // settrolley.Visibility = Visibility.Collapsed;
  1309. }
  1310. // Disable everything
  1311. }
  1312. private void SetPacketToTrolley(string trolley, params ManufacturingPacket[] packets)
  1313. {
  1314. var updates = new List<ManufacturingPacket>();
  1315. foreach (var packet in packets)
  1316. if (string.Equals(packet.Trolleys, trolley))
  1317. {
  1318. packet.Trolleys = trolley;
  1319. updates.Add(packet);
  1320. }
  1321. if (updates.Any())
  1322. using (new WaitCursor())
  1323. {
  1324. new Client<ManufacturingPacket>().Save(updates, string.Format("Moved Packet to Trolley {0}", trolley), (o, e) => { });
  1325. foreach (var update in updates)
  1326. {
  1327. var pktrow = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(update.ID));
  1328. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(update.ID)
  1329. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  1330. .Equals(settings.Section));
  1331. //ManufacturingPacketStage stage = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(x => x.Parent.ID).Equals(update.ID))?.ToObject<ManufacturingPacketStage>();
  1332. var kanban = Kanbans.FirstOrDefault(x => x.ID.Equals(update.ID.ToString()));
  1333. LoadModel(kanban, pktrow, stagerow, true);
  1334. }
  1335. }
  1336. }
  1337. private void SetTrolleyClick(object sender, RoutedEventArgs e)
  1338. {
  1339. var kanbans = (sender as MenuItem).Tag as IEnumerable<ManufacturingKanban>;
  1340. List<string> trolleyPrePopulate = new List<string>();
  1341. foreach (ManufacturingKanban kanban in kanbans)
  1342. {
  1343. if (!string.IsNullOrWhiteSpace(kanban.Trolleys))
  1344. {
  1345. if (kanban.Trolleys.Contains(','))
  1346. {
  1347. var splitTrolleys = kanban.Trolleys.Split(',');
  1348. foreach (string s in splitTrolleys)
  1349. {
  1350. if (!trolleyPrePopulate.Contains(s))
  1351. {
  1352. trolleyPrePopulate.Add(s);
  1353. }
  1354. }
  1355. }
  1356. else
  1357. {
  1358. if (!trolleyPrePopulate.Contains(kanban.Trolleys))
  1359. {
  1360. trolleyPrePopulate.Add(kanban.Trolleys);
  1361. }
  1362. }
  1363. }
  1364. }
  1365. var dlg = new MultiSelectWindow(typeof(ManufacturingTrolley), new Guid[] { }, trolleyPrePopulate);
  1366. if (dlg.ShowDialog() == true)
  1367. using (new WaitCursor())
  1368. {
  1369. var trolleys = new List<string>();
  1370. foreach (ManufacturingTrolley value in dlg.Values)
  1371. trolleys.Add(value.Code);
  1372. var updates = new List<ManufacturingPacket>();
  1373. foreach (var kanban in kanbans)
  1374. {
  1375. var pktrow = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(Guid.Parse(kanban.ID)));
  1376. var stagerow = Stages.Rows.FirstOrDefault(r =>
  1377. r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(Guid.Parse(kanban.ID))
  1378. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID).Equals(settings.Section));
  1379. var packet = pktrow.ToObject<ManufacturingPacket>();
  1380. packet.Trolleys = string.Join(",", trolleys);
  1381. updates.Add(packet);
  1382. pktrow.Set<ManufacturingPacket, string>(x => x.Trolleys, packet.Trolleys);
  1383. LoadModel(kanban, pktrow, stagerow, true);
  1384. }
  1385. if (updates.Any())
  1386. {
  1387. new Client<ManufacturingPacket>().Save(updates, "Set Trolley to " + (sender as MenuItem).Header, (objects, error) => { });
  1388. var src = Kanban.ItemsSource;
  1389. Kanban.ItemsSource = null;
  1390. Kanban.ItemsSource = src;
  1391. }
  1392. }
  1393. //Refresh();
  1394. }
  1395. private void ClearTrolleyClick(object sender, RoutedEventArgs e)
  1396. {
  1397. var kanbans = (sender as MenuItem).Tag as IEnumerable<ManufacturingKanban>;
  1398. using (new WaitCursor())
  1399. {
  1400. var updates = new List<ManufacturingPacket>();
  1401. foreach (var kanban in kanbans)
  1402. {
  1403. var pktrow = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(Guid.Parse(kanban.ID)));
  1404. var stagerow = Stages.Rows.FirstOrDefault(r =>
  1405. r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(Guid.Parse(kanban.ID))
  1406. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  1407. .Equals(settings.Section));
  1408. var packet = pktrow.ToObject<ManufacturingPacket>();
  1409. packet.Trolleys = "";
  1410. updates.Add(packet);
  1411. pktrow.Set<ManufacturingPacket, string>(x => x.Trolleys, packet.Trolleys);
  1412. LoadModel(kanban, pktrow, stagerow, true);
  1413. }
  1414. if (updates.Any())
  1415. {
  1416. new Client<ManufacturingPacket>().Save(updates, "Removed From Trolley", (objects, error) => { });
  1417. var src = Kanban.ItemsSource;
  1418. Kanban.ItemsSource = null;
  1419. Kanban.ItemsSource = src;
  1420. }
  1421. }
  1422. }
  1423. private void SetCurrent_Click(object sender, RoutedEventArgs e)
  1424. {
  1425. var rows = (sender as MenuItem).Tag as IEnumerable<CoreRow>;
  1426. var stages = rows.Select(x => x.ToObject<ManufacturingPacketStage>()).ToArray();
  1427. AddPacketToCurrentWorkload(stages);
  1428. CurrentKanban = Kanbans.FirstOrDefault(x => x.ID.Equals(stages.First().Parent.ID.ToString()));
  1429. UpdateSelectedKanban(false);
  1430. }
  1431. private void AddPacketToCurrentWorkload(params ManufacturingPacketStage[] stages)
  1432. {
  1433. var updates = new List<ManufacturingPacketStage>();
  1434. foreach (var stage in stages)
  1435. if (stage.Station == 0)
  1436. {
  1437. stage.Station = CurrentStation;
  1438. stage.Started = DateTime.Now;
  1439. updates.Add(stage);
  1440. }
  1441. if (updates.Any())
  1442. using (new WaitCursor())
  1443. {
  1444. new Client<ManufacturingPacketStage>().Save(updates, string.Format("Moved Packet to Station {0}", CurrentStation), (o, e) => { });
  1445. foreach (var update in updates)
  1446. {
  1447. var pktrow = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(update.Parent.ID));
  1448. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(x => x.ID).Equals(update.ID));
  1449. Stages.LoadRow(stagerow, update);
  1450. var kanban = Kanbans.FirstOrDefault(x => x.ID.Equals(update.Parent.ID.ToString()));
  1451. LoadModel(kanban, pktrow, stagerow, true);
  1452. }
  1453. }
  1454. }
  1455. private void SetPending_Click(object sender, RoutedEventArgs e)
  1456. {
  1457. var updates = new List<ManufacturingPacketStage>();
  1458. var rows = (sender as MenuItem).Tag as IEnumerable<CoreRow>;
  1459. foreach (var row in rows)
  1460. {
  1461. var stage = row.ToObject<ManufacturingPacketStage>();
  1462. if (stage.Station != 0)
  1463. {
  1464. stage.Station = 0;
  1465. stage.Started = DateTime.MinValue;
  1466. updates.Add(stage);
  1467. }
  1468. }
  1469. if (updates.Any())
  1470. using (new WaitCursor())
  1471. {
  1472. new Client<ManufacturingPacketStage>().Save(updates, string.Format("Removed Packet from Station {0}", CurrentStation));
  1473. foreach (var update in updates)
  1474. {
  1475. var pktrow = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(update.Parent.ID));
  1476. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(x => x.ID).Equals(update.ID));
  1477. Stages.LoadRow(stagerow, update);
  1478. var kanban = Kanbans.FirstOrDefault(x => x.ID.Equals(update.Parent.ID.ToString()));
  1479. LoadModel(kanban, pktrow, stagerow, true);
  1480. }
  1481. CurrentKanban = Kanbans.FirstOrDefault(x => x.ID.Equals(updates.First().Parent.ID.ToString()));
  1482. UpdateSelectedKanban();
  1483. }
  1484. }
  1485. private void UpdateFlag(object sender, string property, bool value)
  1486. {
  1487. var updates = new List<ManufacturingPacket>();
  1488. var rows = (sender as MenuItem).Tag as IEnumerable<CoreRow>;
  1489. foreach (var row in rows)
  1490. {
  1491. var packet = row.ToObject<ManufacturingPacket>();
  1492. CoreUtils.SetPropertyValue(packet, property, value);
  1493. updates.Add(packet);
  1494. }
  1495. if (updates.Any())
  1496. using (new WaitCursor())
  1497. {
  1498. new Client<ManufacturingPacket>().Save(updates, property + " Flag " + (value ? "Set" : "Cleared"));
  1499. Refresh();
  1500. }
  1501. }
  1502. private void SetPriority_Click(object sender, RoutedEventArgs e)
  1503. {
  1504. UpdateFlag(sender, "Priority", true);
  1505. }
  1506. private void ClearPriority_Click(object sender, RoutedEventArgs e)
  1507. {
  1508. UpdateFlag(sender, "Priority", false);
  1509. }
  1510. private void EditIssues_Click(object sender, RoutedEventArgs e)
  1511. {
  1512. var updates = new List<ManufacturingPacket>();
  1513. var rows = (sender as MenuItem).Tag as IEnumerable<CoreRow>;
  1514. var pkts = rows.Select(x => x.ToObject<ManufacturingPacket>()).ToArray();
  1515. if (new DynamicIssuesEditor(pkts, true).ShowDialog() == true)
  1516. {
  1517. Progress.ShowModal("Updating Issues", progress => { new Client<ManufacturingPacket>().Save(pkts, "Updated Issues"); });
  1518. Refresh();
  1519. }
  1520. // String[] issues = rows.Select(r => r.Get<ManufacturingPacket, String>(c => c.Issues)).Distinct().ToArray();
  1521. // if (issues.Length > 1)
  1522. // {
  1523. // if (MessageBox.Show(
  1524. // "Multiple Issues found! If you continue, these may be lost.\n\nAre you sure you wish to continue?",
  1525. // "Multiple Issues",
  1526. // MessageBoxButton.YesNo) != MessageBoxResult.Yes)
  1527. // return;
  1528. // }
  1529. //
  1530. // string issue = issues.Length > 0 ? issues.First() : "";
  1531. // if (!TextBoxDialog.Execute("Edit Issues", ref issue))
  1532. // return;
  1533. //
  1534. // foreach (var row in rows)
  1535. // {
  1536. // ManufacturingPacket packet = row.ToObject<ManufacturingPacket>();
  1537. // packet.Issues = issue;
  1538. // updates.Add(packet);
  1539. // }
  1540. // if (updates.Any())
  1541. // {
  1542. // using (new WaitCursor())
  1543. // {
  1544. // new Client<ManufacturingPacket>().Save(updates, "Updated Issues");
  1545. // Refresh();
  1546. // }
  1547. // }
  1548. }
  1549. private void SetHold_Click(object sender, RoutedEventArgs e)
  1550. {
  1551. if (MessageBox.Show(
  1552. "Are you sure you wish to set this packet on hold?",
  1553. "Set Hold",
  1554. MessageBoxButton.YesNo) != MessageBoxResult.Yes)
  1555. return;
  1556. UpdateFlag(sender, "OnHold", true);
  1557. }
  1558. private void ClearHold_Click(object sender, RoutedEventArgs e)
  1559. {
  1560. if (MessageBox.Show(
  1561. "Are you sure you wish to release this packet from hold?",
  1562. "Set Hold",
  1563. MessageBoxButton.YesNo) != MessageBoxResult.Yes)
  1564. return;
  1565. UpdateFlag(sender, "OnHold", false);
  1566. }
  1567. private void SetDistributed_Click(object sender, RoutedEventArgs e)
  1568. {
  1569. UpdateFlag(sender, "Distributed", true);
  1570. }
  1571. private void ClearDistributed_Click(object sender, RoutedEventArgs e)
  1572. {
  1573. UpdateFlag(sender, "Distributed", false);
  1574. }
  1575. private void SetShared_Click(object sender, RoutedEventArgs e)
  1576. {
  1577. var updates = new List<ManufacturingPacketStage>();
  1578. var rows = (sender as MenuItem).Tag as IEnumerable<CoreRow>;
  1579. foreach (var row in rows)
  1580. {
  1581. var stage = row.ToObject<ManufacturingPacketStage>();
  1582. if (stage.Station > 0)
  1583. {
  1584. stage.Station = -1;
  1585. updates.Add(stage);
  1586. }
  1587. }
  1588. if (updates.Any())
  1589. using (new WaitCursor())
  1590. {
  1591. new Client<ManufacturingPacketStage>().Save(updates, "Set Packet as Shared");
  1592. Refresh();
  1593. }
  1594. }
  1595. private void ClearShared_Click(object sender, RoutedEventArgs e)
  1596. {
  1597. var updates = new List<ManufacturingPacketStage>();
  1598. var rows = (sender as MenuItem).Tag as IEnumerable<CoreRow>;
  1599. foreach (var row in rows)
  1600. {
  1601. var stage = row.ToObject<ManufacturingPacketStage>();
  1602. if (stage.Station == -1)
  1603. {
  1604. stage.Station = CurrentStation;
  1605. updates.Add(stage);
  1606. }
  1607. }
  1608. if (updates.Any())
  1609. using (new WaitCursor())
  1610. {
  1611. new Client<ManufacturingPacketStage>().Save(updates, "Cleared Shared flag from Packet");
  1612. Refresh();
  1613. }
  1614. }
  1615. private void MovePacketClick(object sender, RoutedEventArgs e)
  1616. {
  1617. var item = sender as MenuItem;
  1618. var station = (item.Parent as MenuItem).Items.IndexOf(item) + 1;
  1619. var updates = new List<ManufacturingPacketStage>();
  1620. var rows = (sender as MenuItem).Tag as IEnumerable<CoreRow>;
  1621. foreach (var row in rows)
  1622. {
  1623. var stage = row.ToObject<ManufacturingPacketStage>();
  1624. stage.Station = station;
  1625. updates.Add(stage);
  1626. }
  1627. if (updates.Any())
  1628. using (new WaitCursor())
  1629. {
  1630. new Client<ManufacturingPacketStage>().Save(updates, "Moved Packet to " + item.Header);
  1631. Refresh();
  1632. }
  1633. }
  1634. public void PDFEditorSettingsChanged(object sender, string linecolor, int fontsize)
  1635. {
  1636. settings.LineColor = linecolor;
  1637. settings.FontSize = fontsize;
  1638. new LocalConfiguration<FactoryFloorLocalSettings>().Save(settings);
  1639. }
  1640. #region Employee Stuff
  1641. private Dictionary<Guid, string> Employees = new() { { Guid.Empty, "" } };
  1642. private Guid myID = Guid.Empty;
  1643. private string myName = "";
  1644. #endregion
  1645. #region ManufacturingPacket Stuff
  1646. //FactorySetup settings = new GlobalConfiguration<FactorySetup>().Load();
  1647. //private Dictionary<Guid, Tuple<String,int>> Sections = new Dictionary<Guid, Tuple<String,int>>();
  1648. private ManufacturingFactory[] Factories; // new ManufacturingFactory[] { };
  1649. private ManufacturingSection[] Sections; // new ManufacturingSection[] { };
  1650. private ManufacturingTrolley[] Trolleys; // new ManufacturingTrolley[] { };
  1651. private CoreTable TemplateStages;
  1652. //private ManufacturingTemplateStage[] TemplateStages = null;
  1653. private CoreTable Questions;
  1654. //private IList<CoreRow> AllStages = new CoreRow[] { };
  1655. private CoreTable Packets;
  1656. private CoreTable Stages;
  1657. private ManufacturingSection CurrentSection;
  1658. private int CurrentStation;
  1659. private readonly bool PendingVisible = true;
  1660. private ManufacturingLostTime LostTime;
  1661. #endregion
  1662. #region Stuff to Do with Kanbans
  1663. public ObservableCollection<ManufacturingKanban> Kanbans { get; set; }
  1664. private string CurrentKanbanID = "";
  1665. private ManufacturingKanban CurrentKanban
  1666. {
  1667. get { return Kanbans.FirstOrDefault(x => x.ID == CurrentKanbanID); }
  1668. set => CurrentKanbanID = value != null ? value.ID : "";
  1669. }
  1670. private string SearchFilter = "";
  1671. //Border LastCard = null;
  1672. //Border[] CheckedPackets
  1673. //{
  1674. // get {
  1675. // List<Border> packets = new List<Border>();
  1676. // var cards = Kanban.Columns[0].Cards.Where(x => ((ManufacturingKanban)x.Content).Checked == true);
  1677. // foreach (var card in cards)
  1678. // {
  1679. // var prop = card.GetType().GetProperty("TemplateChild", BindingFlags.NonPublic | BindingFlags.Instance);
  1680. // var val = prop.GetValue(card) as DependencyObject;
  1681. // var border = FindVisualChildren<Border>(val).FirstOrDefault();
  1682. // packets.Add(border);
  1683. // }
  1684. // return packets.ToArray();
  1685. // }
  1686. //}
  1687. private void ClearAllSelections()
  1688. {
  1689. foreach (var kanban in Kanbans.Where(x => x.Checked))
  1690. kanban.Checked = false;
  1691. CurrentKanban = null;
  1692. //var cards = Kanban.Columns[0].Cards.Where(x => ((ManufacturingKanban)x.Content).Checked == true).ToArray();
  1693. //foreach (var card in cards)
  1694. // ((ManufacturingKanban)card.Content).Checked = false;
  1695. //CurrentKanban = null;
  1696. UpdateSelectedKanban();
  1697. }
  1698. private ManufacturingKanban GetKanban(Border border)
  1699. {
  1700. return border.Tag as ManufacturingKanban;
  1701. }
  1702. //private Border GetBorder(ManufacturingKanban kanban)
  1703. //{
  1704. // var card = Kanban.Columns[0].Cards.FirstOrDefault(x => ((ManufacturingKanban)x.Content) == kanban);
  1705. // var prop = card.GetType().GetProperty("TemplateChild", BindingFlags.NonPublic | BindingFlags.Instance);
  1706. // var val = prop.GetValue(card) as DependencyObject;
  1707. // return FindVisualChildren<Border>(val).FirstOrDefault();
  1708. //}
  1709. //private void CheckKanban(Border card, bool ischecked)
  1710. //{
  1711. // var chk = card.FindName("IsChecked") as CheckBox;
  1712. // chk.IsChecked = ischecked;
  1713. // card.ApplyTemplate();
  1714. //}
  1715. private void SelectKanban(Border card, bool isselected)
  1716. {
  1717. var img = card.FindName("IsCurrent") as Image;
  1718. img.Source = isselected ? starred : null;
  1719. }
  1720. private ManufacturingPacket KanbanToPacket(ManufacturingKanban kanban)
  1721. {
  1722. if (Packets == null)
  1723. return null;
  1724. var row = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(Guid.Parse(kanban.ID)));
  1725. if (row == null)
  1726. return null;
  1727. return row.ToObject<ManufacturingPacket>();
  1728. }
  1729. #endregion
  1730. #region Shipping Rack Stuff
  1731. private CoreTable Shipments;
  1732. private CoreTable DeliveryItems;
  1733. private readonly ObservableList<DeliveryItem> rackcontents = new();
  1734. private Guid rackid = Guid.Empty;
  1735. private string rackbarcode = "";
  1736. #endregion
  1737. #region Refresh / Reload
  1738. private string GetQualityStatus(QualityStatus status)
  1739. {
  1740. if (status == QualityStatus.Passed)
  1741. return "PASSED";
  1742. if (status == QualityStatus.Skipped)
  1743. return "SKIPPED";
  1744. if (status == QualityStatus.PassedWithIssues)
  1745. return "ISSUES";
  1746. if (status == QualityStatus.Failed)
  1747. return "FAILED";
  1748. return "QA";
  1749. }
  1750. private BitmapImage GetBarCode(CoreRow row)
  1751. {
  1752. var type = row.Get<ManufacturingPacket, BarcodeType>(c => c.BarcodeType);
  1753. if (!row.Get<ManufacturingPacket, DateTime>(c => c.BarcodePrinted).IsEmpty())
  1754. return type == BarcodeType.Grouped ? grouped : barcode;
  1755. if (type == BarcodeType.None)
  1756. return disabled;
  1757. return null;
  1758. }
  1759. private void CreateKanban(CoreRow pktrow, CoreRow stagerow, bool IsChecked)
  1760. {
  1761. var id = pktrow.Get<ManufacturingPacket, Guid>(c => c.ID);
  1762. //var stagerow = Stages.Rows.FirstOrDefault(r=>r.Get<ManufacturingPacketStage,Guid>(c=>c.Parent.ID).Equals(id));
  1763. if (stagerow == null)
  1764. return;
  1765. var station = stagerow.Get<ManufacturingPacketStage, int>(c => c.Station);
  1766. //var stage = stagerow.ToObject<ManufacturingPacketStage>();
  1767. if ((PendingVisible && station.Equals(0)) || station.Equals(-1) || station.Equals(CurrentStation))
  1768. {
  1769. var model = new ManufacturingKanban();
  1770. LoadModel(model, pktrow, stagerow, IsChecked);
  1771. Kanbans.Add(model);
  1772. }
  1773. }
  1774. private void LoadModel(ManufacturingKanban model, CoreRow packet, CoreRow stage, bool IsChecked)
  1775. {
  1776. var station = stage.Get<ManufacturingPacketStage, int>(c => c.Station);
  1777. var Pending = station == 0;
  1778. var quality = stage.Get<ManufacturingPacketStage, QualityStatus>(c => c.QualityStatus);
  1779. var percentage = stage.Get<ManufacturingPacketStage, double>(c => c.PercentageComplete);
  1780. var packetid = packet.Get<ManufacturingPacket, Guid>(c => c.ID);
  1781. var title = packet.Get<ManufacturingPacket, string>(c => c.Title);
  1782. var watermark = packet.Get<ManufacturingPacket, string>(c => c.WaterMark);
  1783. var issues = packet.Get<ManufacturingPacket, string>(c => c.Issues);
  1784. var trolleys = packet.Get<ManufacturingPacket, string>(c => c.Trolleys);
  1785. var serial = packet.Get<ManufacturingPacket, string>(c => c.Serial);
  1786. var quantity = packet.Get<ManufacturingPacket, int>(c => c.Quantity);
  1787. var barcodes = packet.Get<ManufacturingPacket, int>(c => c.BarcodeQty);
  1788. var setoutnumber = packet.Get<ManufacturingPacket, string>(c => c.SetoutLink.Number);
  1789. var jobname = packet.Get<ManufacturingPacket, string>(c => c.SetoutLink.JobLink.Name);
  1790. var duedate = packet.Get<ManufacturingPacket, DateTime>(c => c.DueDate);
  1791. var location = packet.Get<ManufacturingPacket, string>(c => c.Location);
  1792. var setoutlocation = packet.Get<ManufacturingPacket, string>(c => c.SetoutLink.Location);
  1793. var suppliercode = packet.Get<ManufacturingPacket, string>(c => c.OrderItem.PurchaseOrderLink.SupplierLink.Code);
  1794. var ponumber = packet.Get<ManufacturingPacket, string>(c => c.OrderItem.PurchaseOrderLink.PONumber);
  1795. var receiveddate = packet.Get<ManufacturingPacket, DateTime>(c => c.OrderItem.ReceivedDate);
  1796. var receivedreference = packet.Get<ManufacturingPacket, string>(c => c.OrderItem.ReceivedReference);
  1797. var priority = packet.Get<ManufacturingPacket, bool>(c => c.Priority);
  1798. var estimateddate = packet.Get<ManufacturingPacket, DateTime>(c => c.EstimatedDate);
  1799. var distributed = packet.Get<ManufacturingPacket, bool>(c => c.Distributed);
  1800. var packetsection = packet.Get<ManufacturingPacket, string>(c => c.StageLink.Section);
  1801. model.TemplateID = packet.Get<ManufacturingPacket, Guid>(c => c.ManufacturingTemplateLink.ID);
  1802. model.ID = packetid.ToString();
  1803. model.Title = string.Format(
  1804. "{0}: {1}{2}",
  1805. serial,
  1806. quantity != barcodes ? string.Format("{0} x ", quantity) : "",
  1807. title
  1808. );
  1809. if (!string.IsNullOrWhiteSpace(watermark))
  1810. model.Title = "[" + watermark + "] " + model.Title;
  1811. model.Quantity = barcodes;
  1812. model.JobName = string.Format("{0}: {1}", setoutnumber, jobname);
  1813. model.DueDate = duedate;
  1814. var descrip = new List<string>
  1815. {
  1816. string.IsNullOrEmpty(location) ? setoutlocation : location
  1817. };
  1818. if (packet.IsEntityLinkValid<ManufacturingPacket, PurchaseOrderItemLink>(x => x.OrderItem))
  1819. descrip.Add(string.Format("{0} ({1}) RCVD {2:dd MMM yy} {3}",
  1820. suppliercode,
  1821. ponumber,
  1822. receiveddate,
  1823. string.IsNullOrWhiteSpace(receivedreference) ? "" : ": " + receivedreference
  1824. ));
  1825. model.Description = string.Join("\n", descrip);
  1826. model.Image = GetBarCode(packet);
  1827. //model.IsCurrent = packet.ID.ToString() == CurrentKanbanID ? starred : null;
  1828. model.IsSelected = packet.Get<ManufacturingPacket, Guid>(c => c.ID).ToString() == CurrentKanbanID;
  1829. model.Tags = priority
  1830. ? new[] { "PRIORITY" }
  1831. : new string[] { };
  1832. model.Category = CurrentSection != null
  1833. ? CurrentSection.ID.ToString()
  1834. : ""; // packet.StageLink.SectionID.ToString();
  1835. model.ColorKey = packet.IsEntityLinkValid<ManufacturingPacket, PurchaseOrderItemLink>(x => x.OrderItem)
  1836. ? TREATED_COLOR
  1837. : priority
  1838. ? PRIORITY_COLOR
  1839. : !Pending
  1840. ? GetColor(duedate.IsEmpty()
  1841. ? DateTime.Today
  1842. : duedate, estimateddate.IsEmpty()
  1843. ? DateTime.Today
  1844. : estimateddate)
  1845. : QA_COLOR;
  1846. model.SelectedColor = packet.Get<ManufacturingPacket, Guid>(c => c.ID).ToString() == CurrentKanbanID
  1847. ? SELECTED_COLOR
  1848. : model.ColorKey;
  1849. model.SharedColor = station.Equals(-1)
  1850. ? SHARED_COLOR
  1851. : model.ColorKey;
  1852. model.Checked = IsChecked;
  1853. model.SetoutID = packet.Get<ManufacturingPacket, Guid>(c => c.SetoutLink.ID);
  1854. model.Assignee = Pending
  1855. ? "Not Yet Started"
  1856. : "Current Workload";
  1857. model.Status = !Entity.IsEntityLinkValid<ManufacturingPacket, ManufacturingPacketStageLink>(x => x.StageLink, packet)
  1858. ? " "
  1859. : Pending
  1860. ? "PENDING"
  1861. : string.Format("{0:F0}%", percentage);
  1862. try
  1863. {
  1864. model.Flags = distributed
  1865. ? !packet.Get<ManufacturingPacket, Guid>(c => c.StageLink.SectionID).Equals(CurrentSection.ID)
  1866. ? string.IsNullOrEmpty(packetsection)
  1867. ? ""
  1868. : packetsection.ToUpper().Trim()
  1869. : "DISTRIB"
  1870. : "";
  1871. }
  1872. catch (Exception e)
  1873. {
  1874. Logger.Send(LogType.Error, "", string.Format("*** Unknown Error: {0}\n{1}", e.Message, e.StackTrace));
  1875. }
  1876. model.Issues = issues;
  1877. model.IssuesImage = string.IsNullOrWhiteSpace(issues)
  1878. ? null
  1879. : speechbubble;
  1880. model.Trolleys = trolleys;
  1881. }
  1882. private string GetColor(DateTime duedate, DateTime estdate)
  1883. {
  1884. var color = NOTYETDUE_COLOR;
  1885. if (duedate < estdate)
  1886. color = OVERDUE_COLOR;
  1887. else if (duedate < estdate.AddDays(7))
  1888. color = NEARLYDUE_COLOR;
  1889. return color;
  1890. }
  1891. private void ReloadPackets(bool reloaddata)
  1892. {
  1893. using (new WaitCursor())
  1894. {
  1895. if (reloaddata)
  1896. {
  1897. var sectionid = CurrentSection != null ? CurrentSection.ID : CoreUtils.FullGuid;
  1898. var query = new MultiQuery();
  1899. var stageflt = new Filter<ManufacturingPacketStage>(x => x.Completed).IsEqualTo(DateTime.MinValue)
  1900. .Or(x => x.ManufacturingSectionLink.ID).IsEqualTo(CurrentSection.ID);
  1901. stageflt.Ands.Add(
  1902. new Filter<ManufacturingPacketStage>(x => x.Parent.StageLink.SectionID).IsEqualTo(sectionid)
  1903. .Or(x => x.Parent.Distributed).IsEqualTo(true)
  1904. );
  1905. query.Add(
  1906. stageflt,
  1907. new Columns<ManufacturingPacketStage>(x => x.ID)
  1908. .Add(x => x.Parent.ID)
  1909. .Add(x => x.Station)
  1910. .Add(x => x.QualityStatus)
  1911. .Add(x => x.PercentageComplete)
  1912. .Add(x => x.Time)
  1913. .Add(x => x.Started)
  1914. .Add(x => x.FormData)
  1915. .Add(x => x.Completed)
  1916. .Add(x => x.FormCompleted)
  1917. .Add(x => x.FormCompletedBy.ID)
  1918. .Add(x => x.Sequence)
  1919. .Add(x => x.QualityNotes)
  1920. .Add(x => x.SectionID)
  1921. .Add(x => x.ManufacturingSectionLink.ID)
  1922. );
  1923. var pktfilter = new Filter<ManufacturingPacket>(x => x.Completed).IsLessThan(DateTime.MinValue.AddDays(1))
  1924. .And(x => x.Archived).IsLessThan(DateTime.MinValue.AddDays(1))
  1925. .And(x => x.OnHold).IsEqualTo(false)
  1926. .And(new Filter<ManufacturingPacket>(x => x.OrderItem).NotLinkValid().Or(x => x.OrderItem.ReceivedDate)
  1927. .IsNotEqualTo(DateTime.MinValue))
  1928. .And(new Filter<ManufacturingPacket>(x => x.StageLink.SectionID).IsEqualTo(sectionid).Or(x => x.Distributed).IsEqualTo(true));
  1929. if (!string.IsNullOrWhiteSpace(SearchFilter))
  1930. pktfilter = pktfilter.TextSearch(
  1931. SearchFilter,
  1932. x => x.SetoutLink.JobLink.JobNumber,
  1933. x => x.SetoutLink.JobLink.Name,
  1934. x => x.SetoutLink.Number,
  1935. x => x.SetoutLink.Location,
  1936. //x => x.SetoutLink.Reference,
  1937. x => x.Title,
  1938. x => x.Serial,
  1939. x => x.Trolleys,
  1940. x => x.Location
  1941. );
  1942. var pktcolumns = new Columns<ManufacturingPacket>(x => x.ID)
  1943. .Add(x => x.Serial)
  1944. .Add(x => x.Title)
  1945. .Add(x => x.Quantity)
  1946. .Add(x => x.BarcodeQty)
  1947. .Add(x => x.SetoutLink.ID)
  1948. .Add(x => x.SetoutLink.Number)
  1949. .Add(x => x.SetoutLink.JobLink.JobNumber)
  1950. .Add(x => x.SetoutLink.JobLink.Name)
  1951. .Add(x => x.DueDate)
  1952. .Add(x => x.SetoutLink.Location)
  1953. //.Add(x => x.SetoutLink.Reference)
  1954. .Add(x => x.Priority)
  1955. .Add(x => x.EstimatedDate)
  1956. .Add(x => x.Distributed)
  1957. .Add(x => x.StageLink.ID)
  1958. .Add(x => x.StageLink.SectionID)
  1959. .Add(x => x.StageLink.Section)
  1960. .Add(x => x.StageLink.Deleted)
  1961. .Add(x => x.BarcodePrinted)
  1962. .Add(x => x.BarcodeType)
  1963. .Add(x => x.ManufacturingTemplateLink.ID)
  1964. .Add(x => x.ManufacturingTemplateLink.Name)
  1965. .Add(x => x.ManufacturingTemplateLink.Code)
  1966. //.Add(x => x.CustomAttributes)
  1967. .Add(x => x.Trolleys)
  1968. .Add(x => x.Location)
  1969. .Add(x => x.Group)
  1970. .Add(x => x.Height)
  1971. .Add(x => x.Width)
  1972. .Add(x => x.Length)
  1973. .Add(x => x.OrderItem.ID)
  1974. .Add(x => x.OrderItem.Deleted)
  1975. .Add(x => x.OrderItem.PurchaseOrderLink.SupplierLink.Code)
  1976. .Add(x => x.OrderItem.PurchaseOrderLink.PONumber)
  1977. .Add(x => x.OrderItem.Consignment.EstimatedWarehouseArrival)
  1978. .Add(x => x.OrderItem.ReceivedReference)
  1979. //.Add(x => x.Zone.Code)
  1980. //.Add(x => x.Level.Code)
  1981. .Add(x => x.OrderItem.ReceivedDate)
  1982. .Add(x => x.WaterMark)
  1983. .Add(x => x.Issues)
  1984. .Add(x => x.OnHold)
  1985. .Add(DatabaseSchema.Properties(typeof(ManufacturingPacket))
  1986. .Where(x => x is CustomProperty)
  1987. .Select(x => x.Name).ToArray()
  1988. );
  1989. query.Add(
  1990. pktfilter,
  1991. pktcolumns,
  1992. new SortOrder<ManufacturingPacket>(x => x.Priority, SortDirection.Descending).ThenBy(x => x.SetoutLink.Number)
  1993. );
  1994. query.Add(
  1995. new Filter<DeliveryItem>(x => x.DeliveredDate).IsEqualTo(DateTime.MinValue)
  1996. .And(x => x.ManufacturingPacketLink).LinkValid(),
  1997. new Columns<DeliveryItem>(
  1998. x => x.ID,
  1999. x => x.Barcode,
  2000. x => x.ManufacturingPacketLink.ID,
  2001. x => x.ManufacturingPacketLink.Serial,
  2002. x => x.Description,
  2003. x => x.ShipmentLink.ID)
  2004. );
  2005. query.Query();
  2006. Stages = query.Get<ManufacturingPacketStage>();
  2007. Packets = query.Get<ManufacturingPacket>();
  2008. DeliveryItems = query.Get<DeliveryItem>();
  2009. }
  2010. var checks = Kanbans.Where(x => x.Checked).Select(x => x.ID).ToArray();
  2011. Kanbans.Clear();
  2012. foreach (var pktrow in Packets.Rows)
  2013. {
  2014. var id = pktrow.Get<ManufacturingPacket, Guid>(c => c.ID);
  2015. var distributed = pktrow.Get<ManufacturingPacket, bool>(c => c.Distributed);
  2016. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(id)
  2017. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  2018. .Equals(settings.Section));
  2019. //this was commented out previously - leading to the distributed packet issue. Uncommented and tested to work by Nick. Was there a reason for commenting this out?
  2020. bool bOK = true;
  2021. if (distributed)
  2022. bOK = stagerow?.Get<ManufacturingPacketStage, DateTime>(c => c.Completed).IsEmpty() == true;
  2023. if (bOK)
  2024. CreateKanban(pktrow, stagerow, checks.Contains(id.ToString()));
  2025. }
  2026. var sorted = Kanbans.OrderBy(x => x.Assignee).ThenByDescending(x => x.Tags.Length).ThenBy(x => x.DueDate).ThenBy(x => x.JobName);
  2027. if (CurrentKanban != null && !Kanbans.Contains(CurrentKanban))
  2028. CurrentKanban = sorted.FirstOrDefault();
  2029. Kanban.ItemsSource = null;
  2030. Kanban.ItemsSource =
  2031. sorted; //Kanbans.OrderBy(x => x.Assignee).ThenByDescending(x => x.Tags.Length).ThenBy(x => x.DueDate).ThenBy(x => x.JobName);
  2032. UpdateSelectedKanban();
  2033. }
  2034. }
  2035. private void DoRefresh(bool reloaddata)
  2036. {
  2037. if (!IsReady || Sections == null || !Sections.Any())
  2038. return;
  2039. ReloadPackets(reloaddata);
  2040. //LoadKanban();
  2041. }
  2042. public void Refresh()
  2043. {
  2044. DoRefresh(true);
  2045. }
  2046. #endregion
  2047. #region QAChecks
  2048. private IEnumerable<QAQuestion> LoadQAQuestions(ManufacturingPacket packet, bool section, bool template)
  2049. {
  2050. if (Questions == null)
  2051. Questions = new Client<QAQuestion>().Query();
  2052. if (TemplateStages == null)
  2053. TemplateStages = new Client<ManufacturingTemplateStage>().Query();
  2054. var tstage = TemplateStages.Rows.FirstOrDefault(r =>
  2055. r.Get<ManufacturingTemplateStage, Guid>(c => c.Template.ID).Equals(packet.ManufacturingTemplateLink.ID) &&
  2056. r.Get<ManufacturingTemplateStage, Guid>(c => c.Section.ID).Equals(CurrentSection.ID));
  2057. IEnumerable<CoreRow> rows = null;
  2058. if (section && !template)
  2059. rows = Questions.Rows.Where(r => r.Get<QAQuestion, Guid>(c => c.QAForm.ID).Equals(CurrentSection.QAForm.ID));
  2060. if (!section && template)
  2061. rows = Questions.Rows.Where(r =>
  2062. r.Get<QAQuestion, Guid>(c => c.QAForm.ID).Equals(tstage.Get<ManufacturingTemplateStage, Guid>(x => x.QAForm.ID)));
  2063. if (section && template)
  2064. rows = Questions.Rows.Where(r =>
  2065. r.Get<QAQuestion, Guid>(c => c.QAForm.ID).Equals(CurrentSection.QAForm.ID) || r.Get<QAQuestion, Guid>(c => c.QAForm.ID)
  2066. .Equals(tstage.Get<ManufacturingTemplateStage, Guid>(x => x.QAForm.ID)));
  2067. var result = rows.Where(r => r.Get<QAQuestion, bool>(c => c.QAForm.Active).Equals(true)).Select(r => r.ToObject<QAQuestion>());
  2068. return result;
  2069. }
  2070. private void ViewQualityChecks(object sender, RoutedEventArgs e)
  2071. {
  2072. SetCurrentButton(sender as Button);
  2073. LoadDrawing(Guid.Empty);
  2074. }
  2075. private void QAGridChanged(object sender, Dictionary<Guid, object> values)
  2076. {
  2077. SaveQAData(values);
  2078. }
  2079. private void SaveQAData(Dictionary<Guid, object> values)
  2080. {
  2081. var updates = new List<ManufacturingPacketStage>();
  2082. var cks = Kanbans.Where(x => x.Checked);
  2083. foreach (var ck in cks)
  2084. {
  2085. //var row = Packets.Rows.FirstOrDefault(r => r.Get<ManufacturingPacket, Guid>(c => c.ID).Equals(ck.ID));
  2086. var stagerow = Stages.Rows.FirstOrDefault(r => r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(Guid.Parse(ck.ID))
  2087. && r.Get<ManufacturingPacketStage, Guid>(c => c.ManufacturingSectionLink.ID)
  2088. .Equals(settings.Section));
  2089. if (stagerow != null)
  2090. {
  2091. var stage = stagerow.ToObject<ManufacturingPacketStage>();
  2092. stage.Form.ID = CurrentSection.QAForm.ID;
  2093. stage.FormData = Serialization.Serialize(values);
  2094. stagerow.Set<ManufacturingPacketStage, string>(x => x.FormData, stage.FormData);
  2095. updates.Add(stage);
  2096. }
  2097. }
  2098. if (updates.Any())
  2099. Task.Run(() => { new Client<ManufacturingPacketStage>().Save(updates, "", (o, e) => { }); });
  2100. }
  2101. private void UpdateQuality(QualityStatus status, string note = null)
  2102. {
  2103. var selected = new List<ManufacturingPacket>();
  2104. var stages = new List<ManufacturingPacketStage>();
  2105. foreach (var kanban in Kanbans.Where(x => x.Checked || x.IsSelected))
  2106. {
  2107. selected.Add(KanbanToPacket(kanban));
  2108. var pktid = Guid.Parse(kanban.ID);
  2109. var stagerows = Stages.Rows.Where(r =>
  2110. r.Get<ManufacturingPacketStage, Guid>(c => c.SectionID).Equals(CurrentSection.ID) &&
  2111. r.Get<ManufacturingPacketStage, Guid>(c => c.Parent.ID).Equals(pktid));
  2112. stages.AddRange(stagerows.Select(r => r.ToObject<ManufacturingPacketStage>()));
  2113. }
  2114. if (note == null)
  2115. {
  2116. var form = new NotesForm(Employees) { Caption = "Please detail the quality issues identified with these item(s)" };
  2117. if (form.ShowDialog() != true) return;
  2118. note = form.Text;
  2119. if (form.EmployeeID != Guid.Empty)
  2120. {
  2121. var task = new Kanban();
  2122. task.DueDate = DateTime.Today;
  2123. task.Category = "Open";
  2124. task.EmployeeLink.ID = form.EmployeeID;
  2125. task.ManagerLink.ID = myID;
  2126. task.Title = "QA Issues : " + CurrentSection.Factory.Name + ": " + CurrentSection.Name;
  2127. //task.JobLink.ID = packet.JobLink.ID;
  2128. var details = new List<string>();
  2129. details.Add(form.Text);
  2130. details.Add("");
  2131. details.Add("The following packets are affected by this issue:");
  2132. foreach (var sel in selected)
  2133. details.Add(string.Format("- {0}: {1} ({2})", sel.SetoutLink.Number, sel.Title,
  2134. string.IsNullOrEmpty(sel.Location) ? sel.SetoutLink.Location : sel.Location));
  2135. task.Notes = new[] { string.Join("\n", details) };
  2136. new Client<Kanban>().Save(task, "Created task from Factory Floor");
  2137. note = note + "\n" + "** Task Created for " + task.EmployeeLink.Name;
  2138. }
  2139. }
  2140. foreach (var stage in stages)
  2141. {
  2142. stage.Station = 0;
  2143. stage.QualityStatus = status;
  2144. if (!string.IsNullOrWhiteSpace(note))
  2145. {
  2146. if (!string.IsNullOrWhiteSpace(stage.QualityNotes))
  2147. stage.QualityNotes = string.Format("{0}\n\n{1}", stage.QualityNotes, note);
  2148. else
  2149. stage.QualityNotes = note;
  2150. }
  2151. }
  2152. Progress.Show("");
  2153. new Client<ManufacturingPacketStage>().Save(stages, note);
  2154. DoRefresh(true);
  2155. Progress.Close();
  2156. }
  2157. #endregion
  2158. }
  2159. }