| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using InABox.Core;
- using InABox.Clients;
- using Comal.Classes;
- using Xamarin.Forms;
- using Xamarin.Forms.Xaml;
- using XF.Material.Forms.UI.Dialogs;
- using Xamarin.Essentials;
- using System.IO;
- using PRSSecurity = InABox.Core.Security;
- namespace comal.timesheets
- {
- [XamlCompilation(XamlCompilationOptions.Compile)]
- public partial class Receivals : ContentPage
- {
- #region Fields & Constructor, OnAppearing
- Guid POID = Guid.Empty;
- List<POItemShell> poItemShells = new List<POItemShell>();
- List<StockLocationShell> stockLocationShells = new List<StockLocationShell>();
- bool bOpening = false;
- List<Guid> holdingsToLookup = new List<Guid>();
- string deviceType = "";
- Guid supplierID = Guid.Empty;
- string PONumber = "";
- Guid consignmentID = Guid.Empty;
- string consignmentNumber = "";
- List<POItemShell> listReceived = new List<POItemShell>();
- public Receivals(Guid _poID, string _PONumber, Guid _supplierID)
- {
- InitializeComponent();
- NavigationPage.SetHasBackButton(this, false);
- POID = _poID;
- PONumber = _PONumber;
- poNumberLbl.Text = "PO: " + _PONumber;
- var idiom = DeviceInfo.Idiom;
- if (idiom.Equals(DeviceIdiom.Tablet))
- {
- deviceType = "Tablet";
- }
- LoadPOItems();
- supplierID = _supplierID;
- AddIncomingStores();
- }
- protected override void OnAppearing()
- {
- base.OnAppearing();
- bOpening = false;
- }
- #endregion
- #region User Interaction
- private async void Exit_Clicked(object sender, EventArgs e)
- {
- if (listReceived.Count > 0)
- {
- DisplayAlert("Alert", "Consignment has items received and must be saved with photos before exiting", "OK");
- }
- else
- Navigation.PopAsync();
- }
- private async void Save_Clicked(object sender, EventArgs e)
- {
- ConsignmentCompletionPage completionPage = new ConsignmentCompletionPage(listReceived, consignmentID, consignmentNumber);
- completionPage.OnConsignmentSaved += () =>
- {
- Navigation.PopAsync();
- };
- Navigation.PushAsync(completionPage);
- }
- private void ConsignmentList_Tapped(object sender, EventArgs e)
- {
- if (bOpening)
- return;
- if (!PRSSecurity.IsAllowed<CanReceiveConsignments>())
- {
- DisplayAlert("Not allowed", "Please check security setting: Receive Consignments", "OK");
- return;
- }
- bOpening = true;
- POItemShell poItemShell = poItemListView.SelectedItem as POItemShell;
- if (poItemShell.Nonstock == true)
- {
- ChooseQtyNonStockItem(poItemShell);
- }
- else
- {
- ChooseQtyStockItem(poItemShell);
- }
- }
- private async void ChooseQtyStockItem(POItemShell poItemShell)
- {
- ConsignmentDetailsPopup popup = new ConsignmentDetailsPopup(poItemShell, stockLocationShells);
- popup.OnConsignmentPopupAccepted += async () =>
- {
- using (await MaterialDialog.Instance.LoadingDialogAsync(message: "Loading"))
- {
- poItemShell.StockLocationID = popup._POItemShell.StockLocationID;
- poItemShell.StockLocationCode = popup._POItemShell.StockLocationCode;
- poItemShell.StockLocationDescription = popup._POItemShell.StockLocationDescription;
- poItemShell.ReceivedQty = popup._POItemShell.ReceivedQty;
- StockLocationShell location = stockLocationShells.Find(x => x.ID.Equals(poItemShell.StockLocationID));
- if (location == null)
- {
- StockLocationShell newLocation = new StockLocationShell()
- {
- ID = poItemShell.StockLocationID,
- Code = poItemShell.StockLocationCode,
- Description = poItemShell.StockLocationDescription
- };
- stockLocationShells.Add(newLocation);
- }
- ChooseSavePathwayAsync(poItemShell);
- }
- };
- Navigation.PushAsync(popup);
- bOpening = false;
- }
- private async void ChooseQtyNonStockItem(POItemShell poItemShell)
- {
- Device.BeginInvokeOnMainThread(async () =>
- {
- //if nonstock item - only rec qty, otherwise open popup page
- string chosenOption = await DisplayPromptAsync("Enter Received Quantity", "", initialValue: poItemShell.ExpectedQty.ToString(), keyboard: Keyboard.Numeric);
- if (!string.IsNullOrEmpty(chosenOption) || chosenOption != "Cancel")
- {
- try
- {
- double qty = double.Parse(chosenOption);
- poItemShell.ReceivedQty = qty;
- }
- catch
- {
- DisplayAlert("Error", "Invalid Qty", "OK");
- bOpening = false;
- return;
- }
- bOpening = false;
- ChooseSavePathwayAsync(poItemShell);
- }
- else
- bOpening = false;
- });
- }
- private void SearchEnt_Changed(object sender, EventArgs e)
- {
- if (string.IsNullOrWhiteSpace(searchEnt.Text))
- {
- poItemListView.ItemsSource = poItemShells;
- }
- else
- {
- poItemListView.ItemsSource = poItemShells.Where(x =>
- x.Description.Contains(searchEnt.Text) || x.Description.Contains(UpperCaseFirst(searchEnt.Text)) || x.Description.Contains(LowerCaseFirst(searchEnt.Text))
- || x.Description.Contains(searchEnt.Text.ToUpper()) || x.Description.Contains(searchEnt.Text.ToLower()) ||
- x.ExpectedQty.ToString().Contains(searchEnt.Text)
- );
- }
- }
- static String UpperCaseFirst(string s)
- {
- char[] a = s.ToCharArray();
- a[0] = char.ToUpper(a[0]);
- return new string(a);
- }
- static String LowerCaseFirst(string s)
- {
- char[] a = s.ToCharArray();
- a[0] = char.ToLower(a[0]);
- return new string(a);
- }
- #endregion
- #region Saving
- private async Task ChooseSavePathwayAsync(POItemShell poItemShell)
- {
- if (consignmentID == Guid.Empty)
- await CreateNewConsignment();
- if (poItemShell.ReceivedQty == poItemShell.ExpectedQty)
- {
- SaveCorrectQuantityPOItem(poItemShell);
- }
- else if (poItemShell.ReceivedQty < poItemShell.ExpectedQty && poItemShell.ReceivedQty != 0)
- {
- SaveLesserQuantityPOItem(poItemShell);
- }
- else if (poItemShell.ReceivedQty > poItemShell.ExpectedQty)
- {
- SaveExtraQuantityPOItem(poItemShell);
- }
- }
- private async void SaveCorrectQuantityPOItem(POItemShell poItemShell)
- {
- await Task.Run(() =>
- {
- poItemShell.ReceivedQty = poItemShell.ExpectedQty;
- poItemShell.ReceivedDate = DateTime.Now;
- poItemShell.ConsignmentID = consignmentID;
- poItemShell.ConsignmentNumber = consignmentNumber;
- SavePOItem(poItemShell);
- int index = poItemShells.FindIndex(x => x.ID.Equals(poItemShell.ID));
- poItemShells.RemoveAt(index);
- RefreshLists(poItemShell);
- });
- }
- private void SavePOItem(POItemShell poItemShell)
- {
- Task.Run(() =>
- {
- listReceived.Add(poItemShell);
- PurchaseOrderItem purchaseOrderItem = new PurchaseOrderItem();
- purchaseOrderItem.Description = poItemShell.Description;
- purchaseOrderItem.ID = poItemShell.ID;
- purchaseOrderItem.Qty = poItemShell.ReceivedQty;
- purchaseOrderItem.ReceivedDate = DateTime.Now;
- purchaseOrderItem.Consignment.ID = consignmentID;
- purchaseOrderItem.PurchaseOrderLink.PONumber = poItemShell.PONumber;
- purchaseOrderItem.PurchaseOrderLink.ID = poItemShell.POID;
- purchaseOrderItem = CopyDetails(purchaseOrderItem, poItemShell);
- new Client<PurchaseOrderItem>().Save(purchaseOrderItem, "Updated from mobile device");
- });
- }
- private void RefreshLists(POItemShell poItemShell)
- {
- Device.BeginInvokeOnMainThread(() =>
- {
- poItemListView.ItemsSource = null;
- poItemListView.ItemsSource = poItemShells;
- poItemCountLbl.Text = "Items Unreceived: " + poItemShells.Count;
- if (poItemShell.StockLocationID != Guid.Empty)
- {
- StockLocationShell location = stockLocationShells.Find(x => x.ID.Equals(poItemShell.StockLocationID));
- location.PoItems.Add(poItemShell);
- location.NumberOfReceivedItems = "Received items: " + location.PoItems.Count;
- locationsStackLayout.Children.Clear();
- foreach (StockLocationShell shell in stockLocationShells)
- {
- StockLocationViewCell viewcell = new StockLocationViewCell(shell);
- locationsStackLayout.Children.Add(viewcell);
- }
- }
- });
- }
- private async void SaveLesserQuantityPOItem(POItemShell poItemShell)
- {
- using (await MaterialDialog.Instance.LoadingDialogAsync(message: "Loading"))
- {
- try
- {
- string originalDescription = poItemShell.Description;
- int index = poItemShells.FindIndex(x => x.ID.Equals(poItemShell.ID));
- poItemShells.RemoveAt(index);
- //placeholder added while all the loading / saving happens - to be replaced later when new purchaseorderitem ID is returned
- POItemShell placeHolderShell = poItemShell.DuplicateNewShell(poItemShell);
- placeHolderShell.ExpectedQty = poItemShell.ExpectedQty - poItemShell.ReceivedQty;
- poItemShells.Insert(index, placeHolderShell);
- SavePOItem(poItemShell); //original POItem is saved
- CoreTable table = new Client<PurchaseOrderItem>().Query(new Filter<PurchaseOrderItem>(x => x.ID).IsEqualTo(poItemShell.ID),
- columns);
- PurchaseOrderItem purchaseOrderItem = table.Rows.FirstOrDefault()?.ToObject<PurchaseOrderItem>();
- if (purchaseOrderItem == null)
- return;
- purchaseOrderItem.ID = Guid.Empty;
- purchaseOrderItem.Created = DateTime.Now;
- purchaseOrderItem.LastUpdate = DateTime.Now;
- purchaseOrderItem.OriginalValues.Remove("ID", out object obj);
- purchaseOrderItem.ReceivedDate = DateTime.MinValue;
- purchaseOrderItem.Qty = poItemShell.ExpectedQty - poItemShell.ReceivedQty;
- purchaseOrderItem.Description = originalDescription;
- purchaseOrderItem.Consignment.ID = Guid.Empty;
- purchaseOrderItem = CopyDetails(purchaseOrderItem, poItemShell);
- new Client<PurchaseOrderItem>().Save(purchaseOrderItem, "Update from mobile device");
- //new purchase order is split from original with different quantity and no consignment linked, saved to database
- POItemShell newShell = poItemShell.DuplicateNewShell(poItemShell);
- newShell.ID = purchaseOrderItem.ID;
- newShell.Description = purchaseOrderItem.Description;
- newShell.ExpectedQty = purchaseOrderItem.Qty;
- newShell.ConsignmentID = Guid.Empty;
- newShell.ConsignmentNumber = "";
- //placeholder is replaced by new shell with correct ID
- poItemShells.RemoveAt(index);
- poItemShells.Insert(index, newShell);
- RefreshLists(poItemShell);
- }
- catch { }
- }
- }
- private async void SaveExtraQuantityPOItem(POItemShell poItemShell)
- {
- await Task.Run(() =>
- {
- try
- {
- string originalDescription = poItemShell.Description;
- double originalExpectedQty = poItemShell.ExpectedQty;
- double originalReceivedQty = poItemShell.ReceivedQty;
- double extraSupplied = originalReceivedQty - originalExpectedQty;
- int index = poItemShells.FindIndex(x => x.ID.Equals(poItemShell.ID));
- poItemShells.RemoveAt(index);
- poItemShell.ReceivedDate = DateTime.Now;
- poItemShell.ConsignmentID = consignmentID;
- poItemShell.ConsignmentNumber = consignmentNumber;
- poItemShell.ReceivedQty = poItemShell.ExpectedQty;
- SavePOItem(poItemShell);
- RefreshLists(poItemShell);
- listReceived.Add(poItemShell);
- //for responsive view only
- POItemShell newShell = poItemShell.DuplicateNewShell(poItemShell);
- newShell.ReceivedQty = extraSupplied;
- newShell.ExpectedQty = extraSupplied;
- RefreshLists(newShell);
- listReceived.Add(newShell);
- CoreTable table = new Client<PurchaseOrderItem>().Query(new Filter<PurchaseOrderItem>(x => x.ID).IsEqualTo(poItemShell.ID)
- , columns);
- PurchaseOrderItem newPurchaseOrderItem = table.Rows.FirstOrDefault().ToObject<PurchaseOrderItem>();
- if (newPurchaseOrderItem == null)
- return;
- newPurchaseOrderItem.ReceivedDate = DateTime.Now;
- newPurchaseOrderItem.ID = Guid.Empty;
- newPurchaseOrderItem.Created = DateTime.Now;
- newPurchaseOrderItem.LastUpdate = DateTime.Now;
- newPurchaseOrderItem.OriginalValues.Remove("ID", out object obj);
- newPurchaseOrderItem.Qty = extraSupplied;
- newPurchaseOrderItem.Description = newShell.Description;
- newPurchaseOrderItem.Consignment.ID = consignmentID;
- newPurchaseOrderItem = CopyDetails(newPurchaseOrderItem, poItemShell);
- new Client<PurchaseOrderItem>().Save(newPurchaseOrderItem, "Update from mobile device");
- //new purchase order is split from original with different quantity, and consignment linked, saved to database
- }
- catch
- { }
- });
- }
- private PurchaseOrderItem CopyDetails(PurchaseOrderItem purchaseOrderItem, POItemShell poItemShell)
- {
- purchaseOrderItem.Product.ID = poItemShell.ProductID;
- purchaseOrderItem.Product.NonStock = poItemShell.Nonstock;
- purchaseOrderItem.Job.ID = poItemShell.JobID;
- purchaseOrderItem.Job.JobNumber = poItemShell.JobNumber;
- purchaseOrderItem.Job.Name = poItemShell.JobName;
- purchaseOrderItem.Style.ID = poItemShell.StyleID;
- purchaseOrderItem.Style.Code = poItemShell.StyleCode;
- purchaseOrderItem.Style.Description = poItemShell.StyleDescription;
- purchaseOrderItem.StockLocation.ID = poItemShell.StockLocationID;
- purchaseOrderItem.StockLocation.Description = poItemShell.StockLocationDescription;
- purchaseOrderItem.StockLocation.Code = poItemShell.StockLocationCode;
- purchaseOrderItem.Dimensions.Unit.ID = poItemShell.DimensionsUnitID;
- purchaseOrderItem.Dimensions.Quantity = poItemShell.DimensionsQuantity;
- purchaseOrderItem.Dimensions.Length = poItemShell.DimensionsLength;
- purchaseOrderItem.Dimensions.Width = poItemShell.DimensionsWidth;
- purchaseOrderItem.Dimensions.Height = poItemShell.DimensionsHeight;
- purchaseOrderItem.Dimensions.Weight = poItemShell.DimensionsWeight;
- purchaseOrderItem.Cost = poItemShell.Cost;
- purchaseOrderItem.Dimensions.Unit.HasHeight = poItemShell.DimensionsHasHeight;
- purchaseOrderItem.Dimensions.Unit.HasLength = poItemShell.DimensionsHasLength;
- purchaseOrderItem.Dimensions.Unit.HasWidth = poItemShell.DimensionsHasWidth;
- purchaseOrderItem.Dimensions.Unit.HasWeight = poItemShell.DimensionsHasWeight;
- purchaseOrderItem.Dimensions.Unit.HasQuantity = poItemShell.DimensionsHasQuantity;
- purchaseOrderItem.Dimensions.Unit.Formula = poItemShell.DimensionsUnitFormula;
- purchaseOrderItem.Dimensions.Unit.Format = poItemShell.DimensionsUnitFormat;
- purchaseOrderItem.Dimensions.Unit.Code = poItemShell.DimensionsUnitCode;
- purchaseOrderItem.Dimensions.Unit.Description = poItemShell.DimensionsUnitDescription;
- purchaseOrderItem.Dimensions.UnitSize = poItemShell.DimensionsUnitSize;
- purchaseOrderItem.Dimensions.Value = poItemShell.DimensionsValue;
- return purchaseOrderItem;
- }
- #region ChoosingLocations
- private async void ChooseReceivingLocationBtn_Clicked(object sender, EventArgs e)
- {
- string chosenOption = await DisplayActionSheet("Choose an Option", "Cancel", null, "New Location / Pack", "Existing Location / Pack");
- switch (chosenOption)
- {
- case "Cancel":
- return;
- break;
- case "New Location / Pack":
- ChooseNewLocation();
- break;
- case "Existing Location / Pack":
- ChooseReceivingLocation();
- break;
- default:
- return;
- break;
- }
- }
- private void ChooseNewLocation()
- {
- try
- {
- StockLocation location = new StockLocation();
- location.Active = true;
- location.Warehouse.ID = Guid.Parse("b6249c4a-a834-4927-a42c-87a07895d6bd"); //EXTRUSIONS
- location.Warehouse.Description = "Extrusions";
- location.Warehouse.Code = "EXTRUSIONS";
- location.Area.Warehouse.ID = Guid.Parse("b6249c4a-a834-4927-a42c-87a07895d6bd"); //EXTRUSIONS
- location.Area.Warehouse.Description = "Extrusions";
- location.Area.ID = Guid.Parse("fa02ecd8-e642-49aa-98b5-c04d7ea0f4eb"); //Rack FLOOR
- location.Area.Description = "Rack FLOOR";
- location.Area.Code = "FLOOR";
- LocationDetailsPage locationDetailsPage = new LocationDetailsPage(location);
- locationDetailsPage.OnSave += (o, loc) =>
- {
- if (String.IsNullOrWhiteSpace(loc.Code))
- {
- MaterialDialog.Instance.AlertAsync(message: "Code may not be blank!");
- return false;
- }
- if (String.IsNullOrWhiteSpace(loc.Description))
- {
- MaterialDialog.Instance.AlertAsync(message: "Description may not be blank!");
- return false;
- }
- if (loc.Area.ID == Guid.Empty)
- {
- MaterialDialog.Instance.AlertAsync(message: "Area may not be blank!");
- return false;
- }
- CoreTable others = new Client<StockLocation>().Query(
- new Filter<StockLocation>(x => x.Code).IsEqualTo(loc.Code).And(x => x.ID).IsNotEqualTo(loc.ID),
- new Columns<StockLocation>(x => x.ID)
- );
- if (others.Rows.Any())
- {
- MaterialDialog.Instance.AlertAsync(message: "Location Code already exists!");
- return false;
- }
- try
- {
- new Client<StockLocation>().Save(loc, "Created Location");
- StockLocationShell shell = new StockLocationShell();
- shell.ID = loc.ID;
- shell.Code = loc.Code;
- shell.Description = loc.Description;
- stockLocationShells.Add(shell);
- Device.BeginInvokeOnMainThread(() =>
- {
- locationsStackLayout.Children.Clear();
- foreach (StockLocationShell shell2 in stockLocationShells)
- {
- StockLocationViewCell viewcell = new StockLocationViewCell(shell2);
- viewcell.stockLocationShell.NumberOfReceivedItems = "Received items: " + shell2.PoItems.Count();
- locationsStackLayout.Children.Add(viewcell);
- }
- });
- }
- catch (Exception err)
- {
- MaterialDialog.Instance.AlertAsync(message: "Unable to save Location\n" + err.Message);
- return false;
- }
- return true;
- };
- Navigation.PushAsync(locationDetailsPage);
- }
- catch { }
- }
- private void ChooseReceivingLocation()
- {
- if (bOpening)
- return;
- bOpening = true;
- StockLocationSelectionPage stockLocationSelectionPage = new StockLocationSelectionPage(true);
- stockLocationSelectionPage.OnMultiLocationSelected += async (s) =>
- {
- using (await MaterialDialog.Instance.LoadingDialogAsync(message: "Loading"))
- {
- foreach (StockLocationShell shell in s)
- {
- if (!stockLocationShells.Any(x => x.ID == shell.ID))
- {
- shell.Color = Color.Default;
- shell.NumberOfReceivedItems = "Received items: " + shell.PoItems.Count();
- stockLocationShells.Add(shell);
- }
- }
- Device.BeginInvokeOnMainThread(() =>
- {
- locationsStackLayout.Children.Clear();
- foreach (StockLocationShell shell in stockLocationShells)
- {
- StockLocationViewCell viewcell = new StockLocationViewCell(shell);
- viewcell.stockLocationShell.NumberOfReceivedItems = "Received items: " + shell.PoItems.Count();
- locationsStackLayout.Children.Add(viewcell);
- }
- });
- }
- };
- Navigation.PushAsync(stockLocationSelectionPage);
- }
- #endregion
- #endregion
- #region Loading
- private void AddIncomingStores()
- {
- Task.Run(() =>
- {
- try
- {
- StockLocation location = new Client<StockLocation>().Query(
- new Filter<StockLocation>(x => x.ID).IsEqualTo(Guid.Parse("3ebb1fe3-21f4-4731-b80a-a28f814982ea")),
- new Columns<StockLocation>(x => x.ID, x => x.Code, x => x.Description))
- .Rows.FirstOrDefault().ToObject<StockLocation>();
- stockLocationShells.Add(new StockLocationShell
- {
- ID = location.ID,
- Code = location.Code,
- Description = location.Description,
- NumberOfReceivedItems = "Received items: ",
- });
- StockLocationViewCell viewcell = new StockLocationViewCell(stockLocationShells[0]);
- Device.BeginInvokeOnMainThread(() =>
- {
- locationsStackLayout.Children.Add(viewcell);
- });
- }
- catch { }
- });
- }
- private void LoadPOItems()
- {
- Task.Run(() =>
- {
- try
- {
- CoreTable table = new Client<PurchaseOrderItem>().Query(
- new Filter<PurchaseOrderItem>(x => x.PurchaseOrderLink.ID).IsEqualTo(POID).And(x => x.ReceivedDate).IsEqualTo(DateTime.MinValue),
- columns);
- if (table.Rows.Any())
- {
- foreach (CoreRow row in table.Rows)
- {
- POItemShell item = new POItemShell()
- {
- ID = row.Get<PurchaseOrderItem, Guid>(x => x.ID),
- PONumber = row.Get<PurchaseOrderItem, string>(x => x.PurchaseOrderLink.PONumber),
- ConsignmentNumber = "Cons: " + row.Get<PurchaseOrderItem, string>(x => x.Consignment.Number),
- JobName = row.Get<PurchaseOrderItem, string>(x => x.Job.Name),
- JobNumber = row.Get<PurchaseOrderItem, string>(x => x.Job.JobNumber),
- Description = row.Get<PurchaseOrderItem, string>(x => x.Description),
- ConsignmentID = row.Get<PurchaseOrderItem, Guid>(x => x.Consignment.ID),
- POID = row.Get<PurchaseOrderItem, Guid>(x => x.PurchaseOrderLink.ID),
- ReceivedDate = row.Get<PurchaseOrderItem, DateTime>(x => x.ReceivedDate),
- JobID = row.Get<PurchaseOrderItem, Guid>(x => x.Job.ID),
- SupplierCode = row.Get<PurchaseOrderItem, string>(x => x.SupplierCode),
- ProductID = row.Get<PurchaseOrderItem, Guid>(x => x.Product.ID),
- Nonstock = row.Get<PurchaseOrderItem, bool>(x => x.Product.NonStock),
- StyleID = row.Get<PurchaseOrderItem, Guid>(x => x.Style.ID),
- StyleCode = row.Get<PurchaseOrderItem, string>(x => x.Style.Code),
- StyleDescription = row.Get<PurchaseOrderItem, string>(x => x.Style.Description),
- StockLocationID = row.Get<PurchaseOrderItem, Guid>(x => x.Product.DefaultLocation.ID),
- StockLocationDescription = row.Get<PurchaseOrderItem, string>(x => x.Product.DefaultLocation.Description),
- StockLocationCode = row.Get<PurchaseOrderItem, string>(x => x.Product.DefaultLocation.Code),
- DimensionsUnitID = row.Get<PurchaseOrderItem, Guid>(x => x.Dimensions.Unit.ID),
- DimensionsQuantity = row.Get<PurchaseOrderItem, double>(x => x.Dimensions.Quantity),
- DimensionsLength = row.Get<PurchaseOrderItem, double>(x => x.Dimensions.Length),
- DimensionsWidth = row.Get<PurchaseOrderItem, double>(x => x.Dimensions.Width),
- DimensionsHeight = row.Get<PurchaseOrderItem, double>(x => x.Dimensions.Height),
- DimensionsWeight = row.Get<PurchaseOrderItem, double>(x => x.Dimensions.Weight),
- DimensionsValue = row.Get<PurchaseOrderItem, double>(x => x.Dimensions.Value),
- DimensionsUnitSize = row.Get<PurchaseOrderItem, string>(x => x.Dimensions.UnitSize),
- Cost = row.Get<PurchaseOrderItem, double>(x => x.Cost),
- DimensionsHasHeight = row.Get<PurchaseOrderItem, bool>(x => x.Dimensions.Unit.HasHeight),
- DimensionsHasLength = row.Get<PurchaseOrderItem, bool>(x => x.Dimensions.Unit.HasLength),
- DimensionsHasWidth = row.Get<PurchaseOrderItem, bool>(x => x.Dimensions.Unit.HasWidth),
- DimensionsHasWeight = row.Get<PurchaseOrderItem, bool>(x => x.Dimensions.Unit.HasWeight),
- DimensionsHasQuantity = row.Get<PurchaseOrderItem, bool>(x => x.Dimensions.Unit.HasQuantity),
- DimensionsUnitFormula = row.Get<PurchaseOrderItem, string>(x => x.Dimensions.Unit.Formula),
- DimensionsUnitFormat = row.Get<PurchaseOrderItem, string>(x => x.Dimensions.Unit.Format),
- DimensionsUnitCode = row.Get<PurchaseOrderItem, string>(x => x.Dimensions.Unit.Code),
- DimensionsUnitDescription = row.Get<PurchaseOrderItem, string>(x => x.Dimensions.Unit.Description),
- ExpectedQty = row.Get<PurchaseOrderItem, double>(x => x.Qty),
- };
- if (string.IsNullOrWhiteSpace(item.DimensionsUnitSize) || item.DimensionsUnitID == Guid.Empty)
- item = TryFixPOItem(item, row);
- poItemShells.Add(item);
- }
- LoadProductImages();
- Device.BeginInvokeOnMainThread(() =>
- {
- poItemListView.ItemsSource = poItemShells;
- poItemCountLbl.Text = "Items Unreceived: " + poItemShells.Count;
- });
- }
- }
- catch (Exception ex)
- {
- Device.BeginInvokeOnMainThread(() => { DisplayAlert("Error loading Purchase Order items - please try again", ex.Message, "OK"); });
- }
- });
- }
- private void LoadProductImages()
- {
- Task.Run(() =>
- {
- foreach (POItemShell shell in poItemShells)
- {
- if (shell.ProductID != Guid.Empty)
- {
- CoreTable table = new Client<Product>().Query
- (
- new Filter<Product>(x => x.ID).IsEqualTo(shell.ProductID).And(x => x.Image.ID).IsNotEqualTo(Guid.Empty),
- new Columns<Product>(x => x.Image.ID)
- );
- CoreTable table1 = new Client<Document>().Query
- (
- new Filter<Document>(x => x.ID).IsEqualTo(Guid.Parse(table.Rows.First().Values[0].ToString())),
- new Columns<Document>(x => x.Data)
- );
- CoreRow docrow = table1.Rows.FirstOrDefault();
- if (docrow != null)
- {
- byte[] data = docrow.Get<Document, byte[]>(x => x.Data);
- ImageSource src = ImageSource.FromStream(() => new MemoryStream(data));
- if (src != null)
- {
- shell.ImageSource = src;
- shell.ImageVisible = true;
- if (deviceType == "Tablet")
- {
- shell.LastRowHeight = 300;
- }
- else
- {
- shell.LastRowHeight = 150;
- }
- Device.BeginInvokeOnMainThread(() =>
- {
- poItemListView.ItemsSource = null;
- poItemListView.ItemsSource = poItemShells;
- });
- }
- }
- }
- }
- });
- }
- private async Task CreateNewConsignment()
- {
- using (await MaterialDialog.Instance.LoadingDialogAsync(message: "Creating new consignment"))
- {
- try
- {
- Consignment newConsignment = new Consignment() { };
- string name = "Unknown Supplier";
- if (supplierID != Guid.Empty)
- {
- newConsignment.Supplier.ID = supplierID;
- CoreTable supplierNameTable = new Client<Supplier>().Query(
- new Filter<Supplier>(x => x.ID).IsEqualTo(supplierID),
- new Columns<Supplier>(x => x.Name)
- );
- name = supplierNameTable.Rows.FirstOrDefault().Values[0].ToString();
- }
- newConsignment.Description = "Consignment for receival of items from " + name + ". Auto generated from mobile app by " + GlobalVariables.EmpName;
- CoreTable consignmentNumberTable = new Client<Consignment>().Query(
- new Filter<Consignment>(x => x.Number).Contains("APP").And(x => x.Created).IsGreaterThan(DateTime.Today.AddDays(-60)),
- new Columns<Consignment>(x => x.Number, x => x.Created),
- new SortOrder<Consignment>(x => x.Created));
- if (consignmentNumberTable.Rows.Any())
- {
- SetConsignmentNumber(newConsignment, consignmentNumberTable);
- }
- else
- {
- CoreTable consignmentNumberTable2 = new Client<Consignment>().Query(
- new Filter<Consignment>(x => x.Number).Contains("APP"),
- new Columns<Consignment>(x => x.Number, x => x.Created),
- new SortOrder<Consignment>(x => x.Created));
- if (consignmentNumberTable2.Rows.Any())
- {
- SetConsignmentNumber(newConsignment, consignmentNumberTable2);
- }
- else
- newConsignment.Number = "APP1" + " From PO: " + PONumber;
- }
- new Client<Consignment>().Save(newConsignment, "Updated from mobile device");
- consignmentID = newConsignment.ID;
- saveBtn.IsVisible = true;
- consignmentNumber = newConsignment.Number;
- consignmentNumberLbl.Text = "Consignment: " + newConsignment.Number;
- if (consignmentID == Guid.Empty)
- {
- DisplayAlert("Error", "Unable to create new consignment", "OK");
- Navigation.PopAsync();
- }
- }
- catch { }
- }
- }
- private Consignment SetConsignmentNumber(Consignment newConsignment, CoreTable table)
- {
- List<int> numbers = new List<int>();
- foreach (CoreRow row in table.Rows)
- {
- string number = row.Values[0].ToString();
- if (number.Contains(" From PO"))
- {
- int index = number.IndexOf(" From PO");
- string firstSubstring = number.Substring(0, index);
- string secondSubString = firstSubstring.Substring(3, firstSubstring.Length - 3);
- try
- {
- int i = int.Parse(secondSubString);
- numbers.Add(i);
- }
- catch { }
- }
- }
- numbers.Sort();
- int lastInt = numbers.Last();
- lastInt++;
- newConsignment.Number = "APP" + lastInt.ToString() + " From PO" + PONumber;
- return newConsignment;
- }
- Columns<PurchaseOrderItem> columns = new Columns<PurchaseOrderItem>(x => x.ID,
- x => x.PurchaseOrderLink.PONumber,
- x => x.Consignment.Number,
- x => x.Job.Name,
- x => x.Job.JobNumber,
- x => x.Description,
- x => x.Qty,
- x => x.Consignment.ID,
- x => x.PurchaseOrderLink.ID,
- x => x.ReceivedDate,
- x => x.Job.ID,
- x => x.SupplierCode,
- x => x.Product.ID,
- x => x.Product.NonStock,
- x => x.Style.ID,
- x => x.Style.Code,
- x => x.Style.Description,
- x => x.Product.DefaultLocation.ID,
- x => x.Product.DefaultLocation.Description,
- x => x.Product.DefaultLocation.Code,
- x => x.Dimensions.Unit.ID,
- x => x.Dimensions.Quantity,
- x => x.Dimensions.Length,
- x => x.Dimensions.Width,
- x => x.Dimensions.Height,
- x => x.Dimensions.Weight,
- x => x.Dimensions.Value,
- x => x.Dimensions.UnitSize,
- x => x.Cost,
- x => x.Dimensions.Unit.HasHeight,
- x => x.Dimensions.Unit.HasLength,
- x => x.Dimensions.Unit.HasWidth,
- x => x.Dimensions.Unit.HasWeight,
- x => x.Dimensions.Unit.HasQuantity,
- x => x.Dimensions.Unit.Formula,
- x => x.Dimensions.Unit.Format,
- x => x.Dimensions.Unit.Code,
- x => x.Dimensions.Unit.Description,
- x => x.Product.Dimensions.UnitSize,
- x => x.Product.Dimensions.Unit.ID,
- x => x.Product.Dimensions.Quantity,
- x => x.Product.Dimensions.Length,
- x => x.Product.Dimensions.Width,
- x => x.Product.Dimensions.Weight,
- x => x.Product.Dimensions.Height,
- x => x.Product.Dimensions.Value,
- x => x.Product.Dimensions.Unit.HasHeight,
- x => x.Product.Dimensions.Unit.HasLength,
- x => x.Product.Dimensions.Unit.HasWeight,
- x => x.Product.Dimensions.Unit.HasWidth,
- x => x.Product.Dimensions.Unit.HasQuantity,
- x => x.Product.Dimensions.Unit.Format,
- x => x.Product.Dimensions.Unit.Formula,
- x => x.Product.Dimensions.Unit.Code,
- x => x.Product.Dimensions.Unit.Description
- );
- private POItemShell TryFixPOItem(POItemShell item, CoreRow row)
- {
- PurchaseOrderItem poItem = row.ToObject<PurchaseOrderItem>();
- poItem.Dimensions.Quantity = poItem.Product.Dimensions.Quantity;
- poItem.Dimensions.Length = poItem.Product.Dimensions.Length;
- poItem.Dimensions.Width = poItem.Product.Dimensions.Width;
- poItem.Dimensions.Height = poItem.Product.Dimensions.Height;
- poItem.Dimensions.Weight = poItem.Product.Dimensions.Weight;
- poItem.Dimensions.Unit.ID = poItem.Product.Dimensions.Unit.ID;
- poItem.Dimensions.Unit.HasHeight = poItem.Product.Dimensions.Unit.HasHeight;
- poItem.Dimensions.Unit.HasLength = poItem.Product.Dimensions.Unit.HasLength;
- poItem.Dimensions.Unit.HasWidth = poItem.Product.Dimensions.Unit.HasWidth;
- poItem.Dimensions.Unit.HasWeight = poItem.Product.Dimensions.Unit.HasWeight;
- poItem.Dimensions.Unit.HasQuantity = poItem.Product.Dimensions.Unit.HasQuantity;
- poItem.Dimensions.Unit.Formula = poItem.Product.Dimensions.Unit.Formula;
- poItem.Dimensions.Unit.Code = poItem.Product.Dimensions.Unit.Code;
- poItem.Dimensions.Unit.Description = poItem.Product.Dimensions.Unit.Description;
- poItem.Dimensions.UnitSize = poItem.Product.Dimensions.UnitSize;
- poItem.Dimensions.Value = poItem.Product.Dimensions.Value;
- Task.Run(() => { new Client<PurchaseOrderItem>().Save(poItem, "Fix Dimensions on Receivals App"); });
-
- item.DimensionsQuantity = poItem.Dimensions.Quantity;
- item.DimensionsLength = poItem.Dimensions.Length;
- item.DimensionsWeight = poItem.Dimensions.Weight;
- item.DimensionsWidth = poItem.Dimensions.Width;
- item.DimensionsHeight = poItem.Dimensions.Height;
- item.DimensionsUnitID = poItem.Dimensions.Unit.ID;
- item.DimensionsHasHeight = poItem.Dimensions.Unit.HasHeight;
- item.DimensionsHasLength = poItem.Dimensions.Unit.HasLength;
- item.DimensionsHasWidth = poItem.Dimensions.Unit.HasWidth;
- item.DimensionsHasWeight = poItem.Dimensions.Unit.HasWeight;
- item.DimensionsHasQuantity = poItem.Dimensions.Unit.HasQuantity;
- item.DimensionsUnitFormula = poItem.Dimensions.Unit.Formula;
- item.DimensionsUnitFormat = poItem.Dimensions.Unit.Format;
- item.DimensionsUnitCode = poItem.Dimensions.Unit.Code;
- item.DimensionsUnitDescription = poItem.Dimensions.Unit.Description;
- item.DimensionsUnitSize = poItem.Dimensions.UnitSize;
- item.DimensionsValue = poItem.Dimensions.Value;
- return item;
- }
- }
- #endregion
- }
- #region Classes
- public class POItemShell
- {
- public Guid ID { get; set; }
- public string PONumber { get; set; }
- public string ConsignmentNumber { get; set; }
- public string Description { get; set; }
- public Guid ConsignmentID { get; set; }
- public Guid POID { get; set; }
- public double ExpectedQty { get; set; }
- public Color Color { get; set; }
- public double ReceivedQty { get; set; }
- public bool HasQAForm { get; set; }
- public bool IsReadyForQA { get; set; }
- public Color QATextColor { get; set; }
- public Color QABtnColor { get; set; }
- public Guid DigitalFormID { get; set; }
- public DateTime FormCompleted { get; set; }
- public DateTime ReceivedDate { get; set; }
- public string SupplierCode { get; set; }
- public Guid ProductID { get; set; }
- public bool Nonstock { get; set; }
- public Guid JobID { get; set; }
- public string JobName { get; set; }
- public string JobNumber { get; set; }
- public Guid StyleID { get; set; }
- public string StyleCode { get; set; }
- public string StyleDescription { get; set; }
- public Guid StockLocationID { get; set; }
- public string StockLocationDescription { get; set; }
- public string StockLocationCode { get; set; }
- public bool ImageVisible { get; set; }
- public ImageSource ImageSource { get; set; }
- public double LastRowHeight { get; set; }
- public double Cost { get; set; }
- public Guid DimensionsUnitID { get; set; }
- public double DimensionsQuantity { get; set; }
- public double DimensionsLength { get; set; }
- public double DimensionsWidth { get; set; }
- public double DimensionsHeight { get; set; }
- public double DimensionsWeight { get; set; }
- public double DimensionsValue { get; set; }
- public string DimensionsUnitSize { get; set; }
- public bool DimensionsHasHeight { get; set; }
- public bool DimensionsHasLength { get; set; }
- public bool DimensionsHasWidth { get; set; }
- public bool DimensionsHasWeight { get; set; }
- public bool DimensionsHasQuantity { get; set; }
- public string DimensionsUnitFormula { get; set; }
- public string DimensionsUnitFormat { get; set; }
- public string DimensionsUnitCode { get; set; }
- public string DimensionsUnitDescription { get; set; }
- public POItemShell()
- {
- ID = Guid.Empty;
- PONumber = string.Empty;
- ConsignmentNumber = string.Empty;
- JobID = Guid.Empty;
- JobName = string.Empty;
- JobNumber = string.Empty;
- Description = string.Empty;
- ConsignmentID = Guid.Empty;
- POID = Guid.Empty;
- ExpectedQty = 0;
- Color = Color.Default;
- ReceivedQty = 0;
- HasQAForm = false;
- IsReadyForQA = false;
- QATextColor = Color.LightGray;
- DigitalFormID = Guid.Empty;
- FormCompleted = DateTime.MinValue;
- ReceivedDate = DateTime.MinValue;
- SupplierCode = string.Empty;
- ProductID = Guid.Empty;
- Nonstock = false;
- StyleID = Guid.Empty;
- StyleCode = string.Empty;
- StyleDescription = string.Empty;
- StockLocationID = Guid.Empty;
- StockLocationCode = "";
- StockLocationDescription = "";
- ImageVisible = false;
- ImageSource = "";
- LastRowHeight = 0;
- DimensionsUnitID = Guid.Empty;
- DimensionsQuantity = 0;
- DimensionsLength = 0;
- DimensionsWidth = 0;
- DimensionsHeight = 0;
- DimensionsWeight = 0;
- DimensionsValue = 0;
- DimensionsUnitSize = "";
- Cost = 0.0;
- DimensionsHasHeight = false;
- DimensionsHasLength = false;
- DimensionsHasWidth = false;
- DimensionsHasWeight = false;
- DimensionsHasQuantity = false;
- DimensionsUnitFormula = "";
- DimensionsUnitFormat = "";
- DimensionsUnitCode = "";
- DimensionsUnitDescription = "";
- }
- public POItemShell DuplicateNewShell(POItemShell poitemshell)
- {
- POItemShell shell = new POItemShell
- {
- ID = poitemshell.ID,
- PONumber = poitemshell.PONumber,
- ConsignmentNumber = poitemshell.ConsignmentNumber,
- JobID = poitemshell.JobID,
- JobName = poitemshell.JobName,
- JobNumber = poitemshell.JobNumber,
- Description = poitemshell.Description,
- ConsignmentID = poitemshell.ConsignmentID,
- POID = poitemshell.POID,
- ExpectedQty = poitemshell.ExpectedQty,
- Color = poitemshell.Color,
- ReceivedQty = poitemshell.ReceivedQty,
- HasQAForm = poitemshell.HasQAForm,
- IsReadyForQA = poitemshell.IsReadyForQA,
- QATextColor = poitemshell.QATextColor,
- QABtnColor = poitemshell.QABtnColor,
- DigitalFormID = poitemshell.DigitalFormID,
- FormCompleted = poitemshell.FormCompleted,
- ReceivedDate = poitemshell.ReceivedDate,
- SupplierCode = poitemshell.SupplierCode,
- ProductID = poitemshell.ProductID,
- Nonstock = poitemshell.Nonstock,
- StyleID = poitemshell.StyleID,
- StyleCode = poitemshell.StyleCode,
- StyleDescription = poitemshell.StyleDescription,
- StockLocationID = poitemshell.StockLocationID,
- StockLocationCode = poitemshell.StockLocationCode,
- StockLocationDescription = poitemshell.StockLocationDescription,
- ImageVisible = poitemshell.ImageVisible,
- ImageSource = poitemshell.ImageSource,
- LastRowHeight = poitemshell.LastRowHeight,
- DimensionsUnitID = poitemshell.DimensionsUnitID,
- DimensionsQuantity = poitemshell.DimensionsQuantity,
- DimensionsLength = poitemshell.DimensionsLength,
- DimensionsWidth = poitemshell.DimensionsWidth,
- DimensionsHeight = poitemshell.DimensionsHeight,
- DimensionsWeight = poitemshell.DimensionsWeight,
- DimensionsValue = poitemshell.DimensionsValue,
- DimensionsUnitSize = poitemshell.DimensionsUnitSize,
- Cost = poitemshell.Cost,
- DimensionsHasHeight = poitemshell.DimensionsHasHeight,
- DimensionsHasLength = poitemshell.DimensionsHasLength,
- DimensionsHasWidth = poitemshell.DimensionsHasWidth,
- DimensionsHasWeight = poitemshell.DimensionsHasWeight,
- DimensionsHasQuantity = poitemshell.DimensionsHasQuantity,
- DimensionsUnitFormula = poitemshell.DimensionsUnitFormula,
- DimensionsUnitFormat = poitemshell.DimensionsUnitFormat,
- DimensionsUnitCode = poitemshell.DimensionsUnitCode,
- DimensionsUnitDescription = poitemshell.DimensionsUnitDescription
- };
- return shell;
- }
- }
- #endregion
|