Files
Parasha/SvetoforVKBot/Models/Commands/LK/Cart/ShowCart.cs
2021-10-19 06:04:52 +03:00

192 lines
8.3 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Data.SqlClient;
using System.Linq;
using System.Security.Cryptography;
using Newtonsoft.Json;
using SvetoforVKBot.Models.Updates;
using VkNet;
using VkNet.Enums.SafetyEnums;
using VkNet.Model.Keyboard;
using VkNet.Model.RequestParams;
namespace SvetoforVKBot.Models.Commands.LK.Cart
{
public class ShowCart
{
public void Execute(RootObject update, VkApi client, SvetoforVKBot.Data.SvetoforVKBotEntities db, int curCart) //curCart - порядковый номер в массиве корзины
{
MessagesSendParams @params = new MessagesSendParams();
int cartCount = 0;
var chatId = update.@object.message.from_id;
string msg = "";
//string voronka = "";
List<CategoriesDostavka> categories = new List<CategoriesDostavka>();
List<ProductsDostavka> products = new List<ProductsDostavka>();
int i = 0;
int j = 0;
int prevCart = 0, nextCart = 0;
double sum = 0;
double fullSum = 0;
string label = "";
var keyboardBuilder = new KeyboardBuilder().Clear();
int kkals = 0;
try
{
var user = db.Users.Single(usr => usr.chatId == chatId);
var cartObject = JsonConvert.DeserializeObject<CartObject>(user.cart);
//SqlCommand getCart = new SqlCommand("SELECT cart, voronka FROM Users WHERE chatId = @chatId;", Con);
//getCart.Parameters.AddWithValue("@chatId", chatId);
//SqlDataReader rgetCart = getCart.ExecuteReader();
//rgetCart.Read();
//var cartObject = JsonConvert.DeserializeObject<CartObject>(rgetCart["cart"].ToString());
//voronka = rgetCart["voronka"].ToString();
//rgetCart.Close();
//cartObject.orders.RemoveAll(o => o.article.StartsWith("00-"));
cartObject.dostavkaCost = 100;
//if (cartObject.orders.Count == 0)
//{
// msg = "Корзина пуста.\n📋Возвращаю в основное меню";
// ShowMenuDostavka showMenuDostavka = new ShowMenuDostavka();
// showMenuDostavka.Execute(update, client, Con, msg, 1, 0);
// return;
//}
if (curCart >= cartObject.orders.Count)
{
curCart = cartObject.orders.Count - 1;
prevCart = curCart - 1;
nextCart = 0;
}
else
{
prevCart = curCart - 1;
nextCart = curCart + 1;
}
if ((curCart + 1) == cartObject.orders.Count)
{
prevCart = curCart - 1;
nextCart = 0;
}
if (curCart == 0)
{
prevCart = cartObject.orders.Count - 1;
nextCart = curCart + 1;
}
string promo = "";
msg = "Ваша корзина: \n";
double sumCheck = 0;
foreach (var o in cartObject.orders)
{
sumCheck += o.price * o.number;
}
for (i = 0; i < cartObject.orders.Count; i++)
{
cartCount++;
switch (cartObject.orders[i].id)
{
default:
msg += (i + 1).ToString() + ". " +
cartObject.orders[i].fullname + " - " + cartObject.orders[i].kkal + " ккал. " +
cartObject.orders[i].number + " шт. " +
(cartObject.orders[i].price * cartObject.orders[i].number).ToString() + " ₽ \n";
sum += cartObject.orders[i].price * cartObject.orders[i].number;
kkals += cartObject.orders[i].kkal * cartObject.orders[i].number;
break;
}
//msg += (i + 1).ToString() + ". " +
// cartObject.orders[i].fullname + " - " +
// cartObject.orders[i].number + " шт. " +
// (cartObject.orders[i].price * cartObject.orders[i].number).ToString() + " ₽ \n";
/*cartCount++;
for (j = 0; j < cartObject.orders.Count; j++)
{
msg += " " + cartCount.ToString() + "." + (j + 1).ToString() + " Доп - " +
cartObject.orders[i].addition[j].fullname + " - " +
cartObject.orders[i].addition[j].number + " шт. " +
(cartObject.orders[i].addition[j].price * cartObject.orders[i].addition[j].number).ToString() + " ₽ \n";
}
*/
}
fullSum = sum;
user.cart = JsonConvert.SerializeObject(cartObject);
db.SaveChanges();
//SqlCommand updCart = new SqlCommand("UPDATE Users SET cart = @cart WHERE chatId = @chatId;", Con);
//updCart.Parameters.AddWithValue("@chatId", chatId);
//updCart.Parameters.AddWithValue("@cart", JsonConvert.SerializeObject(cartObject));
//updCart.ExecuteNonQuery();
msg += "\n" +
"Итого: " + fullSum + " ₽ | " + kkals + " ккал.";
label = cartObject.orders[curCart].name + " " +
cartObject.orders[curCart].price + " ₽ * " +
cartObject.orders[curCart].number + " = " +
(cartObject.orders[curCart].price * cartObject.orders[curCart].number).ToString() + " ₽";
if (label.Length > 40)
label = cartObject.orders[curCart].name + " " +
(cartObject.orders[curCart].price * cartObject.orders[curCart].number).ToString() + " ₽";
keyboardBuilder
.AddButton(label, "selectCart-" + curCart, KeyboardButtonColor.Default)
.AddLine()
.AddButton("-", "selectEditCart-1-" + curCart, KeyboardButtonColor.Default)
.AddButton(cartObject.orders[curCart].number + " шт", "selectCartCount-" + curCart, KeyboardButtonColor.Default)
.AddButton("+", "selectEditCart-2-" + curCart, KeyboardButtonColor.Default)
.AddButton("🗑Очистить", "selectConfirmClearCart", KeyboardButtonColor.Default)
.AddLine()
.AddButton("<<", "selectCart-" + prevCart, KeyboardButtonColor.Primary)
.AddButton((curCart + 1).ToString() + "/" + cartObject.orders.Count, "selectCart-" + curCart, KeyboardButtonColor.Default)
.AddButton(">>", "selectCart-" + nextCart, KeyboardButtonColor.Primary);
keyboardBuilder
.AddLine()
.AddButton("Личный кабинет", "startPL", KeyboardButtonColor.Default);
@params.Message = msg;
@params.UserId = chatId;
@params.Keyboard = keyboardBuilder.Build();
@params.DontParseLinks = true;
@params.RandomId = GetRandomId();
client.Messages.SendAsync(@params);
}
catch (Exception ee)
{
@params.Message = "‼Ошибка в ShowCart: " + ee.Message;
@params.Attachments = null;
@params.Keyboard = null;
@params.UserId = 59111081;
@params.RandomId = GetRandomId();
client.Messages.SendAsync(@params);
}
}
private static readonly RandomNumberGenerator Rng = RandomNumberGenerator.Create();
private int GetRandomId()
{
var intBytes = new byte[4];
Rng.GetBytes(intBytes);
return BitConverter.ToInt32(intBytes, 0);
}
}
}