Добавьте файлы проекта.

This commit is contained in:
Daria
2021-10-19 06:04:52 +03:00
parent 6ee25d0f59
commit eab3081ec2
187 changed files with 100839 additions and 0 deletions

View File

@@ -0,0 +1,192 @@
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);
}
}
}