diff --git a/ShoppingAssistantWebClient.Web/Pages/Chat.cshtml b/ShoppingAssistantWebClient.Web/Pages/Chat.cshtml new file mode 100644 index 0000000..e171d7a --- /dev/null +++ b/ShoppingAssistantWebClient.Web/Pages/Chat.cshtml @@ -0,0 +1,227 @@ +@page "/chat/1" +@model ChatModel +@{ + ViewData["Title"] = "Gift for Jessica"; +} + + +
+ +
+ + + + + + + +
+ +
+ + + + +
+ +
+ +
Gift for Jessica
+ +
    + +
  • +

    Give me product recommendation. Ask me questions if you need more directions. I am looking for: hub for my macbook to connect external monitors

    +
  • +
  • +

    Sure! I can help you with that. I will ask you some leading questions. This is the first: +
    + How many external monitors do you want to connect to your MacBook?

    +
  • +
  • +

    7

    +
  • +
  • +

    Thank you. Here is the next question: +
    + What type of external monitors do you have? (e.g., HDMI, DisplayPort, VGA)

    +
  • + +
+ + + + +
+ + + + + Send message + + + +
+ + +
+ +
+
+ + + diff --git a/ShoppingAssistantWebClient.Web/Pages/Chat.cshtml.cs b/ShoppingAssistantWebClient.Web/Pages/Chat.cshtml.cs new file mode 100644 index 0000000..1e11cc4 --- /dev/null +++ b/ShoppingAssistantWebClient.Web/Pages/Chat.cshtml.cs @@ -0,0 +1,21 @@ +using Microsoft.AspNetCore.Mvc; +using Microsoft.AspNetCore.Mvc.RazorPages; +using ShoppingAssistantWebClient.Web.Network; + +namespace ShoppingAssistantWebClient.Web.Pages; +public class ChatModel : PageModel +{ + private readonly ILogger _logger; + + private readonly AuthenticationService _authenticationService; + + public ChatModel(ILogger logger, AuthenticationService authenticationService) + { + _authenticationService = authenticationService; + _logger = logger; + } + + public void OnGet() + { + } +} diff --git a/ShoppingAssistantWebClient.Web/Pages/Index.cshtml b/ShoppingAssistantWebClient.Web/Pages/Index.cshtml index b5f0c15..9a43a55 100644 --- a/ShoppingAssistantWebClient.Web/Pages/Index.cshtml +++ b/ShoppingAssistantWebClient.Web/Pages/Index.cshtml @@ -1,10 +1,234 @@ -@page -@model IndexModel -@{ - ViewData["Title"] = "Home page"; -} - -
-

Welcome

-

Learn about building Web apps with ASP.NET Core.

-
+@page +@model IndexModel +@{ + ViewData["Title"] = "CARTAID"; +} + +
+ +
+ + + + + + + +
+ +
+ + + + +
+ +
+ +
New chat
+
What you're looking for
+ +
+
+ Product +
+
+ Gift +
+
+ + +
What you're looking for, we will help you solve your problem and find it
+ + +
+ +
+ + + + + Send message + + + +
+ + + + +
+ +
+
+ + + diff --git a/ShoppingAssistantWebClient.Web/Program.cs b/ShoppingAssistantWebClient.Web/Program.cs index 6e4be4c..1ae7f58 100644 --- a/ShoppingAssistantWebClient.Web/Program.cs +++ b/ShoppingAssistantWebClient.Web/Program.cs @@ -1,29 +1,29 @@ -using ShoppingAssistantWebClient.Web.Configurations; - -var builder = WebApplication.CreateBuilder(args); - -// Add services to the container. -builder.Services.AddRazorPages(); -builder.Services.AddApiClient(builder.Configuration); - -var app = builder.Build(); - -// Configure the HTTP request pipeline. -if (!app.Environment.IsDevelopment()) -{ - app.UseExceptionHandler("/Error"); - // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. - app.UseHsts(); -} - -app.UseHttpsRedirection(); -app.UseStaticFiles(); - -app.UseRouting(); - -//app.UseAuthorization(); -app.ConfigureGlobalUserMiddleware(); - -app.MapRazorPages(); - -app.Run(); +using ShoppingAssistantWebClient.Web.Configurations; + +var builder = WebApplication.CreateBuilder(args); + +// Add services to the container. +builder.Services.AddRazorPages(); +builder.Services.AddApiClient(builder.Configuration); + +var app = builder.Build(); + +// Configure the HTTP request pipeline. +if (!app.Environment.IsDevelopment()) +{ + app.UseExceptionHandler("/Error"); + // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. + app.UseHsts(); +} + +app.UseHttpsRedirection(); +app.UseStaticFiles(); + +app.UseRouting(); + +app.UseAuthorization(); +//app.ConfigureGlobalUserMiddleware(); + +app.MapRazorPages(); + +app.Run(); diff --git a/ShoppingAssistantWebClient.Web/wwwroot/css/site.css b/ShoppingAssistantWebClient.Web/wwwroot/css/site.css index f8d98fc..77e25df 100644 --- a/ShoppingAssistantWebClient.Web/wwwroot/css/site.css +++ b/ShoppingAssistantWebClient.Web/wwwroot/css/site.css @@ -1,22 +1,361 @@ -html { - font-size: 14px; -} - -@media (min-width: 768px) { - html { - font-size: 16px; - } -} - -.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus { - box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb; -} - -html { - position: relative; - min-height: 100%; -} - -body { - margin-bottom: 60px; +html { + font-family: 'Nunito'; + padding-top: 20px; + padding-bottom: 20px; +} +.menu { + position: relative; + width: 100%; + height: 100%; + border: 1.5px solid; + border-color: #0052CC; + border-radius: 10px; + padding-top: 16px; + padding-bottom: 16px; +} + +.logo { + display: flex; + align-items: center; + padding-bottom: 15PX; +} + +.logo_name { + padding-top: 10px; + padding-left: 3px; + font-size: 17px; + justify-content: center; + /* Горизонтальное центрирование */ + align-items: center; + letter-spacing: 0.5px; + font-weight: 600; + +} + +.logo img { + float: left; + width: 52px; + height: 52px; +} + +.left_frame { + padding-left: 20px; + position: absolute; + height: calc(100% - 105px); + left: 0; + width: 20%; + transition: 1s; +} + + +.wishlist_name { + font-size: 15px; + margin-top: 7px; + margin-bottom: 7px; + color: black; + cursor: pointer; +} + +.elements { + padding-left: 12px; + padding-right: 12px; + +} +.elements_wishlisht{ + overflow-y: scroll; + padding-left: 12px; + padding-right: 12px; + height: 90%; + +} +.elements_wishlisht::-webkit-scrollbar { + visibility: hidden; +} + + +.close_menu { + position: relative; + background-color: #EAEAEA; + border-radius: 10px; + color: #4E4E4E; + font-size: 16px; + width: 90%; + height: 40px; + padding: 7px 9px; +} + +.add_chat { + display: flex; + align-items: center; + justify-content: center; + margin-top: 15px; + margin-bottom: 5px; + background-color: #EAEAEA; + border-radius: 10px; + font-size: 16px; + width: 100px; + height: 40px; + + cursor: pointer; +} +.add_chat a{ + border-radius: 10px; + padding: 7px 9px; + text-decoration: none; + color: #4E4E4E; +} + + +.info_user { + background-color: white; + position:absolute; + bottom: 0; + padding-bottom: 10px; + padding-top: 10px; +} + +.user_name { + font-size: 16px; + padding-left: 7px; +} + +.info_user img { + height: 40px; + width: 40px; + border-radius: 50%; +} + +.line { + position: absolute; + bottom: 60px; + width: 100%; + border-bottom: 1px solid #4b7bc4; +} +.button_close_menu{ + width: 23px; + height: 23px; + position: absolute; + right: 20px; + cursor: pointer; + +} + +.button_close_menu span { + width: 20px; + height: 1.5px; + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + background-color: #4E4E4E; +} + +.button_close_menu span:nth-of-type(2) { + top: calc(50% - 5px); +} +.button_close_menu span:nth-of-type(3) { + top: calc(50% + 5px); +} + +.right_frame { + position: absolute; + border: 1.5px solid; + border-color: #0052CC; + border-radius: 10px; + left: 20px; + height: calc(100% - 40px); + width: calc(100% - 40px); + transition: 1s; + +} + +.button_open_menu{ + z-index: 2; + width: 23px; + height: 23px; + position: absolute; + top: 25px; + left: 25px; + cursor: pointer; +} +.button_open_menu span { + width: 20px; + height: 1.5px; + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + background-color: #4E4E4E; +} + +.button_open_menu span:nth-of-type(2) { + top: calc(50% - 5px); +} +.button_open_menu span:nth-of-type(3) { + top: calc(50% + 5px); +} +.title_one_frame{ + padding-top: 20px ; + color: #0052CC; + font-size: 17px; + text-align: center; +} +.title_two_frame{ + padding-top: 60px ; + padding-bottom: 40px ; + color: black; + font-size: 40px; + text-align: center; + font-weight: 600; +} +.title_three_frame{ + padding-top: 60px ; + padding-bottom: 40px ; + color: #202124; + font-size: 20px; + text-align: center; + font-weight: 400; +} +.topic { + font-size: 18px; + text-align: center; + line-height: 35px; + color: #009FFF; + width: 250px; + margin: 0 auto; +} +.topic div{ + margin-top: 20px; + border: 1.5px solid; + border-color: #009FFF; + border-radius: 10px; + justify-content: center; + align-items: center; + cursor: pointer; +} +.topic div a{ + color: #009FFF; + text-decoration:none; +} +.switch{ + height: 45px; + width: 350px; + margin: 0 auto; + border: 1.5px solid; + border-color: #EAEAEA; + border-radius: 10px; + text-align: center; + position: relative; + +} + +.switch_product{ + position: absolute; + background-color: #0052CC; + border-radius: 10px; + margin: 5px; + width: calc(50% - 10px); + height: calc(100% - 10px); + display: flex; + align-items: center; + justify-content: center; + cursor: pointer; + transition: 0.8s; + color: white; +} + +.switch_gift{ + right: 0; + position: absolute; + border-radius: 10px; + margin: 5px; + width: calc(50% - 10px); + height: calc(100% - 10px); + display: flex; + align-items: center; + justify-content: center; + cursor: pointer; + transition: 0.8s; + color: #202124; +} + +.chat_input{ + position: absolute; + margin-left: 25%; + margin-bottom: 20px; + width: 50%; + border-radius: 10px; + bottom: 0; + +} +.chat_input input{ + font-size: 17px; + width: 100%; + position: relative; + color: #4E4E4E; + background-color: #EAEAEA; + border-radius: 10px; + border: none; + padding: 10px 20px; + outline:none; +} +.button_sende{ + margin-top: 14px; + margin-right: 20px; + cursor: pointer; + height: calc(100% - 28px); + width: 2.8%; + position: absolute; + right: 0; +} +.button_sende img{ + height: 100%; + width: 100%; + position: absolute; + +} + +.new_chat{ + position: absolute; + overflow-y: scroll; + height: 100%; + width: 100%; +} +.new_chat::-webkit-scrollbar { + visibility: hidden; +} + +.chat_box{ + border-radius: 10px; + position: absolute; + margin-left: 25%; + margin-top: 35px; + width: 50%; + list-style: none; + padding:0; + +} +.chat_outgoing{ + display: flex; +} +.chat_incoming{ + display: flex; +} +.chat_box .chat_outgoing p { + margin-left: auto; + background-color: #009FFF; + border-radius: 10px; + color: white; + padding: 10px; + max-width: 60%; + +} +.chat_box .chat_incoming p { + background-color: #EAEAEA; + border-radius: 10px; + color: black; + padding: 10px; + width: 60%; + margin-bottom: 20px ; + margin-top: 20px ; } \ No newline at end of file diff --git a/ShoppingAssistantWebClient.Web/wwwroot/favicon.ico b/ShoppingAssistantWebClient.Web/wwwroot/favicon.ico index 63e859b..cbab12f 100644 Binary files a/ShoppingAssistantWebClient.Web/wwwroot/favicon.ico and b/ShoppingAssistantWebClient.Web/wwwroot/favicon.ico differ diff --git a/ShoppingAssistantWebClient.Web/wwwroot/images/avatar.jpg b/ShoppingAssistantWebClient.Web/wwwroot/images/avatar.jpg new file mode 100644 index 0000000..63b9f5a Binary files /dev/null and b/ShoppingAssistantWebClient.Web/wwwroot/images/avatar.jpg differ diff --git a/ShoppingAssistantWebClient.Web/wwwroot/images/logo.png b/ShoppingAssistantWebClient.Web/wwwroot/images/logo.png new file mode 100644 index 0000000..b984f5b Binary files /dev/null and b/ShoppingAssistantWebClient.Web/wwwroot/images/logo.png differ diff --git a/ShoppingAssistantWebClient.Web/wwwroot/images/send.png b/ShoppingAssistantWebClient.Web/wwwroot/images/send.png new file mode 100644 index 0000000..2793f03 Binary files /dev/null and b/ShoppingAssistantWebClient.Web/wwwroot/images/send.png differ