예제 #1
0
        public async Task <ActionResult> Register(RegisterViewModel model)
        {
            if (ModelState.IsValid)
            {
                var user = new ApplicationUser {
                    UserName = model.Email, Email = model.Email
                };
                var result = await UserManager.CreateAsync(user, model.Password);

                if (result.Succeeded)
                {
                    await SignInManager.SignInAsync(user, isPersistent : false, rememberBrowser : false);

                    // For more information on how to enable account confirmation and password reset please visit https://go.microsoft.com/fwlink/?LinkID=320771
                    // Send an email with this link
                    // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
                    // var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
                    // await UserManager.SendEmailAsync(user.Id, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");

                    using (MenuNewestEntities db = new MenuNewestEntities())
                    {
                        db.AspNetUsers.Find(user.Id = user.Id).Birthday = DateTime.Parse(model.Birthday);
                        db.SaveChanges();
                    }


                    return(RedirectToAction("Index", "Home"));
                }
                AddErrors(result);
            }

            // If we got this far, something failed, redisplay form
            return(View(model));
        }
예제 #2
0
        public ActionResult CharterColumn() // form calorie record into column chart.
        {
            string userid = User.Identity.GetUserId();

            using (MenuNewestEntities db = new MenuNewestEntities())
            {
                ArrayList xValue  = new ArrayList();
                ArrayList yValue  = new ArrayList();
                var       results = (from c in db.CalRecords where c.UserId.Equals(userid)  orderby c.Calories ascending select  new{ c.Calories, c.CreateDate }).Distinct().Take(5);
                results.ToList().ForEach(rs => xValue.Add(rs.CreateDate));
                results.ToList().ForEach(rs => yValue.Add(rs.Calories));
                new Chart(width: 600, height: 600, theme: ChartTheme.Blue).AddTitle("Calories record")
                .AddSeries("Default", chartType: "Column", xValue: xValue, yValues: yValue)
                .Write("bmp");
            }
            return(null);
        }
예제 #3
0
        //
        // GET: /Manage/Index
        public async Task <ActionResult> Index(ManageMessageId?message)
        {
            ViewBag.StatusMessage =
                message == ManageMessageId.ChangePasswordSuccess ? "Your password has been changed."
                : message == ManageMessageId.SetPasswordSuccess ? "Your password has been set."
                : message == ManageMessageId.SetTwoFactorSuccess ? "Your two-factor authentication provider has been set."
                : message == ManageMessageId.Error ? "An error has occurred."
                : message == ManageMessageId.AddPhoneSuccess ? "Your phone number was added."
                : message == ManageMessageId.RemovePhoneSuccess ? "Your phone number was removed."
                : "";

            var userId = User.Identity.GetUserId();

            if (userId.Equals("440b3391-95f7-4803-ba5d-d9b970979063"))
            {
                return(RedirectToAction("AdminPage", "AspNetUsers"));
            }
            string name;
            string date;

            using (MenuNewestEntities db = new MenuNewestEntities()) //Show birthday of each user
            {
                name = db.AspNetUsers.Find(userId).UserName;
                date = db.AspNetUsers.Find(userId).Birthday.ToString();


                //ViewData["DateCollection"] = db.CalRecords.Where(x => x.UserId.Equals(userId)).OrderByDescending(x => x.CreateDate).Select(e => e.CreateDate).Take(5).ToList();
                //ViewData["CalCollection"] = db.CalRecords.Where(x => x.UserId.Equals(userId)).OrderByDescending(x => x.CreateDate).Select(e => e.CreateDate).Take(5).ToList();
            }
            ViewBag.name = name;
            ViewBag.date = date;
            var model = new IndexViewModel
            {
                HasPassword       = HasPassword(),
                PhoneNumber       = await UserManager.GetPhoneNumberAsync(userId),
                TwoFactor         = await UserManager.GetTwoFactorEnabledAsync(userId),
                Logins            = await UserManager.GetLoginsAsync(userId),
                BrowserRemembered = await AuthenticationManager.TwoFactorBrowserRememberedAsync(userId)
            };

            return(View(model));
        }