mattercontrol/SettingsManagement/PrinterSettings.cs
John Lewin f8f70f46e6 Concise queries, reduce to functionality
- Remove DataStorage qualifier, add using statements
 - Remove unnecessary query variables and string.formatting statements
 - Remove duplicate code, reuse .RecordCount method
2016-02-23 14:42:36 -08:00

103 lines
No EOL
2.3 KiB
C#

using MatterHackers.MatterControl.DataStorage;
using System.Collections.Generic;
namespace MatterHackers.MatterControl
{
public class PrinterSettings
{
private static PrinterSettings globalInstance = null;
public Dictionary<string, PrinterSetting> settingsDictionary;
private int ActiveSettingsPrinterId = -1;
public static PrinterSettings Instance
{
get
{
if (globalInstance == null)
{
globalInstance = new PrinterSettings();
globalInstance.LoadData();
}
return globalInstance;
}
}
private void LoadDataIfNeeded()
{
//Lazy load the data (rather than hook to printer change event)
if (ActivePrinterProfile.Instance.ActivePrinter.Id != ActiveSettingsPrinterId)
{
LoadData();
}
}
public string get(string key)
{
string result = null;
if (ActivePrinterProfile.Instance.ActivePrinter == null)
{
//No printer selected
}
else
{
LoadDataIfNeeded();
if (settingsDictionary.ContainsKey(key))
{
result = settingsDictionary[key].Value;
}
}
return result;
}
public void set(string key, string value)
{
if (ActivePrinterProfile.Instance.ActivePrinter == null)
{
//No printer selected
}
else
{
LoadDataIfNeeded();
PrinterSetting setting;
if (settingsDictionary.ContainsKey(key))
{
setting = settingsDictionary[key];
}
else
{
setting = new PrinterSetting();
setting.Name = key;
setting.PrinterId = ActivePrinterProfile.Instance.ActivePrinter.Id;
settingsDictionary[key] = setting;
}
setting.Value = value;
setting.Commit();
}
}
private void LoadData()
{
if (ActivePrinterProfile.Instance.ActivePrinter != null)
{
settingsDictionary = new Dictionary<string, PrinterSetting>();
foreach (PrinterSetting s in GetPrinterSettings())
{
settingsDictionary[s.Name] = s;
}
ActiveSettingsPrinterId = ActivePrinterProfile.Instance.ActivePrinter.Id;
}
}
private IEnumerable<PrinterSetting> GetPrinterSettings()
{
//Retrieve a list of settings from the Datastore
string query = string.Format("SELECT * FROM PrinterSetting WHERE PrinterId = {0};", ActivePrinterProfile.Instance.ActivePrinter.Id);
return Datastore.Instance.dbSQLite.Query<PrinterSetting>(query);
}
}
}