MonodroidStockPortfolio/MonoStockPortfolio.Core/Config/AndroidSqliteConfigRepository.cs

54 lines
No EOL
1.9 KiB
C#

using System.Collections.Generic;
using System.Linq;
using Android.Content;
using Android.Runtime;
using MonoStockPortfolio.Entities;
namespace MonoStockPortfolio.Core.Config
{
[Preserve(AllMembers = true)]
public class AndroidSqliteConfigRepository : AndroidSqliteBase, IConfigRepository
{
public AndroidSqliteConfigRepository(Context context)
: base(context)
{ }
public IEnumerable<StockDataItem> GetStockItems()
{
var cursor = Db.Query(CONFIG_TABLE_NAME, new[] { "StockItems" }, null, null, null, null, null);
string stockItemsCsv = null;
if (cursor.Count > 0)
{
cursor.MoveToNext();
stockItemsCsv = cursor.GetString(0);
if (!cursor.IsClosed) cursor.Close();
}
if (string.IsNullOrEmpty(stockItemsCsv))
{
return DefaultItems();
}
return stockItemsCsv.Split(',').Select(i => (StockDataItem)int.Parse(i));
}
public void UpdateStockItems(List<StockDataItem> stockDataItems)
{
var stockItemsCsv = string.Join(",", stockDataItems.Select(i => ((int) i).ToString()).ToArray());
var contentValues = new ContentValues();
contentValues.Put("StockItems", stockItemsCsv);
Db.Update(CONFIG_TABLE_NAME, contentValues, null, null);
}
// this should never be called, but it's here anyway in case of some catastrophe
private static IEnumerable<StockDataItem> DefaultItems()
{
var items = new List<StockDataItem>();
items.Add(StockDataItem.Ticker);
items.Add(StockDataItem.LastTradePrice);
items.Add(StockDataItem.GainLossRealTime);
items.Add(StockDataItem.Time);
return items;
}
}
}