From 92c18b985afe2db6215188263de95148ed7a4231 Mon Sep 17 00:00:00 2001 From: 107 <107@DESKTOP-UP8U7M2> Date: Wed, 16 Apr 2025 10:24:33 +0700 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D1=8C=D1=82?= =?UTF-8?q?=D0=B5=20=D1=84=D0=B0=D0=B9=D0=BB=D1=8B=20=D0=BF=D1=80=D0=BE?= =?UTF-8?q?=D0=B5=D0=BA=D1=82=D0=B0.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Components/App.razor | 18 ++ Components/Layout/MainLayout.razor | 9 + Components/Layout/MainLayout.razor.css | 18 ++ Components/Pages/BlackjackGame.razor | 264 +++++++++++++++++++++ Components/Pages/BlackjackGame.razor.razor | 169 +++++++++++++ Components/Pages/Error.razor | 36 +++ Components/Pages/Home.razor | 7 + Components/Routes.razor | 6 + Components/_Imports.razor | 10 + Models/Card.cs | 22 ++ Models/Deck.cs | 66 ++++++ Program.cs | 27 +++ Properties/launchSettings.json | 38 +++ appsettings.Development.json | 8 + appsettings.json | 9 + wwwroot/app.css | 29 +++ БлэкДжек.csproj | 9 + БлэкДжек.sln | 25 ++ 18 files changed, 770 insertions(+) create mode 100644 Components/App.razor create mode 100644 Components/Layout/MainLayout.razor create mode 100644 Components/Layout/MainLayout.razor.css create mode 100644 Components/Pages/BlackjackGame.razor create mode 100644 Components/Pages/BlackjackGame.razor.razor create mode 100644 Components/Pages/Error.razor create mode 100644 Components/Pages/Home.razor create mode 100644 Components/Routes.razor create mode 100644 Components/_Imports.razor create mode 100644 Models/Card.cs create mode 100644 Models/Deck.cs create mode 100644 Program.cs create mode 100644 Properties/launchSettings.json create mode 100644 appsettings.Development.json create mode 100644 appsettings.json create mode 100644 wwwroot/app.css create mode 100644 БлэкДжек.csproj create mode 100644 БлэкДжек.sln diff --git a/Components/App.razor b/Components/App.razor new file mode 100644 index 0000000..19aa0af --- /dev/null +++ b/Components/App.razor @@ -0,0 +1,18 @@ + + + + + + + + + + + + + + + + + + diff --git a/Components/Layout/MainLayout.razor b/Components/Layout/MainLayout.razor new file mode 100644 index 0000000..0fd1b20 --- /dev/null +++ b/Components/Layout/MainLayout.razor @@ -0,0 +1,9 @@ +@inherits LayoutComponentBase + +@Body + +
+ An unhandled error has occurred. + Reload + 🗙 +
diff --git a/Components/Layout/MainLayout.razor.css b/Components/Layout/MainLayout.razor.css new file mode 100644 index 0000000..df8c10f --- /dev/null +++ b/Components/Layout/MainLayout.razor.css @@ -0,0 +1,18 @@ +#blazor-error-ui { + background: lightyellow; + bottom: 0; + box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2); + display: none; + left: 0; + padding: 0.6rem 1.25rem 0.7rem 1.25rem; + position: fixed; + width: 100%; + z-index: 1000; +} + + #blazor-error-ui .dismiss { + cursor: pointer; + position: absolute; + right: 0.75rem; + top: 0.5rem; + } diff --git a/Components/Pages/BlackjackGame.razor b/Components/Pages/BlackjackGame.razor new file mode 100644 index 0000000..680d3c9 --- /dev/null +++ b/Components/Pages/BlackjackGame.razor @@ -0,0 +1,264 @@ +@* --- НАЧАЛО КОДА ДЛЯ BlackjackGame.razor --- *@ + +@page "/blackjack" +@using БлэкДжек.Components @* <--- ВОТ ЭТУ СТРОКУ НУЖНО ПРОВЕРИТЬ/ЗАМЕНИТЬ *@ +@implements IDisposable + +

Blackjack

+ +@* Область для сообщений игры *@ +@if (!string.IsNullOrEmpty(GameMessage)) +{ + +} + +@* Основной блок игры, отображается после нажатия "Начать" *@ +@if (IsGameStarted) +{ +
+

Дилер (@(IsPlayerTurn ? "?" : DealerScore.ToString()))

+
+ @foreach (var card in DealerHand) + { + @* Условие для скрытия первой карты дилера во время хода игрока *@ +
+ @((DealerHand.IndexOf(card) == 0 && IsPlayerTurn) ? "???" : card.Display) +
+ } +
+
+ +
+ +
+

Игрок (@PlayerScore)

+
+ @foreach (var card in PlayerHand) + { +
+ @card.Display +
+ } +
+
+ +
+ + @* Кнопки действий *@ +
+ + + +
+} +else +{ + @* Кнопка для старта игры, видна только до начала *@ + +} + + + +@* Блок с C# кодом *@ +@code { + // --- Поля состояния игры --- + private Deck GameDeck; + private List PlayerHand = new List(); // Инициализируем, чтобы избежать null reference до старта + private List DealerHand = new List(); // Инициализируем + + // --- Вычисляемые свойства для счета --- + private int PlayerScore => CalculateScore(PlayerHand); + private int DealerScore => CalculateScore(DealerHand); + + // --- Флаги состояния игры --- + private bool IsPlayerTurn; + private bool IsGameOver; + private bool IsGameStarted; // Показывает, была ли нажата кнопка "Начать игру" + private string GameMessage = string.Empty; // Инициализируем пустой строкой + + // --- Инициализация компонента --- + protected override void OnInitialized() + { + // Игра не начинается автоматически при загрузке страницы + IsGameStarted = false; + } + + // --- Метод начала новой игры --- + private void StartGame() + { + GameDeck = new Deck(); + GameDeck.Shuffle(); + + PlayerHand = new List(); + DealerHand = new List(); + + IsGameOver = false; + IsPlayerTurn = true; + GameMessage = "Ваш ход. Взять карту или стоп?"; + IsGameStarted = true; // Показываем игровое поле + + // Раздаем по 2 карты + PlayerHand.Add(GameDeck.DealCard()); + DealerHand.Add(GameDeck.DealCard()); // Первая карта дилера + PlayerHand.Add(GameDeck.DealCard()); + DealerHand.Add(GameDeck.DealCard()); // Вторая карта дилера + + // Проверка на блэкджек у игрока или дилера сразу после раздачи + if (PlayerScore == 21 && DealerHand.Count == 2) // У игрока блэкджек + { + if (DealerScore == 21) // У дилера тоже блэкджек + { + RevealDealerCardAndEndGame("Ничья! У обоих Блэкджек!"); + } + else // Только у игрока блэкджек + { + RevealDealerCardAndEndGame("Блэкджек! Вы выиграли!"); + } + } + else if (DealerScore == 21 && DealerHand.Count == 2) // Только у дилера блэкджек (проверяем после игрока) + { + RevealDealerCardAndEndGame("Блэкджек у дилера! Вы проиграли."); + } + // Если ни у кого нет блэкджека, игра продолжается с сообщением "Ваш ход..." + + StateHasChanged(); // Обновляем UI, чтобы показать начальное состояние + } + + + // --- Действие игрока: Взять карту (Hit) --- + private void PlayerHit() + { + if (!IsPlayerTurn || IsGameOver) return; // Нельзя брать карту не в свой ход или если игра окончена + + PlayerHand.Add(GameDeck.DealCard()); + + if (PlayerScore > 21) + { + EndGame("Перебор! Вы проиграли."); + } + else if (PlayerScore == 21) + { + // Если игрок набрал ровно 21, его ход автоматически завершается + PlayerStand(); + } + // Если меньше 21, игрок может брать еще + + StateHasChanged(); // Обновляем UI после взятия карты + } + + // --- Действие игрока: Стоп (Stand) --- + private void PlayerStand() + { + if (!IsPlayerTurn || IsGameOver) return; // Нельзя остановиться не в свой ход или если игра окончена + + IsPlayerTurn = false; // Передаем ход дилеру + GameMessage = "Дилер ходит..."; + StateHasChanged(); // Обновим сообщение и откроем карту дилера + + // Можно добавить небольшую задержку перед ходом дилера для наглядности + // await Task.Delay(500); // Если раскомментировать, метод должен быть async Task + DealerTurn(); // Начинаем ход дилера + } + + + // --- Логика хода Дилера --- + // Простая синхронная версия. Для пауз нужен async/await и Task.Delay + private void DealerTurn() + { + // Дилер берет карты, пока его счет меньше 17 + while (DealerScore < 17) + { + // В реальном приложении можно добавить паузу здесь + // await Task.Delay(800); + DealerHand.Add(GameDeck.DealCard()); + // StateHasChanged(); // Обновлять UI после каждой карты дилера, если есть пауза + } + + // После того, как дилер закончил брать карты, определяем победителя + DetermineWinner(); + StateHasChanged(); // Показать финальный результат + } + + // --- Подсчет очков для руки --- + private int CalculateScore(List hand) + { + if (hand == null || hand.Count == 0) return 0; + + int score = 0; + int aceCount = 0; + foreach (var card in hand) + { + score += card.Value; + if (card.Rank == "A") + { + aceCount++; + } + } + + // Корректировка значения Тузов (с 11 на 1 при переборе) + while (score > 21 && aceCount > 0) + { + score -= 10; // Считаем Туз как 1 вместо 11 + aceCount--; + } + return score; + } + + // --- Определение победителя --- + private void DetermineWinner() + { + // Убедимся, что карта дилера видна (IsPlayerTurn уже false) + if (PlayerScore > 21) + { + // Это условие уже должно было быть обработано в PlayerHit, но на всякий случай + EndGame("Перебор! Вы проиграли."); + } + else if (DealerScore > 21) + { + EndGame("У дилера перебор! Вы выиграли!"); + } + else if (PlayerScore > DealerScore) + { + EndGame("Вы выиграли!"); + } + else if (DealerScore > PlayerScore) + { + EndGame("Дилер выиграл!"); + } + else // Очки равны + { + EndGame("Ничья (Push)!"); + } + } + + // --- Метод для завершения игры и установки сообщения --- + private void RevealDealerCardAndEndGame(string message) + { + IsPlayerTurn = false; // Убедимся, что карта дилера видна + EndGame(message); + } + + private void EndGame(string message) + { + IsGameOver = true; + IsPlayerTurn = false; // Больше никто не ходит + GameMessage = message; + // StateHasChanged(); // Обычно вызывается в методе, который вызвал EndGame + } + + // --- Вспомогательный метод для определения цвета карты --- + private string GetCardColor(Card card) + { + return (card.Suit == "♥" || card.Suit == "♦") ? "card-red" : "card-black"; + } + + // --- Реализация IDisposable (пока пустая, но может пригодиться) --- + public void Dispose() + { + // Здесь можно остановить таймеры или отписаться от событий, если они будут добавлены + } +} + +@* --- КОНЕЦ КОДА ДЛЯ BlackjackGame.razor --- *@ \ No newline at end of file diff --git a/Components/Pages/BlackjackGame.razor.razor b/Components/Pages/BlackjackGame.razor.razor new file mode 100644 index 0000000..8e276a2 --- /dev/null +++ b/Components/Pages/BlackjackGame.razor.razor @@ -0,0 +1,169 @@ +/* BlackjackGame.razor.css - Стили для компонента Blackjack */ + +/* Общие стили для секций игрока и дилера */ +h4 { + margin-bottom: 0.8rem; /* Немного больше отступа снизу */ + font-weight: 600; /* Немного жирнее */ + color: #e0e0e0; /* Светлый цвет для темного фона (если будете добавлять) */ + text-shadow: 1px 1px 2px rgba(0,0,0,0.5); /* Легкая тень для читаемости */ +} + +/* Контейнер для карт (рука) */ +.hand { + display: flex; + flex-wrap: wrap; /* Карты будут переноситься, если не помещаются */ + gap: 10px; /* Пространство между картами */ + min-height: 95px; /* Минимальная высота, чтобы контейнер не схлопывался без карт */ + margin-bottom: 1.5rem; /* Отступ под рукой */ + padding: 8px; + background-color: rgba(0, 0, 0, 0.1); /* Легкий фон для области карт */ + border-radius: 8px; + border: 1px solid rgba(255, 255, 255, 0.1); /* Тонкая светлая рамка */ +} + +/* Стиль для отдельной карты */ +.card { + background-color: #fff; /* Белый фон карты */ + border: 1px solid #ababab; /* Серая рамка */ + border-radius: 6px; /* Скругленные углы */ + padding: 15px 10px; /* Внутренние отступы (больше по вертикали) */ + min-width: 65px; /* Минимальная ширина карты */ + text-align: center; + font-size: 1.5em; /* Размер шрифта ранга/масти */ + font-weight: bold; + box-shadow: 3px 3px 7px rgba(0, 0, 0, 0.25); /* Тень для объема */ + display: inline-block; + position: relative; + user-select: none; /* Запретить выделение текста на карте */ + transition: transform 0.1s ease-in-out; /* Плавность при наведении (если добавим) */ +} + +/* Если захотите эффект при наведении */ +/* +.card:hover { + transform: translateY(-3px); +} +*/ + +/* Стиль для скрытой карты дилера ("???") */ +/* Мы не можем легко стилизовать сам текст "???", но можем стилизовать */ +/* первую карту в руке дилера, пока ход игрока. */ +/* Однако, текущая логика просто выводит текст "???" в .card */ +/* Давайте просто сделаем текст "?" серым, если бы мы обернули его в span */ +/* Если вы изменили Razor, как обсуждалось ранее: */ +/* +.hidden-card-content { + color: #9e9e9e; + font-style: italic; + font-size: 0.9em; +} +*/ +/* В текущем варианте специальный стиль для "???" не применяется, она будет в стандартной карте */ + +/* Цвета для мастей */ +.card-red { + color: #D32F2F; /* Насыщенный красный */ +} + +.card-black { + color: #212121; /* Глубокий черный */ +} + +/* Контейнер для кнопок действий */ +.actions { + display: flex; + flex-wrap: wrap; + gap: 12px; /* Расстояние между кнопками */ + margin-top: 1.5rem; /* Отступ сверху */ +} + +/* Стиль для кнопок */ +.actions button, +.btn-lg { /* Стиль для кнопки "Начать игру" */ + padding: 10px 20px; /* Увеличим кнопки */ + font-size: 1em; + cursor: pointer; + border-radius: 5px; + border: none; /* Убираем стандартную рамку Bootstrap */ + transition: background-color 0.2s ease, transform 0.1s ease; /* Плавные переходы */ + box-shadow: 0 2px 5px rgba(0,0,0,0.2); /* Легкая тень для кнопок */ +} + +/* Улучшенные стили для кнопок Bootstrap (можно настроить под себя) */ +.actions .btn-primary { /* Взять карту */ + background-color: #1976D2; /* Синий */ + color: white; +} +.actions .btn-primary:hover:not(:disabled) { + background-color: #1565C0; + transform: translateY(-1px); +} + +.actions .btn-secondary { /* Стоп */ + background-color: #6c757d; /* Серый */ + color: white; +} +.actions .btn-secondary:hover:not(:disabled) { + background-color: #5a6268; + transform: translateY(-1px); +} + +.actions .btn-warning { /* Новая игра */ + background-color: #FFA000; /* Оранжевый */ + color: #212121; /* Темный текст на оранжевом */ +} +.actions .btn-warning:hover:not(:disabled) { + background-color: #FF8F00; + transform: translateY(-1px); +} + +/* Кнопка "Начать игру" */ +.btn-success.btn-lg { + background-color: #388E3C; /* Зеленый */ + color: white; + font-size: 1.2em; /* Крупнее */ + padding: 12px 25px; +} +.btn-success.btn-lg:hover:not(:disabled) { + background-color: #2E7D32; + transform: translateY(-1px); +} + + +/* Стиль для отключенных кнопок */ +.actions button:disabled { + cursor: not-allowed; + opacity: 0.5; /* Сделать полупрозрачными */ + box-shadow: none; /* Убрать тень у неактивных */ +} + +/* Сообщения игры */ +.alert { + margin-top: 1rem; + margin-bottom: 1.5rem; + padding: 1rem; + border-radius: 6px; + font-weight: 500; + box-shadow: 0 2px 4px rgba(0,0,0,0.1); +} + +/* Успешное сообщение (выигрыш) */ +.alert-success { + background-color: #E8F5E9; /* Светло-зеленый фон */ + color: #2E7D32; /* Темно-зеленый текст */ + border: 1px solid #A5D6A7; /* Зеленая рамка */ +} + +/* Информационное сообщение (ход игры, ничья, проигрыш) */ +.alert-info { + background-color: #E3F2FD; /* Светло-голубой фон */ + color: #1565C0; /* Темно-синий текст */ + border: 1px solid #90CAF9; /* Голубая рамка */ +} + +/* Разделитель */ +hr { + border: none; /* Убираем стандартную линию */ + border-top: 1px solid rgba(255, 255, 255, 0.2); /* Светлая полупрозрачная линия */ + margin: 2rem 0; /* Увеличим отступы */ +} \ No newline at end of file diff --git a/Components/Pages/Error.razor b/Components/Pages/Error.razor new file mode 100644 index 0000000..576cc2d --- /dev/null +++ b/Components/Pages/Error.razor @@ -0,0 +1,36 @@ +@page "/Error" +@using System.Diagnostics + +Error + +

Error.

+

An error occurred while processing your request.

+ +@if (ShowRequestId) +{ +

+ Request ID: @RequestId +

+} + +

Development Mode

+

+ Swapping to Development environment will display more detailed information about the error that occurred. +

+

+ The Development environment shouldn't be enabled for deployed applications. + It can result in displaying sensitive information from exceptions to end users. + For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development + and restarting the app. +

+ +@code{ + [CascadingParameter] + private HttpContext? HttpContext { get; set; } + + private string? RequestId { get; set; } + private bool ShowRequestId => !string.IsNullOrEmpty(RequestId); + + protected override void OnInitialized() => + RequestId = Activity.Current?.Id ?? HttpContext?.TraceIdentifier; +} diff --git a/Components/Pages/Home.razor b/Components/Pages/Home.razor new file mode 100644 index 0000000..9001e0b --- /dev/null +++ b/Components/Pages/Home.razor @@ -0,0 +1,7 @@ +@page "/" + +Home + +

Hello, world!

+ +Welcome to your new app. diff --git a/Components/Routes.razor b/Components/Routes.razor new file mode 100644 index 0000000..f756e19 --- /dev/null +++ b/Components/Routes.razor @@ -0,0 +1,6 @@ + + + + + + diff --git a/Components/_Imports.razor b/Components/_Imports.razor new file mode 100644 index 0000000..be06822 --- /dev/null +++ b/Components/_Imports.razor @@ -0,0 +1,10 @@ +@using System.Net.Http +@using System.Net.Http.Json +@using Microsoft.AspNetCore.Components.Forms +@using Microsoft.AspNetCore.Components.Routing +@using Microsoft.AspNetCore.Components.Web +@using static Microsoft.AspNetCore.Components.Web.RenderMode +@using Microsoft.AspNetCore.Components.Web.Virtualization +@using Microsoft.JSInterop +@using БлэкДжек +@using БлэкДжек.Components diff --git a/Models/Card.cs b/Models/Card.cs new file mode 100644 index 0000000..176b24e --- /dev/null +++ b/Models/Card.cs @@ -0,0 +1,22 @@ +namespace БлэкДжек.Components // Замените BlazorBlackjack на имя вашего проекта +{ + public class Card + { + public string Suit { get; set; } // Масть (♥, ♦, ♣, ♠) + public string Rank { get; set; } // Ранг (2, 3, ..., 10, J, Q, K, A) + public int Value { get; set; } // Значение (J,Q,K = 10, A = 11 или 1) + + // Для удобного отображения + public string Display => $"{Rank}{Suit}"; + // Можно добавить свойство для пути к изображению карты, если хотите графику + // public string ImagePath => $"images/cards/{Rank.ToLower()}{SuitChar}.png"; + // private char SuitChar => Suit switch { "♥" => 'h', "♦" => 'd', "♣" => 'c', "♠" => 's', _ => ' ' }; + + public Card(string suit, string rank, int value) + { + Suit = suit; + Rank = rank; + Value = value; + } + } +} \ No newline at end of file diff --git a/Models/Deck.cs b/Models/Deck.cs new file mode 100644 index 0000000..9bd702b --- /dev/null +++ b/Models/Deck.cs @@ -0,0 +1,66 @@ +using System; +using System.Collections.Generic; +using System.Linq; + +namespace БлэкДжек.Components // Замените BlazorBlackjack на имя вашего проекта +{ + public class Deck + { + public List Cards { get; private set; } + + public Deck() + { + InitializeDeck(); + } + + private void InitializeDeck() + { + Cards = new List(); + string[] suits = { "♥", "♦", "♣", "♠" }; + string[] ranks = { "2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "A" }; + + foreach (var suit in suits) + { + foreach (var rank in ranks) + { + int value = 0; + if (int.TryParse(rank, out int numValue)) + { + value = numValue; + } + else if (rank == "J" || rank == "Q" || rank == "K") + { + value = 10; + } + else if (rank == "A") + { + value = 11; // Туз по умолчанию 11 + } + Cards.Add(new Card(suit, rank, value)); + } + } + } + + public void Shuffle() + { + Random rng = new Random(); + Cards = Cards.OrderBy(c => rng.Next()).ToList(); + } + + public Card DealCard() + { + if (Cards.Count == 0) + { + // Можно пересоздать и перемешать колоду, если она закончилась + // InitializeDeck(); + // Shuffle(); + // Или просто вернуть null/выбросить исключение + return null; + } + + Card card = Cards[0]; + Cards.RemoveAt(0); + return card; + } + } +} \ No newline at end of file diff --git a/Program.cs b/Program.cs new file mode 100644 index 0000000..4047a8a --- /dev/null +++ b/Program.cs @@ -0,0 +1,27 @@ +using БлэкДжек.Components; + +var builder = WebApplication.CreateBuilder(args); + +// Add services to the container. +builder.Services.AddRazorComponents() + .AddInteractiveServerComponents(); + +var app = builder.Build(); + +// Configure the HTTP request pipeline. +if (!app.Environment.IsDevelopment()) +{ + app.UseExceptionHandler("/Error", createScopeForErrors: true); + // 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.UseAntiforgery(); + +app.MapRazorComponents() + .AddInteractiveServerRenderMode(); + +app.Run(); diff --git a/Properties/launchSettings.json b/Properties/launchSettings.json new file mode 100644 index 0000000..c1f497e --- /dev/null +++ b/Properties/launchSettings.json @@ -0,0 +1,38 @@ +{ + "$schema": "http://json.schemastore.org/launchsettings.json", + "iisSettings": { + "windowsAuthentication": false, + "anonymousAuthentication": true, + "iisExpress": { + "applicationUrl": "http://localhost:10828", + "sslPort": 44355 + } + }, + "profiles": { + "http": { + "commandName": "Project", + "dotnetRunMessages": true, + "launchBrowser": true, + "applicationUrl": "http://localhost:5097", + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + }, + "https": { + "commandName": "Project", + "dotnetRunMessages": true, + "launchBrowser": true, + "applicationUrl": "https://localhost:7115;http://localhost:5097", + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + }, + "IIS Express": { + "commandName": "IISExpress", + "launchBrowser": true, + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + } + } + } diff --git a/appsettings.Development.json b/appsettings.Development.json new file mode 100644 index 0000000..0c208ae --- /dev/null +++ b/appsettings.Development.json @@ -0,0 +1,8 @@ +{ + "Logging": { + "LogLevel": { + "Default": "Information", + "Microsoft.AspNetCore": "Warning" + } + } +} diff --git a/appsettings.json b/appsettings.json new file mode 100644 index 0000000..10f68b8 --- /dev/null +++ b/appsettings.json @@ -0,0 +1,9 @@ +{ + "Logging": { + "LogLevel": { + "Default": "Information", + "Microsoft.AspNetCore": "Warning" + } + }, + "AllowedHosts": "*" +} diff --git a/wwwroot/app.css b/wwwroot/app.css new file mode 100644 index 0000000..e398853 --- /dev/null +++ b/wwwroot/app.css @@ -0,0 +1,29 @@ +h1:focus { + outline: none; +} + +.valid.modified:not([type=checkbox]) { + outline: 1px solid #26b050; +} + +.invalid { + outline: 1px solid #e50000; +} + +.validation-message { + color: #e50000; +} + +.blazor-error-boundary { + background: url() no-repeat 1rem/1.8rem, #b32121; + padding: 1rem 1rem 1rem 3.7rem; + color: white; +} + + .blazor-error-boundary::after { + content: "An error has occurred." + } + +.darker-border-checkbox.form-check-input { + border-color: #929292; +} diff --git a/БлэкДжек.csproj b/БлэкДжек.csproj new file mode 100644 index 0000000..1b28a01 --- /dev/null +++ b/БлэкДжек.csproj @@ -0,0 +1,9 @@ + + + + net8.0 + enable + enable + + + diff --git a/БлэкДжек.sln b/БлэкДжек.sln new file mode 100644 index 0000000..af9f629 --- /dev/null +++ b/БлэкДжек.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.13.35828.75 d17.13 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "БлэкДжек", "БлэкДжек.csproj", "{11339889-A9DE-4748-A250-599F6D56EDA1}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {11339889-A9DE-4748-A250-599F6D56EDA1}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {11339889-A9DE-4748-A250-599F6D56EDA1}.Debug|Any CPU.Build.0 = Debug|Any CPU + {11339889-A9DE-4748-A250-599F6D56EDA1}.Release|Any CPU.ActiveCfg = Release|Any CPU + {11339889-A9DE-4748-A250-599F6D56EDA1}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {816006BE-33DE-493A-8068-5FFC09509947} + EndGlobalSection +EndGlobal