mirror of
https://github.com/mgroves/MonodroidStockPortfolio.git
synced 2025-01-22 11:12:43 +00:00
52 lines
No EOL
1.9 KiB
C#
52 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
|
|
{
|
|
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;
|
|
}
|
|
}
|
|
} |