Browse Source

Added stuff for refreshing post

Kenric Nugteren 1 year ago
parent
commit
e95bfda0da

+ 1 - 0
prs.classes/Entities/Bill/Bill.cs

@@ -76,6 +76,7 @@ namespace Comal.Classes
 
         [NullEditor]
         [LoggableProperty]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; }
 
         [NullEditor]

+ 1 - 0
prs.classes/Entities/Customer/Customer.cs

@@ -121,6 +121,7 @@ namespace Comal.Classes
         public DateTime Posted { get; set; }
 
         [NullEditor]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; }
 
         [NullEditor]

+ 1 - 0
prs.classes/Entities/Invoice/Invoice.cs

@@ -141,6 +141,7 @@ namespace Comal.Classes
 
         [NullEditor]
         [LoggableProperty]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; } = PostedStatus.NeverPosted;
 
         [NullEditor]

+ 1 - 0
prs.classes/Entities/PurchaseOrder/PurchaseOrder.cs

@@ -163,6 +163,7 @@ namespace Comal.Classes
 
         [NullEditor]
         [LoggableProperty]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; }
 
         [NullEditor]

+ 1 - 0
prs.classes/Entities/Receipt/Receipt.cs

@@ -48,6 +48,7 @@ namespace Comal.Classes
         public DateTime Posted { get; set; }
 
         [NullEditor]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; }
 
         [NullEditor]

+ 1 - 0
prs.classes/Entities/Stock/StockMovement/StockMovement.cs

@@ -207,6 +207,7 @@ namespace Comal.Classes
 
         [NullEditor]
         [LoggableProperty]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; }
 
         [NullEditor]

+ 8 - 0
prs.classes/Entities/Supplier/Supplier.cs

@@ -106,9 +106,17 @@ namespace Comal.Classes
         [Formula(typeof(SupplierBalance))]
         public double Balance { get; set; }
 
+        [NullEditor]
         public DateTime Posted { get; set; }
+
+        [NullEditor]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; }
+
+        [NullEditor]
         public string PostedNote { get; set; }
+
+        [NullEditor]
         public string PostedReference { get; set; }
 
         public override string ToString()

+ 1 - 0
prs.classes/Entities/Timesheet/Timesheet.cs

@@ -109,6 +109,7 @@ namespace Comal.Classes
 
         [NullEditor]
         [LoggableProperty]
+        [RequiredColumn]
         public PostedStatus PostedStatus { get; set; }
 
         [NullEditor]

+ 69 - 70
prs.desktop/Panels/Customers/CustomerContactGrid.cs

@@ -8,88 +8,87 @@ using InABox.Core;
 using InABox.DynamicGrid;
 using InABox.WPF;
 
-namespace PRSDesktop
+namespace PRSDesktop;
+
+public class CustomerContactGrid : DynamicDataGrid<CustomerContact>, ICustomerGrid
 {
-    public class CustomerContactGrid : DynamicDataGrid<CustomerContact>, ICustomerGrid
+    
+    private readonly BitmapImage tick = PRSDesktop.Resources.tick.AsBitmapImage();
+    
+    public CustomerContactGrid()
     {
-        
-        private readonly BitmapImage tick = PRSDesktop.Resources.tick.AsBitmapImage();
-        
-        public CustomerContactGrid()
-        {
-            HiddenColumns.Add(x=>x.Customer.DefaultContact.ID);
-            HiddenColumns.Add(x=>x.Contact.ID);
-            HiddenColumns.Add(x=>x.Customer.ID);
-            ActionColumns.Add(new DynamicImageColumn(IsDefaultImage, SelectDefaultAction) { Position = DynamicActionColumnPosition.Start });
-        }
-        
-        protected override void DoReconfigure(DynamicGridOptions options)
-        {
-            base.DoReconfigure(options);
-            options.AddRows = true;
-            options.EditRows = true;
-            options.SelectColumns = true;
-            options.DeleteRows = true;
-        }
-        
-        private BitmapImage? IsDefaultImage(CoreRow? row)
-        {
-            return row == null
+        HiddenColumns.Add(x=>x.Customer.DefaultContact.ID);
+        HiddenColumns.Add(x=>x.Contact.ID);
+        HiddenColumns.Add(x=>x.Customer.ID);
+        ActionColumns.Add(new DynamicImageColumn(IsDefaultImage, SelectDefaultAction) { Position = DynamicActionColumnPosition.Start });
+    }
+    
+    protected override void DoReconfigure(DynamicGridOptions options)
+    {
+        base.DoReconfigure(options);
+        options.AddRows = true;
+        options.EditRows = true;
+        options.SelectColumns = true;
+        options.DeleteRows = true;
+    }
+    
+    private BitmapImage? IsDefaultImage(CoreRow? row)
+    {
+        return row == null
+            ? tick
+            : row.Get<CustomerContact, Guid>(x => x.Customer.DefaultContact.ID) == row.Get<CustomerContact, Guid>(x => x.Contact.ID)
                 ? tick
-                : row.Get<CustomerContact, Guid>(x => x.Customer.DefaultContact.ID) == row.Get<CustomerContact, Guid>(x => x.Contact.ID)
-                    ? tick
-                    : null;
-        }
+                : null;
+    }
 
-        private bool SelectDefaultAction(CoreRow? row)
+    private bool SelectDefaultAction(CoreRow? row)
+    {
+        if ((row == null) ||row.Get<CustomerContact, Guid>(x => x.Customer.DefaultContact.ID) == row.Get<CustomerContact, Guid>(x => x.Contact.ID))
+            return false;
+        using (new WaitCursor())
         {
-            if ((row == null) ||row.Get<CustomerContact, Guid>(x => x.Customer.DefaultContact.ID) == row.Get<CustomerContact, Guid>(x => x.Contact.ID))
-                return false;
-            using (new WaitCursor())
+            var customer = new Client<Customer>().Query(
+                new Filter<Customer>(x => x.ID).IsEqualTo(row.Get<CustomerContact, Guid>(x => x.Customer.ID)),
+                Columns.Required<Customer>().Add(x => x.ID).Add(x => x.DefaultContact.ID)
+            ).Rows.FirstOrDefault()?.ToObject<Customer>();
+            if (customer != null)
             {
-                var customer = new Client<Customer>().Query(
-                    new Filter<Customer>(x => x.ID).IsEqualTo(row.Get<CustomerContact, Guid>(x => x.Customer.ID)),
-                    Columns.Required<Customer>().Add(x => x.ID).Add(x => x.DefaultContact.ID)
-                ).Rows.FirstOrDefault()?.ToObject<Customer>();
-                if (customer != null)
-                {
-                    customer.DefaultContact.ID = row.Get<CustomerContact, Guid>(x => x.Contact.ID);
-                    new Client<Customer>().Save(customer, "Updated Default Contact");
-                    return true;
-                }
+                customer.DefaultContact.ID = row.Get<CustomerContact, Guid>(x => x.Contact.ID);
+                new Client<Customer>().Save(customer, "Updated Default Contact");
+                return true;
             }
-            return false;
         }
+        return false;
+    }
 
-        public Customer Customer { get; set; }
+    public Customer Customer { get; set; }
 
-        protected override void Reload(Filters<CustomerContact> criteria, Columns<CustomerContact> columns, ref SortOrder<CustomerContact>? sort, Action<CoreTable?, Exception?> action)
-        {
-            criteria.Add(new Filter<CustomerContact>(x => x.Customer).LinkValid(Customer.ID));
-            base.Reload(criteria, columns, ref sort, action);
-        }
+    protected override void Reload(Filters<CustomerContact> criteria, Columns<CustomerContact> columns, ref SortOrder<CustomerContact>? sort, Action<CoreTable?, Exception?> action)
+    {
+        criteria.Add(new Filter<CustomerContact>(x => x.Customer).LinkValid(Customer.ID));
+        base.Reload(criteria, columns, ref sort, action);
+    }
 
-        public override CustomerContact CreateItem()
-        {
-            var result = base.CreateItem();
-            result.Customer.ID = Customer.ID;
-            result.Customer.Synchronise(Customer);
-            return result;
-        }
+    public override CustomerContact CreateItem()
+    {
+        var result = base.CreateItem();
+        result.Customer.ID = Customer.ID;
+        result.Customer.Synchronise(Customer);
+        return result;
+    }
 
-        protected override BaseEditor? GetEditor(object item, DynamicGridColumn column)
-        {
-            if (column.ColumnName.Equals("Customer.ID"))
-                return new NullEditor();
-            return base.GetEditor(item, column);
-        }
+    protected override BaseEditor? GetEditor(object item, DynamicGridColumn column)
+    {
+        if (column.ColumnName.Equals("Customer.ID"))
+            return new NullEditor();
+        return base.GetEditor(item, column);
+    }
 
-        protected override void DoAdd(bool OpenEditorOnDirectEdit = false)
-        {
-            if (Customer.ID == Guid.Empty)
-                MessageBox.Show("Please select a Customer first!");
-            else
-                base.DoAdd();
-        }
+    protected override void DoAdd(bool OpenEditorOnDirectEdit = false)
+    {
+        if (Customer.ID == Guid.Empty)
+            MessageBox.Show("Please select a Customer first!");
+        else
+            base.DoAdd();
     }
 }

+ 30 - 0
prs.desktop/Utils/PostUtils.cs

@@ -130,6 +130,36 @@ public static class PostUtils
                         configurePost);
                 }
             });
+
+            if (postSettings.ShowClearButton)
+            {
+                host.CreatePanelAction(new PanelAction
+                {
+                    Caption = "Clear Posted Flag",
+                    Image = image ?? PRSDesktop.Resources.refresh,
+                    OnExecute = action =>
+                    {
+                        var dataModel = model();
+                        foreach(var (key, table) in dataModel.ModelTables)
+                        {
+                            table.IsDefault = false;
+                        }
+                        dataModel.SetColumns<T>(Columns.Required<T>().Add(x => x.PostedStatus).Add(x => x.PostedReference).Add(x => x.PostedNote).Add(x => x.Posted));
+                        dataModel.SetIsDefault<T>(true);
+                        dataModel.LoadModel();
+                        var items = dataModel.GetTable<T>().ToArray<T>();
+                        foreach(var item in items)
+                        {
+                            item.PostedStatus = PostedStatus.NeverPosted;
+                            item.PostedReference = "";
+                            item.PostedNote = "";
+                            item.Posted = DateTime.MinValue;
+                        }
+                        Client.Save(items, "Cleared posted flag");
+                        refresh();
+                    }
+                });
+            }
         }
 
         if (configurePost is not null && Security.CanConfigurePost<T>())

+ 43 - 1
prs.shared/Posters/MYOB/CustomerMYOBPoster.cs

@@ -16,6 +16,8 @@ using MYOBCustomer = MYOB.AccountRight.SDK.Contracts.Version2.Contact.Customer;
 using MYOBAddress = MYOB.AccountRight.SDK.Contracts.Version2.Contact.Address;
 using MYOB.AccountRight.SDK.Contracts.Version2.Sale;
 using InABox.Clients;
+using InABox.Database;
+using MYOB.AccountRight.SDK;
 
 namespace PRS.Shared.Posters.MYOB;
 
@@ -51,7 +53,47 @@ public static class ContactMYOBUtils
     }
 }
 
-public class CustomerMYOBPoster : IMYOBPoster<Customer, CustomerMYOBPosterSettings>
+public class CustomerMYOBAutoRefresher : IAutoRefresher<Customer>
+{
+    public bool ShouldRepost(Customer customer)
+    {
+        var shouldRepost = customer.HasOriginalValue(x => x.Name)
+            || customer.HasOriginalValue(x => x.Code)
+            || customer.HasOriginalValue(x => x.ABN)
+            || customer.DefaultContact.HasOriginalValue(x => x.ID)
+            || customer.Delivery.HasOriginalValue(x => x.Street)
+            || customer.Delivery.HasOriginalValue(x => x.City)
+            || customer.Delivery.HasOriginalValue(x => x.State)
+            || customer.Delivery.HasOriginalValue(x => x.PostCode)
+            || customer.Postal.HasOriginalValue(x => x.Street)
+            || customer.Postal.HasOriginalValue(x => x.City)
+            || customer.Postal.HasOriginalValue(x => x.State)
+            || customer.Postal.HasOriginalValue(x => x.PostCode);
+        if (shouldRepost)
+        {
+            return true;
+        }
+
+        if(customer.CustomerStatus.HasOriginalValue(x => x.ID))
+        {
+            var originalID = customer.CustomerStatus.GetOriginalValue(x => x.ID);
+            var currentID = customer.CustomerStatus.ID;
+
+            var statuses = DbFactory.Provider.Query<CustomerStatus>(
+                new Filter<CustomerStatus>(x => x.ID).IsEqualTo(originalID).Or(x => x.ID).IsEqualTo(currentID),
+                Columns.None<CustomerStatus>().Add(x => x.ID).Add(x => x.Active))
+                .ToArray<CustomerStatus>();
+            if (statuses.Length == 2 && statuses[0].Active != statuses[1].Active)
+            {
+                return true;
+            }
+        }
+        return false;
+    }
+
+}
+
+public class CustomerMYOBPoster : IMYOBPoster<Customer, CustomerMYOBPosterSettings>, IAutoRefreshPoster<Customer, CustomerMYOBAutoRefresher>
 {
     public CustomerMYOBPosterSettings Settings { get; set; }
     public MYOBGlobalPosterSettings GlobalSettings { get; set; }