| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998 | 
							- using System;
 
- using System.Collections.Generic;
 
- using System.Collections.ObjectModel;
 
- using System.ComponentModel;
 
- using System.Diagnostics;
 
- using System.Drawing;
 
- using System.Drawing.Drawing2D;
 
- using System.Drawing.Imaging;
 
- using System.IO;
 
- using System.Linq;
 
- using System.Net.Http;
 
- using System.Reflection;
 
- using System.Runtime.InteropServices;
 
- using System.Threading.Tasks;
 
- using System.Windows;
 
- using System.Windows.Controls;
 
- using System.Windows.Forms;
 
- using System.Windows.Input;
 
- using System.Windows.Interop;
 
- using System.Windows.Media;
 
- using System.Windows.Threading;
 
- using AvalonDock.Layout;
 
- using Comal.Classes;
 
- using Comal.Stores;
 
- using Comal.TaskScheduler.Shared;
 
- using H.Pipes;
 
- using InABox.Clients;
 
- using InABox.Configuration;
 
- using InABox.Core;
 
- using InABox.Database;
 
- using InABox.Database.SQLite;
 
- using InABox.DynamicGrid;
 
- using InABox.Mail;
 
- using InABox.Rpc;
 
- using InABox.Scripting;
 
- using InABox.Wpf;
 
- using InABox.WPF;
 
- using NAudio.Wave;
 
- using PRS.Shared;
 
- using InABox.WPF.Themes;
 
- using PRSDesktop.Configuration;
 
- using PRSDesktop.Forms;
 
- using PRSServer;
 
- using SharpAvi.Codecs;
 
- using SharpAvi.Output;
 
- using Syncfusion.Windows.Shared;
 
- using Syncfusion.Windows.Tools.Controls;
 
- using Application = System.Windows.Application;
 
- using ButtonBase = System.Windows.Controls.Primitives.ButtonBase;
 
- using Color = System.Windows.Media.Color;
 
- using ColorConverter = System.Windows.Media.ColorConverter;
 
- using Control = System.Windows.Controls.Control;
 
- using Image = System.Drawing.Image;
 
- using KeyEventArgs = System.Windows.Input.KeyEventArgs;
 
- using MessageBox = System.Windows.MessageBox;
 
- using Pen = System.Drawing.Pen;
 
- using PixelFormat = System.Drawing.Imaging.PixelFormat;
 
- using SortDirection = InABox.Core.SortDirection;
 
- using InABox.Wpf.Reports;
 
- using Comal.Classes.SecurityDescriptors;
 
- using System.Threading;
 
- using H.Formatters;
 
- using PRSDesktop.Forms.Issues;
 
- using Brushes = System.Windows.Media.Brushes;
 
- namespace PRSDesktop;
 
- public enum PanelType
 
- {
 
-     InPlace,
 
-     NewWindow
 
- }
 
- public class SimpleCommand : ICommand
 
- {
 
-     
 
-     public Action OnExecute { get; private set; }
 
-     
 
-     public bool CanExecute(object? parameter) => true; 
 
-     public event EventHandler? CanExecuteChanged
 
-     {
 
-         add => CommandManager.RequerySuggested += value;
 
-         remove => CommandManager.RequerySuggested -= value;
 
-     }
 
-     public void Execute(object? parameter)
 
-     {
 
-         OnExecute?.Invoke();
 
-     }
 
-     public SimpleCommand(Action onExecute)
 
-     {
 
-         OnExecute = onExecute;
 
-     }
 
-     
 
- }
 
- /// <summary>
 
- ///     Interaction logic for Main.xaml
 
- /// </summary>
 
- public partial class MainWindow : IPanelHostControl
 
- {
 
-     //private const int WM_LBUTTONDOWN = 0x201;
 
-     private static PipeServer<string>? _client;
 
-     private IRpcClientTransport? _transport;
 
-     private WaveIn? _audio;
 
-     private bool _audioMuted;
 
-     private MemoryStream? _audioStream;
 
-     private readonly Dictionary<DateTime, Stream> _bitmaps = new();
 
-     private DesktopConsole? _console;
 
-     private Dictionary<DateTime, Tuple<Rectangle, string>> _notes = new();
 
-     private DispatcherTimer? _recorder;
 
-     private Process? _recordingnotes;
 
-     private int _screenheight = 720;
 
-     private int _screenleft;
 
-     private int _screentop;
 
-     private int _screenwidth = 1280;
 
-     private readonly Dictionary<Guid, SecondaryWindow> SecondaryWindows = new();
 
-     private CoreTable? _timesheets;
 
-     private DailyActivityHistory? ActivityHistory;
 
-     private readonly List<Control> CurrentModules = new();
 
-     private Fluent.RibbonTabItem? CurrentTab;
 
-     private Fluent.Button? CurrentButton;
 
-     private readonly int FRAMES_PER_SECOND = 10;
 
-     private DatabaseType DatabaseType;
 
-     private readonly Dictionary<int, int> messages = new();
 
-     private readonly DispatcherTimer NotificationsWatchDog;
 
-     private DateTime pausestarted = DateTime.MinValue;
 
-     private readonly Scheduler scheduler = new() { Interval = new TimeSpan(0, 5, 0) };
 
-     // We use a Guid for the StationID rather than an IP or Mac address
 
-     // because we want true single-instance restriction.  Using either of
 
-     // the above allows for two instances on the once machine, and thus
 
-     // double-counting in the Heartbeat() function
 
-     private Login station = new() { StationID = Guid.NewGuid().ToString() };
 
-     private TimeSpan totalpauses = new(0);
 
-     private readonly int VIDEO_HEIGHT = 1080;
 
-     private readonly int VIDEO_WIDTH = 1920;
 
-     private PanelHost PanelHost;
 
-     public MainWindow()
 
-     {
 
-         PanelHost = new PanelHost(this);
 
-         NotificationsWatchDog = new DispatcherTimer { IsEnabled = false };
 
-         NotificationsWatchDog.Tick += Notifications_Tick;
 
-         NotificationsWatchDog.Interval = new TimeSpan(0, 2, 0);
 
-         ClientFactory.PushHandlers.AddHandler<Notification>(ReceiveNotification);
 
-         ClientFactory.RegisterMailer(EmailType.IMAP, typeof(IMAPMailer));
 
-         ClientFactory.RegisterMailer(EmailType.Exchange, typeof(ExchangeMailer));
 
-         ClientFactory.OnLog += (type, userid, message, parameters) => Logger.Send(LogType.Information, ClientFactory.UserID, message, parameters);
 
-         ClientFactory.OnRequestError += ClientFactory_OnRequestError;
 
-         HotKeyManager.Initialize();
 
-         HotKeyManager.RegisterHotKey(Key.F1, ShowHelp);
 
-         //HotKeyManager.RegisterHotKey(Key.F5, ToggleRecording);
 
-         //HotKeyManager.RegisterHotKey(Key.F6, ShowRecordingNotes);
 
-         //HotKeyManager.RegisterHotKey(Key.F4, ToggleRecordingAudio);
 
-         Logger.Send(LogType.Information, "", "Connecting to server");
 
-         var settings = App.DatabaseSettings;
 
-         bool dbConnected;
 
-         DatabaseType = settings.DatabaseType;
 
-         switch (DatabaseType)
 
-         {
 
-             case DatabaseType.Standalone:
 
-                 ClientFactory.SetClientType(typeof(LocalClient<>), Platform.Wpf, CoreUtils.GetVersion());
 
-                 DbFactory.ColorScheme = App.DatabaseSettings.ColorScheme;
 
-                 DbFactory.Logo = App.DatabaseSettings.Logo;
 
-                 dbConnected = true;
 
-                 break;
 
-             case DatabaseType.Networked:
 
-                 if (App.DatabaseSettings.Protocol == SerializerProtocol.RPC)
 
-                 {
 
-                     _transport = new RpcClientSocketTransport(App.DatabaseSettings.URLs);
 
-                     _transport.OnClose += TransportConnectionLost;
 
-                     _transport.OnException += Transport_OnException;
 
-                     _transport.OnOpen += Transport_OnOpen; ;
 
-                     dbConnected = _transport.Connect();
 
-                     ClientFactory.SetClientType(typeof(RpcClient<>), Platform.Wpf, CoreUtils.GetVersion(),
 
-                         _transport);
 
-                 }
 
-                 else
 
-                 {
 
-                     var url = RestClient<User>.Ping(App.DatabaseSettings.URLs, out DatabaseInfo info);
 
-                     ClientFactory.SetClientType(typeof(RestClient<>), Platform.Wpf, CoreUtils.GetVersion(), url, true);
 
-                     dbConnected = true;
 
-                 }
 
-                 break;
 
-             case DatabaseType.Local:
 
-                 //new RPC stuff (temporary disabled - for enabling when RPC is ready)
 
-                 var pipename = DatabaseServerProperties.GetPipeName(App.DatabaseSettings.LocalServerName, true);
 
-                 _transport = new RpcClientPipeTransport(pipename);
 
-                 _transport.OnClose += TransportConnectionLost;
 
-                 dbConnected = _transport.Connect();
 
-                 ClientFactory.SetClientType(typeof(RpcClient<>), Platform.Wpf, CoreUtils.GetVersion(), _transport );
 
-                 
 
-                 //ClientFactory.SetClientType(typeof(IPCClient<>), Platform.Wpf, CoreUtils.GetVersion(),
 
-                 //    DatabaseServerProperties.GetPipeName(App.DatabaseSettings.LocalServerName, false));
 
-                 //dbConnected = true;
 
-                 
 
-                 break;
 
-             default:
 
-                 throw new Exception($"Invalid database type {DatabaseType}");
 
-         }
 
-         InitializeComponent();
 
-         if (!dbConnected)
 
-         {
 
-             switch (DoConnectionFailed())
 
-             {
 
-                 case ConnectionFailedResult.Quit:
 
-                     Close();
 
-                     return;
 
-                 case ConnectionFailedResult.Restart:
 
-                     App.ShouldRestart = true;
 
-                     Close();
 
-                     return;
 
-                 case ConnectionFailedResult.Ok:
 
-                     // Do nothing
 
-                     break;
 
-             }
 
-         }
 
-         ThemeManager.BaseColor = Colors.CornflowerBlue;
 
-         Progress.DisplayImage = PRSDesktop.Resources.splash_small.AsBitmapImage();
 
-         try
 
-         {
 
-             var dbInfo = new Client<User>().Info();
 
-             ClientFactory.DatabaseID = dbInfo.DatabaseID;
 
-             ThemeManager.BaseColor = (Color)ColorConverter.ConvertFromString(dbInfo.ColorScheme);
 
-             if (dbInfo.Logo?.Any() == true)
 
-                 using (var ms = new MemoryStream(dbInfo.Logo))
 
-                 {
 
-                     Progress.DisplayImage = new Bitmap(ms).AsBitmapImage();
 
-                 }
 
-         }
 
-         catch
 
-         {
 
-         }
 
-         //VideoRecordingStatus.Source = PRSDesktop.Resources.videorecording.AsGrayScale().AsBitmapImage();
 
-         //AudioRecordingStatus.Source = PRSDesktop.Resources.audiorecording.AsGrayScale().AsBitmapImage();
 
-         //SecondaryWindowStatus.Source = PRSDesktop.Resources.target.AsGrayScale().AsBitmapImage();
 
-         
 
-         ConsoleStatus.Source = PRSDesktop.Resources.view.AsGrayScale().AsBitmapImage();
 
-         SelectTask.Source = PRSDesktop.Resources.uparrow.Invert().AsBitmapImage();
 
-         Title = $"{(String.Equals(App.Profile?.ToUpper(), "DEFAULT") ? "PRS Desktop" : App.Profile)} (Release {CoreUtils.GetVersion()})";
 
-         
 
-         Logger.Send(LogType.Information, "", "Checking for updates");
 
-         SupportUtils.CheckForUpdates();
 
-         Exception? startupException = null;
 
-         ValidationStatus? loginStatus = null;
 
-         Progress.ShowModal("Loading PRS", progress =>
 
-         {
 
-             DynamicGridUtils.PreviewReport = (t, m) => { ReportUtils.PreviewReport(t, m, false, Security.IsAllowed<CanDesignReports>()); };
 
-             DynamicGridUtils.PrintMenu = (e, s, m, p) => { ReportUtils.PrintMenu(e, s, m, Security.IsAllowed<CanDesignReports>(), p); };
 
-             ImportFactory.Register(typeof(ExcelImporter<>), "Excel File", "Excel Files (*.xls;*.xlsx;*.xlsm)|*.xls;*.xlsx;*.xlsm");
 
-             ImportFactory.Register(typeof(CustomImporter<>), "Custom", "All Files (*.*)|*.*");
 
-             FormUtils.Register();
 
-             
 
-             DigitalFormDocumentFactory.Init(
 
-                 new WpfDigitalFormDocumentHandler(
 
-                     b => Dispatcher.BeginInvoke(() =>
 
-                         {
 
-                             BackgroundUploadStatus.Visibility = b
 
-                                 ? Visibility.Visible
 
-                                 : Visibility.Hidden;
 
-                         }
 
-                     ),
 
-                     () => _transport?.IsConnected() ?? false
 
-                 )
 
-             );
 
-             DigitalFormDocumentFactory.Run();
 
-             
 
-             Logger.Send(LogType.Information, "", "Registering Classes");
 
-             progress.Report("Registering Classes");
 
-             var tasks = new List<Task>
 
-             {
 
-                 Task.Run(() =>
 
-                 {
 
-                     CoreUtils.RegisterClasses(typeof(TaskGrid).Assembly);
 
-                     CoreUtils.RegisterClasses();
 
-                     ComalUtils.RegisterClasses();
 
-                     PRSSharedUtils.RegisterClasses();
 
-                     WPFUtils.RegisterClasses();
 
-                     ReportUtils.RegisterClasses();
 
-                     ConfigurationUtils.RegisterClasses();
 
-                 }),
 
-                 Task.Run(() =>
 
-                 {
 
-                     ScriptDocument.DefaultAssemblies.AddRange(
 
-                         Assembly.Load("RoslynPad.Roslyn.Windows"),
 
-                         Assembly.Load("RoslynPad.Editor.Windows"),
 
-                         typeof(Control).Assembly,
 
-                         typeof(MessageBox).Assembly,
 
-                         typeof(SolidColorBrush).Assembly
 
-                     );
 
-                     ScriptDocument.Initialize();
 
-                 }),
 
-                 Task.Run(() => DatabaseUpdateScripts.RegisterScripts())
 
-             };
 
-             Task.WaitAll(tasks.ToArray());
 
-             Logger.Send(LogType.Information, "", "Configuring Application");
 
-             progress.Report("Configuring Application");
 
-             RegisterModules(progress);
 
-             if (DatabaseType == DatabaseType.Standalone)
 
-             {
 
-                 progress.Report("Starting local database...");
 
-                 try
 
-                 {
 
-                     StartLocalDatabase(progress);
 
-                 }
 
-                 catch (Exception err)
 
-                 {
 
-                     startupException = new Exception(
 
-                         string.Format(
 
-                             "Unable to open database ({0})\n\n{1}\n\n{2}",
 
-                             App.DatabaseSettings.FileName,
 
-                             err.Message,
 
-                             err.StackTrace
 
-                         )
 
-                     );
 
-                 }
 
-             }
 
-         });
 
-         if (startupException is null && App.DatabaseSettings.Autologin)
 
-         {
 
-             try
 
-             {
 
-                 Logger.Send(LogType.Information, "", "Logging in");
 
-                 Dispatcher.Invoke(() =>
 
-                 {
 
-                     loginStatus = TryAutoLogin();
 
-                 });
 
-                 if(loginStatus == ValidationStatus.VALID)
 
-                 {
 
-                     // Do the AfterLogin() here so that we aren't opening and closing progress windows again and again.
 
-                     Progress.ShowModal("Loading PRS", progress =>
 
-                     {
 
-                         AfterLogin(progress);
 
-                     });
 
-                 }
 
-             }
 
-             catch(Exception e)
 
-             {
 
-                 startupException = e;
 
-             }
 
-         }
 
-         if (startupException != null)
 
-         {
 
-             MessageWindow.ShowError("Error during startup.", startupException);
 
-         }
 
-         
 
-         // If the login status is valid, then we've already loaded everything, so we don't here.
 
-         if(loginStatus != ValidationStatus.VALID)
 
-         {
 
-             Logger.Send(LogType.Information, "", "Logging in");
 
-             if (DoLogin() == ValidationStatus.VALID)
 
-             {
 
-                 AfterLogin(null);
 
-             }
 
-             else
 
-             {
 
-                 ConfigureMainScreen(null);
 
-             }
 
-         }
 
-         ProfileName.Content = App.Profile;
 
-         URL.Content = GetDatabaseConnectionDescription();
 
-         if (loginStatus == ValidationStatus.VALID && DatabaseType == DatabaseType.Standalone)
 
-         {
 
-             Progress.ShowModal("Starting Scheduler", progress =>
 
-             {
 
-                 scheduler.Start();
 
-             });
 
-         }
 
-     }
 
-     #region Connection Management
 
-     private string GetDatabaseConnectionDescription()
 
-     {
 
-         return DatabaseType switch
 
-         {
 
- #if RPC
 
-             DatabaseType.Networked => (ClientFactory.Parameters?.FirstOrDefault() as RpcClientSocketTransport)?.Host,
 
- #else
 
-             DatabaseType.Networked => ClientFactory.Parameters?.FirstOrDefault() as string,
 
- #endif
 
-             DatabaseType.Standalone => App.DatabaseSettings?.FileName,
 
-             DatabaseType.Local => App.DatabaseSettings?.LocalServerName,
 
-             _ => ""
 
-         } ?? "";
 
-     }
 
-     /// <summary>
 
-     /// Reconnect to the server.
 
-     /// </summary>
 
-     /// <returns><see langword="true"/> if connection was successful.</returns>
 
-     private bool Reconnect()
 
-     {
 
-         if (_transport != null)
 
-         {
 
-             return _transport.Connect();
 
-         }
 
-         Logger.Send(LogType.Error, ClientFactory.UserID, "Trying to reconnect without a transport set.");
 
-         return true; // Returning true so we don't get stuck in infinite loops in exceptional circumstances.
 
-     }
 
-     private enum ConnectionFailedResult
 
-     {
 
-         Quit,
 
-         Restart,
 
-         Ok
 
-     }
 
-     /// <summary>
 
-     /// To be called when initial connection to the server has failed; asks the user if they want to retry,
 
-     /// change the database settings, or simply quit PRS.
 
-     /// </summary>
 
-     /// <returns>The action to take next.</returns>
 
-     /// <exception cref="Exception"></exception>
 
-     private ConnectionFailedResult DoConnectionFailed()
 
-     {
 
-         bool connected = false;
 
-         while (!connected)
 
-         {
 
-             var connectionFailedWindow = new ConnectionFailed();
 
-             connectionFailedWindow.ShowDialog();
 
-             var reconnect = false;
 
-             switch (connectionFailedWindow.Result)
 
-             {
 
-                 case ConnectionFailedWindowResult.OpenDatabaseConfiguration:
 
-                     var result = ShowDatabaseConfiguration();
 
-                     switch (result)
 
-                     {
 
-                         case DatabaseConfigurationResult.RestartRequired:
 
-                             var shouldRestart = MessageBox.Show(
 
-                                 "A restart is required to apply these changes. Do you wish to restart now?",
 
-                                 "Restart?",
 
-                                 MessageBoxButton.YesNo);
 
-                             if (shouldRestart == MessageBoxResult.Yes)
 
-                             {
 
-                                 return ConnectionFailedResult.Restart;
 
-                             }
 
-                             else
 
-                             {
 
-                                 reconnect = true;
 
-                             }
 
-                             break;
 
-                         case DatabaseConfigurationResult.RestartNotRequired:
 
-                             reconnect = true;
 
-                             break;
 
-                         case DatabaseConfigurationResult.Cancel:
 
-                             reconnect = true;
 
-                             break;
 
-                         default:
 
-                             throw new Exception($"Invalid enum result {result}");
 
-                     }
 
-                     break;
 
-                 case ConnectionFailedWindowResult.RetryConnection:
 
-                     reconnect = true;
 
-                     break;
 
-                 case ConnectionFailedWindowResult.Quit:
 
-                     return ConnectionFailedResult.Quit;
 
-                 default:
 
-                     throw new Exception($"Invalid enum result {connectionFailedWindow.Result}");
 
-             }
 
-             if (!reconnect)
 
-             {
 
-                 return ConnectionFailedResult.Quit;
 
-             }
 
-             connected = Reconnect();
 
-         }
 
-         return ConnectionFailedResult.Ok;
 
-     }
 
-     private void Transport_OnOpen(IRpcTransport transport, RpcTransportOpenArgs e)
 
-     {
 
-         Logger.Send(LogType.Information, ClientFactory.UserID, "Connection opened");
 
-     }
 
-     private void Transport_OnException(IRpcTransport transport, RpcTransportExceptionArgs e)
 
-     {
 
-         Logger.Send(LogType.Error, ClientFactory.UserID, $"Error in connection: {CoreUtils.FormatException(e.Exception)}");
 
-     }
 
-     private void TransportConnectionLost(IRpcTransport transport, RpcTransportCloseArgs e)
 
-     {
 
-         Logger.Send(LogType.Information, ClientFactory.UserID, "Connection lost");
 
-         if (transport is IRpcClientTransport client)
 
-         {
 
-             Dispatcher.Invoke(() =>
 
-             {
 
-                 var reconnection = new ReconnectionWindow();
 
-                 var cancellationTokenSource = new CancellationTokenSource();
 
-                 reconnection.OnCancelled = () => cancellationTokenSource.Cancel();
 
-                 var ct = cancellationTokenSource.Token;
 
-                 var work = () =>
 
-                 {
 
-                     try
 
-                     {
 
-                         DateTime lost = DateTime.Now;
 
-                         while (!client.IsConnected() && !ct.IsCancellationRequested)
 
-                         {
 
-                             try
 
-                             {
 
-                                 Logger.Send(LogType.Error, ClientFactory.UserID, $"Reconnecting - ({DateTime.Now - lost:hh\\:mm})");
 
-                                 if (client.Connect(ct))
 
-                                 {
 
-                                     break;
 
-                                 }
 
-                             }
 
-                             catch (System.Exception e1)
 
-                             {
 
-                                 Logger.Send(LogType.Error, ClientFactory.UserID, $"Reconnect Failed: {e1.Message}");
 
-                                 // TODO: Remove this suppression
 
-                                 if (e1.Message.StartsWith("The socket is connected, you needn't connect again!"))
 
-                                 {
 
-                                     break;
 
-                                 }
 
-                             }
 
-                         }
 
-                         if (client.IsConnected())
 
-                         {
 
-                             Logger.Send(LogType.Information, ClientFactory.UserID, "Reconnected");
 
-                             ClientFactory.Validate(ClientFactory.SessionID);
 
-                             Logger.Send(LogType.Information, ClientFactory.UserID, "Validated");
 
-                             return true;
 
-                         }
 
-                     }
 
-                     catch (Exception e)
 
-                     {
 
-                         Logger.Send(LogType.Error, ClientFactory.UserID, $"Reconnect Failed: {e.Message}");
 
-                     }
 
-                     return false;
 
-                 };
 
-                 var task = Task.Run(() =>
 
-                 {
 
-                     var result = work();
 
-                     Dispatcher.Invoke(() =>
 
-                     {
 
-                         reconnection.Close();
 
-                     });
 
-                     return result;
 
-                 }, ct);
 
-                 reconnection.ShowDialog();
 
-                 if (!task.Result)
 
-                 {
 
-                     Close();
 
-                 }
 
-             });
 
-         }
 
-     }
 
-     #endregion
 
-     private bool _loggingOut = false;
 
-     private void ClientFactory_OnRequestError(RequestException e)
 
-     {
 
-         if (e.Status == StatusCode.Unauthenticated)
 
-         {
 
-             switch (e.Method)
 
-             {
 
-                 case RequestMethod.Query:
 
-                 case RequestMethod.Save:
 
-                 case RequestMethod.Delete:
 
-                 case RequestMethod.MultiQuery:
 
-                 case RequestMethod.MultiSave:
 
-                 case RequestMethod.MultiDelete:
 
-                     if (!_loggingOut)
 
-                     {
 
-                         Dispatcher.InvokeAsync(() =>
 
-                         {
 
-                             _loggingOut = true;
 
-                             try
 
-                             {
 
-                                 Logout(null, true);
 
-                             }
 
-                             finally
 
-                             {
 
-                                 _loggingOut = false;
 
-                             }
 
-                         });
 
-                     }
 
-                     break;
 
-                 default:
 
-                     break;
 
-             }
 
-         }
 
-     }
 
-     private void ApplyColorScheme()
 
-     {
 
-         Color baseColor;
 
-         try
 
-         {
 
-             baseColor = (Color)ColorConverter.ConvertFromString(App.DatabaseSettings.ColorScheme);
 
-         }
 
-         catch
 
-         {
 
-             baseColor = Colors.CornflowerBlue;
 
-         }
 
-         ThemeManager.BaseColor = baseColor;
 
-         DynamicGridUtils.SelectionBackground = ThemeManager.SelectionBackgroundBrush;
 
-         DynamicGridUtils.SelectionForeground = ThemeManager.SelectionForegroundBrush;
 
-         DynamicGridUtils.FilterBackground = ThemeManager.FilterBackgroundBrush;
 
-         //_ribbon.Background =  new SolidColorBrush(Colors.White);
 
-         //_ribbon.BackStageColor = ThemeConverter.GetBrush(ElementType.Ribbon, BrushType.Background);
 
-         ////_ribbon.BackStage.Background = ThemeConverter.GetBrush(ElementType.Ribbon, BrushType.Background);
 
-         ////_ribbon.BackStage.Foreground = ThemeConverter.GetBrush(ElementType.Ribbon, BrushType.Foreground);
 
-         UpdateRibbonColors();
 
-         PanelHost.Refresh();
 
-     }
 
-     #region Configuration
 
-     /*
 
-     protected override void OnSourceInitialized(EventArgs e)
 
-     {
 
-         base.OnSourceInitialized(e);
 
-         var source = PresentationSource.FromVisual(this) as HwndSource;
 
-         source?.AddHook(WndProc);
 
-     }
 
-     private IntPtr WndProc(IntPtr hwnd, int msg, IntPtr wParam, IntPtr lParam, ref bool handled)
 
-     {
 
-         var message = (App.Message)msg;
 
-         switch (message)
 
-         {
 
-             case App.Message.Maximise:
 
-                 WindowState = WindowState.Maximized;
 
-                 break;
 
-         }
 
-         return IntPtr.Zero;
 
-     }*/
 
-     private void ConfigureMainScreen(IProgress<string>? progress)
 
-     {
 
-         var bMaps = Security.CanView<Equipment>()
 
-                     || Security.CanView<Job>()
 
-                     || Security.CanView<TimeSheet>()
 
-                     || Security.CanView<GPSTracker>();
 
-         var sections = new[]
 
-         {
 
-             new ProgressSection("Configuring Main Screen", SetupMainScreen),
 
-             new ProgressSection("Configuring Projects", () => SetupProjectsTab(bMaps)),
 
-             new ProgressSection("Configuring Manufacturing", () => SetupManufacturingTab(bMaps)),
 
-             new ProgressSection("Configuring Logistics", () => SetupLogisticsTab(bMaps)),
 
-             new ProgressSection("Configuring Products", () => SetupProductsTab(bMaps)),
 
-             new ProgressSection("Configuring Human Resources", () => SetupHumanResourcesTab(bMaps)),
 
-             new ProgressSection("Configuring Accounts", () => SetupAccountsTab(bMaps)),
 
-             new ProgressSection("Configuring Equipment", () => SetupEquipmentTab(bMaps)),
 
-             new ProgressSection("Configuring DigitalForms", () => SetupDigitalFormsTab(bMaps)),
 
-             new ProgressSection("Configuring Dashboards", () => SetupDashboardsTab(bMaps)),
 
-             new ProgressSection("Configuring System Modules", SetupSystemModules)
 
-         };
 
-         if(progress is not null)
 
-         {
 
-             Dispatcher.Invoke(SetupScreen);
 
-             foreach(var section in sections)
 
-             {
 
-                 progress.Report(section.Message);
 
-                 Dispatcher.Invoke(section.Action);
 
-             }
 
-         }
 
-         else
 
-         {
 
-             SetupScreen();
 
-             Progress.ShowModal(sections);
 
-         }
 
-     }
 
-     private void SetupScreen()
 
-     {
 
-         var button = _ribbon.FindVisualChildren<Fluent.DropDownButton>().FirstOrDefault();
 
-         if (button != null)
 
-             button.Visibility = Visibility.Collapsed;
 
-         if (ClientFactory.UserGuid == Guid.Empty)
 
-             _ribbonRow.Height = new GridLength(30, GridUnitType.Pixel);
 
-         else
 
-             _ribbonRow.Height = new GridLength(1, GridUnitType.Auto);
 
-     }
 
-     private void SetupMainScreen()
 
-     {
 
-         //DockManager.SidePanelSize = OutstandingDailyReports(false) ? 0.00F : 30.00F;
 
-         // Notifications Area
 
-         SetFrameworkItemVisibility(SendNotification, Security.CanView<Notification>());
 
-         SetFrameworkItemVisibility(Notifications, Security.CanView<Notification>());
 
-         SetFrameworkItemVisibility(TaskTracking, Security.IsAllowed<CanTrackTasksInDailyReport>());
 
-         UserID.Content = ClientFactory.UserID;
 
-         if (ClientFactory.PasswordExpiration != DateTime.MinValue)
 
-         {
 
-             var timeUntilExpiration = ClientFactory.PasswordExpiration - DateTime.Now;
 
-             if (timeUntilExpiration.Days < 14)
 
-             {
 
-                 PasswordExpiryNotice.Content = $"Password will expire in {timeUntilExpiration.Days} days!";
 
-                 PasswordExpiryNotice.Visibility = Visibility.Visible;
 
-             }
 
-             else
 
-             {
 
-                 PasswordExpiryNotice.Visibility = Visibility.Collapsed;
 
-             }
 
-         }
 
-     }
 
-     private void SetupSystemModules()
 
-     {
 
-         SetFrameworkItemVisibility(CompanyInformation, Security.CanView<CompanyInformation>());
 
-         SetVisibleIfAny(BackstageSeparator0, CompanyInformation);
 
-         SetFrameworkItemVisibility(SecurityDefaultsButton,
 
-             ClientFactory.IsSupported<GlobalSecurityToken>() && Security.IsAllowed<CanCustomiseSecurityDefaults>());
 
-         SetVisibleIfAny(BackstageSeparator1, SecurityDefaultsButton);
 
-         BackstageSeparator1a.Visibility = Visibility.Visible;
 
-         SystemLogsButton.Visibility = Visibility.Visible;
 
-         SetFrameworkItemVisibility(DocumentTypeList, ClientFactory.IsSupported<DocumentType>() && Security.IsAllowed<CanViewDocumentTypes>());
 
-         SetFrameworkItemVisibility(EventList, Security.IsAllowed<CanManageEvents>());
 
-         SetVisibleIfAny(BackstageSeparator2, DocumentTypeList, EventList);
 
-         //SetModuleVisibility<>(VideoRecordingButton, Security.IsAllowed<CanRecordScreen>());
 
-         LogoutButton.Visibility = ClientFactory.UserGuid == Guid.Empty ? Visibility.Collapsed : Visibility.Visible;
 
-         LoginButton.Visibility = ClientFactory.UserGuid != Guid.Empty ? Visibility.Collapsed : Visibility.Visible;
 
-         EditDetailsButton.Visibility = ClientFactory.UserGuid == Guid.Empty ? Visibility.Collapsed : Visibility.Visible;
 
-         SetupDock<CanViewContactsDock>(ContactDock, Contacts);
 
-         SetupDock<CanViewJobDock>(JobDock, Jobs);
 
-         SetupDock<CanViewConsignmentDock>(ConsignmentDock, Consignments);
 
-         SetupDock<CanViewDeliveryDock>(DeliveryDock, Deliveries);
 
-         SetupDock<CanViewProductDock>(ProductLookupDock, ProductLookup);
 
-         SetupDock<CanViewDigitalFormsDock>(DigitalFormsDock, DigitalForms);
 
-         SetupDock<CanViewProblemsDock>(ProblemsDock, Problems);
 
-         SetupDock<CanViewRequisitionsDock>(RequisitionsDock, Requisitions);
 
-         _ribbon.InvalidateArrange();
 
-     }
 
-     private void SetupDashboardsTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopDashboardsTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(DashboardsDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(DashboardMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(DashboardsTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(DashboardsAttendanceButton, ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(DashboardsMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(DashboardsDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<FactoryProductivityDashboard>(FactoryProductivityButton,
 
-             ClientFactory.IsSupported<ManufacturingHistory>() 
 
-             && Security.IsAllowed<CanViewFactoryKPIs>()
 
-             && Security.IsAllowed<ViewDesktopFactoryKPIsDashboard>());
 
-         SetModuleVisibility<ManufacturingTemplateAnalysis>(TemplateAnalysisButton,
 
-             ClientFactory.IsSupported<ManufacturingTemplate, ManufacturingHistory>() 
 
-             && Security.IsAllowed<CanViewTemplateAnalysis>()
 
-             && Security.IsAllowed<ViewDesktopTemplateAnalysisDashboard>());
 
-         SetModuleVisibility<FactoryFloorAnalysis>(FactoryAnalysisButton,
 
-             ClientFactory.IsSupported<ManufacturingTemplate, ManufacturingHistory>() 
 
-             && Security.IsAllowed<CanViewFactoryAnalysis>()
 
-             && Security.IsAllowed<ViewDesktopFactoryAnalysisDashboard>());
 
-         SetModuleVisibility<DatabaseActivityDashboard>(DatabaseActivityButton,
 
-             ClientFactory.IsSupported<UserTracking>() 
 
-             && Security.IsAllowed<CanViewDatabaseActivity>()
 
-             && Security.IsAllowed<ViewDesktopDatabaseActivityDashboard>());
 
-         SetModuleVisibility<UserActivity>(UserActivityButton, ClientFactory.IsSupported<ModuleTracking>() 
 
-                                                         && Security.IsAllowed<CanViewUserActivity>()
 
-                                                         && Security.IsAllowed<ViewDesktopUserActivityDashboard>());
 
-         SetModuleVisibility<WidgetDashboard>(QuickStatusButton, Security.IsAllowed<CanViewQuickStatus>() && Security.IsAllowed<ViewDesktopQuickStatusDashboard>());
 
-         SetVisibleIfEither(DashboardsTaskSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                             DashboardsDashboardButton, DashboardMessagesButton, DashboardsTaskButton, DashboardsAttendanceButton,
 
-                             DashboardsMapButton,
 
-                             DashboardsDailyReportButton
 
-             },
 
-             new FrameworkElement[]
 
-             {
 
-                             FactoryProductivityButton, TemplateAnalysisButton, FactoryAnalysisButton, DatabaseActivityButton, UserActivityButton, QuickStatusButton
 
-             });
 
-         SetVisibleIfAny(DashboardsActions, DashboardsDashboardButton, DashboardMessagesButton, DashboardsTaskButton,
 
-             DashboardsAttendanceButton, DashboardsDailyReportButton, FactoryProductivityButton, TemplateAnalysisButton,
 
-             FactoryAnalysisButton, DatabaseActivityButton, UserActivityButton, QuickStatusButton);
 
-         //DashboardsActions.IsLauncherButtonVisible = Security.IsAllowed<CanCustomiseModules>();
 
-         //DashboardsReports.IsLauncherButtonVisible = Security.IsAllowed<CanDesignReports>();
 
-         SetVisibleIfAny(DashboardsTab, FactoryProductivityButton, TemplateAnalysisButton, FactoryAnalysisButton,
 
-             DatabaseActivityButton,
 
-             UserActivityButton, QuickStatusButton);
 
-     }
 
-     
 
-     private void SetupDigitalFormsTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopDigitalFormsTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(DigitalFormsDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(DigitalFormsMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(DigitalFormsTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(DigitalFormsAttendanceButton, ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(DigitalFormsMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(DigitalFormsDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<DigitalFormsLibrary>(DigitalFormsFormsLibraryButton, ClientFactory.IsSupported<DigitalForm>()
 
-                                                                            && Security.CanView<DigitalForm>()
 
-                                                                            && Security.IsAllowed<CanAdministerDigitalFormsLibrary>());
 
-         SetModuleVisibility<CompletedFormsPanel>(DigitalFormsCompletedFormsButton, Security.IsAllowed<CanViewDigitalFormsDashbaord>() && Security.IsAllowed<ViewDesktopDigitalFormsDashboard>());
 
-         SetVisibleIfEither(DigitalFormsTaskSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                 DigitalFormsDashboardButton, DigitalFormsMessagesButton, DigitalFormsTaskButton, DigitalFormsAttendanceButton, DigitalFormsMapButton,
 
-                 DigitalFormsDailyReportButton
 
-             }, new FrameworkElement[] { DigitalFormsFormsLibraryButton, DigitalFormsCompletedFormsButton });
 
-         SetVisibleIfAny(DigitalFormsActions, DigitalFormsDashboardButton, DigitalFormsMessagesButton, DigitalFormsTaskButton,
 
-             DigitalFormsAttendanceButton, DigitalFormsDailyReportButton, DigitalFormsFormsLibraryButton, DigitalFormsCompletedFormsButton);
 
-         SetTabVisibleIfAny(DigitalFormsTab, DigitalFormsFormsLibraryButton, DigitalFormsCompletedFormsButton);
 
-     }
 
-     
 
-     private void SetupEquipmentTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopEquipmentTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(EquipmentDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(EquipmentMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(EquipmentTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(EquipmentAttendanceButton, ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(EquipmentMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(EquipmentDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<EquipmentPanel>(EquipmentButton, ClientFactory.IsSupported<Equipment>() 
 
-                                                        && Security.CanView<Equipment>()
 
-                                                        && Security.IsAllowed<ViewDesktopEquipmentListScreen>());
 
-         
 
-         SetModuleVisibility<EquipmentMaintenancePanel>(EquipmentMaintenanceButton,
 
-             ClientFactory.IsSupported<Equipment>() 
 
-             && Security.CanView<Equipment>()
 
-             && Security.IsAllowed<ViewDesktopEquipmentMaintenanceScreen>() );
 
-         SetModuleVisibility<EquipmentPlannerPanel>(EquipmentPlannerButton, 
 
-             ClientFactory.IsSupported<Equipment>() 
 
-             && Security.CanView<Equipment>()
 
-             && ClientFactory.IsSupported<Assignment>() 
 
-             && Security.CanView<Assignment>()
 
-             && Security.IsAllowed<ViewDesktopEquipmentPlannerScreen>());
 
-         SetVisibleIfEither(EquipmentTaskSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                             EquipmentDashboardButton, EquipmentMessagesButton, EquipmentTaskButton, EquipmentAttendanceButton, EquipmentMapButton,
 
-                             EquipmentDailyReportButton
 
-             }, new FrameworkElement[] { EquipmentButton, EquipmentPlannerButton });
 
-         
 
-         SetVisibleIfAny(EquipmentActions, EquipmentDashboardButton, EquipmentMessagesButton, EquipmentTaskButton,
 
-             EquipmentAttendanceButton, EquipmentDailyReportButton, EquipmentButton, EquipmentPlannerButton);
 
-         SetModuleVisibility<GPSTrackers>(TrackersMasterList, Security.CanView<GPSTracker>() && Security.IsAllowed<ViewDesktopGPSTrackersScreen>());
 
-         SetTabVisibleIfAny(EquipmentTab, EquipmentButton, TrackersMasterList);
 
-     }
 
-     private void SetupAccountsTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopAccountsTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(AccountsDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(AccountsMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(AccountsTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(AccountsAttendanceButton, ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(AccountsMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(AccountsDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<CustomerPanel>(CustomerList, ClientFactory.IsSupported<Customer>() 
 
-                                                    && Security.CanView<Customer>()
 
-                                                    && Security.IsAllowed<ViewDesktopCustomersScreen>());
 
-         SetModuleVisibility<InvoicePanel>(InvoiceList, ClientFactory.IsSupported<Invoice>() 
 
-                                                  && Security.CanView<Invoice>()
 
-                                                  && Security.IsAllowed<ViewDesktopInvoicesScreen>());
 
-         SetModuleVisibility<CustomerReceipts>(ReceiptList, ClientFactory.IsSupported<Receipt>() 
 
-                                                      && Security.CanView<Receipt>()
 
-                                                      && Security.IsAllowed<ViewDesktopReceiptsScreen>());
 
-         SetModuleVisibility<SupplierPanel>(SupplierList, ClientFactory.IsSupported<Supplier>() 
 
-                                                    && Security.CanView<Supplier>()
 
-                                                    && Security.IsAllowed<ViewDesktopSuppliersScreen>());
 
-         SetModuleVisibility<DataEntryPanel>(AccountsDataButton, Security.IsAllowed<CanViewDataEntryPanel>());
 
-         SetModuleVisibility<SupplierPurchaseOrderPanel>(PurchasesList, ClientFactory.IsSupported<PurchaseOrder>() 
 
-                                                                  && Security.CanView<PurchaseOrder>()
 
-                                                                  && Security.IsAllowed<ViewDesktopPurchaseOrdersScreen>());
 
-         SetModuleVisibility<SupplierBillPanel>(BillsList, ClientFactory.IsSupported<Bill>() 
 
-                                                     && Security.CanView<Bill>()
 
-                                                     && Security.IsAllowed<ViewDesktopBillsScreen>());
 
-         SetModuleVisibility<SupplierPayments>(PaymentsList, ClientFactory.IsSupported<Payment>() 
 
-                                                       && Security.CanView<Payment>()
 
-                                                       && Security.IsAllowed<ViewDesktopPaymentsScreen>());
 
-         SetVisibleIfEither(AccountsTaskSeparator1,
 
-             new FrameworkElement[]
 
-             {
 
-                             AccountsDashboardButton, AccountsMessagesButton, AccountsTaskButton, AccountsAttendanceButton, AccountsMapButton,
 
-                             AccountsDailyReportButton
 
-             }, new FrameworkElement[] { CustomerList, InvoiceList, ReceiptList });
 
-         SetVisibleIfEither(AccountsTaskSeparator2, new FrameworkElement[] { CustomerList, InvoiceList, ReceiptList },
 
-             new FrameworkElement[] { SupplierList, AccountsDataButton, PurchasesList, BillsList, PaymentsList });
 
-         SetVisibleIfAny(AccountsActions, AccountsDashboardButton, AccountsMessagesButton, AccountsTaskButton,
 
-             AccountsAttendanceButton,
 
-             AccountsDailyReportButton, CustomerList, InvoiceList, ReceiptList, SupplierList, PurchasesList, BillsList, PaymentsList);
 
-         SetTabVisibleIfAny(AccountsTab, CustomerList, InvoiceList, ReceiptList, SupplierList, AccountsDataButton, PurchasesList, BillsList, PaymentsList);
 
-     }
 
-     private void SetupHumanResourcesTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopHumanResourcesTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(HumanResourcesDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(HumanResourcesMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(HumanResourcesTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(HumanResourcesAttendanceButton,
 
-             ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(HumanResourcesMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(HumanResourcesDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<CalendarPanel>(CalendarButton, Security.CanView<Assignment>() && Security.IsAllowed<ViewDesktopCalendarScreen>());
 
-         SetModuleVisibility<EmployeeResourcePlannerPanel>(EmployeePlannerButton, Security.CanView<Assignment>() && Security.IsAllowed<ViewDesktopEmployeePlannerScreen>());
 
-         SetModuleVisibility<TimesheetPanel>(TimesheetsButton, Security.CanView<TimeSheet>() && Security.IsAllowed<ViewDesktopStaffTimeSheetsScreen>());
 
-         SetModuleVisibility<LeaveRequestPanel>(LeaveRequestsButton, Security.CanView<LeaveRequest>() && Security.IsAllowed<ViewDesktopLeaveRequestsScreen>());
 
-         SetModuleVisibility<OrgChartPanel>(OrgChartButton,
 
-             ClientFactory.IsSupported<Employee>()
 
-             && 
 
-             Security.IsAllowed<ViewDesktopOrgChartScreen>()
 
-         );
 
-         SetModuleVisibility<MeetingPanel>(MeetingsButton, Security.IsAllowed<ViewDesktopMeetingsScreen>());
 
-         SetVisibleIfEither(HumanResourcesTaskSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                             HumanResourcesDashboardButton, HumanResourcesMessagesButton, HumanResourcesTaskButton, HumanResourcesAttendanceButton,
 
-                             HumanResourcesMapButton, HumanResourcesDailyReportButton
 
-             }, new FrameworkElement[] { CalendarButton, EmployeePlannerButton, TimesheetsButton, LeaveRequestsButton, OrgChartButton });
 
-         SetVisibleIfAny(HumanResourcesActions, HumanResourcesDashboardButton, HumanResourcesTaskButton,
 
-             HumanResourcesAttendanceButton,
 
-             HumanResourcesDailyReportButton, CalendarButton, EmployeePlannerButton, TimesheetsButton, LeaveRequestsButton, OrgChartButton);
 
-         SetModuleVisibility<UserPanel>(UsersButton, Security.CanView<User>() && Security.IsAllowed<ViewDesktopUserAccountsScreen>());
 
-         SetModuleVisibility<EmployeePanel>(EmployeesButton, Security.CanView<Employee>() && Security.IsAllowed<ViewDesktopEmployeeListScreen>());
 
-         SetVisibleIfEither(HumanResourcesSetupSeparator1,
 
-             new FrameworkElement[] { CalendarButton, TimesheetsButton, LeaveRequestsButton, OrgChartButton },
 
-             new FrameworkElement[] { UsersButton, EmployeesButton });
 
-         SetTabVisibleIfAny(HumanResourcesTab, CalendarButton, TimesheetsButton, LeaveRequestsButton, OrgChartButton, UsersButton, EmployeesButton);
 
-     }
 
-     private void SetupProductsTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopProductManagementTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(ProductsDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(ProductsMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(ProductsTaskButton, Security.CanView<Kanban>());
 
-         SetModuleVisibility<AttendancePanel>(ProductsAttendanceButton, Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(ProductsMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(ProductsDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<ProductsPanel>(ProductsMasterList, Security.CanView<Product>() && Security.IsAllowed<ViewDesktopProductListScreen>());
 
-         SetModuleVisibility<StockLocationPanel>(StockLocationList, Security.CanView<StockLocation>() && Security.IsAllowed<ViewDesktopStockLocationsScreen>());
 
-         SetModuleVisibility<StockMovementPanel>(StockMovementList, Security.CanView<StockMovement>() && Security.IsAllowed<ViewDesktopStockMovementsScreen>());
 
-         SetModuleVisibility<StockForecastPanel>(StockForecastButton, Security.CanView<Product>()
 
-                                                                      && Security.CanView<JobMaterial>()
 
-                                                                      && Security.IsAllowed<ViewDesktopStockForecastScreen>());
 
-         SetModuleVisibility<ReservationManagementPanel>(ReservationManagementButton, Security.IsAllowed<ViewDesktopReservationManagementScreen>());
 
-         SetVisibleIfEither(ProductsTaskSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                             ProductsDashboardButton, ProductsMessagesButton, ProductsTaskButton, ProductsAttendanceButton, ProductsMapButton,
 
-                             ProductsDailyReportButton
 
-             }, new FrameworkElement[] { ProductsMasterList, StockLocationList, StockMovementList, StockForecastButton });
 
-         SetVisibleIfAny(ProductActions, ProductsMasterList, StockLocationList, StockMovementList, StockForecastButton);
 
-         SetTabVisibleIfAny(ProductTab, ProductActions);
 
-     }
 
-     private void SetupLogisticsTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopLogisticsTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(LogisticsDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(LogisticsMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(LogisticsTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(LogisticsAttendanceButton, ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(LogisticsMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(LogisticsDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<ReadyToGoPanel>(ReadyToGoItemsButton,
 
-             ClientFactory.IsSupported<DeliveryItem>()
 
-             && Security.IsAllowed<CanViewLogisticsReadyToGo>()
 
-             && Security.IsAllowed<ViewDesktopReadyToGoScreen>());
 
-         SetModuleVisibility<DispatchPanel>(DispatchButton, Security.CanView<Shipment>()
 
-                                                            && Security.CanView<DeliveryItem>()
 
-                                                            && Security.IsAllowed<ViewDesktopRackListScreen>());
 
-         SetModuleVisibility<RequisitionPanel>(RequisitionsButton, Security.CanView<Requisition>() && Security.IsAllowed<ViewDesktopSiteRequisitionsScreen>());
 
-         SetModuleVisibility<DeliveryPanel>(DeliveriesButton, Security.IsAllowed<CanViewDeliveriesModule>() && Security.IsAllowed<ViewDesktopDeliveriesScren>());
 
-         SetModuleVisibility<DeliveredOnSitePanel>(DeliveredItemsButton,
 
-             ClientFactory.IsSupported<DeliveryItem>()
 
-             && Security.IsAllowed<CanViewDeliveredOnSite>()
 
-             && Security.IsAllowed<ViewDesktopDeliveredOnSiteScreen>());
 
-         SetModuleVisibility<ConsignmentsPanel>(ConsignmentButton, Security.CanView<Consignment>() && Security.IsAllowed<ViewDesktopIncomingConsignmentsScreen>());
 
-         SetVisibleIfEither(LogisticsTaskSeparator1,
 
-             new FrameworkElement[]
 
-             {
 
-                             LogisticsDashboardButton, LogisticsMessagesButton, LogisticsTaskButton, LogisticsAttendanceButton, LogisticsMapButton,
 
-                             LogisticsDailyReportButton
 
-             },
 
-             new FrameworkElement[]
 
-                 { ReadyToGoItemsButton, DispatchButton, RequisitionsButton, DeliveriesButton, DeliveredItemsButton });
 
-         SetVisibleIfEither(LogisticsTaskSeparator2,
 
-             new FrameworkElement[]
 
-                 { ReadyToGoItemsButton, DispatchButton, RequisitionsButton, DeliveriesButton, DeliveredItemsButton },
 
-             new FrameworkElement[] { ConsignmentButton });
 
-         SetTabVisibleIfAny(LogisticsTab, DispatchButton, RequisitionsButton, DeliveriesButton, ReadyToGoItemsButton,
 
-             DeliveredItemsButton,
 
-             ConsignmentButton);
 
-     }
 
-     private void SetupManufacturingTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopManufacturingTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(ManufacturingDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(ManufacturingMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(ManufacturingTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(ManufacturingAttendanceButton,
 
-             ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(ManufacturingMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(ManufacturingDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         
 
-         SetVisibleIfAny(ManufacturingTaskSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                 ManufacturingDashboardButton, ManufacturingMessagesButton, ManufacturingTaskButton, ManufacturingAttendanceButton,
 
-                 ManufacturingMapButton, ManufacturingDailyReportButton
 
-             });
 
-         
 
-         SetModuleVisibility<StagingPanel>(DesignManagementButton, Security.CanView<Job>() && Security.IsAllowed<ViewDesktopDesignManagementScreen>());
 
-         SetFrameworkItemVisibility(ManufacturingDesignSeparator, Security.CanView<Job>() && Security.IsAllowed<ViewDesktopDesignManagementScreen>());
 
-         
 
-         SetModuleVisibility<ManufacturingPanel>(FactoryStatusButton,
 
-             ClientFactory.IsSupported<ManufacturingFactory, ManufacturingPacket>()
 
-             && Security.IsAllowed<CanViewFactoryStatus>()
 
-             && Security.IsAllowed<ViewDesktopManufacturingStatusScreen>());
 
-         SetModuleVisibility<ManufacturingAllocationPanel>(FactoryAllocationButton,
 
-             ClientFactory.IsSupported<ManufacturingFactory, ManufacturingPacket, ManufacturingPacketStage>()
 
-             && Security.IsAllowed<CanViewFactoryAllocation>()
 
-             && Security.IsAllowed<ViewDesktopFactoryAllocationScreen>());
 
-         //SetModuleVisibility<>(FactoryScheduleButton, ClientFactory.IsSupported<Booking>() && ClientFactory.IsEnabled<>());
 
-         SetModuleVisibility<FactoryPanel>(FactoryFloorButton,
 
-             ClientFactory.IsSupported<ManufacturingPacket>()
 
-             && Security.IsAllowed<CanViewFactoryFloor>()
 
-             && Security.IsAllowed<ViewDesktopFactoryFloorScreen>());
 
-         //SetModuleVisibility<>(FactoryReadyButton, ClientFactory.IsSupported<ManufacturingPacket>() && Security.IsAllowed<CanViewFactoryReadyToGo>());
 
-         
 
-         SetVisibleIfAny(ManufacturingActionSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                 FactoryStatusButton, FactoryAllocationButton, FactoryFloorButton
 
-             });
 
-         
 
-         
 
-         SetVisibleIfAny(ManufacturingActions, ManufacturingDashboardButton, ManufacturingMessagesButton, ManufacturingTaskButton,
 
-             ManufacturingAttendanceButton, ManufacturingDailyReportButton, FactoryStatusButton, FactoryAllocationButton,
 
-             FactoryFloorButton);
 
-         SetTabVisibleIfAny(ManufacturingTab, FactoryStatusButton, FactoryAllocationButton, FactoryFloorButton);
 
-     }
 
-     private void SetupProjectsTab(bool bMaps)
 
-     {
 
-         if (!Security.IsAllowed<ViewDesktopProjectsTab>())
 
-             return;
 
-         SetModuleVisibility<UtilityDashboard>(ProjectsDashboardButton, Security.IsAllowed<CanViewUserDefinedDashboards>());
 
-         SetModuleVisibility<NotificationPanel>(ProjectMessagesButton, Security.CanView<Notification>());
 
-         SetModuleVisibility<TaskPanel>(ProjectTaskButton, ClientFactory.IsSupported<Kanban>() && Security.IsAllowed<CanViewTasks>());
 
-         SetModuleVisibility<AttendancePanel>(ProjectAttendanceButton, ClientFactory.IsSupported<TimeSheet>() && Security.IsAllowed<CanViewInOutBoard>());
 
-         SetModuleVisibility<MapsPanel>(ProjectsMapButton, bMaps);
 
-         SetModuleVisibility<DailyReport>(ProjectDailyReportButton,
 
-             ClientFactory.IsSupported<TimeSheet, Assignment>() && Security.IsAllowed<CanViewDailyReports>());
 
-         SetModuleVisibility<ProjectsPanel>(ProjectsButton, Security.CanView<Job>() && Security.IsAllowed<ViewDesktopProjectsScreen>());
 
-         //SetModuleVisibility<>(ServiceButton, Security.CanView<Job>() && Security.IsAllowed<ViewDesktopServiceScreen>());
 
-         SetModuleVisibility<JobResourcePlannerPanel>(ProjectPlannerButton, Security.CanView<Job>() && Security.IsAllowed<ViewDesktopProjectPlannerScreen>());
 
-         
 
-         SetVisibleIfEither(ProjectTaskSeparator,
 
-             new FrameworkElement[]
 
-             {
 
-                             ProjectsDashboardButton, ProjectMessagesButton, ProjectTaskButton, ProjectAttendanceButton, ProjectsMapButton,
 
-                             ProjectDailyReportButton
 
-             }, new FrameworkElement[] { QuotesButton, ProjectsButton, ProjectPlannerButton });
 
-         
 
-         SetModuleVisibility<QuotePanel>(QuotesButton, Security.CanView<Quote>() && Security.IsAllowed<ViewDesktopQuotesScreen>());
 
-         SetModuleVisibility<KitPanel>(KitsMasterList, Security.CanView<Kit>() && Security.IsAllowed<ViewDesktopProductKitsScreen>());
 
-         SetModuleVisibility<CostSheetPanel>(CostSheetsMasterList, Security.CanView<CostSheet>() && Security.IsAllowed<ViewDesktopCostSheetsScreen>());
 
-         SetVisibleIfAny(ProjectsSetup, KitsMasterList, CostSheetsMasterList);
 
-         //ProjectsActions.IsLauncherButtonVisible = Security.IsAllowed<CanCustomiseModules>();
 
-         //ProjectReports.IsLauncherButtonVisible = Security.IsAllowed<CanDesignReports>();
 
-         SetTabVisibleIfAny(ProjectsTab, QuotesButton, ProjectsButton, ProjectPlannerButton, CostSheetsMasterList, KitsMasterList);
 
-     }
 
-     
 
-     private void SetupDock<TSecurityDescriptor>(LayoutAnchorable layout, IDockPanel dock)
 
-         where TSecurityDescriptor : ISecurityDescriptor, new()
 
-     {
 
-         if (Security.IsAllowed<TSecurityDescriptor>())
 
-         {
 
-             if (!DockGroup.Children.Any(x => x == layout))
 
-             {
 
-                 DockGroup.Children.Add(layout);
 
-             }
 
-             if (layout.IsVisible && (ClientFactory.UserGuid != Guid.Empty))
 
-                 dock.Setup();
 
-         }
 
-         else
 
-         {
 
-             DockGroup.RemoveChild(layout);
 
-         }
 
-     }
 
-     private void LoadApplicationState()
 
-     {
 
-         if (ClientFactory.UserGuid != Guid.Empty)
 
-         {
 
-             _ribbon.IsCollapsed = false;
 
-             if (OutstandingDailyReports(false))
 
-             {
 
-                 MessageWindow.ShowMessage("There are outstanding Daily Reports that must be filled out before continuing!"
 
-                     + "\n\nAccess to PRS is restricted until this is corrected.",
 
-                     "Outstanding Reports");
 
-                 var dailyReportPanel = LoadWindow<DailyReport>(ProjectDailyReportButton);
 
-                 if(dailyReportPanel is not null)
 
-                 {
 
-                     dailyReportPanel.OnTimeSheetConfirmed += e =>
 
-                     {
 
-                         if (!OutstandingDailyReports(true))
 
-                         {
 
-                             ConfigureMainScreen(null);
 
-                             LoadApplicationState();
 
-                         }
 
-                     };
 
-                 }
 
-                 return;
 
-             }
 
-             using (new WaitCursor())
 
-             {
 
-                 _ribbon.IsCollapsed = false;
 
-                 LoadInitialWindow();
 
-             }
 
-         }
 
-     }
 
-     private void LoadInitialWindow()
 
-     {
 
-         var app = new LocalConfiguration<AppSettings>().Load();
 
-         if (app.Settings.ContainsKey("CurrentPanel"))
 
-         {
 
-             try
 
-             {
 
-                 var bFound = false;
 
-                 var module = app.Settings["CurrentPanel"].Split(new[] { " / " }, StringSplitOptions.None);
 
-                 if (module.Length == 2)
 
-                     foreach (Fluent.RibbonTabItem tab in _ribbon.Tabs)
 
-                     {
 
-                         if (String.Equals(tab.Header, module.First()))
 
-                         {
 
-                             _ribbon.SelectedTabItem = tab;
 
-                             foreach (Fluent.RibbonGroupBox bar in tab.Groups)
 
-                             {
 
-                                 foreach (var item in bar.Items)
 
-                                 {
 
-                                     var button = item as Fluent.Button;
 
-                                     if (button != null && String.Equals(button.Header, module.Last()))
 
-                                     {
 
-                                         bFound = true;
 
-                                         if (button.Command is SimpleCommand command)
 
-                                             command.Execute(null);
 
-                                         //button.RaiseEvent(new RoutedEventArgs(ButtonBase.ClickEvent));
 
-                                         break;
 
-                                     }
 
-                                 }
 
-                                 if (bFound)
 
-                                     break;
 
-                             }
 
-                         }
 
-                         if (bFound)
 
-                             break;
 
-                     }
 
-             }
 
-             catch (Exception e)
 
-             {
 
-                 MessageWindow.ShowError($"Unable to load {app.Settings["CurrentPanel"]}", e);
 
-             }
 
-         }
 
-     }
 
-     private void _ribbon_OnLoaded(object sender, RoutedEventArgs e)
 
-     {
 
-         _ribbon.SelectedTabItem = CurrentTab;
 
-     }
 
-     private void LoadSecondaryWindows()
 
-     {
 
-         if (ClientFactory.UserGuid != Guid.Empty)
 
-         {
 
-             var windows = App.DatabaseSettings.SecondaryWindows;
 
-             foreach (var key in windows.Keys.ToArray())
 
-             {
 
-                 SecondaryWindows[key] = new SecondaryWindow(
 
-                     key,
 
-                     windows[key].Item1,
 
-                     windows[key].Item2,
 
-                     windows[key].Item3,
 
-                     windows[key].Item4,
 
-                     windows[key].Item5,
 
-                     windows[key].Item6
 
-                 );
 
-                 SecondaryWindows[key].Closed += (o, e) => { SecondaryWindows.Remove(key); };
 
-                 SecondaryWindows[key].Show();
 
-             }
 
-         }
 
-         else
 
-         {
 
-             foreach (var key in SecondaryWindows.Keys.ToArray())
 
-             {
 
-                 App.IsClosing = true;
 
-                 SecondaryWindows[key].Close();
 
-                 App.IsClosing = false;
 
-             }
 
-         }
 
-     }
 
-     private Fluent.RibbonTabItem GetTabItem(FrameworkElement? sender)
 
-     {
 
-         if (sender == null)
 
-             throw new Exception("No Tab Found!");
 
-         if (sender is Fluent.RibbonTabItem)
 
-             return (Fluent.RibbonTabItem)sender;
 
-         return GetTabItem(sender.Parent as FrameworkElement);
 
-     }
 
-     private IEnumerable<IBasePanel> Panels
 
-     {
 
-         get
 
-         {
 
-             if(PanelHost.CurrentPanel is not null)
 
-             {
 
-                 yield return PanelHost.CurrentPanel;
 
-             }
 
-             foreach(var window in SecondaryWindows.Values)
 
-             {
 
-                 yield return window.Panel;
 
-             }
 
-         }
 
-     }
 
-     
 
-     #region LoadWindow / LoadSecondaryWindow
 
-     private T? LoadWindow<T>(Fluent.Button sender) where T : class, IBasePanel, new()
 
-     {
 
-         return LoadWindow<T>(sender, new CancelEventArgs());
 
-     }
 
-     public IBasePanel? LoadWindow(Type t, Fluent.Button sender, CancelEventArgs cancel)
 
-     {
 
-         using (new WaitCursor())
 
-         {
 
-             UnloadWindow(cancel);
 
-             if (cancel.Cancel)
 
-             {
 
-                 return null;
 
-             }
 
-             CurrentTab = GetTabItem(sender);
 
-             CurrentButton = sender;
 
-             //CurrentButton.IsSelected = true;
 
-             UpdateRibbonColors();
 
-             var moduleName = sender.Header?.ToString() ?? "";
 
-             var panel = PanelHost.LoadPanel(t, moduleName);
 
-             ContentControl.Content = panel;
 
-             Title =
 
-                 $"{moduleName} - {(String.Equals(App.Profile?.ToUpper(), "DEFAULT") ? "PRS Desktop" : App.Profile)} (Release {CoreUtils.GetVersion()})";
 
-             PanelHost.Refresh();
 
-             if (panel is NotificationPanel)
 
-             {
 
-                 Logger.Send(LogType.Information, ClientFactory.UserID, "Disabling Heartbeat");
 
-                 NotificationsWatchDog.IsEnabled = false;
 
-                 Notifications.Visibility = Visibility.Collapsed;
 
-                 DockingGrid.ColumnDefinitions[1].Width = new GridLength(0, GridUnitType.Pixel);
 
-                 DockingGrid.ColumnDefinitions[2].Width = new GridLength(0, GridUnitType.Pixel);
 
-             }
 
-             else
 
-             {
 
-                 ReloadNotifications();
 
-             }
 
-             if (sender != null)
 
-             {
 
-                 var settings = new LocalConfiguration<AppSettings>().Load();
 
-                 var module = string.Format("{0} / {1}", CurrentTab?.Header, sender.Header);
 
-                 if (!settings.Settings.ContainsKey("CurrentPanel") || module != settings.Settings["CurrentPanel"])
 
-                 {
 
-                     settings.Settings["CurrentPanel"] = module;
 
-                     try
 
-                     {
 
-                         new LocalConfiguration<AppSettings>().Save(settings);
 
-                     }
 
-                     catch (Exception e)
 
-                     {
 
-                         Logger.Send(LogType.Error, "", string.Format("*** Unknown Error: {0}\n{1}", e.Message, e.StackTrace));
 
-                     }
 
-                 }
 
-             }
 
-             return panel;
 
-         }
 
-     }
 
-     
 
-     private T? LoadWindow<T>(Fluent.Button sender, CancelEventArgs cancel) where T : class, IBasePanel, new()
 
-     {
 
-         return LoadWindow(typeof(T), sender, cancel) as T;
 
-     }
 
-     private void LoadSecondaryWindow(Type t, Fluent.Button sender)
 
-     {
 
-         var id = Guid.NewGuid();
 
-         var window = new Tuple<string, string, double, double, double, double>(
 
-             t.EntityName(),
 
-             sender.Header?.ToString() ?? "",
 
-             Left + 100,
 
-             Top + 100,
 
-             Width - 200,
 
-             Height - 200
 
-         );
 
-         App.DatabaseSettings.SecondaryWindows[id] = window;
 
-         new LocalConfiguration<DatabaseSettings>(App.Profile).Save(App.DatabaseSettings);
 
-         SecondaryWindows[id] = new SecondaryWindow(
 
-             id,
 
-             window.Item1,
 
-             window.Item2,
 
-             window.Item3,
 
-             window.Item4,
 
-             window.Item5,
 
-             window.Item6
 
-         );
 
-         SecondaryWindows[id].Show();
 
-     }
 
-     
 
-     private void LoadSecondaryWindow<T>(Fluent.Button sender) where T : class, IBasePanel, new() 
 
-         => LoadSecondaryWindow(typeof(T), sender);
 
-     
 
-     // private void SecondaryWindow_Click(object sender, RoutedEventArgs e)
 
-     // {
 
-     //     var panel = PanelHost.CurrentPanel;
 
-     //     if (panel is null) return;
 
-     //
 
-     //     var id = Guid.NewGuid();
 
-     //     var window = new Tuple<string, string, double, double, double, double>(
 
-     //         panel.GetType().EntityName(),
 
-     //         PanelHost.CurrentModuleName,
 
-     //         Left + 100,
 
-     //         Top + 100,
 
-     //         Width - 200,
 
-     //         Height - 200
 
-     //     );
 
-     //     App.DatabaseSettings.SecondaryWindows[id] = window;
 
-     //     new LocalConfiguration<DatabaseSettings>(App.Profile).Save(App.DatabaseSettings);
 
-     //     SecondaryWindows[id] = new SecondaryWindow(
 
-     //         id,
 
-     //         window.Item1,
 
-     //         window.Item2,
 
-     //         window.Item3,
 
-     //         window.Item4,
 
-     //         window.Item5,
 
-     //         window.Item6
 
-     //     );
 
-     //     SecondaryWindows[id].Show();
 
-     // }
 
-     
 
-     #endregion
 
-     private void UpdateRibbonColors()
 
-     {
 
-         foreach (var tab in _ribbon.Tabs)
 
-         {
 
-             bool bFound = false;
 
-             foreach (var grp in tab.Groups)
 
-             {
 
-                 foreach (var btn in grp.Items)
 
-                 {
 
-                     if (btn is Fluent.Button fluentbutton)
 
-                     {
 
-                         bFound = bFound || (btn == CurrentButton);
 
-                         fluentbutton.Background = (btn == CurrentButton) ? ThemeManager.SelectedTabItemBackgroundBrush : new SolidColorBrush(Colors.White);
 
-                         fluentbutton.Foreground = (btn == CurrentButton) ? ThemeManager.SelectedTabItemForegroundBrush : new SolidColorBrush(Colors.Black);
 
-                     }
 
-                 }
 
-                 tab.Background = bFound ? ThemeManager.SelectedTabItemBackgroundBrush : new SolidColorBrush(Colors.White);
 
-                 tab.Foreground = bFound ? ThemeManager.SelectedTabItemForegroundBrush : new SolidColorBrush(Colors.Black);
 
-             }
 
-         }
 
-     }
 
-     private static void StartLocalDatabase(IProgress<string> progress)
 
-     {
 
-         var dirName = Path.GetDirectoryName(App.DatabaseSettings.FileName);
 
-         if (!Directory.Exists(dirName) && dirName != null)
 
-             Directory.CreateDirectory(dirName);
 
-         var FileName = App.DatabaseSettings.FileName;
 
-         var Exists = File.Exists(FileName);
 
-         progress.Report("Configuring Stores");
 
-         DbFactory.Stores = CoreUtils.TypeList(
 
-             new[]
 
-             {
 
-                 typeof(Store<>).Assembly,
 
-                 typeof(EquipmentStore).Assembly
 
-             },
 
-             myType =>
 
-                 myType.IsClass
 
-                 && !myType.IsAbstract
 
-                 && !myType.IsGenericType
 
-                 && myType.GetInterfaces().Contains(typeof(IStore))
 
-         ).ToArray();
 
-         DbFactory.DefaultStore = typeof(BaseStore<>);
 
-         DbFactory.ProviderFactory = new SQLiteProviderFactory(App.DatabaseSettings.FileName);
 
-         DbFactory.ColorScheme = App.DatabaseSettings.ColorScheme;
 
-         DbFactory.Logo = App.DatabaseSettings.Logo;
 
-         progress.Report("Starting Local Database");
 
-         DbFactory.Start();
 
-         ClientFactory.DatabaseID = DbFactory.ID;
 
-         progress.Report("Checking Database");
 
-         var users = DbFactory.NewProvider(Logger.Main).Load<User>();
 
-         if (!users.Any())
 
-         {
 
-             var user = new User { UserID = "ADMIN", Password = "admin" };
 
-             DbFactory.NewProvider(Logger.Main).Save(user);
 
-             var employee = DbFactory.NewProvider(Logger.Main).Load(new Filter<Employee>(x => x.Code).IsEqualTo("ADMIN")).FirstOrDefault();
 
-             employee ??= new Employee { Code = "ADMIN", Name = "Administrator Account" };
 
-             employee.UserLink.ID = user.ID;
 
-             DbFactory.NewProvider(Logger.Main).Save(employee);
 
-         }
 
-         StoreUtils.GoogleAPIKey = App.DatabaseSettings.GoogleAPIKey;
 
-         Job.JobNumberPrefix = App.DatabaseSettings.JobPrefix;
 
-         PurchaseOrder.PONumberPrefix = App.DatabaseSettings.PurchaseOrderPrefix;
 
-     }
 
-     #endregion
 
-     #region Login Management
 
-     private ValidationStatus? TryAutoLogin()
 
-     {
 
-         ValidationStatus? result = null;
 
-         if (App.DatabaseSettings.LoginType == LoginType.UserID)
 
-         {
 
-             try
 
-             {
 
-                 result = ClientFactory.Validate(App.DatabaseSettings.UserID, App.DatabaseSettings.Password);
 
-             }
 
-             catch (Exception e)
 
-             {
 
-                 MessageWindow.ShowError("Error connecting to server.\nPlease check the server URL and port number.", e);
 
-                 result = null;
 
-             }
 
-             if (result == ValidationStatus.INVALID)
 
-             {
 
-                 MessageWindow.ShowMessage("Unable to Login with User ID: " + App.DatabaseSettings.UserID, "Login failed");
 
-             }
 
-         }
 
-         return result;
 
-     }
 
-     private ValidationStatus? DoLogin()
 
-     {
 
-         ValidationStatus? result = null;
 
-         if (result != ValidationStatus.VALID)
 
-         {
 
-             var login = new PinLogin(CoreUtils.GetVersion(), result ?? ValidationStatus.INVALID);
 
-             if (login.ShowDialog() == true)
 
-             {
 
-                 result = ValidationStatus.VALID;
 
-             }
 
-         }
 
-         return result ?? ValidationStatus.INVALID;
 
-     }
 
-     /// <summary>
 
-     /// To be called after <see cref="DoLogin(bool)"/> and if a valid login session exists. Configures the main screen and loads the windows.
 
-     /// </summary>
 
-     /// <param name="progress">If not <see langword="null"/>, then rather than opening a new progress window, just uses that.</param>
 
-     private void AfterLogin(IProgress<string>? progress)
 
-     {
 
-         Logger.Send(LogType.Information, "", "Checking Support Ticket Status");
 
-         CheckSupportTicketStatus();
 
-         
 
-         Logger.Send(LogType.Information, "", "Loading employee");
 
-         LoadCurrentEmployee();
 
-         if (CheckTimesheetBypass(true))
 
-         {
 
-             UpdateCurrentLogin();
 
-         }
 
-         else
 
-         {
 
-             MessageWindow.ShowMessage("You must clock on before logging in to PRS!", "Not clocked in.");
 
-             ClientFactory.InvalidateUser();
 
-             App.EmployeeID = Guid.Empty;
 
-             App.EmployeeName = "";
 
-             App.EmployeeCode = "";
 
-             App.EmployeeEmail = "";
 
-         }
 
-         Logger.Send(LogType.Information, "", "Setting colours");
 
-         if(progress is null)
 
-         {
 
-             ApplyColorScheme();
 
-         }
 
-         else
 
-         {
 
-             Dispatcher.Invoke(ApplyColorScheme);
 
-         }
 
-         Logger.Send(LogType.Information, "", "Configuring main window");
 
-         ConfigureMainScreen(progress);
 
-         Logger.Send(LogType.Information, "", "Loading current window");
 
-         if(progress is null)
 
-         {
 
-             LoadApplicationState();
 
-         }
 
-         else
 
-         {
 
-             Dispatcher.Invoke(LoadApplicationState);
 
-         }
 
-         Logger.Send(LogType.Information, "", "Loading secondary window");
 
-         if(progress is null)
 
-         {
 
-             LoadSecondaryWindows();
 
-         }
 
-         else
 
-         {
 
-             Dispatcher.Invoke(LoadSecondaryWindows);
 
-         }
 
-         //if (_ribbon.Menu.IsVisible)
 
-         //{
 
-         //    _ribbon.;
 
-         //}
 
-     }
 
-     /// <summary>
 
-     /// Creates a new <see cref="Login"/> if one does not already exist. Otherwise, updates the <see cref="Login"/> entry in the database with new Station ID.
 
-     /// </summary>
 
-     private void UpdateCurrentLogin()
 
-     {
 
-         if (CoreUtils.GetVersion().Equals("???"))
 
-             return;
 
-         // Register this station with the Server
 
-         // Later on, the heartbeat will check to make sure 
 
-         // that the StationID hasn't changed.  If it has,
 
-         // then we've logged in somewhere else and we'll
 
-         // drop out of this station
 
-         var curr = new Client<Login>().Query(
 
-             new Filter<Login>(x => x.User.ID).IsEqualTo(ClientFactory.UserGuid),
 
-             null
 
-         ).Rows.FirstOrDefault();
 
-         if (curr != null)
 
-         {
 
-             var c = curr.ToObject<Login>();
 
-             c.StationID = station.StationID;
 
-             station = c;
 
-         }
 
-         else
 
-         {
 
-             station.User.ID = ClientFactory.UserGuid;
 
-             station.TimeStamp = DateTime.Now;
 
-         }
 
-         new Client<Login>().Save(station, "", (o, e) => { });
 
-     }
 
-     private void LoadCurrentEmployee()
 
-     {
 
-         var me = new Client<Employee>().Query(
 
-             new Filter<Employee>(x => x.UserLink.ID).IsEqualTo(ClientFactory.UserGuid),
 
-             Columns.None<Employee>().Add(x => x.ID).Add(x => x.Email).Add(x => x.Name)
 
-         );
 
-         App.EmployeeID = me.Rows.FirstOrDefault()?.Get<Employee, Guid>(x => x.ID) ?? Guid.Empty;
 
-         App.EmployeeName = me.Rows.FirstOrDefault()?.Get<Employee, String>(x => x.Name) ?? "";
 
-         App.EmployeeCode = me.Rows.FirstOrDefault()?.Get<Employee, String>(x => x.Code) ?? "";
 
-         App.EmployeeEmail = me.Rows.FirstOrDefault()?.Get<Employee, String>(x => x.Email) ?? "";
 
-     }
 
-     private void ExecuteLogout()
 
-     {
 
-         new Client<Login>().Delete(station, "");
 
-         station.ID = Guid.Empty;
 
-         App.EmployeeID = Guid.Empty;
 
-         App.EmployeeName = "";
 
-         App.EmployeeEmail = "";
 
-     }
 
-     /// <summary>
 
-     /// Logs the user out and unloads windows
 
-     /// </summary>
 
-     /// <param name="message">A message to display as the reason for logging out, or <c>null</c> for no message.</param>
 
-     private bool Logout(string? message = null, bool force = false)
 
-     {
 
-         // I really don't like all these try-catch blocks; unfortunately, if we are trying to log out and invalidate due to an unauthenticated user,
 
-         // all the queries that get called here will throw exceptions and thus break our system, failing to log out.
 
-         try
 
-         {
 
-             FinalizeAutoTimesheet();
 
-         }
 
-         catch
 
-         {
 
-             if (!force) throw;
 
-         }
 
-         // Try to unload the window;
 
-         try
 
-         {
 
-             UnloadWindow(null);
 
-             if (DatabaseType == DatabaseType.Standalone && !CoreUtils.GetVersion().Equals("???"))
 
-                 scheduler.Stop();
 
-         }
 
-         catch
 
-         {
 
-             if (!force) throw;
 
-         }
 
-         // Next, try to set things to being empty
 
-         try
 
-         {
 
-             if (!CoreUtils.GetVersion().Equals("???"))
 
-                 if (station.ID != Guid.Empty)
 
-                 {
 
-                     ExecuteLogout();
 
-                 }
 
-             ClearTrackingKanban();
 
-         }
 
-         catch
 
-         {
 
-             if (!force) throw;
 
-         }
 
-         ClientFactory.InvalidateUser();
 
-         ConfigureMainScreen(null);
 
-         LoadSecondaryWindows();
 
-         if (message != null)
 
-         {
 
-             MessageWindow.ShowMessage(message, "Logged out");
 
-         }
 
-         if (DoLogin() == ValidationStatus.VALID)
 
-         {
 
-             AfterLogin(null);
 
-         }
 
-         return true;
 
-     }
 
-     #endregion
 
-     #region Timesheets
 
-     private void RefreshTimeSheets()
 
-     {
 
-         if (App.EmployeeID == Guid.Empty)
 
-             return;
 
-         var filter = new Filter<TimeSheet>(x => x.EmployeeLink.ID).IsEqualTo(App.EmployeeID);
 
-         filter = filter.And(new Filter<TimeSheet>(x => x.Confirmed).IsEqualTo(DateTime.MinValue).Or(x => x.Date).IsEqualTo(DateTime.Today));
 
-         _timesheets = new Client<TimeSheet>().Query(
 
-             filter,
 
-             Columns.None<TimeSheet>().Add(
 
-                 x => x.ID,
 
-                 x => x.Date,
 
-                 x => x.Finish
 
-             )
 
-         );
 
-     }
 
-     private CoreTable GetTimesheet()
 
-     {
 
-         return new Client<TimeSheet>().Query(
 
-             new Filter<TimeSheet>(x => x.Date).IsEqualTo(DateTime.Today)
 
-                 .And(x => x.EmployeeLink.ID).IsEqualTo(App.EmployeeID)
 
-                 .And(x => x.Finish).IsEqualTo(TimeSpan.Zero)
 
-         );
 
-     }
 
-     private bool CheckTimesheetBypass(bool message)
 
-     {
 
-         if (!ClientFactory.IsSupported<TimeSheet>())
 
-             return true;
 
-         var isClockedOn = IsClockedOn();
 
-         if (!Security.IsAllowed<CanBypassTimeBench>())
 
-         {
 
-             if (!isClockedOn)
 
-             {
 
-                 if (message)
 
-                     MessageBox.Show("You must clock on before opening this screen");
 
-                 return false;
 
-             }
 
-             return true;
 
-         }
 
-         if (Security.IsAllowed<AutoGenerateTimesheet>())
 
-             if (!isClockedOn)
 
-             {
 
-                 var ts = new TimeSheet();
 
-                 ts.Date = DateTime.Today;
 
-                 ts.Start = DateTime.Now.TimeOfDay;
 
-                 ts.EmployeeLink.ID = App.EmployeeID;
 
-                 ts.Notes = "Automatic Login from PRS Desktop";
 
-                 new Client<TimeSheet>().Save(ts, "AutoLogon because Timebench Bypass is enabled", (o, e) => { });
 
-             }
 
-         return true;
 
-     }
 
-     private bool IsClockedOn()
 
-     {
 
-         RefreshTimeSheets();
 
-         if (_timesheets == null)
 
-             return false;
 
-         return _timesheets.Rows.Any(r =>
 
-             r.Get<TimeSheet, DateTime>(c => c.Date).Date == DateTime.Today && r.Get<TimeSheet, TimeSpan>(c => c.Finish) == new TimeSpan());
 
-     }
 
-     private void FinalizeAutoTimesheet()
 
-     {
 
-         if (Security.IsAllowed<AutoGenerateTimesheet>())
 
-         {
 
-             var check = new Client<TimeSheet>().Query(
 
-                 new Filter<TimeSheet>(x => x.Date).IsEqualTo(DateTime.Today).And(x => x.EmployeeLink.ID).IsEqualTo(App.EmployeeID).And(x => x.Finish)
 
-                     .IsEqualTo(TimeSpan.Zero)
 
-             );
 
-             if (check.Rows.Any())
 
-             {
 
-                 var ts = check.Rows.First().ToObject<TimeSheet>();
 
-                 if (DateTime.Now.TimeOfDay < ts.Start.Add(new TimeSpan(0, 2, 0)))
 
-                 {
 
-                     new Client<TimeSheet>().Delete(ts, "Deleting Auto TimeSheet because TimeBench Bypass is enabled", (o, ex) => { });
 
-                 }
 
-                 else
 
-                 {
 
-                     ts.Finish = DateTime.Now.TimeOfDay;
 
-                     new Client<TimeSheet>().Save(ts, "Clocking off Auto Timesheet because Timesheet Bypass is enabled", (o, ex) => { });
 
-                 }
 
-             }
 
-         }
 
-     }
 
-     #endregion
 
-     private string CurrentPanelSlug()
 
-     {
 
-         var app = new LocalConfiguration<AppSettings>().Load();
 
-         var module = app.Settings["CurrentPanel"].Split(new[] { " / " }, StringSplitOptions.None);
 
-         return module.LastOrDefault()?.Replace(" ", "_").Replace("/", "") ?? "";
 
-     }
 
-     private bool ShowHelp()
 
-     {
 
-         Process.Start(new ProcessStartInfo("https://prsdigital.com.au/wiki/index.php/" + CurrentPanelSlug()) { UseShellExecute = true });
 
-         return true;
 
-     }
 
-     private void Wiki_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         ShowHelp();
 
-     }
 
-     private void Window_Loaded(object sender, RoutedEventArgs e)
 
-     {
 
-     }
 
-     private void UnloadWindow(CancelEventArgs? cancel)
 
-     {
 
-         PanelHost.UnloadPanel(cancel);
 
-         if (cancel?.Cancel == true)
 
-         {
 
-             return;
 
-         }
 
-         Title =
 
-             $" - {(String.Equals(App.Profile?.ToUpper(), "DEFAULT") ? "PRS Desktop" : App.Profile)} (Release {CoreUtils.GetVersion()})";
 
-         if (CurrentTab is not null)
 
-         {
 
-             var border = VisualUtils.EnumChildrenOfType(CurrentTab, typeof(Border)).LastOrDefault();
 
-             if (border != null)
 
-             {
 
-                 ((Border)border).Background = new SolidColorBrush(Colors.Transparent);
 
-                 ((Border)border).BorderBrush = new SolidColorBrush(Colors.Transparent);
 
-             }
 
-             var ReportsBar = FindRibbonBar(CurrentTab, x => x.Header.Equals("Print"));
 
-             if (ReportsBar is not null)
 
-             {
 
-                 ReportsBar.Items.Clear();
 
-                 ReportsBar.Visibility = Visibility.Collapsed;
 
-                 ReportsBar.IsLauncherVisible = false;
 
-             }
 
-             var ActionBar = FindRibbonBar(CurrentTab, x => x.Header.Equals("Actions"));
 
-             if (ActionBar is not null)
 
-             {
 
-                 ActionBar.IsLauncherVisible = false;
 
-                 foreach (var module in CurrentModules)
 
-                     ActionBar.Items.Remove(module);
 
-             }
 
-         }
 
-         CurrentTab = null;
 
-         CurrentButton = null;
 
-         ContentControl.Content = null;
 
-     }
 
-     private void RibbonWindow_Activated(object sender, EventArgs e)
 
-     {
 
-     }
 
-     private void RegisterModules(IProgress<string> progress)
 
-     {
 
-         foreach (Fluent.RibbonTabItem tab in _ribbon.Tabs)
 
-             foreach (Fluent.RibbonGroupBox bar in tab.Groups)
 
-                 foreach (var item in bar.Items)
 
-                     Dispatcher.Invoke(() =>
 
-                     {
 
-                         var button = item as RibbonButton;
 
-                         if (button != null && button.Label != "Refresh")
 
-                             if (bar.Header.Equals("Actions"))
 
-                                 Modules.Register(button.Label);
 
-                     });
 
-     }
 
-     #region Visibility
 
-     private void SetFrameworkItemVisibility(FrameworkElement button, bool visible)
 
-     {
 
-         var vResult = true;
 
-         var eResult = ClientFactory.UserGuid != Guid.Empty && visible;
 
-         button.Visibility = vResult && eResult ? Visibility.Visible : Visibility.Collapsed;
 
-         if (button is Fluent.Button rb)
 
-         {
 
-             CustomModules.Register(rb.Header?.ToString() ?? "");
 
-             rb.IsEnabled = !OutstandingDailyReports(false);
 
-         }
 
-     }
 
-     
 
-     private void SetModuleVisibility<T>(Fluent.Button button, bool visible) where T : class, IBasePanel, new()
 
-     {
 
-         SetFrameworkItemVisibility(button,visible);
 
-         
 
-         button.MinWidth = 60;
 
-         
 
-         if (button.Command == null)
 
-         {
 
-             button.Command = new SimpleCommand(() => LoadWindow<T>(button));
 
-        
 
-             var menu = new ContextMenu();
 
-             menu.Items.Add(new MenuItem()
 
-             {
 
-                 Header = "Open in New Window",
 
-                 Icon =  new System.Windows.Controls.Image() { Source = PRSDesktop.Resources.target.AsBitmapImage() },
 
-                 Command = new SimpleCommand(() => LoadSecondaryWindow<T>(button))
 
-             });
 
-             button.ContextMenu = menu;
 
-         }
 
-     }
 
-     private static void SetVisibleIfEither(FrameworkElement separator, FrameworkElement[] left, FrameworkElement[] right)
 
-     {
 
-         var bLeft = false;
 
-         foreach (var button in left)
 
-             bLeft = bLeft || button.Visibility == Visibility.Visible;
 
-         var bRight = false;
 
-         foreach (var button in right)
 
-             bRight = bRight || button.Visibility == Visibility.Visible;
 
-         separator.Visibility = bLeft && bRight ? Visibility.Visible : Visibility.Collapsed;
 
-     }
 
-     private static void SetVisibleIfAny(FrameworkElement separator, params FrameworkElement[] buttons)
 
-     {
 
-         var bVisible = false;
 
-         foreach (var button in buttons)
 
-             bVisible = bVisible || button.Visibility == Visibility.Visible;
 
-         separator.Visibility = bVisible ? Visibility.Visible : Visibility.Collapsed;
 
-     }
 
-     private static void SetTabVisibleIfAny(Fluent.RibbonTabItem tab, params FrameworkElement[] buttons)
 
-     {
 
-         var bVisible = false;
 
-         foreach (var button in buttons)
 
-             bVisible = bVisible || button.Visibility == Visibility.Visible;
 
-         tab.Visibility = bVisible ? Visibility.Visible : Visibility.Collapsed;
 
-     }
 
-     #endregion
 
-     private static Fluent.RibbonGroupBox? FindRibbonBar(Fluent.RibbonTabItem tab, Func<Fluent.RibbonGroupBox, bool> predicate)
 
-     {
 
-         foreach (var group in tab.Groups)
 
-         {
 
-             if (group != null)
 
-                 if (predicate.Invoke(group))
 
-                     return group;
 
-         }
 
-         return null;
 
-     }
 
-     #region Button Event Handlers
 
-     
 
-     
 
-     #region Accounts
 
-     #endregion
 
-     
 
-     #region Dashboards
 
-     #endregion
 
-     private void Console_Click(object sender, RoutedEventArgs a)
 
-     {
 
-         if (_console is null)
 
-         {
 
-             _console = new DesktopConsole("Console");
 
-             _console.Closing += (o, args) => _console = null;
 
-         }
 
-         _console.Show();
 
-     }
 
-     
 
-     private void RefreshMenu_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         PanelHost.Refresh();
 
-     }
 
-     
 
-     //private void NotificationsList_SelectionChanged(object sender, System.Windows.Controls.SelectionChangedEventArgs e)
 
-     //{
 
-     //    if (NotificationsList.SelectedIndex < 0)
 
-     //        return;
 
-     //    var editors = NotificationsList.FindVisualChildren<InABox.DynamicGrid.ExtendedRichTextEditor>().ToArray();
 
-     //    var selected = editors[NotificationsList.SelectedIndex];
 
-     //    selected.Text = (String)selected.Tag; //NotificationsList.SelectedIndex.ToString();
 
-     //}
 
-     //private void ViewNotification_Click(object sender, System.Windows.Input.MouseButtonEventArgs e)
 
-     //{
 
-     //    Notification notification = (sender as Label).Tag as Notification;
 
-     //    NotificationDetails details = new NotificationDetails(notification);
 
-     //    details.ShowDialog();
 
-     //    ReloadNotifications();
 
-     //}
 
-     
 
-     private void Library_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         Process.Start(
 
-             new ProcessStartInfo
 
-             {
 
-                 FileName = App.DatabaseSettings.LibraryLocation,
 
-                 UseShellExecute = true,
 
-                 Verb = "open"
 
-             }
 
-         );
 
-     }
 
-     private void SendNotificationClick(object sender, RoutedEventArgs e)
 
-     {
 
-         var form = new NotificationForm { Description = "" };
 
-         if (form.ShowDialog() == true)
 
-             ReloadNotifications();
 
-     }
 
-     private void CompanyInformation_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         var info = new Client<CompanyInformation>().Load().FirstOrDefault();
 
-         if (info == null)
 
-             info = new CompanyInformation();
 
-         new DynamicDataGrid<CompanyInformation>().EditItems(new[] { info });
 
-     }
 
-     
 
-     private void Setup_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         var tab = _ribbon.SelectedTabItem;
 
-         if (tab is null)
 
-             return;
 
-         var menu = new ContextMenu();
 
-         PanelHost.InitialiseSetupMenu(menu);
 
-         menu.IsOpen = true;
 
-     }
 
-     private void Issues_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         try
 
-         {
 
-             IssuesWindow.Execute();
 
-             CheckSupportTicketStatus();
 
-         }
 
-         catch(Exception err)
 
-         {
 
-             MessageWindow.ShowError("Could not load issues.", err);
 
-         }
 
-     }
 
-     private void StartForm<TEntityForm, TEntity, TEntityLink>(DigitalForm form)
 
-         where TEntityForm : EntityForm<TEntity, TEntityLink, TEntityForm>, new()
 
-         where TEntity : Entity, new()
 
-         where TEntityLink : EntityLink<TEntity>, new()
 
-     {
 
-         var entityForm = new TEntityForm();
 
-         entityForm.Form.CopyFrom(form);
 
-         entityForm.Description = form.Description;
 
-         entityForm.FormStarted = DateTime.Now;
 
-         var entity = DFUtils.NewEntity<TEntityForm, TEntity, TEntityLink>(form);
 
-         if (DynamicFormEditWindow.EditDigitalForm(entityForm, out var dataModel, entity))
 
-         {
 
-             dataModel.Update(null);
 
-         }
 
-     }
 
-     private void Forms_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         var select = new MultiSelectDialog<DigitalForm>(
 
-             Filter<DigitalForm>.And(
 
-                 LookupFactory.DefineChildFilter<KanbanForm, DigitalForm>(Array.Empty<KanbanForm>()),
 
-                 new Filter<DigitalForm>(x => x.ID).InQuery(
 
-                     new Filter<EmployeeDigitalForm>(x => x.Employee.ID).IsEqualTo(App.EmployeeID),
 
-                     x => x.Form.ID)),
 
-             LookupFactory.DefineChildColumns<KanbanForm, DigitalForm>()
 
-                 .Add(x => x.Description),
 
-             false);
 
-         if (select.ShowDialog() == true)
 
-         {
 
-             var digitalForm = select.Data().Rows.FirstOrDefault()?.ToObject<DigitalForm>();
 
-             if (digitalForm is not null)
 
-             {
 
-                 StartForm<KanbanForm, Kanban, KanbanLink>(digitalForm);
 
-             }
 
-         };
 
-     }
 
-     #endregion
 
-     private bool OutstandingDailyReports(bool refresh)
 
-     {
 
-         if (!Security.IsAllowed<CanViewDailyReports>() || Security.IsAllowed<BypassOutstandingDailyReports>())
 
-             return false;
 
-         if (refresh)
 
-             RefreshTimeSheets();
 
-         if (_timesheets == null)
 
-             return false;
 
-         return _timesheets.Rows.Any(r => r.Get<TimeSheet, DateTime>(c => c.Date).Date < DateTime.Today);
 
-     }
 
-     private void ShutDownTransport()
 
-     {
 
-         if (_transport != null)
 
-         {
 
-             _transport.OnClose -= TransportConnectionLost;
 
-             if (_transport.IsConnected())
 
-                 _transport.Disconnect();
 
-             _transport = null;
 
-         }
 
-     }
 
-     private void Window_Unloaded(object sender, RoutedEventArgs e)
 
-     {
 
-         ShutDownTransport();
 
-     }
 
-     private void RibbonWindow_Closed(object sender, EventArgs e)
 
-     {
 
-         ShutDownTransport();
 
-         //DisconnectRecorderNotes();
 
-         Application.Current.Shutdown();
 
-     }
 
-     //private bool _closingFromSystemMenu = false;
 
-     private void Window_Closing(object sender, CancelEventArgs e)
 
-     {
 
-         /*if (!_closingFromSystemMenu && !CoreUtils.GetVersion().Equals("???"))
 
-         {
 
-             WindowState = WindowState.Minimized;
 
-             e.Cancel = true;
 
-             return;
 
-         }*/
 
-         PanelHost.UnloadPanel(e);
 
-         if (!e.Cancel)
 
-         {
 
-             ISubPanelHost.Global.ShutdownSubPanels(e);
 
-         }
 
-         if (e.Cancel)
 
-         {
 
-             return;
 
-         }
 
-         App.IsClosing = true;
 
-         FinalizeAutoTimesheet();
 
-         if (!CoreUtils.GetVersion().Equals("???"))
 
-             scheduler.Stop();
 
-         CurrentTab = null;
 
-         UpdateRibbonColors();
 
-         if (!CoreUtils.GetVersion().Equals("???"))
 
-             if (station.ID != Guid.Empty)
 
-                 ExecuteLogout();
 
-         ShutDownTransport();
 
-     }
 
-     #region Notifications + Heartbeat
 
-     private void ReceiveNotification(Notification notification)
 
-     {
 
-         if (Security.CanView<Notification>())
 
-         {
 
-             Notifications.AddNotification(notification);
 
-         }
 
-         foreach(var panel in Panels.OfType<NotificationPanel>())
 
-         {
 
-             panel.AddNotification(notification);
 
-         }
 
-     }
 
-     private void Notifications_Tick(object? sender, EventArgs e)
 
-     {
 
-         if (ClientFactory.UserGuid != Guid.Empty)
 
-         {
 
-             try
 
-             {
 
-                 ReloadNotifications();
 
-             }
 
-             catch (Exception err)
 
-             {
 
-                 Logger.Send(LogType.Error, ClientFactory.UserID,
 
-                     string.Format("Exception in Notifications_Tick:ReloadNotifications() {0}\n{1}", err.Message, err.StackTrace));
 
-             }
 
-             Heartbeat();
 
-             try
 
-             {
 
-                 CheckIsLoggedOn();
 
-             }
 
-             catch (Exception err2)
 
-             {
 
-                 Logger.Send(LogType.Error, ClientFactory.UserID,
 
-                     string.Format("Exception in Notifications_Tick:CheckIsLoggedOn() {0}\n{1}", err2.Message, err2.StackTrace));
 
-             }
 
-         }
 
-         //else
 
-         //{
 
-         //    Logger.Send(LogType.Information, ClientFactory.UserID, "Notifications_Tick: ClientFactory.UserGuid is empty");
 
-         //}
 
-     }
 
-     private void CheckIsLoggedOn()
 
-     {
 
-         if (CoreUtils.GetVersion().Equals("???"))
 
-             return;
 
-         var bLogout = false;
 
-         if (!Security.IsAllowed<CanBypassTimeBench>())
 
-             if (!IsClockedOn())
 
-             {
 
-                 Logger.Send(LogType.Information, ClientFactory.UserID, "User is no longer clocked in!");
 
-                 bLogout = true;
 
-                 Dispatcher.Invoke(() => { Logout(); });
 
-             }
 
-         if (!bLogout)
 
-             new Client<Login>().Query(
 
-                 new Filter<Login>(x => x.User.ID).IsEqualTo(ClientFactory.UserGuid),
 
-                 Columns.None<Login>().Add(x => x.StationID),
 
-                 null,
 
-                 CoreRange.All,
 
-                 (o, e) =>
 
-                 {
 
-                     if (e is RemoteException remote)
 
-                     {
 
-                         if (remote.Status == StatusCode.Unauthenticated)
 
-                         {
 
-                             Logger.Send(LogType.Information, ClientFactory.UserID, "User has been logged out");
 
-                             Dispatcher.Invoke(() =>
 
-                             {
 
-                                 Logout("You have been logged out due to inactivity");
 
-                             });
 
-                         }
 
-                         else
 
-                         {
 
-                             Logger.Send(LogType.Information, ClientFactory.UserID, $"Error in CheckIsLoggedOn(): {CoreUtils.FormatException(remote)}");
 
-                         }
 
-                     }
 
-                     else if (e is not null)
 
-                     {
 
-                         Logger.Send(LogType.Information, ClientFactory.UserID, $"Error in CheckIsLoggedOn(): {CoreUtils.FormatException(e)}");
 
-                     }
 
-                     else if (o is not null)
 
-                     {
 
-                         var row = o.Rows.FirstOrDefault();
 
-                         if (row == null)
 
-                         {
 
-                             station.ID = Guid.Empty;
 
-                             new Client<Login>().Save(station, "", (o1, e1) => { });
 
-                         }
 
-                         else if (!row.Get<Login, string>(c => c.StationID).Equals(station.StationID))
 
-                         {
 
-                             Logger.Send(LogType.Information, ClientFactory.UserID, "User logged in somewhere else!");
 
-                             bLogout = true;
 
-                             Dispatcher.Invoke(() => { Logout(); });
 
-                         }
 
-                     }
 
-                 }
 
-             );
 
-     }
 
-     private void Heartbeat()
 
-     {
 
-         //Task.Run(() =>
 
-         //{
 
-         try
 
-         {
 
-             CheckSupportTicketStatus();
 
-             
 
-             bool IsClockedOn = this.IsClockedOn();
 
-             if (IsClockedOn)
 
-             {
 
-                 if ((_kanbantrackingassignment != null) && (_kanbantrackingassignment.Actual.Finish < DateTime.Now.TimeOfDay))
 
-                 {
 
-                     _kanbantrackingassignment.Actual.Finish = DateTime.Now.TimeOfDay;
 
-                     new Client<Assignment>().Save(_kanbantrackingassignment, "");
 
-                 }
 
-                 if (Security.IsAllowed<MonitorApplicationWindows>())
 
-                 {
 
-                     if (ActivityHistory == null)
 
-                         ActivityHistory = new LocalConfiguration<DailyActivityHistory>().Load();
 
-                     var appname = OpenWindowGetter.GetActiveWindowProcess();
 
-                     var title = OpenWindowGetter.GetActiveWindowTitle();
 
-                     ActivityHistory.Activities[DateTime.Now] = (!string.IsNullOrWhiteSpace(appname) ? appname.Trim() + " - " : "") + title;
 
-                     new LocalConfiguration<DailyActivityHistory>().Save(ActivityHistory);
 
-                 }
 
-             }
 
-             PanelHost.Heartbeat();
 
-             foreach(var window in SecondaryWindows.Values)
 
-             {
 
-                 window.Heartbeat();
 
-             }
 
-         }
 
-         catch (Exception err)
 
-         {
 
-             Logger.Send(LogType.Error, ClientFactory.UserID, string.Format("Exception in Heartbeat: {0}\n{1}", err.Message, err.StackTrace));
 
-         }
 
-         //});
 
-     }
 
-     private void CheckSupportTicketStatus()
 
-     {
 
-         Dispatcher.BeginInvoke(() =>
 
-         {
 
-             IssuesButton.Background = IssuesWindow.Check()
 
-                 ? new SolidColorBrush(Colors.Red) { Opacity = 0.5 }
 
-                 : Brushes.Transparent;
 
-         });
 
-     }
 
-     private void Notifications_Changed(object sender)
 
-     {
 
-         if (Notifications.IsActive)
 
-         {
 
-             Notifications.Visibility = Visibility.Visible;
 
-             DockingGrid.ColumnDefinitions[1].Width = new GridLength(4, GridUnitType.Pixel);
 
-             DockingGrid.ColumnDefinitions[2].Width = Equals(0.0, DockingGrid.ColumnDefinitions[2].Width.Value)
 
-                 ? new GridLength(300, GridUnitType.Pixel)
 
-                 : DockingGrid.ColumnDefinitions[2].Width;
 
-         }
 
-         else
 
-         {
 
-             Notifications.Visibility = Visibility.Collapsed;
 
-             DockingGrid.ColumnDefinitions[1].Width = new GridLength(0, GridUnitType.Pixel);
 
-             DockingGrid.ColumnDefinitions[2].Width = new GridLength(0, GridUnitType.Pixel);
 
-         }
 
-     }
 
-     private void ReloadNotifications()
 
-     {
 
-         if (Security.CanView<Notification>())
 
-             Notifications.Refresh();
 
-         if (!NotificationsWatchDog.IsEnabled)
 
-         {
 
-             //Logger.Send(LogType.Information, ClientFactory.UserID, "Enabling Heartbeat");
 
-             NotificationsWatchDog.IsEnabled = true;
 
-         }
 
-     }
 
-     #endregion
 
-     private void RibbonWindow_PreviewMouseUp(object sender, MouseButtonEventArgs e)
 
-     {
 
-         PanelHost.IncrementTrackingModuleClick();
 
-     }
 
-     private void RibbonWindow_PreviewKeyUp(object sender, KeyEventArgs e)
 
-     {
 
-         PanelHost.IncrementTrackingModuleKey();
 
-     }
 
-     public static void ActivateWindow(Window window)
 
-     {
 
-         var hwnd = new WindowInteropHelper(window).EnsureHandle();
 
-         var threadId1 = GetWindowThreadProcessId(GetForegroundWindow(), IntPtr.Zero);
 
-         var threadId2 = GetWindowThreadProcessId(hwnd, IntPtr.Zero);
 
-         if (threadId1 != threadId2)
 
-         {
 
-             AttachThreadInput(threadId1, threadId2, true);
 
-             SetForegroundWindow(hwnd);
 
-             AttachThreadInput(threadId1, threadId2, false);
 
-         }
 
-         else
 
-         {
 
-             SetForegroundWindow(hwnd);
 
-         }
 
-     }
 
-     private static IntPtr GetForegroundWindow()
 
-     {
 
-         var active = GetActiveWindow();
 
-         var window = Application.Current.Windows.OfType<Window>().SingleOrDefault(x => new WindowInteropHelper(x).Handle == active);
 
-         var hwnd = new WindowInteropHelper(window).EnsureHandle();
 
-         return hwnd;
 
-     }
 
-     [DllImport("user32.dll", SetLastError = true)]
 
-     private static extern IntPtr SetForegroundWindow(IntPtr hWnd);
 
-     [DllImport("user32.dll")]
 
-     private static extern uint GetWindowThreadProcessId(IntPtr hWnd, IntPtr ProcessId);
 
-     [DllImport("user32.dll")]
 
-     private static extern bool AttachThreadInput(uint idAttach, uint idAttachTo, bool fAttach);
 
-     [DllImport("user32.dll")]
 
-     private static extern IntPtr GetActiveWindow();
 
-     #region Modules + Reports
 
-     public void ClearActions()
 
-     {
 
-         foreach (var module in CurrentModules)
 
-         {
 
-             if (module.Parent is Fluent.RibbonGroupBox bar)
 
-                 bar.Items.Remove(module);
 
-         }
 
-         CurrentModules.Clear();
 
-     }
 
-     public void ClearReports()
 
-     {
 
-         if (CurrentTab is not null)
 
-         {
 
-             var ReportsBar = FindRibbonBar(CurrentTab, x => x.Header.Equals("Print"));
 
-             if (ReportsBar is not null)
 
-             {
 
-                 ReportsBar.Visibility = Visibility.Collapsed;
 
-                 ReportsBar.Items.Clear();
 
-             }
 
-         }
 
-     }
 
-     public void CreateReport(PanelAction action)
 
-     {
 
-         if (CurrentTab is null)
 
-             return;
 
-         var ReportsBar = FindRibbonBar(CurrentTab, x => x.Header.Equals("Print"));
 
-         if (ReportsBar is not null)
 
-         {
 
-             var button = new Fluent.Button
 
-             {
 
-                 Header = action.Caption,
 
-                 LargeIcon = action.Image?.AsBitmapImage(),
 
-                 MinWidth = 60
 
-             };
 
-             if (action.Menu is not null)
 
-             {
 
-                 button.ContextMenu = action.Menu;
 
-             }
 
-             button.Click += (o, e) =>
 
-             {
 
-                 action.Execute();
 
-             };
 
-             ReportsBar.Visibility = Security.IsAllowed<CanPrintReports>() ? Visibility.Visible : Visibility.Collapsed;
 
-             ReportsBar.Items.Add(button);
 
-         }
 
-     }
 
-     private NullConverter<Visibility>? _vis = null;
 
-     
 
-     public void CreatePanelAction(PanelAction action)
 
-     {
 
-         if (CurrentTab is null)
 
-             return;
 
-         if (_vis == null)
 
-         {
 
-             _vis = new();
 
-             _vis.Converting += (o, e) =>
 
-             {
 
-             };
 
-         }
 
-         
 
-         var Actions = FindRibbonBar(CurrentTab, x => x.Header.Equals("Actions"));
 
-         if (Actions is not null)
 
-         {
 
-             if (!CurrentModules.Any(x => x.GetType().Equals(typeof(RibbonSeparator))))
 
-             {
 
-                 var sep = new RibbonSeparator();
 
-                 CurrentModules.Add(sep);
 
-                 Actions.Items.Add(sep);
 
-             }
 
-             if (action.OnPopulate != null)
 
-             {
 
-                 Fluent.DropDownButton button;
 
-                 if (action.OnExecute != null)
 
-                 {
 
-                     button = new Fluent.SplitButton();
 
-                     ((Fluent.SplitButton)button).Click += (o, e) => action.Execute();
 
-                 }
 
-                 else
 
-                     button = new Fluent.DropDownButton();
 
-                 
 
-                 button.MinWidth = 60;
 
-                 button.DataContext = action;
 
-                 button.DropDownOpened += (sender, args) => { button.ItemsSource = CreateMenuItems(action); };
 
-                 button.Bind<PanelAction, String>(Fluent.DropDownButton.HeaderProperty, x => x.Caption, null);
 
-                 button.Bind<PanelAction, Bitmap?>(Fluent.DropDownButton.LargeIconProperty, x => x.Image,
 
-                     new BitmapToBitmapImageConverter());
 
-                 button.Bind<PanelAction, ContextMenu?>(ContextMenuProperty, x => x.Menu);
 
-                 button.Bind<PanelAction, bool>(IsEnabledProperty, x => x.IsEnabled);
 
-                 button.Bind<PanelAction, Visibility>(Fluent.DropDownButton.VisibilityProperty, x => x.Visibility, _vis);                    
 
-                 Actions.Items.Add(button);
 
-                 CurrentModules.Add(button);
 
-             }
 
-             
 
-             else
 
-             {
 
-                 var button = new Fluent.Button()
 
-                 {
 
-                     MinWidth = 60,
 
-                     DataContext = action
 
-                 };
 
-                 button.Bind<PanelAction, String>(Fluent.Button.HeaderProperty, x => x.Caption, null);
 
-                 button.Bind<PanelAction, Bitmap?>(Fluent.Button.LargeIconProperty, x => x.Image,
 
-                     new BitmapToBitmapImageConverter());
 
-                 button.Bind<PanelAction, ContextMenu?>(Fluent.Button.ContextMenuProperty, x => x.Menu);
 
-                 button.Bind<PanelAction, bool>(Fluent.Button.IsEnabledProperty, x => x.IsEnabled);
 
-                 button.Bind<PanelAction, Visibility>(Fluent.Button.VisibilityProperty, x => x.Visibility, _vis);
 
-                 button.Click += (o, e) => action.Execute();
 
-                 Actions.Items.Add(button);
 
-                 CurrentModules.Add(button);
 
-             }
 
-         }
 
-     }
 
-     private static ObservableCollection<MenuItem> CreateMenuItems(PanelAction action)
 
-     {
 
-         var items = new ObservableCollection<MenuItem>();
 
-         var entries = action.Populate();
 
-         if (entries != null)
 
-         {
 
-             foreach (var entry in entries)
 
-             {
 
-                 var item = new Fluent.MenuItem()
 
-                 {
 
-                     Header = entry.Caption,
 
-                     DataContext = entry.Data,
 
-                     Icon = entry.Image?.AsBitmapImage()
 
-                 };
 
-                 item.Click += (o, eventArgs) => entry.Execute();
 
-                 items.Add(item);
 
-             }
 
-         }
 
-         return items;
 
-     }
 
-     #endregion
 
-     #region Tracking Kanban
 
-     private void SelectTask_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         ContextMenu menu = new ContextMenu();
 
-         MenuItem others = new MenuItem() { Header = "Other Tasks" };
 
-         using (new WaitCursor())
 
-         {
 
-             var kanbans = new Client<KanbanSubscriber>().Query(
 
-                 new Filter<KanbanSubscriber>(x => x.Employee.UserLink.ID).IsEqualTo(ClientFactory.UserGuid)
 
-                     .And(x => x.Kanban.Completed).IsEqualTo(DateTime.MinValue)
 
-                     .And(x => x.Kanban.Closed).IsEqualTo(DateTime.MinValue),
 
-                 Columns.None<KanbanSubscriber>().Add(x => x.Kanban.ID)
 
-                     .Add(x => x.Kanban.Number)
 
-                     .Add(x => x.Kanban.Title)
 
-                     .Add(x => x.Assignee),
 
-                 new SortOrder<KanbanSubscriber>(x => x.Kanban.Number, SortDirection.Ascending)
 
-             );
 
-             foreach (var row in kanbans.Rows)
 
-             {
 
-                 CreateTaskMenu(row.Get<KanbanSubscriber, bool>(c => c.Assignee) ? menu.Items : others.Items,
 
-                     String.Format("{0} {1}",
 
-                         row.Get<KanbanSubscriber, int>(c => c.Kanban.Number),
 
-                         row.Get<KanbanSubscriber, String>(c => c.Kanban.Title)),
 
-                     row.Get<KanbanSubscriber, Guid>(c => c.Kanban.ID)
 
-                 );
 
-             }
 
-             menu.Items.Add(new Separator());
 
-             menu.Items.Add(others);
 
-             menu.Items.Add(new Separator());
 
-             CreateTaskMenu(menu.Items, "(No Task Selected)", Guid.Empty);
 
-         }
 
-         menu.IsOpen = true;
 
-     }
 
-     private Assignment? _kanbantrackingassignment = null;
 
-     private void SetTrackingKanban(Guid kanbanID, string header)
 
-     {
 
-         SelectedTaskName.Content = header;
 
-         var createNewAssignment = false;
 
-         if (_kanbantrackingassignment is not null)
 
-         {
 
-             if (_kanbantrackingassignment.Actual.Finish < DateTime.Now.TimeOfDay)
 
-             {
 
-                 _kanbantrackingassignment.Actual.Finish = DateTime.Now.TimeOfDay;
 
-                 new Client<Assignment>().Save(_kanbantrackingassignment, "");
 
-             }
 
-             // Update Existing Kanban
 
-             if (kanbanID == Guid.Empty)
 
-                 _kanbantrackingassignment = null;
 
-             else if (_kanbantrackingassignment.Task.ID != kanbanID)
 
-             {
 
-                 createNewAssignment = true;
 
-             }
 
-         }
 
-         else if (kanbanID != Guid.Empty)
 
-         {
 
-             createNewAssignment = true;
 
-         }
 
-         if (createNewAssignment)
 
-         {
 
-             _kanbantrackingassignment = new Assignment();
 
-             _kanbantrackingassignment.Task.ID = kanbanID;
 
-             _kanbantrackingassignment.EmployeeLink.ID = App.EmployeeID;
 
-             _kanbantrackingassignment.Title = header;
 
-             _kanbantrackingassignment.Date = DateTime.Today;
 
-             _kanbantrackingassignment.Actual.Start = DateTime.Now.TimeOfDay;
 
-             _kanbantrackingassignment.Actual.Finish = DateTime.Now.TimeOfDay.Add(new TimeSpan(0, 2, 0));
 
-             new Client<Assignment>().Save(_kanbantrackingassignment, "");
 
-         }
 
-     }
 
-     private void ClearTrackingKanban()
 
-         => SetTrackingKanban(Guid.Empty, "(No Task Selected)");
 
-     private void CreateTaskMenu(ItemCollection items, String title, Guid id)
 
-     {
 
-         var item = new MenuItem()
 
-         {
 
-             Header = title,
 
-             Tag = id
 
-         };
 
-         item.Click += (o, args) =>
 
-         {
 
-             if (o is not MenuItem menu) return;
 
-             SetTrackingKanban((Guid)item.Tag, (menu.Header as string) ?? "");
 
-         };
 
-         items.Add(item);
 
-     }
 
-     #endregion
 
-     private void DockPanelBorder_IsVisibleChanged(object sender, DependencyPropertyChangedEventArgs e)
 
-     {
 
-         if (sender is not Border border || !border.IsVisible)
 
-             return;
 
-         var dock = border.Child is IDockPanel panel ? panel : border.Child?.FindVisualChildren<IDockPanel>().FirstOrDefault();
 
-         if (dock is null)
 
-             return;
 
-         dock.Refresh();
 
-     }
 
-     private void DockPanel_OnIsActiveChanged(object? sender, EventArgs e)
 
-     {
 
-         if (sender is not LayoutAnchorable layout)
 
-             return;
 
-         var content = layout.Content as DependencyObject;
 
-         var dock = content is IDockPanel panel ? panel : content?.FindVisualChildren<IDockPanel>().FirstOrDefault();
 
-         if (dock is null)
 
-             return;
 
-         if (layout.IsActive && layout.IsVisible)
 
-             dock.Refresh();
 
-     }
 
-     private void _ribbon_OnPreviewMouseDoubleClick(object sender, MouseButtonEventArgs e)
 
-     {
 
-         e.Handled = true;
 
-     }
 
-     #region Backstage Functions
 
-     private enum DatabaseConfigurationResult
 
-     {
 
-         RestartRequired,
 
-         RestartNotRequired,
 
-         Cancel
 
-     }
 
-     private DatabaseConfigurationResult ShowDatabaseConfiguration()
 
-     {
 
-         DatabaseConfigurationResult result;
 
-         var config = new DataBaseConfiguration();
 
-         if (config.ShowDialog() == true)
 
-         {
 
-             var newsettings = new LocalConfiguration<DatabaseSettings>(App.Profile).Load();
 
-             if (newsettings.RestartRequired(App.DatabaseSettings))
 
-             {
 
-                 result = DatabaseConfigurationResult.RestartRequired;
 
-             }
 
-             else
 
-             {
 
-                 result = DatabaseConfigurationResult.RestartNotRequired;
 
-             }
 
-             if ((newsettings.DatabaseType == DatabaseType.Standalone) && (newsettings.ColorScheme != App.DatabaseSettings.ColorScheme))
 
-             {
 
-                 App.DatabaseSettings.ColorScheme = newsettings.ColorScheme;
 
-                 ApplyColorScheme();
 
-             }
 
-         }
 
-         else
 
-         {
 
-             result = DatabaseConfigurationResult.Cancel;
 
-         }
 
-         return result;
 
-     }
 
-     private void DatabaseSettings_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         switch (ShowDatabaseConfiguration())
 
-         {
 
-             case DatabaseConfigurationResult.RestartRequired:
 
-                 MessageBox.Show("Please restart the application to apply these changes!");
 
-                 break;
 
-         }
 
-     }
 
-     private void CompanyInformation_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         var info = new Client<CompanyInformation>().Load().FirstOrDefault();
 
-         if (info == null)
 
-             info = new CompanyInformation();
 
-         new DynamicDataGrid<CompanyInformation>().EditItems(new[] { info });
 
-     }
 
-     private void SecurityDefaultsButton_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         var window = new GlobalTokenWindow();
 
-         window.ShowDialog();
 
-         Security.Reset();
 
-     }
 
-     private void SystemLogsButton_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         var logfile = CoreUtils.GetLogFile();
 
-         if (File.Exists(logfile))
 
-         {
 
-             var startInfo = new ProcessStartInfo("notepad.exe", logfile);
 
-             startInfo.Verb = "open";
 
-             startInfo.UseShellExecute = true;
 
-             Process.Start(startInfo);
 
-         }
 
-         else
 
-         {
 
-             MessageBox.Show(logfile + " does not exist!");
 
-         }
 
-     }
 
-     
 
-     private void CheckForUpdates_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         if (!SupportUtils.CheckForUpdates())
 
-         {
 
-             if (MessageWindow.ShowYesNo(
 
-                     "You appear to be using the latest version already!\n\nRun the installer anyway?", "Update"))
 
-             {
 
-                 SupportUtils.DownloadAndRunInstaller();
 
-             }
 
-         }
 
-     }
 
-     
 
-     private void OpenSupportSession_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         SupportUtils.OpenSupportSession();
 
-     }
 
-     private void DocumentTypeList_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         var list = new MasterList(typeof(DocumentType));
 
-         list.ShowDialog();
 
-     }
 
-     private void EventList_Click(object sender, RoutedEventArgs e)
 
-     {
 
-         var list = new MasterList(typeof(Event));
 
-         list.ShowDialog();
 
-     }
 
-     private void EditDetailsButton_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         var employee = new Client<Employee>().Query(
 
-                 new Filter<Employee>(x => x.UserLink.ID).IsEqualTo(ClientFactory.UserGuid))
 
-             .Rows.FirstOrDefault()?.ToObject<Employee>();
 
-         var item = new MyDetailsConfiguration(employee);
 
-         item.User = ClientFactory.UserGuid;
 
-         var buttons = new DynamicEditorButtons();
 
-         buttons.Add("Change Password", null, item, (sender, item) =>
 
-         {
 
-             var details = (item as MyDetailsConfiguration)!;
 
-             var changePassword = new ChangePassword(details.User);
 
-             if (changePassword.ShowDialog() == true && changePassword.Password != null)
 
-             {
 
-                 var newUser = new User();
 
-                 newUser.ID = details.User;
 
-                 ChangePassword.ChangeUserPassword(newUser, changePassword.Password);
 
-                 new Client<User>().Save(newUser, "Changed Password");
 
-                 MessageBox.Show("Password changed!");
 
-             }
 
-         });
 
-         var editor = new DynamicEditorForm(typeof(MyDetailsConfiguration), buttons: buttons);
 
-         if (employee == null)
 
-         {
 
-             editor.OnFormCustomiseEditor += (sender, items, column, editor) =>
 
-             {
 
-                 editor.Editable = Editable.Disabled;
 
-             };
 
-         }
 
-         editor.Items = new BaseObject[] { item };
 
-         if (editor.ShowDialog() == true)
 
-         {
 
-             if (employee != null)
 
-             {
 
-                 item.SaveTo(employee);
 
-                 new Client<Employee>().Save(employee, "Edited by user");
 
-             }
 
-         }
 
-     }
 
-     private void LogoutButton_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         Logout();
 
-     }
 
-     private void LoginButton_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         if (DoLogin() == ValidationStatus.VALID)
 
-             AfterLogin(null);
 
-     }
 
-     private void ExitButton_OnClick(object sender, RoutedEventArgs e)
 
-     {
 
-         //_closingFromSystemMenu = true;
 
-         Close();
 
-     }
 
-     #endregion
 
- }
 
 
  |