MonodroidStockPortfolio/MonoStockPortfolio.Core/Config/AndroidSqliteConfigRepository.cs

54 lines
1.9 KiB
C#
Raw Normal View History

2011-01-03 02:00:10 +00:00
using System.Collections.Generic;
2011-02-06 01:48:55 +00:00
using System.Linq;
using Android.Content;
using Android.Runtime;
2011-01-03 02:00:10 +00:00
using MonoStockPortfolio.Entities;
2010-11-02 16:26:36 +00:00
namespace MonoStockPortfolio.Core.Config
{
[Preserve(AllMembers = true)]
2011-02-06 01:48:55 +00:00
public class AndroidSqliteConfigRepository : AndroidSqliteBase, IConfigRepository
2010-11-02 16:26:36 +00:00
{
public AndroidSqliteConfigRepository(Context context)
: base(context)
2011-02-06 01:48:55 +00:00
{ }
2011-01-03 02:00:10 +00:00
public IEnumerable<StockDataItem> GetStockItems()
2011-02-06 01:48:55 +00:00
{
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()
2010-11-02 16:26:36 +00:00
{
2011-01-03 02:00:10 +00:00
var items = new List<StockDataItem>();
items.Add(StockDataItem.Ticker);
items.Add(StockDataItem.LastTradePrice);
items.Add(StockDataItem.GainLossRealTime);
items.Add(StockDataItem.Time);
return items;
2010-11-02 16:26:36 +00:00
}
}
}