Beispiel #1
0
        public string CreateAccount(double _sum, String _name)
        {
            string res = "1;1";
            var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
            using (var db = new SQLiteConnection(dbPath))
            {
                // Работа с БД
                var _acc = new AccountTable() { _Name = _name, CurrentMoneyAmount = _sum };
                db.Insert(_acc);
                var _change = new ChangesTable() { _DBString = "INSERT INTO AccountTable(_Name, CurrentMoneyAmount) VALUES('" + _name + "', '" + _sum + "');", _ChangesDatetime = DateTime.Now };
                db.Insert(_change);
            }

            return res;
        }
Beispiel #2
0
 // устанавливаем значения из параметров
 public string ChangeAccount(int _acc_id, double _sum, String _name)
 {
     string res = "";
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД     
         var _acc = new AccountTable() {_account_Id = _acc_id, _Name = _name, CurrentMoneyAmount = _sum };
         db.Update(_acc);
         var _change = new ChangesTable() { _DBString = "UPDATE AccountTable SET _Name='" + _name + "', CurrentMoneyAmount='" + _sum + "' WHERE _account_ID='" + _acc_id + "';", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
     }
     return res;
 }
Beispiel #3
0
 public string DeleteCategory(int id)
 {
     string result = "1:1";
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         db.Delete<CategoryTable>(id);
         var _change = new ChangesTable() { _DBString = "DELETE FROM CategoryTable WHERE ID =" + id + "');", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
     }
     return result;
 }
Beispiel #4
0
 /// <summary>
 /// Добавление новой категории
 /// </summary>
 /// <param name="Name"></param>
 /// <returns></returns>
 public string AddCategory(string Name)
 {
     string result = "1:1";
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД
         var _bud = new CategoryTable()
         {
             _Name = Name
         };
         db.Insert(_bud);
         var _change = new ChangesTable() { _DBString = "INSERT INTO CategoryTable(_Name) VALUES('" + Name + "');", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
     }
     return result;
 }
Beispiel #5
0
 public string ChangeCategory(int id, string name)
 {
     string result = "1:1";
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД
         var _bud = new CategoryTable()
         {
             _Name = name, ID = id
         };
         db.Update(_bud);
         var _change = new ChangesTable() { _DBString = "UPDATE CategoryTable SET _Name='" + name +"' WHERE ID='" + id + "';", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
     }
     return result;
 }
Beispiel #6
0
 public string AddBudget(string Name, double Limit,  int CategoryId, string TP)
 {
     string result = "1;1";
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД
         var _bud = new BudgetTable() { _CategoryID = CategoryId,
                                        _Limit = Limit,
                                        _Name = Name,
                                        _TimePeriod = TP};
         db.Insert(_bud);
         var _change = new ChangesTable() { _DBString = "INSERT INTO BudgetTable(_ID, _Limit, _Name, _TimePeriod) VALUES('" + CategoryId + "', '" + Limit + "', '" + Name + "', '" + TP + "');", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
     }
     return result;
 }
Beispiel #7
0
 /// <summary>
 /// Метод изменения параметров бюджета
 /// </summary>
 /// <param name="id">Уникальный Id</param>
 /// <param name="Name">Название текущее или старое</param>
 /// <param name="NewName">Если указано, то бюджет переименовывается</param>
 /// <param name="Limit">Лимит по данному бюджету</param>
 /// <param name="TimePeriod">Период, на который расчитан бюджет</param>
 /// <param name="CategoryId">ID категории списания</param>
 /// <returns>Возвращает строку в формате -код ошибки;доп. информация-</returns>
 public string ChangeBudget(int id, string Name,  double Limit, string TimePeriod, int CategoryId)
 {
     string result = "1;1";
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД                                        
         var _bud = new BudgetTable()
         {
             _ID = id,
             _CategoryID = CategoryId,
             _Limit = Limit,
             _Name = Name,
             _TimePeriod = TimePeriod
         };
         db.Update(_bud);
         var _change = new ChangesTable() { _DBString = "UPDATE BudgetTable SET _CategoryID='" + CategoryId + "', _Limit='" + Limit + "', _Name='" + (Name) + "', _TimePeriod='" + (TimePeriod) + "' WHERE _ID='" + id + "';", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
     }
     return result;
 }
Beispiel #8
0
        public string ChangeMFU(int _id, int AccId, double Summ, int CategoryID, string comment, DateTime date)
        {
            string res = "";
            var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
            using (var db = new SQLiteConnection(dbPath))
            {
                // Работа с БД     
                var command = db.CreateCommand("Select _Account_Id from MoneyFlowUnitTable WHERE _MFU_Id =" + _id);
                var _acc_id = command.ExecuteScalar<int>();
                var command1 = db.CreateCommand("Select _Count from MoneyFlowUnitTable WHERE _MFU_Id =" + _id);
                var count = command1.ExecuteScalar<double>();
                var command2 = db.CreateCommand("Select _Category from MoneyFlowUnitTable WHERE _MFU_Id =" + _id);
                var _cat_id = command2.ExecuteScalar<int>();
                ChangeAccount(_acc_id, -count, _cat_id);

                var _mfu = new MoneyFlowUnitTable() {_MFU_Id=_id, _Date=DateTime.Now, Date = date, _Account_Id = AccId,
                 _Category = CategoryID, _Count = Summ, Comment = comment};
                ChangeAccount(AccId, Summ, CategoryID);
                db.Update(_mfu);
                var _change = new ChangesTable() { _DBString = "UPDATE MoneyFlowUnitTable SET _Date='" + DateTime.Now + "', Date='" + date + "', _Account_Id='" + AccId
                    + "',  _Category='" + CategoryID + "', _Count='" + Summ + "', Comment='" + comment + "' WHERE _MFU_Id='" + _id + "';", _ChangesDatetime = DateTime.Now };
                db.Insert(_change);
            }
            return res;
        }
Beispiel #9
0
        public string DeleteMFU(int id)
        {
            string result = "1;1";

            var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
            using (var db = new SQLiteConnection(dbPath))
            {
                // Работа с БД
                var command = db.CreateCommand("Select _Account_Id from MoneyFlowUnitTable WHERE _MFU_Id =" + id);
                var _acc_id = command.ExecuteScalar<int>();
                var command1 = db.CreateCommand("Select _Count from MoneyFlowUnitTable WHERE _MFU_Id =" + id);
                var count = command1.ExecuteScalar<double>();
                var command2 = db.CreateCommand("Select _Category from MoneyFlowUnitTable WHERE _MFU_Id =" + id);
                var _cat_id = command2.ExecuteScalar<int>();
                ChangeAccount(_acc_id, -count, _cat_id);
                db.Delete<MoneyFlowUnitTable>(id);
                var _change = new ChangesTable() { _DBString = "DELETE FROM MoneyFlowUnitTable WHERE _MFU_Id = '" + id + "';", _ChangesDatetime = DateTime.Now };
                db.Insert(_change);
            }
            return result;
        }
Beispiel #10
0
 /// <summary>
 /// Добавить зачисление или списание
 /// </summary>
 /// <param name="AccId">Id счета</param>
 /// <param name="Summ">Сумма (положительная при зачислении и отрицательная при списании)</param>
 /// <param name="CategoryID">Id категории</param>
 /// <returns>Возвращает строку в формате -код ошибки;доп. информация-</returns>
 public string AddMoneyFlow(int AccId, double Summ, int CategoryID, string comment, DateTime date)
 {
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД
         var _mfu = new MoneyFlowUnitTable() {Date = date,                                                      
                                              _Account_Id = AccId, 
                                              _Category = CategoryID,   
                                              Comment = comment,
                                              _Count = Summ,
                                              _Date = DateTime.Now};
         db.Insert(_mfu);
         var _change = new ChangesTable() { _DBString = "INSERT INTO MoneyFlowUnitTable(Date, _Account_Id, _Category, Comment, _Count, _Date) VALUES('" + date + "', '" 
             + AccId + "', '" + CategoryID + "', '" + comment + "', '" + Summ + "', '" + DateTime.Now + "');", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
         ChangeAccount(AccId, Summ, CategoryID);
     }
     return "1;1";
 }
Beispiel #11
0
 // удаление счета
 public void DeleteAccount(int _acc_id)
 {
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД
         db.Delete<AccountTable>(_acc_id);
         var _change = new ChangesTable() { _DBString = "DELETE FROM AccountTable WHERE _account_ID =" + _acc_id + "');", _ChangesDatetime = DateTime.Now };
         db.Insert(_change);
     }
 }
Beispiel #12
0
 // применяем к счету значение из параметра (меняется только значение суммы на счете, запоминаем экшн)
 public string ChangeAccount(int _acc_id, double _sum, int _cat_id)
 {
     string res = "";
     var dbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, dbname);
     using (var db = new SQLiteConnection(dbPath))
     {
         // Работа с БД
         var command = db.CreateCommand("SELECT CurrentMoneyAmount from AccountTable WHERE _account_Id =" + _acc_id);
         var current_sum = command.ExecuteScalar<double>();
         var command1 = db.CreateCommand("Select _Name from AccountTable WHERE _account_Id =" + _acc_id);
         var _name = command1.ExecuteScalar<string>();
         var _acc = new AccountTable() { _account_Id = _acc_id, CurrentMoneyAmount = current_sum + _sum, _Name = _name };
         db.Update(_acc);
         var _act = new ActionTable() {AccountID = _acc_id, Money =  _sum, CategoryID = _cat_id};
         db.Insert(_act);
         // Если до этого был просто быдлокод, то теперь будет быдлокод в квадрате!!!
         var _change_acc = new ChangesTable() { _DBString = "UPDATE AccountTable SET _Name='" + _name + "', CurrentMoneyAmount='" + (current_sum + _sum) + "' WHERE _account_ID='" + _acc_id + "';", _ChangesDatetime = DateTime.Now };
         db.Insert(_change_acc);
         var _change_act = new ChangesTable() { _DBString = "INSERT INTO ActionTable(AccountID, Money, CategoryID) VALUES('" + _acc_id + "', '" + _sum + "', '" + _cat_id + "');", _ChangesDatetime = DateTime.Now };
         db.Insert(_change_act);
     }
     return res;
 }