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 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 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 DefaultItems() { var items = new List(); items.Add(StockDataItem.Ticker); items.Add(StockDataItem.LastTradePrice); items.Add(StockDataItem.GainLossRealTime); items.Add(StockDataItem.Time); return items; } } }