// GET: BankAccount/Delete/5
        public async Task <ActionResult> Delete(Guid?id)
        {
            Permissions p    = new Permissions();
            bool        auth = p.isGranted(User.Identity.Name, this.ControllerContext.RouteData.Values["controller"].ToString() + "_" + this.ControllerContext.RouteData.Values["action"].ToString());

            if (!auth)
            {
                return(new ViewResult()
                {
                    ViewName = "Unauthorized"
                });
            }
            else
            {
                if (id == null)
                {
                    return(new HttpStatusCodeResult(HttpStatusCode.BadRequest));
                }
                BankAccountModels bankAccountModels = await db.BankAccount.FindAsync(id);

                if (bankAccountModels == null)
                {
                    return(HttpNotFound());
                }
                return(View(bankAccountModels));
            }
        }
        public async Task <ActionResult> DeleteConfirmed(Guid id)
        {
            BankAccountModels bankAccountModels = await db.BankAccount.FindAsync(id);

            db.BankAccount.Remove(bankAccountModels);
            await db.SaveChangesAsync();

            return(RedirectToAction("Index"));
        }
        public async Task <ActionResult> Create([Bind(Include = "Id,Name,Owner_Id,Owner_RefId,BankName,AccountNumber,Notes,Active,Internal")] BankAccountModels bankAccountModels)
        {
            if (ModelState.IsValid)
            {
                bankAccountModels.Id = Guid.NewGuid();
                db.BankAccount.Add(bankAccountModels);
                await db.SaveChangesAsync();

                return(RedirectToAction("Create"));
            }

            return(View(bankAccountModels));
        }
        // GET: BankAccount/Details/5
        public async Task <ActionResult> Details(Guid?id)
        {
            if (id == null)
            {
                return(new HttpStatusCodeResult(HttpStatusCode.BadRequest));
            }
            BankAccountModels bankAccountModels = await db.BankAccount.FindAsync(id);

            if (bankAccountModels == null)
            {
                return(HttpNotFound());
            }
            return(View(bankAccountModels));
        }
        public async Task <ActionResult> Edit([Bind(Include = "Id,Name,Owner_Id,Owner_RefId,BankName,AccountNumber,Notes,Active,Internal")] BankAccountModels bankAccountModels)
        {
            if (ModelState.IsValid)
            {
                db.Entry(bankAccountModels).State = EntityState.Modified;
                await db.SaveChangesAsync();

                return(RedirectToAction("Index"));
            }

            if (bankAccountModels.Owner_Id == 1)
            {
                ViewBag.listOwner = new SelectList(db.Clients.Where(x => x.Active == true).OrderBy(x => x.CompanyName).ToList(), "Id", "CompanyName");
            }
            else
            {
                ViewBag.listOwner = new SelectList(db.User.OrderBy(x => x.FullName).ToList(), "Id", "FullName");
            }
            return(View(bankAccountModels));
        }
        // GET: BankAccount/Edit/5
        public async Task <ActionResult> Edit(Guid?id)
        {
            Permissions p    = new Permissions();
            bool        auth = p.isGranted(User.Identity.Name, this.ControllerContext.RouteData.Values["controller"].ToString() + "_" + this.ControllerContext.RouteData.Values["action"].ToString());

            if (!auth)
            {
                return(new ViewResult()
                {
                    ViewName = "Unauthorized"
                });
            }
            else
            {
                if (id == null)
                {
                    return(new HttpStatusCodeResult(HttpStatusCode.BadRequest));
                }
                BankAccountModels bankAccountModels = await db.BankAccount.FindAsync(id);

                if (bankAccountModels == null)
                {
                    return(HttpNotFound());
                }

                if (bankAccountModels.Owner_Id == 1)
                {
                    ViewBag.listOwner = new SelectList(db.Clients.Where(x => x.Active == true).OrderBy(x => x.CompanyName).ToList(), "Id", "CompanyName");
                }
                else if (bankAccountModels.Owner_Id == 2)
                {
                    ViewBag.listOwner = new SelectList(db.User.OrderBy(x => x.FullName).ToList(), "Id", "FullName");
                }
                else
                {
                    ViewBag.listOwner = null;
                }
                return(View(bankAccountModels));
            }
        }