20
app/Http/Controllers/LocaleController.php
Normal file
20
app/Http/Controllers/LocaleController.php
Normal file
@@ -0,0 +1,20 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class LocaleController extends Controller
|
||||
{
|
||||
public function __invoke(Request $request, string $locale): RedirectResponse
|
||||
{
|
||||
$supportedLocales = array_keys((array) config('app.supported_locales', []));
|
||||
|
||||
abort_unless(in_array($locale, $supportedLocales, true), 404);
|
||||
|
||||
$request->session()->put('locale', $locale);
|
||||
|
||||
return back();
|
||||
}
|
||||
}
|
||||
@@ -28,6 +28,6 @@ class AccountController extends Controller
|
||||
|
||||
$request->user()->update($validated);
|
||||
|
||||
return back()->with('status', 'Данные профиля обновлены.');
|
||||
return back()->with('status', __('Данные профиля обновлены.'));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -34,7 +34,7 @@ class AuthController extends Controller
|
||||
if (!$this->captchaIsValid($request, self::LOGIN_CAPTCHA_CONTEXT)) {
|
||||
return back()
|
||||
->withInput($request->only('email', 'remember'))
|
||||
->withErrors(['captcha' => 'Неверный ответ на капчу.']);
|
||||
->withErrors(['captcha' => __('Неверный ответ на капчу.')]);
|
||||
}
|
||||
|
||||
$credentials = [
|
||||
@@ -47,7 +47,7 @@ class AuthController extends Controller
|
||||
if (!Auth::attempt($credentials, $remember)) {
|
||||
return back()
|
||||
->withInput($request->only('email', 'remember'))
|
||||
->withErrors(['email' => 'Неверный email или пароль.']);
|
||||
->withErrors(['email' => __('Неверный email или пароль.')]);
|
||||
}
|
||||
|
||||
$request->session()->regenerate();
|
||||
@@ -75,7 +75,7 @@ class AuthController extends Controller
|
||||
if (!$this->captchaIsValid($request, self::REGISTER_CAPTCHA_CONTEXT)) {
|
||||
return back()
|
||||
->withInput($request->only('name', 'email'))
|
||||
->withErrors(['captcha' => 'Неверный ответ на капчу.']);
|
||||
->withErrors(['captcha' => __('Неверный ответ на капчу.')]);
|
||||
}
|
||||
|
||||
$user = User::create([
|
||||
|
||||
@@ -46,20 +46,20 @@ class CartController extends Controller
|
||||
public function add(Product $product)
|
||||
{
|
||||
if (!$product->is_active || $product->stock < 1) {
|
||||
return back()->with('status', 'Товар сейчас недоступен для заказа.');
|
||||
return back()->with('status', __('Товар сейчас недоступен для заказа.'));
|
||||
}
|
||||
|
||||
$cart = (array) session()->get('cart', []);
|
||||
$current = (int) ($cart[$product->id] ?? 0);
|
||||
|
||||
if ($current >= $product->stock) {
|
||||
return back()->with('status', 'В корзине уже максимальное доступное количество.');
|
||||
return back()->with('status', __('В корзине уже максимальное доступное количество.'));
|
||||
}
|
||||
|
||||
$cart[$product->id] = $current + 1;
|
||||
session()->put('cart', $cart);
|
||||
|
||||
return back()->with('status', "Товар \"{$product->name}\" добавлен в корзину.");
|
||||
return back()->with('status', __('Товар ":name" добавлен в корзину.', ['name' => $product->name]));
|
||||
}
|
||||
|
||||
public function update(Request $request, Product $product)
|
||||
@@ -80,15 +80,15 @@ class CartController extends Controller
|
||||
unset($cart[$product->id]);
|
||||
session()->put('cart', $cart);
|
||||
|
||||
return back()->with('status', "Товар \"{$product->name}\" удален из корзины.");
|
||||
return back()->with('status', __('Товар ":name" удален из корзины.', ['name' => $product->name]));
|
||||
}
|
||||
|
||||
$cart[$product->id] = $quantity;
|
||||
session()->put('cart', $cart);
|
||||
|
||||
$message = $quantity < (int) $validated['quantity']
|
||||
? 'Количество ограничено текущим остатком.'
|
||||
: 'Количество товара обновлено.';
|
||||
? __('Количество ограничено текущим остатком.')
|
||||
: __('Количество товара обновлено.');
|
||||
|
||||
return back()->with('status', $message);
|
||||
}
|
||||
@@ -101,6 +101,6 @@ class CartController extends Controller
|
||||
session()->put('cart', $cart);
|
||||
}
|
||||
|
||||
return back()->with('status', "Товар \"{$product->name}\" удален из корзины.");
|
||||
return back()->with('status', __('Товар ":name" удален из корзины.', ['name' => $product->name]));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -40,7 +40,7 @@ class ChatController extends Controller
|
||||
$messageText = $this->sanitizeMessage((string) $validated['message']);
|
||||
if ($messageText === '') {
|
||||
throw ValidationException::withMessages([
|
||||
'message' => 'Сообщение содержит недопустимые символы.',
|
||||
'message' => __('Сообщение содержит недопустимые символы.'),
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -156,7 +156,7 @@ class ChatController extends Controller
|
||||
'status' => $conversation->status,
|
||||
'is_closed' => $conversation->isClosed(),
|
||||
'notice' => $conversation->isClosed()
|
||||
? 'Чат закрыт администратором. Отправьте новое сообщение, чтобы начать новый диалог.'
|
||||
? __('Чат закрыт администратором. Отправьте новое сообщение, чтобы начать новый диалог.')
|
||||
: null,
|
||||
];
|
||||
}
|
||||
|
||||
@@ -19,7 +19,7 @@ class CheckoutController extends Controller
|
||||
$items = $this->cartItems($request);
|
||||
|
||||
if ($items->isEmpty()) {
|
||||
return redirect()->route('cart.index')->with('status', 'Корзина пустая. Добавьте товары перед оформлением.');
|
||||
return redirect()->route('cart.index')->with('status', __('Корзина пустая. Добавьте товары перед оформлением.'));
|
||||
}
|
||||
|
||||
return view('shop.checkout', [
|
||||
@@ -34,7 +34,7 @@ class CheckoutController extends Controller
|
||||
$items = $this->cartItems($request);
|
||||
|
||||
if ($items->isEmpty()) {
|
||||
return redirect()->route('cart.index')->with('status', 'Корзина пустая. Добавьте товары перед оформлением.');
|
||||
return redirect()->route('cart.index')->with('status', __('Корзина пустая. Добавьте товары перед оформлением.'));
|
||||
}
|
||||
|
||||
$validated = $request->validate([
|
||||
@@ -56,12 +56,12 @@ class CheckoutController extends Controller
|
||||
$items = $this->cartItems($request);
|
||||
|
||||
if ($items->isEmpty()) {
|
||||
return redirect()->route('cart.index')->with('status', 'Корзина пустая. Добавьте товары перед оформлением.');
|
||||
return redirect()->route('cart.index')->with('status', __('Корзина пустая. Добавьте товары перед оформлением.'));
|
||||
}
|
||||
|
||||
$customer = $request->session()->get(self::CHECKOUT_CUSTOMER_KEY);
|
||||
if (!is_array($customer)) {
|
||||
return redirect()->route('checkout.show')->with('status', 'Сначала заполните данные получателя.');
|
||||
return redirect()->route('checkout.show')->with('status', __('Сначала заполните данные получателя.'));
|
||||
}
|
||||
|
||||
return view('shop.checkout-payment', [
|
||||
@@ -77,12 +77,12 @@ class CheckoutController extends Controller
|
||||
$items = $this->cartItems($request);
|
||||
|
||||
if ($items->isEmpty()) {
|
||||
return redirect()->route('cart.index')->with('status', 'Корзина пустая. Добавьте товары перед оформлением.');
|
||||
return redirect()->route('cart.index')->with('status', __('Корзина пустая. Добавьте товары перед оформлением.'));
|
||||
}
|
||||
|
||||
$validated = $request->session()->get(self::CHECKOUT_CUSTOMER_KEY);
|
||||
if (!is_array($validated)) {
|
||||
return redirect()->route('checkout.show')->with('status', 'Сначала заполните данные получателя.');
|
||||
return redirect()->route('checkout.show')->with('status', __('Сначала заполните данные получателя.'));
|
||||
}
|
||||
|
||||
$validator = validator($validated, [
|
||||
|
||||
@@ -44,24 +44,24 @@ class CompareController extends Controller
|
||||
$compare = array_values(array_filter($compare, fn (int $id) => $id !== $product->id));
|
||||
session()->put('compare', $compare);
|
||||
|
||||
return back()->with('status', "Товар \"{$product->name}\" удален из сравнения.");
|
||||
return back()->with('status', __('Товар ":name" удален из сравнения.', ['name' => $product->name]));
|
||||
}
|
||||
|
||||
if (count($compare) >= 4) {
|
||||
return back()->with('status', 'Можно сравнить не более 4 товаров одновременно.');
|
||||
return back()->with('status', __('Можно сравнить не более 4 товаров одновременно.'));
|
||||
}
|
||||
|
||||
$compare[] = $product->id;
|
||||
session()->put('compare', array_values(array_unique($compare)));
|
||||
|
||||
return back()->with('status', "Товар \"{$product->name}\" добавлен в сравнение.");
|
||||
return back()->with('status', __('Товар ":name" добавлен в сравнение.', ['name' => $product->name]));
|
||||
}
|
||||
|
||||
public function clear()
|
||||
{
|
||||
session()->forget('compare');
|
||||
|
||||
return back()->with('status', 'Список сравнения очищен.');
|
||||
return back()->with('status', __('Список сравнения очищен.'));
|
||||
}
|
||||
|
||||
private function compareIds(): array
|
||||
|
||||
@@ -24,7 +24,7 @@ class ContactController extends Controller
|
||||
if ($botToken === '' || $chatId === '') {
|
||||
return back()
|
||||
->withInput()
|
||||
->withErrors(['contact' => 'Не настроена отправка в Telegram. Заполните SHOP_TELEGRAM_BOT_TOKEN и SHOP_TELEGRAM_CHAT_ID.']);
|
||||
->withErrors(['contact' => __('Не настроена отправка в Telegram. Заполните SHOP_TELEGRAM_BOT_TOKEN и SHOP_TELEGRAM_CHAT_ID.')]);
|
||||
}
|
||||
|
||||
$message = $this->buildTelegramMessage($validated, $request);
|
||||
@@ -41,16 +41,16 @@ class ContactController extends Controller
|
||||
} catch (Throwable) {
|
||||
return back()
|
||||
->withInput()
|
||||
->withErrors(['contact' => 'Не удалось отправить заявку в Telegram. Попробуйте еще раз.']);
|
||||
->withErrors(['contact' => __('Не удалось отправить заявку в Telegram. Попробуйте еще раз.')]);
|
||||
}
|
||||
|
||||
if (!$response->successful() || $response->json('ok') !== true) {
|
||||
return back()
|
||||
->withInput()
|
||||
->withErrors(['contact' => 'Telegram не принял заявку. Проверьте токен бота и chat id.']);
|
||||
->withErrors(['contact' => __('Telegram не принял заявку. Проверьте токен бота и chat id.')]);
|
||||
}
|
||||
|
||||
return back()->with('status', 'Заявка отправлена. Мы свяжемся с вами в ближайшее время.');
|
||||
return back()->with('status', __('Заявка отправлена. Мы свяжемся с вами в ближайшее время.'));
|
||||
}
|
||||
|
||||
private function buildTelegramMessage(array $data, Request $request): string
|
||||
|
||||
@@ -34,13 +34,13 @@ class FavoriteController extends Controller
|
||||
$favorites = array_values(array_filter($favorites, fn (int $id) => $id !== $product->id));
|
||||
session()->put('favorites', $favorites);
|
||||
|
||||
return back()->with('status', "Товар \"{$product->name}\" удален из избранного.");
|
||||
return back()->with('status', __('Товар ":name" удален из избранного.', ['name' => $product->name]));
|
||||
}
|
||||
|
||||
$favorites[] = $product->id;
|
||||
session()->put('favorites', array_values(array_unique($favorites)));
|
||||
|
||||
return back()->with('status', "Товар \"{$product->name}\" добавлен в избранное.");
|
||||
return back()->with('status', __('Товар ":name" добавлен в избранное.', ['name' => $product->name]));
|
||||
}
|
||||
|
||||
private function favoriteIds(): array
|
||||
|
||||
25
app/Http/Middleware/SetLocale.php
Normal file
25
app/Http/Middleware/SetLocale.php
Normal file
@@ -0,0 +1,25 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Middleware;
|
||||
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
|
||||
class SetLocale
|
||||
{
|
||||
public function handle(Request $request, Closure $next): Response
|
||||
{
|
||||
$supportedLocales = array_keys((array) config('app.supported_locales', []));
|
||||
$defaultLocale = (string) config('app.locale', 'ru');
|
||||
|
||||
$locale = (string) $request->session()->get('locale', $defaultLocale);
|
||||
if (!in_array($locale, $supportedLocales, true)) {
|
||||
$locale = $defaultLocale;
|
||||
}
|
||||
|
||||
app()->setLocale($locale);
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
}
|
||||
@@ -47,7 +47,7 @@ class ChatConversation extends Model
|
||||
return $this->user->name;
|
||||
}
|
||||
|
||||
return 'Гость #' . $this->id;
|
||||
return __('Гость #:number', ['number' => $this->id]);
|
||||
}
|
||||
|
||||
public function isClosed(): bool
|
||||
|
||||
@@ -43,8 +43,21 @@ class Order extends Model
|
||||
public function getPaymentMethodLabelAttribute(): string
|
||||
{
|
||||
return match ($this->payment_method) {
|
||||
'card_transfer' => 'Перевод по реквизитам (на карту)',
|
||||
default => 'Не указан',
|
||||
'card_transfer' => __('Перевод по реквизитам (на карту)'),
|
||||
default => __('Не указан'),
|
||||
};
|
||||
}
|
||||
|
||||
public function getStatusLabelAttribute(): string
|
||||
{
|
||||
return match ($this->status) {
|
||||
'new' => __('Новый'),
|
||||
'processing' => __('В обработке'),
|
||||
'paid' => __('Оплачен'),
|
||||
'shipped' => __('Отправлен'),
|
||||
'completed' => __('Завершен'),
|
||||
'cancelled' => __('Отменен'),
|
||||
default => (string) $this->status,
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
<?php
|
||||
|
||||
use App\Http\Middleware\SetLocale;
|
||||
use Illuminate\Foundation\Application;
|
||||
use Illuminate\Foundation\Configuration\Exceptions;
|
||||
use Illuminate\Foundation\Configuration\Middleware;
|
||||
@@ -11,7 +12,9 @@ return Application::configure(basePath: dirname(__DIR__))
|
||||
health: '/up',
|
||||
)
|
||||
->withMiddleware(function (Middleware $middleware): void {
|
||||
//
|
||||
$middleware->web(append: [
|
||||
SetLocale::class,
|
||||
]);
|
||||
})
|
||||
->withExceptions(function (Exceptions $exceptions): void {
|
||||
//
|
||||
|
||||
@@ -78,11 +78,30 @@ return [
|
||||
|
|
||||
*/
|
||||
|
||||
'locale' => env('APP_LOCALE', 'en'),
|
||||
'locale' => env('APP_LOCALE', 'ru'),
|
||||
|
||||
'fallback_locale' => env('APP_FALLBACK_LOCALE', 'en'),
|
||||
'fallback_locale' => env('APP_FALLBACK_LOCALE', 'ru'),
|
||||
|
||||
'faker_locale' => env('APP_FAKER_LOCALE', 'en_US'),
|
||||
'faker_locale' => env('APP_FAKER_LOCALE', 'ru_RU'),
|
||||
|
||||
'supported_locales' => [
|
||||
'ru' => [
|
||||
'label' => 'Русский',
|
||||
'native' => 'Русский',
|
||||
'short' => 'Рус',
|
||||
'flag' => '🇷🇺',
|
||||
'hreflang' => 'ru-RU',
|
||||
'og_locale' => 'ru_RU',
|
||||
],
|
||||
'kk' => [
|
||||
'label' => 'Kazakh',
|
||||
'native' => 'Қазақша',
|
||||
'short' => 'Қаз',
|
||||
'flag' => '🇰🇿',
|
||||
'hreflang' => 'kk-KZ',
|
||||
'og_locale' => 'kk_KZ',
|
||||
],
|
||||
],
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
server {
|
||||
listen 80;
|
||||
listen [::]:80;
|
||||
server_name shop.example.com www.shop.example.com;
|
||||
server_name tehnobox.shop www.tehnobox.shop;
|
||||
root /var/www/pc-shop/public;
|
||||
|
||||
location ^~ /.well-known/acme-challenge/ {
|
||||
@@ -17,12 +17,12 @@ server {
|
||||
server {
|
||||
listen 443 ssl http2;
|
||||
listen [::]:443 ssl http2;
|
||||
server_name shop.example.com www.shop.example.com;
|
||||
server_name tehnobox.shop www.tehnobox.shop;
|
||||
root /var/www/pc-shop/public;
|
||||
index index.php;
|
||||
|
||||
ssl_certificate /etc/letsencrypt/live/shop.example.com/fullchain.pem;
|
||||
ssl_certificate_key /etc/letsencrypt/live/shop.example.com/privkey.pem;
|
||||
ssl_certificate /etc/letsencrypt/live/tehnobox.shop/fullchain.pem;
|
||||
ssl_certificate_key /etc/letsencrypt/live/tehnobox.shop/privkey.pem;
|
||||
include /etc/letsencrypt/options-ssl-nginx.conf;
|
||||
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
|
||||
|
||||
|
||||
402
lang/kk.json
Normal file
402
lang/kk.json
Normal file
@@ -0,0 +1,402 @@
|
||||
{
|
||||
"(c) :year :company. Все права защищены.": "(c) :year :company. Барлық құқықтар қорғалған.",
|
||||
"1-3 дня по стране": "Ел бойынша 1-3 күн",
|
||||
"8 ядер, 16 потоков, до 5.4 ГГц.": "8 ядро, 16 ағын, 5.4 ГГц-ке дейін.",
|
||||
"12 ГБ GDDR6X, DLSS 3.": "12 ГБ GDDR6X, DLSS 3.",
|
||||
"13.5\\\", компактный ультрабук.": "13.5\\\", ықшам ультрабук.",
|
||||
"13.6\\\", чип M2, 8/256 ГБ.": "13.6\\\", M2 чипі, 8/256 ГБ.",
|
||||
"14\\\", легкий для работы.": "14\\\", жұмысқа жеңіл.",
|
||||
"15.6\\\", Ryzen 7, RTX 4060.": "15.6\\\", Ryzen 7, RTX 4060.",
|
||||
"16 ГБ GDDR6, отличная производительность.": "16 ГБ GDDR6, жоғары өнімділік.",
|
||||
"16 ядер, для мощных систем.": "16 ядро, қуатты жүйелерге арналған.",
|
||||
"43\\\", 4K UHD, Android TV.": "43\\\", 4K UHD, Android TV.",
|
||||
"50\\\", NanoCell, webOS.": "50\\\", NanoCell, webOS.",
|
||||
"55\\\", 4K UHD, Smart TV.": "55\\\", 4K UHD, Smart TV.",
|
||||
"6.1\\\", 128 ГБ, отличное состояние.": "6.1\\\", 128 ГБ, өте жақсы күйде.",
|
||||
"650 Вт, стабильная линия питания.": "650 Вт, тұрақты қорек желісі.",
|
||||
"750 Вт, 80 Plus Gold.": "750 Вт, 80 Plus Gold.",
|
||||
"850 Вт, тихий режим работы.": "850 Вт, тыныш жұмыс режимі.",
|
||||
":category, комплектующие, купить, фильтры товаров": ":category, жинақтаушы, сатып алу, тауар сүзгілері",
|
||||
":company работает для тех, кому важно собрать быстрый и надежный ПК без ошибок по совместимости. В каталоге есть комплектующие для домашних, рабочих и игровых систем: процессоры, материнские платы, видеокарты, память, накопители, блоки питания, корпуса, системы охлаждения, ноутбуки и периферия.": ":company үйлесімділік қателерінсіз жылдам әрі сенімді ПК жинау маңызды адамдар үшін жұмыс істейді. Каталогта үйге, жұмысқа және ойынға арналған жүйелерге керек бөлшектер бар: процессорлар, аналық платалар, бейнекарталар, жад, жинақтауыштар, қуат блоктары, корпустар, салқындату жүйелері, ноутбуктер және периферия.",
|
||||
":company — интернет-магазин компьютерных комплектующих.": ":company — компьютер бөлшектері интернет-дүкені.",
|
||||
":company — поддержка клиентов": ":company — клиенттерге қолдау",
|
||||
":label: :from - :to": ":label: :from - :to",
|
||||
":product - миниатюра :number": ":product - миниатюра :number",
|
||||
":product - фото :number": ":product - сурет :number",
|
||||
":product, :category, купить": ":product, :category, сатып алу",
|
||||
"AM5, усиленное питание, PCIe 4.0.": "AM5, күшейтілген қорек, PCIe 4.0.",
|
||||
"ATX, сетчатый фронт.": "ATX, торлы алдыңғы панель.",
|
||||
"Apple": "Apple",
|
||||
"Smart TV": "Smart TV",
|
||||
"Telegram не принял заявку. Проверьте токен бота и chat id.": "Telegram өтінімді қабылдамады. Бот токені мен chat id тексеріңіз.",
|
||||
"Telegram": "Telegram",
|
||||
"DDR4 3200 МГц, 2x8 ГБ.": "DDR4 3200 МГц, 2x8 ГБ.",
|
||||
"DDR4 3600 МГц, 2x16 ГБ.": "DDR4 3600 МГц, 2x16 ГБ.",
|
||||
"DDR5 6000 МГц, 2x16 ГБ.": "DDR5 6000 МГц, 2x16 ГБ.",
|
||||
"GPU": "GPU",
|
||||
"Email": "Email",
|
||||
"NVMe SSD с высокой скоростью.": "Жоғары жылдамдықты NVMe SSD.",
|
||||
"SSD и HDD для хранения данных.": "Деректерді сақтауға арналған SSD және HDD.",
|
||||
"AM5": "AM5",
|
||||
"Android TV": "Android TV",
|
||||
"DLSS 3.": "DLSS 3.",
|
||||
"mATX": "mATX",
|
||||
"Wi‑Fi": "Wi‑Fi",
|
||||
"Wi-Fi": "Wi-Fi",
|
||||
"Адрес доставки": "Жеткізу мекенжайы",
|
||||
"Артикул:": "Артикул:",
|
||||
"Банк": "Банк",
|
||||
"Банковский перевод": "Банктік аударым",
|
||||
"Безналичный расчет для юрлиц": "Заңды тұлғаларға қолма-қолсыз есеп айырысу",
|
||||
"Белый": "Ақ",
|
||||
"Блоки питания": "Қуат блоктары",
|
||||
"Блоки питания.": "Қуат блоктары.",
|
||||
"Быстрая доставка и удобная оплата.": "Жылдам жеткізу және ыңғайлы төлем.",
|
||||
"Б/у": "Қолданылған",
|
||||
"В избранное": "Таңдаулыларға",
|
||||
"В корзине": "Себетте",
|
||||
"В корзине уже максимальное доступное количество.": "Себетте қолжетімді ең көп саны бар.",
|
||||
"В корзину": "Себетке",
|
||||
"В обработке": "Өңделуде",
|
||||
"В сравнение": "Салыстыруға",
|
||||
"Варианты доставки": "Жеткізу нұсқалары",
|
||||
"Ваш заказ": "Сіздің тапсырысыңыз",
|
||||
"Ваше имя": "Атыңыз",
|
||||
"Введите email и пароль для доступа к заказам и профилю.": "Тапсырыстар мен профильге кіру үшін email мен құпиясөзді енгізіңіз.",
|
||||
"Введите запрос в строку поиска, чтобы открыть список найденных товаров.": "Табылған тауарлар тізімін ашу үшін іздеу жолына сұраныс енгізіңіз.",
|
||||
"Введите название товара, чтобы увидеть найденные позиции.": "Табылған тауарларды көру үшін атауын енгізіңіз.",
|
||||
"Введите сообщение...": "Хабарлама енгізіңіз...",
|
||||
"Видеокарты": "Бейнекарталар",
|
||||
"Войти": "Кіру",
|
||||
"Вперед": "Алға",
|
||||
"Все": "Барлығы",
|
||||
"Все категории": "Барлық санаттар",
|
||||
"Вход": "Кіру",
|
||||
"Выбирайте курьера или доставку по времени с безопасной оплатой.": "Курьерді не уақыт бойынша жеткізуді таңдап, қауіпсіз төлем жасаңыз.",
|
||||
"Выбор языка": "Тілді таңдау",
|
||||
"Выйти": "Шығу",
|
||||
"Главная": "Басты бет",
|
||||
"Гость #:number": "Қонақ №:number",
|
||||
"Данные аккаунта": "Аккаунт деректері",
|
||||
"Данные получателя": "Алушы деректері",
|
||||
"Данные профиля обновлены.": "Профиль деректері жаңартылды.",
|
||||
"День в день в пределах города": "Қала ішінде сол күні",
|
||||
"Для нас важны прозрачность и сервис: актуальные цены, понятные характеристики и честная обратная связь. Мы стремимся, чтобы покупка техники была удобной как для новичков, так и для опытных пользователей, которые собирают ПК самостоятельно.": "Біз үшін ашықтық пен сервис маңызды: өзекті бағалар, түсінікті сипаттамалар және адал кері байланыс. Жаңадан бастағандарға да, компьютерді өздері жинайтын тәжірибелі қолданушыларға да техника сатып алу ыңғайлы болғанын қалаймыз.",
|
||||
"Для этой категории фильтры пока не заданы.": "Бұл санат үшін сүзгілер әлі берілмеген.",
|
||||
"До": "Дейін",
|
||||
"Добавить в избранное": "Таңдаулыларға қосу",
|
||||
"Добавить в сравнение": "Салыстыруға қосу",
|
||||
"Добавьте товары в избранное из каталога или со страницы товара.": "Тауарларды каталогтан немесе тауар бетінен таңдаулыларға қосыңыз.",
|
||||
"Добавьте товары в сравнение из карточек каталога.": "Тауарларды каталог карточкаларынан салыстыруға қосыңыз.",
|
||||
"Добавьте товары из каталога, чтобы оформить заказ.": "Тапсырысты рәсімдеу үшін каталогтан тауар қосыңыз.",
|
||||
"Дополнительные изображения товара": "Тауардың қосымша суреттері",
|
||||
"Доставка": "Жеткізу",
|
||||
"Доставка и оплата": "Жеткізу және төлем",
|
||||
"Доставка курьером по городу": "Қала бойынша курьермен жеткізу",
|
||||
"Если вам нужна консультация перед покупкой, команда :company поможет подобрать комплектующие и предложит сбалансированные варианты под ваши задачи.": "Сатып алар алдында кеңес керек болса, :company командасы қажетті бөлшектерді таңдап, міндеттеріңізге сай теңгерімді нұсқаларды ұсынады.",
|
||||
"Жесткие диски": "Қатты дискілер",
|
||||
"Жидкостное охлаждение 240 мм.": "240 мм сұйық салқындату.",
|
||||
"Завершен": "Аяқталды",
|
||||
"Задайте вопрос — администратор ответит в этом окне.": "Сұрақ қойыңыз — әкімші осы терезеде жауап береді.",
|
||||
"Заказ #:number": "Тапсырыс №:number",
|
||||
"Заказ оформлен": "Тапсырыс рәсімделді",
|
||||
"Заказ №:number успешно оформлен": "Тапсырыс №:number сәтті рәсімделді",
|
||||
"Закрыть меню": "Мәзірді жабу",
|
||||
"Заполните контакты и перейдите на страницу с реквизитами для оплаты.": "Байланыс деректерін толтырып, төлем деректемелері бетіне өтіңіз.",
|
||||
"Запомнить меня": "Мені есте сақтау",
|
||||
"Запрос: \":query\"": "Сұраныс: \":query\"",
|
||||
"Зарегистрироваться": "Тіркелу",
|
||||
"Заявка отправлена. Мы свяжемся с вами в ближайшее время.": "Өтінім жіберілді. Жақын арада хабарласамыз.",
|
||||
"Золотой": "Алтын түсті",
|
||||
"Избранное": "Таңдаулылар",
|
||||
"Избранные товары": "Таңдаулы тауарлар",
|
||||
"Изменить данные": "Деректерді өзгерту",
|
||||
"Имя": "Аты",
|
||||
"Имя получателя": "Алушының аты",
|
||||
"Интернет-магазин компьютерных комплектующих": "Компьютер бөлшектері интернет-дүкені",
|
||||
"Интернет-магазин компьютерных комплектующих, ноутбуков и периферии. Подбор, сравнение и заказ в одном месте.": "Компьютер бөлшектері, ноутбуктер және периферия интернет-дүкені. Таңдау, салыстыру және тапсырыс — бәрі бір жерде.",
|
||||
"Интернет-магазин комплектующих для ПК: процессоры, материнские платы, видеокарты, ноутбуки и периферия.": "ПК бөлшектерінің интернет-дүкені: процессорлар, аналық платалар, бейнекарталар, ноутбуктер және периферия.",
|
||||
"Искать": "Іздеу",
|
||||
"Итого": "Барлығы",
|
||||
"Кабинет": "Кабинет",
|
||||
"Как мы помогаем клиентам": "Клиенттерге қалай көмектесеміз",
|
||||
"Капча: решите пример :question": "Капча: :question мысалын шешіңіз",
|
||||
"Каталог": "Каталог",
|
||||
"Каталог компьютерных комплектующих и техники.": "Компьютер бөлшектері мен техниканың каталогы.",
|
||||
"Каталог компьютерных комплектующих: процессоры, материнские платы, видеокарты, память, накопители и ноутбуки.": "Компьютер бөлшектерінің каталогы: процессорлар, аналық платалар, бейнекарталар, жад, жинақтауыштар және ноутбуктер.",
|
||||
"Каталог товаров": "Тауарлар каталогы",
|
||||
"Категории": "Санаттар",
|
||||
"Категории пока не добавлены.": "Санаттар әлі қосылмаған.",
|
||||
"Категории товаров": "Тауар санаттары",
|
||||
"Категория": "Санат",
|
||||
"Категория товаров :category": ":category санаты",
|
||||
"Количество вентиляторов": "Желдеткіш саны",
|
||||
"Количество модулей": "Модуль саны",
|
||||
"Количество ограничено текущим остатком.": "Саны ағымдағы қалдықпен шектелді.",
|
||||
"Количество товара обновлено.": "Тауар саны жаңартылды.",
|
||||
"Количество ядер": "Ядро саны",
|
||||
"Комментарий к заказу": "Тапсырысқа түсініктеме",
|
||||
"Комментарий:": "Түсініктеме:",
|
||||
"Компания": "Компания",
|
||||
"Компактная mATX для LGA1700.": "LGA1700 үшін ықшам mATX.",
|
||||
"Компактный и продуваемый.": "Ықшам әрі жақсы желдетіледі.",
|
||||
"Контакты": "Байланыс",
|
||||
"Контакты магазина: телефон, email, адрес и часы работы поддержки.": "Дүкен байланыстары: телефон, email, мекенжай және қолдау уақыты.",
|
||||
"Корзина": "Себет",
|
||||
"Корзина пустая": "Себет бос",
|
||||
"Корзина пустая. Добавьте товары перед оформлением.": "Себет бос. Рәсімдеу алдында тауар қосыңыз.",
|
||||
"Корпуса": "Корпустар",
|
||||
"Корпуса с отличным airflow.": "Ауа айналымы жақсы корпустар.",
|
||||
"Кто мы": "Біз кімбіз",
|
||||
"Купить :product по выгодной цене.": ":product-ті тиімді бағамен сатып алыңыз.",
|
||||
"Кэш көлемі": "Кэш көлемі",
|
||||
"Личный кабинет": "Жеке кабинет",
|
||||
"Макс. длина видеокарты": "Бейнекартаның ең ұзын өлшемі",
|
||||
"Максимальный объем памяти": "Жадтың ең көп көлемі",
|
||||
"Максимальный объем памяти (ГБ)": "Жадтың ең көп көлемі (ГБ)",
|
||||
"Материнские платы": "Аналық платалар",
|
||||
"Меню": "Мәзір",
|
||||
"Мини‑корпус для ITX.": "ITX үшін шағын корпус.",
|
||||
"Модель": "Модель",
|
||||
"Модель видеокарты": "Бейнекарта моделі",
|
||||
"Модель процессора": "Процессор моделі",
|
||||
"Можно сравнить не более 4 товаров одновременно.": "Бір уақытта 4 тауардан артық салыстыруға болмайды.",
|
||||
"Мои заказы": "Менің тапсырыстарым",
|
||||
"Мощность": "Қуаты",
|
||||
"Мы делаем акцент на понятном выборе: категории с фильтрами, сравнение товаров, избранное, корзина и личный кабинет с историей заказов. Это помогает быстрее принять решение и не потерять важные позиции при подборе сборки.": "Біз түсінікті таңдауға мән береміз: сүзгілері бар санаттар, тауарларды салыстыру, таңдаулылар, себет және тапсырыс тарихы бар жеке кабинет. Бұл шешімді тезірек қабылдауға және маңызды позицияларды жоғалтпауға көмектеседі.",
|
||||
"Мы помогаем подобрать совместимую сборку, оформить заказ и получить технику с понятной поддержкой после покупки.": "Біз үйлесімді жинақ таңдауға, тапсырыс рәсімдеуге және сатып алғаннан кейін түсінікті қолдаумен техниканы алуға көмектесеміз.",
|
||||
"Мы приняли заказ в обработку. Статус заказа:": "Тапсырысыңызды өңдеуге қабылдадық. Тапсырыс мәртебесі:",
|
||||
"Назад": "Артқа",
|
||||
"Назначение платежа:": "Төлем мақсаты:",
|
||||
"Найденные товары по запросу «:query». Выберите подходящий товар и откройте подробную карточку.": "«:query» сұранысы бойынша табылған тауарлар. Сәйкес тауарды таңдап, толық карточканы ашыңыз.",
|
||||
"Найдено товаров:": "Табылған тауар саны:",
|
||||
"Найдено:": "Табылды:",
|
||||
"Найти": "Іздеу",
|
||||
"Например, Ryzen 7 или RTX 4060": "Мысалы, Ryzen 7 немесе RTX 4060",
|
||||
"Начать новый чат": "Жаңа чатты бастау",
|
||||
"Наш подход": "Біздің ұстаным",
|
||||
"Не настроена отправка в Telegram. Заполните SHOP_TELEGRAM_BOT_TOKEN и SHOP_TELEGRAM_CHAT_ID.": "Telegram-ға жіберу бапталмаған. SHOP_TELEGRAM_BOT_TOKEN және SHOP_TELEGRAM_CHAT_ID толтырыңыз.",
|
||||
"Не удалось отправить заявку в Telegram. Попробуйте еще раз.": "Telegram-ға өтінімді жіберу мүмкін болмады. Қайта көріңіз.",
|
||||
"Не указан": "Көрсетілмеген",
|
||||
"Неверный email или пароль.": "Email немесе құпиясөз қате.",
|
||||
"Неверный ответ на капчу.": "Капчаға жауап қате.",
|
||||
"Надежные блоки питания.": "Сенімді қуат блоктары.",
|
||||
"Надежные платы для любых конфигураций.": "Кез келген конфигурацияға арналған сенімді платалар.",
|
||||
"Надежный HDD для хранения.": "Сақтауға арналған сенімді HDD.",
|
||||
"Нет в наличии": "Қоймада жоқ",
|
||||
"Новые товары": "Жаңа тауарлар",
|
||||
"Новый": "Жаңа",
|
||||
"Новое": "Жаңа",
|
||||
"Номер заказа будет присвоен после подтверждения": "Тапсырыс нөмірі растаудан кейін беріледі",
|
||||
"Номер карты": "Карта нөмірі",
|
||||
"Ноутбуки": "Ноутбуктер",
|
||||
"Ноутбуки для работы и игр.": "Жұмыс пен ойынға арналған ноутбуктер.",
|
||||
"О компании": "Компания туралы",
|
||||
"О компании: помощь в подборе комплектующих, консультации и поддержка при сборке ПК.": "Компания туралы: бөлшектерді таңдауға көмек, кеңес және ПК жинауға қолдау.",
|
||||
"О нас": "Біз туралы",
|
||||
"Обновить": "Жаңарту",
|
||||
"Обновление": "Жаңарту",
|
||||
"Объем": "Көлемі",
|
||||
"Объем видеопамяти": "Бейнежад көлемі",
|
||||
"Объем кэша": "Кэш көлемі",
|
||||
"Объем накопителя": "Жинақтауыш көлемі",
|
||||
"Объем памяти": "Жад көлемі",
|
||||
"Объясняем условия доставки, оплаты, возврата и гарантии простым языком.": "Жеткізу, төлем, қайтару және кепілдік шарттарын қарапайым тілмен түсіндіреміз.",
|
||||
"Онлайн-чат": "Онлайн-чат",
|
||||
"Онлайн‑треккинг": "Онлайн бақылау",
|
||||
"Описание": "Сипаттама",
|
||||
"Описание товара будет добавлено позже.": "Тауар сипаттамасы кейін қосылады.",
|
||||
"Оперативная память": "Жедел жад",
|
||||
"Оплата": "Төлем",
|
||||
"Оплата банковской картой": "Банк картасымен төлеу",
|
||||
"Оплата картой онлайн": "Картамен онлайн төлем",
|
||||
"Оплата по реквизитам": "Деректемелер бойынша төлем",
|
||||
"Оплачен": "Төленген",
|
||||
"Оптимален для игровых сборок.": "Ойын жинақтары үшін оңтайлы.",
|
||||
"Оставьте заявку — поможем подобрать комплектующие и ответим по доставке.": "Өтінім қалдырыңыз — бөлшектерді таңдауға көмектесіп, жеткізу бойынша жауап береміз.",
|
||||
"От": "Бастап",
|
||||
"Открыть заказ": "Тапсырысты ашу",
|
||||
"Открыть каталог": "Каталогты ашу",
|
||||
"Отменен": "Бас тартылды",
|
||||
"Отправить": "Жіберу",
|
||||
"Отправить сообщение": "Хабарлама жіберу",
|
||||
"Отправка по стране 1-3 дня": "Ел бойынша жеткізу 1-3 күн",
|
||||
"Отправлен": "Жіберілген",
|
||||
"Отличная производительность.": "Жоғары өнімділік.",
|
||||
"Очистить": "Тазарту",
|
||||
"Очистить сравнение": "Салыстыруды тазарту",
|
||||
"Пагинация": "Беттеу",
|
||||
"Пароль": "Құпиясөз",
|
||||
"Переведите сумму заказа по реквизитам ниже и подтвердите оформление.": "Төлемді төмендегі деректемелер бойынша аударып, рәсімдеуді растаңыз.",
|
||||
"Перевод по реквизитам (на карту)": "Деректемелер бойынша аударым (картаға)",
|
||||
"Перейти в каталог": "Каталогқа өту",
|
||||
"Перейти к оформлению": "Рәсімдеуге өту",
|
||||
"Перейти к реквизитам": "Төлем деректеріне өту",
|
||||
"По вашему запросу ничего не найдено.": "Сұранысыңыз бойынша ештеңе табылмады.",
|
||||
"По названию": "Атауы бойынша",
|
||||
"Поддержка": "Қолдау",
|
||||
"Подробнее": "Толығырақ",
|
||||
"Подсказываем оптимальные варианты под бюджет и задачи.": "Бюджет пен міндетке сай оңтайлы нұсқаларды ұсынамыз.",
|
||||
"Подтвердить оформление заказа": "Тапсырысты рәсімдеуді растау",
|
||||
"Подтверждение оплаты в личном кабинете": "Төлемді жеке кабинетте растау",
|
||||
"Подтверждение пароля": "Құпиясөзді растау",
|
||||
"Поиск": "Іздеу",
|
||||
"Поиск товаров": "Тауар іздеу",
|
||||
"Поиск товаров по наименованию": "Тауарларды атауы бойынша іздеу",
|
||||
"Поиск товаров по наименованию: процессоры, видеокарты, материнские платы, ноутбуки и периферия.": "Атауы бойынша тауар іздеу: процессорлар, бейнекарталар, аналық платалар, ноутбуктер және периферия.",
|
||||
"Поиск: :query": "Іздеу: :query",
|
||||
"Пока нет заказов.": "Тапсырыстар әлі жоқ.",
|
||||
"Пока нет новых товаров.": "Жаңа тауарлар әзірге жоқ.",
|
||||
"Пока нет популярных товаров.": "Танымал тауарлар әзірге жоқ.",
|
||||
"Пока нет товаров в этой категории.": "Бұл санатта әзірге тауар жоқ.",
|
||||
"Пока нет товаров.": "Тауарлар әзірге жоқ.",
|
||||
"Показать": "Көрсету",
|
||||
"Показать фото :number": ":number суретті көрсету",
|
||||
"Получатель": "Алушы",
|
||||
"Покупателю": "Сатып алушыға",
|
||||
"Поможем с вашей сборкой.": "Жинағыңызды таңдауға көмектесеміз.",
|
||||
"Популярные товары": "Танымал тауарлар",
|
||||
"После оплаты отправьте чек в поддержку для подтверждения заказа.": "Төлемнен кейін тапсырысты растау үшін чекті қолдауға жіберіңіз.",
|
||||
"Почта": "Email",
|
||||
"Почта:": "Email:",
|
||||
"Предыдущие товары": "Алдыңғы тауарлар",
|
||||
"Предыдущий слайд": "Алдыңғы слайд",
|
||||
"Проверяем ключевые характеристики и совместимость комплектующих.": "Бөлшектердің негізгі сипаттамалары мен үйлесімділігін тексереміз.",
|
||||
"Продолжить покупки": "Сатып алуды жалғастыру",
|
||||
"Производитель": "Өндіруші",
|
||||
"Производитель видеокарты": "Бейнекарта өндірушісі",
|
||||
"Производитель процессора": "Процессор өндірушісі",
|
||||
"Процессоры": "Процессорлар",
|
||||
"Процессоры для игровых и рабочих сборок.": "Ойын және жұмыс жинақтарына арналған процессорлар.",
|
||||
"Процессоры, видеокарты, материнские платы, ноутбуки и периферия в одном каталоге.": "Процессорлар, бейнекарталар, аналық платалар, ноутбуктер және периферия бір каталогта.",
|
||||
"Процессоры, видеокарты, материнские платы, ноутбуки и периферия с доставкой по стране.": "Процессорлар, бейнекарталар, аналық платалар, ноутбуктер және периферия ел бойынша жеткізіледі.",
|
||||
"Процессоры, материнские платы, видеокарты, ноутбуки и периферия в одном каталоге.": "Процессорлар, аналық платалар, бейнекарталар, ноутбуктер және периферия бір каталогта.",
|
||||
"Разделы сайта": "Сайт бөлімдері",
|
||||
"Разрешение экрана": "Экран ажыратымдылығы",
|
||||
"Расскажите о вашей сборке": "Жинағыңыз туралы жазыңыз",
|
||||
"Рассрочка на крупные заказы": "Ірі тапсырыстарға бөліп төлеу",
|
||||
"Регистрация": "Тіркелу",
|
||||
"Результаты по запросу: \":query\"": "\":query\" сұранысы бойынша нәтижелер",
|
||||
"Результаты поиска": "Іздеу нәтижелері",
|
||||
"Результаты поиска по запросу «:query». Подберите нужные комплектующие по наименованию.": "«:query» сұранысы бойынша нәтижелер. Қажетті бөлшектерді атауы бойынша таңдаңыз.",
|
||||
"Результаты поиска: :query": "Іздеу нәтижелері: :query",
|
||||
"Реквизиты для оплаты": "Төлем деректемелері",
|
||||
"Сбербанк": "Сбербанк",
|
||||
"Самовывоз из пункта выдачи": "Беру пунктінен алып кету",
|
||||
"Сбросить": "Тазарту",
|
||||
"Свернуть чат": "Чатты жинау",
|
||||
"Свяжитесь с нами для консультации по вашей сборке.": "Жинағыңыз бойынша кеңес алу үшін бізге хабарласыңыз.",
|
||||
"Сервис": "Сервис",
|
||||
"Серебристый": "Күміс түсті",
|
||||
"Сертификат 80 Plus": "80 Plus сертификаты",
|
||||
"Синий": "Көк",
|
||||
"Системы охлаждения": "Салқындату жүйелері",
|
||||
"Слайд на главной странице": "Басты беттегі слайд",
|
||||
"Следующие товары": "Келесі тауарлар",
|
||||
"Следующий слайд": "Келесі слайд",
|
||||
"Сначала дешевле": "Алдымен арзаны",
|
||||
"Сначала дороже": "Алдымен қымбаты",
|
||||
"Сначала заполните данные получателя.": "Алдымен алушы деректерін толтырыңыз.",
|
||||
"Сначала новые": "Алдымен жаңалары",
|
||||
"Собирайте ПК быстрее": "ПК-ні тезірек жинаңыз",
|
||||
"Создайте аккаунт, чтобы отслеживать заказы и сохранять избранное.": "Тапсырыстарды қадағалау және таңдаулыларды сақтау үшін аккаунт жасаңыз.",
|
||||
"Создать аккаунт": "Аккаунт жасау",
|
||||
"Сообщение": "Хабарлама",
|
||||
"Сообщение содержит недопустимые символы.": "Хабарламада рұқсат етілмеген таңбалар бар.",
|
||||
"Сопровождаем заказ от оформления до получения.": "Тапсырысты рәсімдеуден бастап алғанға дейін бірге жүреміз.",
|
||||
"Сортировка:": "Сұрыптау:",
|
||||
"Состав заказа": "Тапсырыс құрамы",
|
||||
"Сохранить": "Сақтау",
|
||||
"Список пуст": "Тізім бос",
|
||||
"Список сравнения очищен.": "Салыстыру тізімі тазартылды.",
|
||||
"Список сравнения пуст": "Салыстыру тізімі бос",
|
||||
"Способ оплаты:": "Төлем тәсілі:",
|
||||
"Способы оплаты": "Төлем тәсілдері",
|
||||
"Сравнение": "Салыстыру",
|
||||
"Сравнение товаров": "Тауарларды салыстыру",
|
||||
"Сравнить": "Салыстыру",
|
||||
"Стабильная линия питания.": "Тұрақты қорек желісі.",
|
||||
"Стандарт Wi-Fi": "Wi-Fi стандарты",
|
||||
"Статус:": "Мәртебе:",
|
||||
"Сумма": "Сома",
|
||||
"Сумма заказа:": "Тапсырыс сомасы:",
|
||||
"Сумма к оплате:": "Төлем сомасы:",
|
||||
"Система охлаждения": "Салқындату жүйесі",
|
||||
"Телевизоры": "Теледидарлар",
|
||||
"Телевизоры для дома и офиса.": "Үй мен офиске арналған теледидарлар.",
|
||||
"Телефон": "Телефон",
|
||||
"Телефон:": "Телефон:",
|
||||
"Тихая работа и охлаждение.": "Тыныш жұмыс және салқындату.",
|
||||
"Тихий режим работы.": "Тыныш жұмыс режимі.",
|
||||
"Товар \":name\" добавлен в избранное.": "«:name» тауары таңдаулыларға қосылды.",
|
||||
"Товар \":name\" добавлен в корзину.": "«:name» тауары себетке қосылды.",
|
||||
"Товар \":name\" добавлен в сравнение.": "«:name» тауары салыстыруға қосылды.",
|
||||
"Товар \":name\" удален из избранного.": "«:name» тауары таңдаулылардан алынды.",
|
||||
"Товар \":name\" удален из корзины.": "«:name» тауары себеттен алынды.",
|
||||
"Товар \":name\" удален из сравнения.": "«:name» тауары салыстырудан алынды.",
|
||||
"Товар сейчас недоступен для заказа.": "Бұл тауарға қазір тапсырыс беруге болмайды.",
|
||||
"Товаров": "Тауар",
|
||||
"Товары в корзине": "Себеттегі тауарлар",
|
||||
"Товары категории :category. Фильтры и сортировка для быстрого подбора.": ":category санатындағы тауарлар. Жылдам таңдау үшін сүзгілер мен сұрыптау.",
|
||||
"Товар": "Тауар",
|
||||
"Топовый воздушный кулер.": "Үздік ауа кулері.",
|
||||
"Тип": "Түрі",
|
||||
"Тип видеопамяти": "Бейнежад түрі",
|
||||
"Тип матрицы": "Матрица түрі",
|
||||
"Тип памяти": "Жад түрі",
|
||||
"Тип поддерживаемой памяти": "Қолдайтын жад түрі",
|
||||
"Тип процессора": "Процессор түрі",
|
||||
"Тип сокета": "Сокет түрі",
|
||||
"Тип устройства": "Құрылғы түрі",
|
||||
"Типоразмер": "Өлшемі",
|
||||
"Топовый воздушный кулер": "Үздік ауа кулері",
|
||||
"Убрать из избранного": "Таңдаулылардан алып тастау",
|
||||
"Убрать из сравнения": "Салыстырудан алып тастау",
|
||||
"Удалить": "Жою",
|
||||
"Уже есть аккаунт": "Аккаунтым бар",
|
||||
"Узнайте сроки доставки и способы оплаты заказа.": "Жеткізу мерзімдері мен тапсырыс төлеу тәсілдерін біліңіз.",
|
||||
"Управляйте данными профиля и просматривайте историю заказов.": "Профиль деректерін басқарып, тапсырыстар тарихын қараңыз.",
|
||||
"Условия доставки и способы оплаты заказов в интернет-магазине комплектующих.": "Бөлшектер интернет-дүкеніндегі жеткізу шарттары мен төлем тәсілдері.",
|
||||
"Условия доставки, способы оплаты и сроки отправки.": "Жеткізу шарттары, төлем тәсілдері және жөнелту мерзімі.",
|
||||
"Устройства Apple: ноутбуки, планшеты и смартфоны.": "Apple құрылғылары: ноутбуктер, планшеттер және смартфондар.",
|
||||
"Фиолетовый": "Күлгін",
|
||||
"Фильтр": "Сүзгі",
|
||||
"Фильтры": "Сүзгілер",
|
||||
"Форм-фактор": "Форм-фактор",
|
||||
"Характеристика": "Сипаттама",
|
||||
"Характеристики": "Сипаттамалар",
|
||||
"Характеристики еще не добавлены.": "Сипаттамалар әлі қосылмаған.",
|
||||
"Хлебные крошки": "Навигация жолы",
|
||||
"Цвет": "Түсі",
|
||||
"Цена": "Баға",
|
||||
"Цена: :from - :to": "Баға: :from - :to",
|
||||
"Часы:": "Жұмыс уақыты:",
|
||||
"Частота": "Жиілігі",
|
||||
"Частота обновления": "Жаңарту жиілігі",
|
||||
"Чат": "Чат",
|
||||
"Чат закрыт администратором. Отправьте новое сообщение, чтобы начать новый диалог.": "Чатты әкімші жапты. Жаңа диалог бастау үшін жаңа хабарлама жіберіңіз.",
|
||||
"Чем занимаемся и как помогаем выбрать комплектующие.": "Не істейтініміз және жинақтаушыны қалай таңдауға көмектесетініміз.",
|
||||
"Черный": "Қара",
|
||||
"Что еще посмотреть в этой категории": "Осы санатта тағы не көруге болады",
|
||||
"Чипсет": "Чипсет",
|
||||
"Электронная почта": "Электрондық пошта",
|
||||
"Ядро": "Ядро",
|
||||
"о компании, магазин комплектующих, поддержка": "компания туралы, бөлшектер дүкені, қолдау",
|
||||
"доставка, оплата, условия заказа": "жеткізу, төлем, тапсырыс шарттары",
|
||||
"интернет-магазин пк, комплектующие, процессоры, видеокарты, ноутбуки": "пк интернет-дүкені, бөлшектер, процессорлар, бейнекарталар, ноутбуктер",
|
||||
"каталог комплектующих, поиск товаров, процессоры, материнские платы, видеокарты": "бөлшектер каталогы, тауар іздеу, процессорлар, аналық платалар, бейнекарталар",
|
||||
"контакты магазина, телефон, email, адрес": "дүкен байланыстары, телефон, email, мекенжай",
|
||||
"поиск товаров, результаты поиска, комплектующие пк, ноутбуки": "тауар іздеу, іздеу нәтижелері, пк бөлшектері, ноутбуктер",
|
||||
"товар": "тауар",
|
||||
"Пн-Вс: 10:00-20:00": "Дс-Жс: 10:00-20:00",
|
||||
"Сбербанк": "Сбербанк",
|
||||
"ул. Технопарк, 24, Техноград": "Технопарк көшесі, 24, Техноград",
|
||||
"Материнские платы.": "Аналық платалар.",
|
||||
"Производитель": "Өндіруші",
|
||||
"Производитель видеокарты": "Бейнекарта өндірушісі",
|
||||
"Производитель процессора": "Процессор өндірушісі",
|
||||
"Память": "Жад",
|
||||
"Оперативная память": "Жедел жад",
|
||||
"Системы охлаждения.": "Салқындату жүйелері.",
|
||||
"Төлем": "Төлем"
|
||||
}
|
||||
@@ -138,12 +138,150 @@ body.pc-body {
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.pc-header-tools {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.pc-header-icons {
|
||||
display: flex;
|
||||
gap: 14px;
|
||||
align-items: flex-start;
|
||||
}
|
||||
|
||||
.pc-lang-switcher {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-trigger {
|
||||
list-style: none;
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
gap: 8px;
|
||||
min-height: 40px;
|
||||
padding: 8px 12px;
|
||||
border-radius: 999px;
|
||||
border: 1px solid var(--border);
|
||||
background: #ffffff;
|
||||
color: var(--ink);
|
||||
cursor: pointer;
|
||||
font-size: 0.82rem;
|
||||
font-weight: 700;
|
||||
transition:
|
||||
border-color 0.2s ease,
|
||||
background 0.2s ease,
|
||||
box-shadow 0.2s ease;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-trigger::-webkit-details-marker {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-trigger:hover {
|
||||
border-color: rgba(15, 23, 42, 0.2);
|
||||
background: #f8fafc;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-trigger:focus-visible {
|
||||
outline: 2px solid rgba(226, 74, 74, 0.25);
|
||||
outline-offset: 2px;
|
||||
}
|
||||
|
||||
.pc-lang-switcher[open] .pc-lang-switcher-trigger {
|
||||
border-color: rgba(199, 58, 58, 0.24);
|
||||
box-shadow: 0 0 0 4px rgba(226, 74, 74, 0.08);
|
||||
}
|
||||
|
||||
.pc-lang-switcher-current {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-chevron {
|
||||
width: 18px;
|
||||
height: 18px;
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
color: var(--muted);
|
||||
transition: transform 0.2s ease, color 0.2s ease;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-chevron svg {
|
||||
width: 14px;
|
||||
height: 14px;
|
||||
fill: currentColor;
|
||||
}
|
||||
|
||||
.pc-lang-switcher[open] .pc-lang-switcher-chevron {
|
||||
transform: rotate(180deg);
|
||||
color: var(--ink);
|
||||
}
|
||||
|
||||
.pc-lang-switcher-menu {
|
||||
position: absolute;
|
||||
top: calc(100% + 8px);
|
||||
right: 0;
|
||||
min-width: 170px;
|
||||
padding: 8px;
|
||||
border-radius: 14px;
|
||||
border: 1px solid var(--border);
|
||||
background: rgba(255, 255, 255, 0.98);
|
||||
box-shadow: var(--shadow);
|
||||
display: grid;
|
||||
gap: 6px;
|
||||
z-index: 120;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-option {
|
||||
width: 100%;
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
gap: 8px;
|
||||
padding: 9px 10px;
|
||||
border: 0;
|
||||
border-radius: 10px;
|
||||
background: transparent;
|
||||
color: var(--ink);
|
||||
font: inherit;
|
||||
text-align: left;
|
||||
cursor: pointer;
|
||||
transition: background 0.2s ease, color 0.2s ease;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-option:hover:not(:disabled) {
|
||||
background: #f8fafc;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-option:disabled {
|
||||
opacity: 1;
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-option-main {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-option.is-active {
|
||||
background: rgba(226, 74, 74, 0.08);
|
||||
color: #b23434;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-check {
|
||||
font-size: 1.1rem;
|
||||
line-height: 1;
|
||||
}
|
||||
|
||||
.pc-lang-switcher-flag {
|
||||
font-size: 1rem;
|
||||
line-height: 1;
|
||||
}
|
||||
|
||||
.pc-mobile-menu-toggle {
|
||||
display: none;
|
||||
}
|
||||
@@ -2560,14 +2698,18 @@ body.pc-body {
|
||||
letter-spacing: 0.08em;
|
||||
}
|
||||
|
||||
.pc-header-tools {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.pc-catalog-btn {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.pc-hamburger {
|
||||
display: inline-flex;
|
||||
order: 2;
|
||||
margin-left: auto;
|
||||
order: 3;
|
||||
margin-left: 0;
|
||||
}
|
||||
|
||||
.pc-mobile-menu-head {
|
||||
@@ -2610,11 +2752,33 @@ body.pc-body {
|
||||
flex: 0 0 100%;
|
||||
}
|
||||
|
||||
.pc-mobile-menu-toggle:checked ~ .pc-header-tools {
|
||||
display: flex;
|
||||
order: 3;
|
||||
margin-left: 0;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.pc-mobile-menu-toggle:checked ~ .pc-header-tools .pc-lang-switcher {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.pc-mobile-menu-toggle:checked ~ .pc-header-tools .pc-lang-switcher-trigger {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.pc-mobile-menu-toggle:checked ~ .pc-header-tools .pc-lang-switcher-menu {
|
||||
left: 0;
|
||||
right: auto;
|
||||
width: 100%;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
.pc-mobile-menu-toggle:checked ~ .pc-header-center {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 10px;
|
||||
order: 3;
|
||||
order: 4;
|
||||
width: 100%;
|
||||
padding-top: 0;
|
||||
border-top: 0;
|
||||
@@ -2625,7 +2789,7 @@ body.pc-body {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(4, minmax(0, 1fr));
|
||||
gap: 8px;
|
||||
order: 4;
|
||||
order: 5;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
@@ -2634,6 +2798,7 @@ body.pc-body {
|
||||
grid-template-columns: 1fr;
|
||||
gap: 6px;
|
||||
width: 100%;
|
||||
order: 6;
|
||||
max-height: none;
|
||||
opacity: 1;
|
||||
overflow: visible;
|
||||
|
||||
@@ -54,6 +54,8 @@ const initChatWidget = () => {
|
||||
const fetchUrl = widget.dataset.fetchUrl;
|
||||
const sendUrl = widget.dataset.sendUrl;
|
||||
const csrf = widget.dataset.csrf;
|
||||
const sendLabel = widget.dataset.sendLabel || 'Send';
|
||||
const restartLabel = widget.dataset.restartLabel || 'Restart';
|
||||
const textarea = form.querySelector('textarea[name="message"]');
|
||||
const submitButton = form.querySelector('button[type="submit"]');
|
||||
|
||||
@@ -83,7 +85,7 @@ const initChatWidget = () => {
|
||||
note.textContent = conversationClosed && closedNotice !== '' ? closedNotice : defaultNoteText;
|
||||
}
|
||||
|
||||
submitButton.textContent = conversationClosed ? 'Начать новый чат' : 'Отправить';
|
||||
submitButton.textContent = conversationClosed ? restartLabel : sendLabel;
|
||||
|
||||
if (conversationClosed) {
|
||||
stopPolling();
|
||||
@@ -560,6 +562,46 @@ const initCategoryFilterToggle = () => {
|
||||
});
|
||||
};
|
||||
|
||||
const initLanguageSwitchers = () => {
|
||||
const switchers = Array.from(document.querySelectorAll('[data-locale-switcher]')).filter(
|
||||
(switcher) => switcher instanceof HTMLDetailsElement,
|
||||
);
|
||||
|
||||
if (switchers.length === 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
document.addEventListener('click', (event) => {
|
||||
switchers.forEach((switcher) => {
|
||||
if (!(switcher instanceof HTMLDetailsElement) || !switcher.open) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (event.target instanceof Node && switcher.contains(event.target)) {
|
||||
return;
|
||||
}
|
||||
|
||||
switcher.open = false;
|
||||
});
|
||||
});
|
||||
|
||||
switchers.forEach((switcher) => {
|
||||
const summary = switcher.querySelector('summary');
|
||||
|
||||
switcher.addEventListener('keydown', (event) => {
|
||||
if (event.key !== 'Escape') {
|
||||
return;
|
||||
}
|
||||
|
||||
switcher.open = false;
|
||||
|
||||
if (summary instanceof HTMLElement) {
|
||||
summary.focus();
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
document.addEventListener('submit', (event) => {
|
||||
const form = event.target;
|
||||
if (!(form instanceof HTMLFormElement)) {
|
||||
@@ -620,3 +662,4 @@ initHomeSliders();
|
||||
initProductCarousels();
|
||||
initProductGallery();
|
||||
initCategoryFilterToggle();
|
||||
initLanguageSwitchers();
|
||||
|
||||
@@ -4,32 +4,34 @@
|
||||
data-fetch-url="{{ route('chat.messages') }}"
|
||||
data-send-url="{{ route('chat.send') }}"
|
||||
data-csrf="{{ csrf_token() }}"
|
||||
data-send-label="{{ __('Отправить') }}"
|
||||
data-restart-label="{{ __('Начать новый чат') }}"
|
||||
>
|
||||
<button class="pc-chat-toggle" type="button" data-chat-toggle>
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M4 5h16v10H8l-4 4V5zm2 2v7.17L7.17 13H18V7H6z"></path>
|
||||
</svg>
|
||||
<span>Чат</span>
|
||||
<span>{{ __('Чат') }}</span>
|
||||
</button>
|
||||
|
||||
<section class="pc-chat-panel" data-chat-panel hidden>
|
||||
<header class="pc-chat-header">
|
||||
<h3>Онлайн-чат</h3>
|
||||
<button class="pc-chat-close" type="button" data-chat-close aria-label="Свернуть чат">×</button>
|
||||
<h3>{{ __('Онлайн-чат') }}</h3>
|
||||
<button class="pc-chat-close" type="button" data-chat-close aria-label="{{ __('Свернуть чат') }}">×</button>
|
||||
</header>
|
||||
<p class="pc-chat-note" data-chat-note>Задайте вопрос — администратор ответит в этом окне.</p>
|
||||
<p class="pc-chat-note" data-chat-note>{{ __('Задайте вопрос — администратор ответит в этом окне.') }}</p>
|
||||
|
||||
<div class="pc-chat-messages" data-chat-messages></div>
|
||||
|
||||
<form class="pc-chat-form" data-chat-form>
|
||||
<textarea
|
||||
name="message"
|
||||
placeholder="Введите сообщение..."
|
||||
placeholder="{{ __('Введите сообщение...') }}"
|
||||
maxlength="2000"
|
||||
rows="3"
|
||||
required
|
||||
></textarea>
|
||||
<button class="pc-btn primary" type="submit">Отправить</button>
|
||||
<button class="pc-btn primary" type="submit">{{ __('Отправить') }}</button>
|
||||
</form>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
@@ -1,10 +1,10 @@
|
||||
@php
|
||||
$companyName = config('shop.company_name', config('app.name'));
|
||||
$companyDescription = config('shop.company_description');
|
||||
$companyDescription = __(config('shop.company_description'));
|
||||
$contactPhone = trim((string) config('shop.contact_phone'));
|
||||
$contactEmail = trim((string) config('shop.contact_email'));
|
||||
$contactTelegram = trim((string) config('shop.contact_telegram'));
|
||||
$contactHours = trim((string) config('shop.contact_hours'));
|
||||
$contactHours = trim((string) __(config('shop.contact_hours')));
|
||||
$telegramUrl = '';
|
||||
$phoneUrl = '';
|
||||
$emailUrl = '';
|
||||
@@ -32,28 +32,28 @@
|
||||
</div>
|
||||
<div class="pc-footer-columns">
|
||||
<div class="pc-footer-col">
|
||||
<h4>Каталог</h4>
|
||||
<h4>{{ __('Каталог') }}</h4>
|
||||
<ul class="pc-footer-list">
|
||||
<li><a href="{{ route('catalog.index') }}">Все категории</a></li>
|
||||
<li><a href="{{ route('catalog.category', 'processors') }}">Процессоры</a></li>
|
||||
<li><a href="{{ route('catalog.category', 'graphics-cards') }}">Видеокарты</a></li>
|
||||
<li><a href="{{ route('catalog.category', 'laptops') }}">Ноутбуки</a></li>
|
||||
<li><a href="{{ route('catalog.index') }}">{{ __('Все категории') }}</a></li>
|
||||
<li><a href="{{ route('catalog.category', 'processors') }}">{{ __('Процессоры') }}</a></li>
|
||||
<li><a href="{{ route('catalog.category', 'graphics-cards') }}">{{ __('Видеокарты') }}</a></li>
|
||||
<li><a href="{{ route('catalog.category', 'laptops') }}">{{ __('Ноутбуки') }}</a></li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="pc-footer-col">
|
||||
<h4>Покупателю</h4>
|
||||
<h4>{{ __('Покупателю') }}</h4>
|
||||
<ul class="pc-footer-list">
|
||||
<li><a href="{{ route('cart.index') }}">Корзина</a></li>
|
||||
<li><a href="{{ route('favorites.index') }}">Избранное</a></li>
|
||||
<li><a href="{{ route('compare.index') }}">Сравнение</a></li>
|
||||
<li><a href="{{ route('pages.shipping-payment') }}">Доставка и оплата</a></li>
|
||||
<li><a href="{{ route('cart.index') }}">{{ __('Корзина') }}</a></li>
|
||||
<li><a href="{{ route('favorites.index') }}">{{ __('Избранное') }}</a></li>
|
||||
<li><a href="{{ route('compare.index') }}">{{ __('Сравнение') }}</a></li>
|
||||
<li><a href="{{ route('pages.shipping-payment') }}">{{ __('Доставка и оплата') }}</a></li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="pc-footer-col">
|
||||
<h4>Контакты</h4>
|
||||
<h4>{{ __('Контакты') }}</h4>
|
||||
<div class="pc-footer-contact">
|
||||
@if ($phoneUrl !== '')
|
||||
<span>Телефон: <a href="{{ $phoneUrl }}">{{ $contactPhone }}</a></span>
|
||||
<span>{{ __('Телефон') }}: <a href="{{ $phoneUrl }}">{{ $contactPhone }}</a></span>
|
||||
@endif
|
||||
@if ($emailUrl !== '')
|
||||
<span>Email: <a href="{{ $emailUrl }}">{{ $contactEmail }}</a></span>
|
||||
@@ -69,7 +69,7 @@
|
||||
</div>
|
||||
</div>
|
||||
<div class="pc-footer-bottom">
|
||||
<span>(c) {{ date('Y') }} {{ $companyName }}. Все права защищены.</span>
|
||||
<span><a href="{{ route('pages.about') }}">О компании</a> / <a href="{{ route('pages.contacts') }}">Контакты</a></span>
|
||||
<span>{{ __('(c) :year :company. Все права защищены.', ['year' => date('Y'), 'company' => $companyName]) }}</span>
|
||||
<span><a href="{{ route('pages.about') }}">{{ __('О компании') }}</a> / <a href="{{ route('pages.contacts') }}">{{ __('Контакты') }}</a></span>
|
||||
</div>
|
||||
</footer>
|
||||
|
||||
@@ -3,52 +3,90 @@
|
||||
$compareCount = count((array) session('compare', []));
|
||||
$cartCount = collect((array) session('cart', []))->sum(fn ($quantity) => (int) $quantity);
|
||||
$companyName = config('shop.company_name', config('app.name'));
|
||||
$supportedLocales = (array) config('app.supported_locales', []);
|
||||
$currentLocale = app()->getLocale();
|
||||
$currentLocaleData = $supportedLocales[$currentLocale] ?? $supportedLocales[config('app.locale', 'ru')] ?? [
|
||||
'native' => 'Русский',
|
||||
'short' => 'Рус',
|
||||
'flag' => '🇷🇺',
|
||||
];
|
||||
$navItems = [
|
||||
['label' => 'Главная', 'route' => route('home'), 'active' => request()->routeIs('home')],
|
||||
['label' => __('Главная'), 'route' => route('home'), 'active' => request()->routeIs('home')],
|
||||
[
|
||||
'label' => 'Каталог',
|
||||
'label' => __('Каталог'),
|
||||
'route' => route('catalog.index'),
|
||||
'active' => request()->routeIs('catalog.*') || request()->routeIs('products.show') || request()->routeIs('search.index'),
|
||||
],
|
||||
['label' => 'О нас', 'route' => route('pages.about'), 'active' => request()->routeIs('pages.about')],
|
||||
['label' => __('О нас'), 'route' => route('pages.about'), 'active' => request()->routeIs('pages.about')],
|
||||
[
|
||||
'label' => 'Доставка и оплата',
|
||||
'label' => __('Доставка и оплата'),
|
||||
'route' => route('pages.shipping-payment'),
|
||||
'active' => request()->routeIs('pages.shipping-payment'),
|
||||
],
|
||||
['label' => 'Контакты', 'route' => route('pages.contacts'), 'active' => request()->routeIs('pages.contacts')],
|
||||
['label' => __('Контакты'), 'route' => route('pages.contacts'), 'active' => request()->routeIs('pages.contacts')],
|
||||
];
|
||||
@endphp
|
||||
|
||||
<header class="pc-header pc-animate" style="--delay: 0s">
|
||||
<input type="checkbox" id="pc-mobile-menu-toggle" class="pc-mobile-menu-toggle">
|
||||
<label for="pc-mobile-menu-toggle" class="pc-hamburger" aria-label="Меню">
|
||||
<label for="pc-mobile-menu-toggle" class="pc-hamburger" aria-label="{{ __('Меню') }}">
|
||||
<span></span>
|
||||
<span></span>
|
||||
<span></span>
|
||||
</label>
|
||||
<div class="pc-mobile-menu-head">
|
||||
<label for="pc-mobile-menu-toggle" class="pc-mobile-menu-close" aria-label="Закрыть меню">×</label>
|
||||
<label for="pc-mobile-menu-toggle" class="pc-mobile-menu-close" aria-label="{{ __('Закрыть меню') }}">×</label>
|
||||
</div>
|
||||
<div class="pc-header-left">
|
||||
<a class="pc-logo" href="{{ route('home') }}">
|
||||
<span class="pc-logo-mark"></span>
|
||||
{{ $companyName }}
|
||||
</a>
|
||||
<a class="pc-btn pc-catalog-btn" href="{{ route('catalog.index') }}">Каталог</a>
|
||||
<a class="pc-btn pc-catalog-btn" href="{{ route('catalog.index') }}">{{ __('Каталог') }}</a>
|
||||
</div>
|
||||
<div class="pc-header-center">
|
||||
<form class="pc-search" action="{{ route('search.index') }}" method="get">
|
||||
<input type="text" name="q" placeholder="Поиск товаров по наименованию" value="{{ request('q') }}" />
|
||||
<button class="pc-search-submit" type="submit" aria-label="Искать">
|
||||
<input type="text" name="q" placeholder="{{ __('Поиск товаров по наименованию') }}" value="{{ request('q') }}" />
|
||||
<button class="pc-search-submit" type="submit" aria-label="{{ __('Искать') }}">
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M15.5 14h-.79l-.28-.27a6 6 0 1 0-.71.71l.27.28v.79L20 20.5 21.5 19 15.5 14zm-5.5 0A4.5 4.5 0 1 1 10 5a4.5 4.5 0 0 1 0 9z"></path>
|
||||
</svg>
|
||||
</button>
|
||||
</form>
|
||||
</div>
|
||||
<div class="pc-header-tools">
|
||||
<details class="pc-lang-switcher" data-locale-switcher>
|
||||
<summary class="pc-lang-switcher-trigger" aria-label="{{ __('Выбор языка') }}">
|
||||
<span class="pc-lang-switcher-current">
|
||||
<span class="pc-lang-switcher-flag" aria-hidden="true">{{ $currentLocaleData['flag'] ?? '🌐' }}</span>
|
||||
<span class="pc-lang-switcher-label">{{ $currentLocaleData['short'] ?? strtoupper($currentLocale) }}</span>
|
||||
</span>
|
||||
<span class="pc-lang-switcher-chevron" aria-hidden="true">
|
||||
<svg viewBox="0 0 20 20">
|
||||
<path d="M5.3 7.8a1 1 0 0 1 1.4 0L10 11l3.3-3.2a1 1 0 1 1 1.4 1.4l-4 3.9a1 1 0 0 1-1.4 0l-4-3.9a1 1 0 0 1 0-1.4z"></path>
|
||||
</svg>
|
||||
</span>
|
||||
</summary>
|
||||
<div class="pc-lang-switcher-menu">
|
||||
@foreach ($supportedLocales as $locale => $localeData)
|
||||
<form method="post" action="{{ route('locale.switch', $locale) }}" data-preserve-scroll="true">
|
||||
@csrf
|
||||
<button class="pc-lang-switcher-option {{ $locale === $currentLocale ? 'is-active' : '' }}" type="submit" @disabled($locale === $currentLocale)>
|
||||
<span class="pc-lang-switcher-option-main">
|
||||
<span class="pc-lang-switcher-flag" aria-hidden="true">{{ $localeData['flag'] ?? '🌐' }}</span>
|
||||
<span>{{ $localeData['native'] ?? strtoupper($locale) }}</span>
|
||||
</span>
|
||||
@if ($locale === $currentLocale)
|
||||
<span class="pc-lang-switcher-check" aria-hidden="true">•</span>
|
||||
@endif
|
||||
</button>
|
||||
</form>
|
||||
@endforeach
|
||||
</div>
|
||||
</details>
|
||||
</div>
|
||||
<div class="pc-header-icons">
|
||||
<a class="pc-icon-link" href="{{ route('favorites.index') }}" aria-label="Избранное">
|
||||
<a class="pc-icon-link" href="{{ route('favorites.index') }}" aria-label="{{ __('Избранное') }}">
|
||||
<span class="pc-icon">
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M12 20s-7-4.5-9-9c-1.2-2.7.7-6 4.2-6 2 0 3.2 1 3.8 2 0.6-1 1.8-2 3.8-2 3.5 0 5.4 3.3 4.2 6-2 4.5-9 9-9 9z"></path>
|
||||
@@ -57,9 +95,9 @@
|
||||
<span class="pc-icon-count">{{ $favoritesCount }}</span>
|
||||
@endif
|
||||
</span>
|
||||
<span class="pc-icon-label">Избранное</span>
|
||||
<span class="pc-icon-label">{{ __('Избранное') }}</span>
|
||||
</a>
|
||||
<a class="pc-icon-link" href="{{ route('compare.index') }}" aria-label="Сравнение">
|
||||
<a class="pc-icon-link" href="{{ route('compare.index') }}" aria-label="{{ __('Сравнение') }}">
|
||||
<span class="pc-icon">
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M5 4h3v16H5zM16 4h3v16h-3zM10.5 8h3v12h-3z"></path>
|
||||
@@ -68,9 +106,9 @@
|
||||
<span class="pc-icon-count">{{ $compareCount }}</span>
|
||||
@endif
|
||||
</span>
|
||||
<span class="pc-icon-label">Сравнение</span>
|
||||
<span class="pc-icon-label">{{ __('Сравнение') }}</span>
|
||||
</a>
|
||||
<a class="pc-icon-link" href="{{ route('cart.index') }}" aria-label="Корзина">
|
||||
<a class="pc-icon-link" href="{{ route('cart.index') }}" aria-label="{{ __('Корзина') }}">
|
||||
<span class="pc-icon">
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M6 6h14l-2 9H8L6 6zm-2-2h3l1 2h-4zM9 20a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3zm8 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3z"></path>
|
||||
@@ -79,18 +117,18 @@
|
||||
<span class="pc-icon-count">{{ $cartCount }}</span>
|
||||
@endif
|
||||
</span>
|
||||
<span class="pc-icon-label">Корзина</span>
|
||||
<span class="pc-icon-label">{{ __('Корзина') }}</span>
|
||||
</a>
|
||||
<a class="pc-icon-link" href="{{ auth()->check() ? route('account') : route('login') }}" aria-label="Личный кабинет">
|
||||
<a class="pc-icon-link" href="{{ auth()->check() ? route('account') : route('login') }}" aria-label="{{ __('Личный кабинет') }}">
|
||||
<span class="pc-icon">
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M12 12a4 4 0 1 0-4-4 4 4 0 0 0 4 4zm0 2c-4.4 0-8 2.2-8 5v1h16v-1c0-2.8-3.6-5-8-5z"></path>
|
||||
</svg>
|
||||
</span>
|
||||
<span class="pc-icon-label">{{ auth()->check() ? 'Кабинет' : 'Войти' }}</span>
|
||||
<span class="pc-icon-label">{{ auth()->check() ? __('Кабинет') : __('Войти') }}</span>
|
||||
</a>
|
||||
</div>
|
||||
<nav class="pc-header-nav" aria-label="Разделы сайта">
|
||||
<nav class="pc-header-nav" aria-label="{{ __('Разделы сайта') }}">
|
||||
@foreach ($navItems as $item)
|
||||
<a class="pc-header-nav-link {{ $item['active'] ? 'is-active' : '' }}" href="{{ $item['route'] }}">
|
||||
{{ $item['label'] }}
|
||||
|
||||
@@ -1,12 +1,15 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="ru">
|
||||
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
|
||||
<head>
|
||||
@php
|
||||
$supportedLocales = (array) config('app.supported_locales', []);
|
||||
$currentLocale = app()->getLocale();
|
||||
$currentLocaleData = $supportedLocales[$currentLocale] ?? $supportedLocales[config('app.locale', 'ru')] ?? [];
|
||||
$siteName = config('seo.site_name', config('app.name', 'PC Shop'));
|
||||
$metaTitleRaw = trim($__env->yieldContent('meta_title'));
|
||||
$metaTitle = $metaTitleRaw !== '' ? "{$metaTitleRaw} - {$siteName}" : config('seo.default_title', $siteName);
|
||||
$metaDescription = trim($__env->yieldContent('meta_description')) ?: config('seo.default_description');
|
||||
$metaKeywords = trim($__env->yieldContent('meta_keywords')) ?: config('seo.default_keywords');
|
||||
$metaTitle = $metaTitleRaw !== '' ? "{$metaTitleRaw} - {$siteName}" : __(config('seo.default_title', $siteName));
|
||||
$metaDescription = trim($__env->yieldContent('meta_description')) ?: __(config('seo.default_description'));
|
||||
$metaKeywords = trim($__env->yieldContent('meta_keywords')) ?: __(config('seo.default_keywords'));
|
||||
$metaCanonical = trim($__env->yieldContent('meta_canonical')) ?: url()->current();
|
||||
$metaOgType = trim($__env->yieldContent('meta_og_type')) ?: 'website';
|
||||
$request = request();
|
||||
@@ -30,10 +33,10 @@
|
||||
$metaImageAlt = trim($__env->yieldContent('meta_image_alt')) ?: $metaTitle;
|
||||
$siteUrl = url('/');
|
||||
$companyName = config('shop.company_name', $siteName);
|
||||
$companyDescription = config('shop.company_description', $metaDescription);
|
||||
$companyDescription = __(config('shop.company_description', $metaDescription));
|
||||
$companyPhone = trim((string) config('shop.contact_phone', ''));
|
||||
$companyEmail = trim((string) config('shop.contact_email', ''));
|
||||
$companyAddress = trim((string) config('shop.contact_address', ''));
|
||||
$companyAddress = trim((string) __(config('shop.contact_address', '')));
|
||||
$companyTelegram = trim((string) config('shop.contact_telegram', ''));
|
||||
if ($companyTelegram !== '' && str_starts_with($companyTelegram, '@')) {
|
||||
$companyTelegram = 'https://t.me/' . ltrim($companyTelegram, '@');
|
||||
@@ -86,10 +89,12 @@
|
||||
<meta name="keywords" content="{{ $metaKeywords }}">
|
||||
<meta name="robots" content="{{ $metaRobots }}">
|
||||
<link rel="canonical" href="{{ $metaCanonical }}">
|
||||
<link rel="alternate" hreflang="ru-RU" href="{{ $metaCanonical }}">
|
||||
@foreach ($supportedLocales as $localeData)
|
||||
<link rel="alternate" hreflang="{{ $localeData['hreflang'] ?? 'ru-RU' }}" href="{{ $metaCanonical }}">
|
||||
@endforeach
|
||||
<link rel="alternate" hreflang="x-default" href="{{ $metaCanonical }}">
|
||||
<meta property="og:type" content="{{ $metaOgType }}">
|
||||
<meta property="og:locale" content="ru_RU">
|
||||
<meta property="og:locale" content="{{ $currentLocaleData['og_locale'] ?? 'ru_RU' }}">
|
||||
<meta property="og:site_name" content="{{ $siteName }}">
|
||||
<meta property="og:title" content="{{ $metaTitle }}">
|
||||
<meta property="og:description" content="{{ $metaDescription }}">
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
@extends('layouts.shop')
|
||||
|
||||
@section('meta_title', 'О компании')
|
||||
@section('meta_description', 'О компании: помощь в подборе комплектующих, консультации и поддержка при сборке ПК.')
|
||||
@section('meta_keywords', 'о компании, магазин комплектующих, поддержка')
|
||||
@section('meta_title', __('О компании'))
|
||||
@section('meta_description', __('О компании: помощь в подборе комплектующих, консультации и поддержка при сборке ПК.'))
|
||||
@section('meta_keywords', __('о компании, магазин комплектующих, поддержка'))
|
||||
@section('meta_canonical', route('pages.about'))
|
||||
|
||||
@section('content')
|
||||
@@ -12,33 +12,33 @@
|
||||
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'О нас', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('О нас'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>{{ $companyName }} — интернет-магазин компьютерных комплектующих.</h2>
|
||||
<p>Мы помогаем подобрать совместимую сборку, оформить заказ и получить технику с понятной поддержкой после покупки.</p>
|
||||
<h2>{{ __(':company — интернет-магазин компьютерных комплектующих.', ['company' => $companyName]) }}</h2>
|
||||
<p>{{ __('Мы помогаем подобрать совместимую сборку, оформить заказ и получить технику с понятной поддержкой после покупки.') }}</p>
|
||||
</div>
|
||||
|
||||
<div class="pc-about-content">
|
||||
<h3>Кто мы</h3>
|
||||
<p>{{ $companyName }} работает для тех, кому важно собрать быстрый и надежный ПК без ошибок по совместимости. В каталоге есть комплектующие для домашних, рабочих и игровых систем: процессоры, материнские платы, видеокарты, память, накопители, блоки питания, корпуса, системы охлаждения, ноутбуки и периферия.</p>
|
||||
<p>Мы делаем акцент на понятном выборе: категории с фильтрами, сравнение товаров, избранное, корзина и личный кабинет с историей заказов. Это помогает быстрее принять решение и не потерять важные позиции при подборе сборки.</p>
|
||||
<h3>{{ __('Кто мы') }}</h3>
|
||||
<p>{{ __(':company работает для тех, кому важно собрать быстрый и надежный ПК без ошибок по совместимости. В каталоге есть комплектующие для домашних, рабочих и игровых систем: процессоры, материнские платы, видеокарты, память, накопители, блоки питания, корпуса, системы охлаждения, ноутбуки и периферия.', ['company' => $companyName]) }}</p>
|
||||
<p>{{ __('Мы делаем акцент на понятном выборе: категории с фильтрами, сравнение товаров, избранное, корзина и личный кабинет с историей заказов. Это помогает быстрее принять решение и не потерять важные позиции при подборе сборки.') }}</p>
|
||||
|
||||
<h3>Как мы помогаем клиентам</h3>
|
||||
<h3>{{ __('Как мы помогаем клиентам') }}</h3>
|
||||
<ul class="pc-list">
|
||||
<li>Проверяем ключевые характеристики и совместимость комплектующих.</li>
|
||||
<li>Подсказываем оптимальные варианты под бюджет и задачи.</li>
|
||||
<li>Сопровождаем заказ от оформления до получения.</li>
|
||||
<li>Объясняем условия доставки, оплаты, возврата и гарантии простым языком.</li>
|
||||
<li>{{ __('Проверяем ключевые характеристики и совместимость комплектующих.') }}</li>
|
||||
<li>{{ __('Подсказываем оптимальные варианты под бюджет и задачи.') }}</li>
|
||||
<li>{{ __('Сопровождаем заказ от оформления до получения.') }}</li>
|
||||
<li>{{ __('Объясняем условия доставки, оплаты, возврата и гарантии простым языком.') }}</li>
|
||||
</ul>
|
||||
|
||||
<h3>Наш подход</h3>
|
||||
<p>Для нас важны прозрачность и сервис: актуальные цены, понятные характеристики и честная обратная связь. Мы стремимся, чтобы покупка техники была удобной как для новичков, так и для опытных пользователей, которые собирают ПК самостоятельно.</p>
|
||||
<p>Если вам нужна консультация перед покупкой, команда {{ $companyName }} поможет подобрать комплектующие и предложит сбалансированные варианты под ваши задачи.</p>
|
||||
<h3>{{ __('Наш подход') }}</h3>
|
||||
<p>{{ __('Для нас важны прозрачность и сервис: актуальные цены, понятные характеристики и честная обратная связь. Мы стремимся, чтобы покупка техники была удобной как для новичков, так и для опытных пользователей, которые собирают ПК самостоятельно.') }}</p>
|
||||
<p>{{ __('Если вам нужна консультация перед покупкой, команда :company поможет подобрать комплектующие и предложит сбалансированные варианты под ваши задачи.', ['company' => $companyName]) }}</p>
|
||||
</div>
|
||||
</section>
|
||||
@endsection
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
@extends('layouts.shop')
|
||||
|
||||
@section('meta_title', 'Контакты')
|
||||
@section('meta_description', 'Контакты магазина: телефон, email, адрес и часы работы поддержки.')
|
||||
@section('meta_keywords', 'контакты магазина, телефон, email, адрес')
|
||||
@section('meta_title', __('Контакты'))
|
||||
@section('meta_description', __('Контакты магазина: телефон, email, адрес и часы работы поддержки.'))
|
||||
@section('meta_keywords', __('контакты магазина, телефон, email, адрес'))
|
||||
@section('meta_canonical', route('pages.contacts'))
|
||||
|
||||
@section('content')
|
||||
@@ -11,7 +11,7 @@
|
||||
$contactPhone = trim((string) config('shop.contact_phone'));
|
||||
$contactEmail = trim((string) config('shop.contact_email'));
|
||||
$contactTelegram = trim((string) config('shop.contact_telegram'));
|
||||
$contactHours = trim((string) config('shop.contact_hours'));
|
||||
$contactHours = trim((string) __(config('shop.contact_hours')));
|
||||
$telegramUrl = '';
|
||||
$phoneUrl = '';
|
||||
$emailUrl = '';
|
||||
@@ -33,48 +33,48 @@
|
||||
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Контакты', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Контакты'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Поможем с вашей сборкой.</h2>
|
||||
<p>Оставьте заявку — поможем подобрать комплектующие и ответим по доставке.</p>
|
||||
<h2>{{ __('Поможем с вашей сборкой.') }}</h2>
|
||||
<p>{{ __('Оставьте заявку — поможем подобрать комплектующие и ответим по доставке.') }}</p>
|
||||
</div>
|
||||
<div class="pc-grid pc-grid-2">
|
||||
<article class="pc-card">
|
||||
<div class="pc-card-meta">Поддержка</div>
|
||||
<h3>{{ $companyName }} — поддержка клиентов</h3>
|
||||
<div class="pc-card-meta">{{ __('Поддержка') }}</div>
|
||||
<h3>{{ __(':company — поддержка клиентов', ['company' => $companyName]) }}</h3>
|
||||
@if ($phoneUrl !== '')
|
||||
<p>Телефон: <a class="pc-contact-link" href="{{ $phoneUrl }}">{{ $contactPhone }}</a></p>
|
||||
<p>{{ __('Телефон:') }} <a class="pc-contact-link" href="{{ $phoneUrl }}">{{ $contactPhone }}</a></p>
|
||||
@endif
|
||||
@if ($emailUrl !== '')
|
||||
<p>Почта: <a class="pc-contact-link" href="{{ $emailUrl }}">{{ $contactEmail }}</a></p>
|
||||
<p>{{ __('Почта:') }} <a class="pc-contact-link" href="{{ $emailUrl }}">{{ $contactEmail }}</a></p>
|
||||
@endif
|
||||
@if ($telegramUrl !== '')
|
||||
<p>Telegram: <a class="pc-contact-link" href="{{ $telegramUrl }}" target="_blank" rel="noopener noreferrer">{{ $contactTelegram }}</a></p>
|
||||
@endif
|
||||
@if ($contactHours !== '')
|
||||
<p>Часы: {{ $contactHours }}</p>
|
||||
<p>{{ __('Часы:') }} {{ $contactHours }}</p>
|
||||
@endif
|
||||
</article>
|
||||
<form class="pc-card pc-form" method="post" action="{{ route('pages.contacts.submit') }}">
|
||||
@csrf
|
||||
<label>
|
||||
Имя
|
||||
<input type="text" name="name" value="{{ old('name') }}" placeholder="Ваше имя" required />
|
||||
{{ __('Имя') }}
|
||||
<input type="text" name="name" value="{{ old('name') }}" placeholder="{{ __('Ваше имя') }}" required />
|
||||
</label>
|
||||
<label>
|
||||
Почта
|
||||
{{ __('Почта') }}
|
||||
<input type="email" name="email" value="{{ old('email') }}" placeholder="mail@example.com" required />
|
||||
</label>
|
||||
<label>
|
||||
Сообщение
|
||||
<textarea name="message" placeholder="Расскажите о вашей сборке" required>{{ old('message') }}</textarea>
|
||||
{{ __('Сообщение') }}
|
||||
<textarea name="message" placeholder="{{ __('Расскажите о вашей сборке') }}" required>{{ old('message') }}</textarea>
|
||||
</label>
|
||||
<button type="submit" class="pc-btn primary">Отправить сообщение</button>
|
||||
<button type="submit" class="pc-btn primary">{{ __('Отправить сообщение') }}</button>
|
||||
</form>
|
||||
</div>
|
||||
</section>
|
||||
|
||||
@@ -1,40 +1,40 @@
|
||||
@extends('layouts.shop')
|
||||
|
||||
@section('meta_title', 'Доставка и оплата')
|
||||
@section('meta_description', 'Условия доставки и способы оплаты заказов в интернет-магазине комплектующих.')
|
||||
@section('meta_keywords', 'доставка, оплата, условия заказа')
|
||||
@section('meta_title', __('Доставка и оплата'))
|
||||
@section('meta_description', __('Условия доставки и способы оплаты заказов в интернет-магазине комплектующих.'))
|
||||
@section('meta_keywords', __('доставка, оплата, условия заказа'))
|
||||
@section('meta_canonical', route('pages.shipping-payment'))
|
||||
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Доставка и оплата', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Доставка и оплата'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Быстрая доставка и удобная оплата.</h2>
|
||||
<p>Выбирайте курьера или доставку по времени с безопасной оплатой.</p>
|
||||
<h2>{{ __('Быстрая доставка и удобная оплата.') }}</h2>
|
||||
<p>{{ __('Выбирайте курьера или доставку по времени с безопасной оплатой.') }}</p>
|
||||
</div>
|
||||
<div class="pc-grid pc-grid-2">
|
||||
<article class="pc-card">
|
||||
<div class="pc-card-meta">Доставка</div>
|
||||
<h3>Варианты доставки</h3>
|
||||
<div class="pc-card-meta">{{ __('Доставка') }}</div>
|
||||
<h3>{{ __('Варианты доставки') }}</h3>
|
||||
<ul class="pc-list">
|
||||
<li>День в день в пределах города</li>
|
||||
<li>1-3 дня по стране</li>
|
||||
<li>Онлайн‑треккинг</li>
|
||||
<li>{{ __('День в день в пределах города') }}</li>
|
||||
<li>{{ __('1-3 дня по стране') }}</li>
|
||||
<li>{{ __('Онлайн‑треккинг') }}</li>
|
||||
</ul>
|
||||
</article>
|
||||
<article class="pc-card">
|
||||
<div class="pc-card-meta">Оплата</div>
|
||||
<h3>Способы оплаты</h3>
|
||||
<div class="pc-card-meta">{{ __('Оплата') }}</div>
|
||||
<h3>{{ __('Способы оплаты') }}</h3>
|
||||
<ul class="pc-list">
|
||||
<li>Оплата банковской картой</li>
|
||||
<li>Безналичный расчет для юрлиц</li>
|
||||
<li>Подтверждение оплаты в личном кабинете</li>
|
||||
<li>{{ __('Оплата банковской картой') }}</li>
|
||||
<li>{{ __('Безналичный расчет для юрлиц') }}</li>
|
||||
<li>{{ __('Подтверждение оплаты в личном кабинете') }}</li>
|
||||
</ul>
|
||||
</article>
|
||||
</div>
|
||||
|
||||
@@ -31,7 +31,7 @@
|
||||
];
|
||||
@endphp
|
||||
|
||||
<nav class="pc-breadcrumbs" aria-label="Хлебные крошки">
|
||||
<nav class="pc-breadcrumbs" aria-label="{{ __('Хлебные крошки') }}">
|
||||
@foreach ($items as $item)
|
||||
@if (!$loop->last && !empty($item['url']))
|
||||
<a href="{{ $item['url'] }}">{{ $item['label'] }}</a>
|
||||
|
||||
@@ -11,7 +11,7 @@
|
||||
$hasSubtitle = $slide->show_subtitle && !empty($slide->subtitle);
|
||||
$hasButton = $slide->show_button && !empty($slide->button_text) && !empty($slide->button_url);
|
||||
$hasContent = $hasTitle || $hasSubtitle || $hasButton;
|
||||
$altText = $hasTitle ? $slide->title : 'Слайд на главной странице';
|
||||
$altText = $hasTitle ? __($slide->title) : __('Слайд на главной странице');
|
||||
@endphp
|
||||
<article class="pc-home-slide {{ $loop->first ? 'is-active' : '' }}" data-home-slide>
|
||||
<img src="{{ $slide->image_url }}" alt="{{ $altText }}" loading="{{ $loop->first ? 'eager' : 'lazy' }}">
|
||||
@@ -19,13 +19,13 @@
|
||||
@if ($hasContent)
|
||||
<div class="pc-home-slide-content">
|
||||
@if ($hasTitle)
|
||||
<h2>{{ $slide->title }}</h2>
|
||||
<h2>{{ __($slide->title) }}</h2>
|
||||
@endif
|
||||
@if ($hasSubtitle)
|
||||
<p>{{ $slide->subtitle }}</p>
|
||||
<p>{{ __($slide->subtitle) }}</p>
|
||||
@endif
|
||||
@if ($hasButton)
|
||||
<a class="pc-btn primary" href="{{ $slide->button_url }}">{{ $slide->button_text }}</a>
|
||||
<a class="pc-btn primary" href="{{ $slide->button_url }}">{{ __($slide->button_text) }}</a>
|
||||
@endif
|
||||
</div>
|
||||
@endif
|
||||
@@ -34,16 +34,16 @@
|
||||
<article class="pc-home-slide is-active is-fallback" data-home-slide>
|
||||
<div class="pc-home-slide-overlay"></div>
|
||||
<div class="pc-home-slide-content">
|
||||
<h2>{{ $fallbackTitle ?? 'Собирайте ПК быстрее' }}</h2>
|
||||
<p>{{ $fallbackText ?? 'Загрузите баннеры в админке, чтобы вывести акции и подборки товаров на главной странице.' }}</p>
|
||||
<h2>{{ __($fallbackTitle ?? 'Собирайте ПК быстрее') }}</h2>
|
||||
<p>{{ __($fallbackText ?? 'Загрузите баннеры в админке, чтобы вывести акции и подборки товаров на главной странице.') }}</p>
|
||||
@if (!empty($fallbackUrl))
|
||||
<a class="pc-btn primary" href="{{ $fallbackUrl }}">{{ $fallbackButton ?? 'Открыть каталог' }}</a>
|
||||
<a class="pc-btn primary" href="{{ $fallbackUrl }}">{{ __($fallbackButton ?? 'Открыть каталог') }}</a>
|
||||
@endif
|
||||
</div>
|
||||
</article>
|
||||
@endforelse
|
||||
</div>
|
||||
|
||||
<button class="pc-home-slider-btn is-prev" type="button" data-home-slider-prev aria-label="Предыдущий слайд" @disabled($isSingle)>‹</button>
|
||||
<button class="pc-home-slider-btn is-next" type="button" data-home-slider-next aria-label="Следующий слайд" @disabled($isSingle)>›</button>
|
||||
<button class="pc-home-slider-btn is-prev" type="button" data-home-slider-prev aria-label="{{ __('Предыдущий слайд') }}" @disabled($isSingle)>‹</button>
|
||||
<button class="pc-home-slider-btn is-next" type="button" data-home-slider-next aria-label="{{ __('Следующий слайд') }}" @disabled($isSingle)>›</button>
|
||||
</div>
|
||||
|
||||
@@ -1,11 +1,11 @@
|
||||
@if ($paginator->hasPages())
|
||||
<nav class="pc-pager" role="navigation" aria-label="Пагинация">
|
||||
<nav class="pc-pager" role="navigation" aria-label="{{ __('Пагинация') }}">
|
||||
<ul class="pc-pager-list">
|
||||
<li>
|
||||
@if ($paginator->onFirstPage())
|
||||
<span class="pc-pager-link is-disabled" aria-disabled="true">Назад</span>
|
||||
<span class="pc-pager-link is-disabled" aria-disabled="true">{{ __('Назад') }}</span>
|
||||
@else
|
||||
<a class="pc-pager-link" href="{{ $paginator->previousPageUrl() }}" rel="prev">Назад</a>
|
||||
<a class="pc-pager-link" href="{{ $paginator->previousPageUrl() }}" rel="prev">{{ __('Назад') }}</a>
|
||||
@endif
|
||||
</li>
|
||||
|
||||
@@ -31,9 +31,9 @@
|
||||
|
||||
<li>
|
||||
@if ($paginator->hasMorePages())
|
||||
<a class="pc-pager-link" href="{{ $paginator->nextPageUrl() }}" rel="next">Вперед</a>
|
||||
<a class="pc-pager-link" href="{{ $paginator->nextPageUrl() }}" rel="next">{{ __('Вперед') }}</a>
|
||||
@else
|
||||
<span class="pc-pager-link is-disabled" aria-disabled="true">Вперед</span>
|
||||
<span class="pc-pager-link is-disabled" aria-disabled="true">{{ __('Вперед') }}</span>
|
||||
@endif
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
@@ -13,33 +13,33 @@
|
||||
@endphp
|
||||
|
||||
<div class="pc-payment-details {{ $class ?? '' }}">
|
||||
<h3>{{ $title ?? 'Оплата по реквизитам' }}</h3>
|
||||
<h3>{{ __($title ?? 'Оплата по реквизитам') }}</h3>
|
||||
|
||||
@isset($amount)
|
||||
<p class="pc-payment-total">Сумма к оплате: <strong>{{ number_format((float) $amount, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong></p>
|
||||
<p class="pc-payment-total">{{ __('Сумма к оплате:') }} <strong>{{ number_format((float) $amount, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong></p>
|
||||
@endisset
|
||||
|
||||
<div class="pc-payment-grid">
|
||||
<div class="pc-payment-row">
|
||||
<span class="pc-payment-key">Банк</span>
|
||||
<strong class="pc-payment-value">{{ $paymentBank }}</strong>
|
||||
<span class="pc-payment-key">{{ __('Банк') }}</span>
|
||||
<strong class="pc-payment-value">{{ __($paymentBank) }}</strong>
|
||||
</div>
|
||||
<div class="pc-payment-row">
|
||||
<span class="pc-payment-key">Получатель</span>
|
||||
<span class="pc-payment-key">{{ __('Получатель') }}</span>
|
||||
<strong class="pc-payment-value">{{ $paymentCardHolder }}</strong>
|
||||
</div>
|
||||
<div class="pc-payment-row">
|
||||
<span class="pc-payment-key">Номер карты</span>
|
||||
<span class="pc-payment-key">{{ __('Номер карты') }}</span>
|
||||
<strong class="pc-payment-value">{{ $paymentCardNumber }}</strong>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@isset($purpose)
|
||||
<p class="pc-payment-purpose">Назначение платежа: <strong>{{ $purpose }}</strong></p>
|
||||
<p class="pc-payment-purpose">{{ __('Назначение платежа:') }} <strong>{{ $purpose }}</strong></p>
|
||||
@endisset
|
||||
|
||||
@if (!empty($showHelp))
|
||||
<p class="pc-muted">После оплаты отправьте чек в поддержку для подтверждения заказа.</p>
|
||||
<p class="pc-muted">{{ __('После оплаты отправьте чек в поддержку для подтверждения заказа.') }}</p>
|
||||
@if ($telegramUrl !== '')
|
||||
<p class="pc-muted">Telegram: <a class="pc-contact-link" href="{{ $telegramUrl }}" target="_blank" rel="noopener noreferrer">{{ $telegram }}</a></p>
|
||||
@endif
|
||||
|
||||
@@ -12,7 +12,7 @@
|
||||
<div class="pc-product-tools">
|
||||
<form method="post" action="{{ route('favorites.toggle', $product) }}" class="pc-product-tool-form" data-preserve-scroll="true">
|
||||
@csrf
|
||||
<button class="pc-product-tool {{ $isFavorite ? 'is-active' : '' }}" type="submit" aria-label="Добавить в избранное" title="В избранное">
|
||||
<button class="pc-product-tool {{ $isFavorite ? 'is-active' : '' }}" type="submit" aria-label="{{ __('Добавить в избранное') }}" title="{{ __('В избранное') }}">
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M12 20s-7-4.5-9-9c-1.2-2.7.7-6 4.2-6 2 0 3.2 1 3.8 2 0.6-1 1.8-2 3.8-2 3.5 0 5.4 3.3 4.2 6-2 4.5-9 9-9 9z"></path>
|
||||
</svg>
|
||||
@@ -20,7 +20,7 @@
|
||||
</form>
|
||||
<form method="post" action="{{ route('compare.toggle', $product) }}" class="pc-product-tool-form" data-preserve-scroll="true">
|
||||
@csrf
|
||||
<button class="pc-product-tool {{ $isCompared ? 'is-active' : '' }}" type="submit" aria-label="Добавить в сравнение" title="Сравнить">
|
||||
<button class="pc-product-tool {{ $isCompared ? 'is-active' : '' }}" type="submit" aria-label="{{ __('Добавить в сравнение') }}" title="{{ __('Сравнить') }}">
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M5 4h3v16H5zM16 4h3v16h-3zM10.5 8h3v12h-3z"></path>
|
||||
</svg>
|
||||
@@ -37,7 +37,7 @@
|
||||
<a class="pc-product-link" href="{{ route('products.show', $product) }}">{{ $product->name }}</a>
|
||||
</h3>
|
||||
@if (!empty($product->short_description))
|
||||
<p>{{ $product->short_description }}</p>
|
||||
<p>{{ __($product->short_description) }}</p>
|
||||
@endif
|
||||
<div class="pc-product-meta">
|
||||
<strong>{{ number_format($product->price, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>
|
||||
@@ -50,11 +50,11 @@
|
||||
<form method="post" action="{{ route('cart.add', $product) }}" data-preserve-scroll="true">
|
||||
@csrf
|
||||
<button class="pc-btn ghost {{ $isInCart ? 'is-active' : '' }}" type="submit">
|
||||
{{ $isInCart ? 'В корзине' : 'В корзину' }}
|
||||
{{ $isInCart ? __('В корзине') : __('В корзину') }}
|
||||
</button>
|
||||
</form>
|
||||
@else
|
||||
<button class="pc-btn ghost" type="button" disabled>Нет в наличии</button>
|
||||
<button class="pc-btn ghost" type="button" disabled>{{ __('Нет в наличии') }}</button>
|
||||
@endif
|
||||
</div>
|
||||
</article>
|
||||
|
||||
@@ -4,17 +4,17 @@
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>{{ $title ?? 'Товары' }}</h2>
|
||||
<h2>{{ __($title ?? 'Товары') }}</h2>
|
||||
@if (!empty($description))
|
||||
<p>{{ $description }}</p>
|
||||
<p>{{ __($description) }}</p>
|
||||
@endif
|
||||
</div>
|
||||
|
||||
@if ($items->isEmpty())
|
||||
<div class="pc-card">{{ $emptyText ?? 'Пока нет товаров.' }}</div>
|
||||
<div class="pc-card">{{ __($emptyText ?? 'Пока нет товаров.') }}</div>
|
||||
@else
|
||||
<div class="pc-product-carousel" data-product-carousel>
|
||||
<button class="pc-product-carousel-btn is-prev" type="button" data-product-carousel-prev aria-label="Предыдущие товары">‹</button>
|
||||
<button class="pc-product-carousel-btn is-prev" type="button" data-product-carousel-prev aria-label="{{ __('Предыдущие товары') }}">‹</button>
|
||||
<div class="pc-product-carousel-track" data-product-carousel-track>
|
||||
@foreach ($items as $product)
|
||||
<div class="pc-product-carousel-item">
|
||||
@@ -22,7 +22,7 @@
|
||||
</div>
|
||||
@endforeach
|
||||
</div>
|
||||
<button class="pc-product-carousel-btn is-next" type="button" data-product-carousel-next aria-label="Следующие товары">›</button>
|
||||
<button class="pc-product-carousel-btn is-next" type="button" data-product-carousel-next aria-label="{{ __('Следующие товары') }}">›</button>
|
||||
</div>
|
||||
@endif
|
||||
</section>
|
||||
|
||||
@@ -3,24 +3,24 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Личный кабинет', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Личный кабинет'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Личный кабинет</h2>
|
||||
<p>Управляйте данными профиля и просматривайте историю заказов.</p>
|
||||
<h2>{{ __('Личный кабинет') }}</h2>
|
||||
<p>{{ __('Управляйте данными профиля и просматривайте историю заказов.') }}</p>
|
||||
</div>
|
||||
|
||||
<div class="pc-grid pc-grid-2">
|
||||
<div class="pc-card">
|
||||
<form class="pc-form" method="post" action="{{ route('account.update') }}">
|
||||
@csrf
|
||||
<h3>Данные аккаунта</h3>
|
||||
<h3>{{ __('Данные аккаунта') }}</h3>
|
||||
<label>
|
||||
Имя
|
||||
{{ __('Имя') }}
|
||||
<input type="text" name="name" value="{{ old('name', $user->name) }}" required>
|
||||
</label>
|
||||
<label>
|
||||
@@ -28,25 +28,25 @@
|
||||
<input type="email" name="email" value="{{ old('email', $user->email) }}" required>
|
||||
</label>
|
||||
<div class="pc-product-actions">
|
||||
<button class="pc-btn primary" type="submit">Сохранить</button>
|
||||
<button class="pc-btn primary" type="submit">{{ __('Сохранить') }}</button>
|
||||
</div>
|
||||
</form>
|
||||
<form method="post" action="{{ route('logout') }}">
|
||||
@csrf
|
||||
<button class="pc-btn ghost" type="submit">Выйти</button>
|
||||
<button class="pc-btn ghost" type="submit">{{ __('Выйти') }}</button>
|
||||
</form>
|
||||
</div>
|
||||
|
||||
<div class="pc-card">
|
||||
<h3>Мои заказы</h3>
|
||||
<h3>{{ __('Мои заказы') }}</h3>
|
||||
@if ($orders->isEmpty())
|
||||
<p>Пока нет заказов.</p>
|
||||
<a class="pc-btn ghost" href="{{ route('catalog.index') }}">Перейти в каталог</a>
|
||||
<p>{{ __('Пока нет заказов.') }}</p>
|
||||
<a class="pc-btn ghost" href="{{ route('catalog.index') }}">{{ __('Перейти в каталог') }}</a>
|
||||
@else
|
||||
<div class="pc-account-orders">
|
||||
@foreach ($orders as $order)
|
||||
<a class="pc-account-order" href="{{ route('account.orders.show', $order) }}">
|
||||
<span>Заказ #{{ $order->id }}</span>
|
||||
<span>{{ __('Заказ #:number', ['number' => $order->id]) }}</span>
|
||||
<strong>{{ number_format($order->total, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>
|
||||
</a>
|
||||
@endforeach
|
||||
|
||||
@@ -3,15 +3,15 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Вход', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Вход'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section pc-auth-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Вход</h2>
|
||||
<p>Введите email и пароль для доступа к заказам и профилю.</p>
|
||||
<h2>{{ __('Вход') }}</h2>
|
||||
<p>{{ __('Введите email и пароль для доступа к заказам и профилю.') }}</p>
|
||||
</div>
|
||||
|
||||
<form class="pc-card pc-form pc-auth-form" method="post" action="{{ route('login.attempt') }}">
|
||||
@@ -21,20 +21,20 @@
|
||||
<input type="email" name="email" value="{{ old('email') }}" required>
|
||||
</label>
|
||||
<label>
|
||||
Пароль
|
||||
{{ __('Пароль') }}
|
||||
<input type="password" name="password" required>
|
||||
</label>
|
||||
<label>
|
||||
Капча: решите пример {{ $captchaQuestion }}
|
||||
{{ __('Капча: решите пример :question', ['question' => $captchaQuestion]) }}
|
||||
<input type="text" name="captcha" inputmode="numeric" autocomplete="off" required>
|
||||
</label>
|
||||
<label class="pc-checkbox">
|
||||
<input type="checkbox" name="remember" value="1" @checked(old('remember'))>
|
||||
<span>Запомнить меня</span>
|
||||
<span>{{ __('Запомнить меня') }}</span>
|
||||
</label>
|
||||
<div class="pc-product-actions">
|
||||
<button class="pc-btn primary" type="submit">Войти</button>
|
||||
<a class="pc-btn ghost" href="{{ route('register') }}">Создать аккаунт</a>
|
||||
<button class="pc-btn primary" type="submit">{{ __('Войти') }}</button>
|
||||
<a class="pc-btn ghost" href="{{ route('register') }}">{{ __('Создать аккаунт') }}</a>
|
||||
</div>
|
||||
</form>
|
||||
</section>
|
||||
|
||||
@@ -3,21 +3,21 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Регистрация', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Регистрация'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section pc-auth-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Регистрация</h2>
|
||||
<p>Создайте аккаунт, чтобы отслеживать заказы и сохранять избранное.</p>
|
||||
<h2>{{ __('Регистрация') }}</h2>
|
||||
<p>{{ __('Создайте аккаунт, чтобы отслеживать заказы и сохранять избранное.') }}</p>
|
||||
</div>
|
||||
|
||||
<form class="pc-card pc-form pc-auth-form" method="post" action="{{ route('register.store') }}">
|
||||
@csrf
|
||||
<label>
|
||||
Имя
|
||||
{{ __('Имя') }}
|
||||
<input type="text" name="name" value="{{ old('name') }}" required>
|
||||
</label>
|
||||
<label>
|
||||
@@ -25,20 +25,20 @@
|
||||
<input type="email" name="email" value="{{ old('email') }}" required>
|
||||
</label>
|
||||
<label>
|
||||
Пароль
|
||||
{{ __('Пароль') }}
|
||||
<input type="password" name="password" required>
|
||||
</label>
|
||||
<label>
|
||||
Подтверждение пароля
|
||||
{{ __('Подтверждение пароля') }}
|
||||
<input type="password" name="password_confirmation" required>
|
||||
</label>
|
||||
<label>
|
||||
Капча: решите пример {{ $captchaQuestion }}
|
||||
{{ __('Капча: решите пример :question', ['question' => $captchaQuestion]) }}
|
||||
<input type="text" name="captcha" inputmode="numeric" autocomplete="off" required>
|
||||
</label>
|
||||
<div class="pc-product-actions">
|
||||
<button class="pc-btn primary" type="submit">Зарегистрироваться</button>
|
||||
<a class="pc-btn ghost" href="{{ route('login') }}">Уже есть аккаунт</a>
|
||||
<button class="pc-btn primary" type="submit">{{ __('Зарегистрироваться') }}</button>
|
||||
<a class="pc-btn ghost" href="{{ route('login') }}">{{ __('Уже есть аккаунт') }}</a>
|
||||
</div>
|
||||
</form>
|
||||
</section>
|
||||
|
||||
@@ -3,21 +3,21 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Корзина', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Корзина'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Товары в корзине</h2>
|
||||
<h2>{{ __('Товары в корзине') }}</h2>
|
||||
</div>
|
||||
|
||||
@if ($items->isEmpty())
|
||||
<div class="pc-card">
|
||||
<h3>Корзина пустая</h3>
|
||||
<p>Добавьте товары из каталога, чтобы оформить заказ.</p>
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">Перейти в каталог</a>
|
||||
<h3>{{ __('Корзина пустая') }}</h3>
|
||||
<p>{{ __('Добавьте товары из каталога, чтобы оформить заказ.') }}</p>
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">{{ __('Перейти в каталог') }}</a>
|
||||
</div>
|
||||
@else
|
||||
<div class="pc-cart-layout">
|
||||
@@ -38,13 +38,13 @@
|
||||
@csrf
|
||||
@method('patch')
|
||||
<input type="number" name="quantity" min="1" max="{{ max(1, $product->stock) }}" value="{{ $item['quantity'] }}">
|
||||
<button class="pc-btn ghost" type="submit">Обновить</button>
|
||||
<button class="pc-btn ghost" type="submit">{{ __('Обновить') }}</button>
|
||||
</form>
|
||||
<strong class="pc-cart-subtotal">{{ number_format($item['subtotal'], 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>
|
||||
<form method="post" action="{{ route('cart.remove', $product) }}" data-preserve-scroll="true">
|
||||
@csrf
|
||||
@method('delete')
|
||||
<button class="pc-btn ghost" type="submit">Удалить</button>
|
||||
<button class="pc-btn ghost" type="submit">{{ __('Удалить') }}</button>
|
||||
</form>
|
||||
</div>
|
||||
</article>
|
||||
@@ -52,16 +52,16 @@
|
||||
</div>
|
||||
|
||||
<aside class="pc-card pc-cart-summary">
|
||||
<h3>Итого</h3>
|
||||
<h3>{{ __('Итого') }}</h3>
|
||||
<div class="pc-cart-summary-row">
|
||||
<span>Товаров</span>
|
||||
<span>{{ __('Товаров') }}</span>
|
||||
<strong>{{ $itemsCount }}</strong>
|
||||
</div>
|
||||
<div class="pc-cart-summary-row">
|
||||
<span>Сумма</span>
|
||||
<span>{{ __('Сумма') }}</span>
|
||||
<strong>{{ number_format($total, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>
|
||||
</div>
|
||||
<a class="pc-btn primary" href="{{ route('checkout.show') }}">Перейти к оформлению</a>
|
||||
<a class="pc-btn primary" href="{{ route('checkout.show') }}">{{ __('Перейти к оформлению') }}</a>
|
||||
</aside>
|
||||
</div>
|
||||
@endif
|
||||
|
||||
@@ -9,15 +9,15 @@
|
||||
'@type' => 'ListItem',
|
||||
'position' => $index + 1,
|
||||
'url' => route('catalog.category', $category),
|
||||
'name' => $category->name,
|
||||
'name' => __($category->name),
|
||||
])
|
||||
->all();
|
||||
$catalogSchema = [
|
||||
'@context' => 'https://schema.org',
|
||||
'@type' => 'CollectionPage',
|
||||
'name' => 'Каталог товаров',
|
||||
'name' => __('Каталог товаров'),
|
||||
'url' => route('catalog.index'),
|
||||
'description' => 'Каталог компьютерных комплектующих и техники.',
|
||||
'description' => __('Каталог компьютерных комплектующих и техники.'),
|
||||
'mainEntity' => [
|
||||
'@type' => 'ItemList',
|
||||
'numberOfItems' => count($catalogCategoryList),
|
||||
@@ -25,14 +25,14 @@
|
||||
],
|
||||
];
|
||||
@endphp
|
||||
@section('meta_title', $searchQuery !== '' ? "Поиск: {$searchQuery}" : 'Каталог товаров')
|
||||
@section('meta_title', $searchQuery !== '' ? __('Поиск: :query', ['query' => $searchQuery]) : __('Каталог товаров'))
|
||||
@section(
|
||||
'meta_description',
|
||||
$searchQuery !== ''
|
||||
? "Результаты поиска по запросу «{$searchQuery}». Подберите нужные комплектующие по наименованию."
|
||||
: 'Каталог компьютерных комплектующих: процессоры, материнские платы, видеокарты, память, накопители и ноутбуки.'
|
||||
? __('Результаты поиска по запросу «:query». Подберите нужные комплектующие по наименованию.', ['query' => $searchQuery])
|
||||
: __('Каталог компьютерных комплектующих: процессоры, материнские платы, видеокарты, память, накопители и ноутбуки.')
|
||||
)
|
||||
@section('meta_keywords', 'каталог комплектующих, поиск товаров, процессоры, материнские платы, видеокарты')
|
||||
@section('meta_keywords', __('каталог комплектующих, поиск товаров, процессоры, материнские платы, видеокарты'))
|
||||
@section('meta_canonical', route('catalog.index'))
|
||||
@section('meta_robots', $hasCatalogQuery ? 'noindex,follow' : 'index,follow')
|
||||
|
||||
@@ -45,24 +45,24 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Каталог', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Каталог'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Категории товаров</h2>
|
||||
<h2>{{ __('Категории товаров') }}</h2>
|
||||
</div>
|
||||
|
||||
<div class="pc-grid pc-grid-4 pc-category-grid">
|
||||
@forelse ($categories as $category)
|
||||
<a class="pc-card pc-category-card pc-category-link" href="{{ route('catalog.category', $category) }}">
|
||||
<div class="pc-category-image" role="img" aria-label="{{ $category->name }}"></div>
|
||||
<h3 class="pc-category-title">{{ $category->name }}</h3>
|
||||
<div class="pc-category-image" role="img" aria-label="{{ __($category->name) }}"></div>
|
||||
<h3 class="pc-category-title">{{ __($category->name) }}</h3>
|
||||
</a>
|
||||
@empty
|
||||
<div class="pc-card">Категории пока не добавлены.</div>
|
||||
<div class="pc-card">{{ __('Категории пока не добавлены.') }}</div>
|
||||
@endforelse
|
||||
</div>
|
||||
</section>
|
||||
@@ -71,16 +71,16 @@
|
||||
<section class="pc-section">
|
||||
<div class="pc-category-toolbar">
|
||||
<div class="pc-section-title">
|
||||
<h2>Результаты по запросу: "{{ request('q') }}"</h2>
|
||||
<h2>{{ __('Результаты по запросу: ":query"', ['query' => request('q')]) }}</h2>
|
||||
</div>
|
||||
<p class="pc-muted">Найдено: <strong>{{ $products->total() }}</strong></p>
|
||||
<p class="pc-muted">{{ __('Найдено:') }} <strong>{{ $products->total() }}</strong></p>
|
||||
</div>
|
||||
|
||||
<div class="pc-products-grid">
|
||||
@forelse ($products as $product)
|
||||
@include('partials.product-card', ['product' => $product])
|
||||
@empty
|
||||
<div class="pc-card">По вашему запросу ничего не найдено.</div>
|
||||
<div class="pc-card">{{ __('По вашему запросу ничего не найдено.') }}</div>
|
||||
@endforelse
|
||||
</div>
|
||||
|
||||
|
||||
@@ -1,6 +1,8 @@
|
||||
@extends('layouts.shop')
|
||||
|
||||
@php
|
||||
$translatedCategoryName = __($category->name);
|
||||
$translatedCategoryDescription = $category->description ? __($category->description) : __('Категория товаров :category', ['category' => $translatedCategoryName]);
|
||||
$hasSeoFilters = request()->filled('q')
|
||||
|| request()->filled('sort')
|
||||
|| request()->filled('page')
|
||||
@@ -24,9 +26,9 @@
|
||||
$categorySchema = [
|
||||
'@context' => 'https://schema.org',
|
||||
'@type' => 'CollectionPage',
|
||||
'name' => $category->name,
|
||||
'name' => $translatedCategoryName,
|
||||
'url' => route('catalog.category', $category),
|
||||
'description' => $category->description ?: 'Категория товаров ' . $category->name,
|
||||
'description' => $translatedCategoryDescription,
|
||||
'mainEntity' => [
|
||||
'@type' => 'ItemList',
|
||||
'numberOfItems' => $products->total(),
|
||||
@@ -35,9 +37,9 @@
|
||||
];
|
||||
@endphp
|
||||
|
||||
@section('meta_title', $category->name)
|
||||
@section('meta_description', ($category->description ?: 'Товары категории ' . $category->name . '.') . ' Фильтры и сортировка для быстрого подбора.')
|
||||
@section('meta_keywords', $category->name . ', комплектующие, купить, фильтры товаров')
|
||||
@section('meta_title', $translatedCategoryName)
|
||||
@section('meta_description', __('Товары категории :category. Фильтры и сортировка для быстрого подбора.', ['category' => $translatedCategoryName]))
|
||||
@section('meta_keywords', __(':category, комплектующие, купить, фильтры товаров', ['category' => $translatedCategoryName]))
|
||||
@section('meta_canonical', route('catalog.category', $category))
|
||||
@section('meta_robots', $hasSeoFilters ? 'noindex,follow' : 'index,follow')
|
||||
|
||||
@@ -50,15 +52,15 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Каталог', 'url' => route('catalog.index')],
|
||||
['label' => $category->name, 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Каталог'), 'url' => route('catalog.index')],
|
||||
['label' => $translatedCategoryName, 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section pc-category-page">
|
||||
<div class="pc-section-title">
|
||||
<h2>{{ $category->name }}</h2>
|
||||
<h2>{{ $translatedCategoryName }}</h2>
|
||||
</div>
|
||||
|
||||
@php
|
||||
@@ -69,7 +71,7 @@
|
||||
if (request()->filled('price_from') || request()->filled('price_to')) {
|
||||
$priceFromLabel = trim((string) request('price_from', ''));
|
||||
$priceToLabel = trim((string) request('price_to', ''));
|
||||
$activeFilters->push("Цена: {$priceFromLabel} - {$priceToLabel}");
|
||||
$activeFilters->push(__('Цена: :from - :to', ['from' => $priceFromLabel, 'to' => $priceToLabel]));
|
||||
}
|
||||
|
||||
foreach ((array) ($filters ?? []) as $filter) {
|
||||
@@ -90,12 +92,16 @@
|
||||
|
||||
$fromLabel = trim((string) request($fromParam, ''));
|
||||
$toLabel = trim((string) request($toParam, ''));
|
||||
$activeFilters->push(($filter['label'] ?? $rangeKey) . ": {$fromLabel} - {$toLabel}");
|
||||
$activeFilters->push(__(':label: :from - :to', [
|
||||
'label' => __($filter['label'] ?? $rangeKey),
|
||||
'from' => $fromLabel,
|
||||
'to' => $toLabel,
|
||||
]));
|
||||
}
|
||||
@endphp
|
||||
|
||||
<div class="pc-category-toolbar">
|
||||
<p class="pc-muted">Найдено товаров: <strong>{{ $products->total() }}</strong></p>
|
||||
<p class="pc-muted">{{ __('Найдено товаров:') }} <strong>{{ $products->total() }}</strong></p>
|
||||
<div class="pc-category-toolbar-controls">
|
||||
<form class="pc-sort-form" method="get">
|
||||
@foreach ((array) ($appliedFilters ?? []) as $key => $value)
|
||||
@@ -124,12 +130,12 @@
|
||||
@if (request()->filled('q'))
|
||||
<input type="hidden" name="q" value="{{ request('q') }}">
|
||||
@endif
|
||||
<label for="sort">Сортировка:</label>
|
||||
<label for="sort">{{ __('Сортировка:') }}</label>
|
||||
<select id="sort" name="sort" onchange="this.form.submit()">
|
||||
<option value="newest" @selected($sort === 'newest')>Сначала новые</option>
|
||||
<option value="price_asc" @selected($sort === 'price_asc')>Сначала дешевле</option>
|
||||
<option value="price_desc" @selected($sort === 'price_desc')>Сначала дороже</option>
|
||||
<option value="name_asc" @selected($sort === 'name_asc')>По названию</option>
|
||||
<option value="newest" @selected($sort === 'newest')>{{ __('Сначала новые') }}</option>
|
||||
<option value="price_asc" @selected($sort === 'price_asc')>{{ __('Сначала дешевле') }}</option>
|
||||
<option value="price_desc" @selected($sort === 'price_desc')>{{ __('Сначала дороже') }}</option>
|
||||
<option value="name_asc" @selected($sort === 'name_asc')>{{ __('По названию') }}</option>
|
||||
</select>
|
||||
</form>
|
||||
<button
|
||||
@@ -142,7 +148,7 @@
|
||||
<svg viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M4 6h16v2H4V6zm3 5h10v2H7v-2zm3 5h4v2h-4v-2z"></path>
|
||||
</svg>
|
||||
<span>Фильтр</span>
|
||||
<span>{{ __('Фильтр') }}</span>
|
||||
@if ($activeFilters->isNotEmpty())
|
||||
<span class="pc-filter-toggle-count">{{ $activeFilters->count() }}</span>
|
||||
@endif
|
||||
@@ -161,7 +167,7 @@
|
||||
<aside class="pc-filters">
|
||||
<div id="pc-category-filters" class="pc-filter-details {{ $activeFilters->isNotEmpty() ? 'is-open' : '' }}">
|
||||
<form method="get">
|
||||
<div class="pc-filter-title">Фильтры</div>
|
||||
<div class="pc-filter-title">{{ __('Фильтры') }}</div>
|
||||
@if ($sort !== 'newest')
|
||||
<input type="hidden" name="sort" value="{{ $sort }}">
|
||||
@endif
|
||||
@@ -169,7 +175,7 @@
|
||||
<input type="hidden" name="q" value="{{ request('q') }}">
|
||||
@endif
|
||||
<label class="pc-filter-block">
|
||||
<span>Цена</span>
|
||||
<span>{{ __('Цена') }}</span>
|
||||
<div class="pc-range-fields">
|
||||
<input
|
||||
type="number"
|
||||
@@ -178,7 +184,7 @@
|
||||
value="{{ $priceFilter['from'] ?? '' }}"
|
||||
@if (!empty($priceFilter['min'])) min="{{ $priceFilter['min'] }}" @endif
|
||||
@if (!empty($priceFilter['max'])) max="{{ $priceFilter['max'] }}" @endif
|
||||
placeholder="От"
|
||||
placeholder="{{ __('От') }}"
|
||||
>
|
||||
<input
|
||||
type="number"
|
||||
@@ -187,7 +193,7 @@
|
||||
value="{{ $priceFilter['to'] ?? '' }}"
|
||||
@if (!empty($priceFilter['min'])) min="{{ $priceFilter['min'] }}" @endif
|
||||
@if (!empty($priceFilter['max'])) max="{{ $priceFilter['max'] }}" @endif
|
||||
placeholder="До"
|
||||
placeholder="{{ __('До') }}"
|
||||
>
|
||||
</div>
|
||||
</label>
|
||||
@@ -200,7 +206,7 @@
|
||||
@continue($filterKey === '')
|
||||
@if ($isRangeFilter)
|
||||
<label class="pc-filter-block">
|
||||
<span>{{ $filter['label'] }}</span>
|
||||
<span>{{ __($filter['label']) }}</span>
|
||||
<div class="pc-range-fields">
|
||||
<input
|
||||
type="number"
|
||||
@@ -209,7 +215,7 @@
|
||||
value="{{ $rangeData['from'] ?? '' }}"
|
||||
@if (!empty($rangeData['min'])) min="{{ $rangeData['min'] }}" @endif
|
||||
@if (!empty($rangeData['max'])) max="{{ $rangeData['max'] }}" @endif
|
||||
placeholder="От"
|
||||
placeholder="{{ __('От') }}"
|
||||
>
|
||||
<input
|
||||
type="number"
|
||||
@@ -218,33 +224,33 @@
|
||||
value="{{ $rangeData['to'] ?? '' }}"
|
||||
@if (!empty($rangeData['min'])) min="{{ $rangeData['min'] }}" @endif
|
||||
@if (!empty($rangeData['max'])) max="{{ $rangeData['max'] }}" @endif
|
||||
placeholder="До"
|
||||
placeholder="{{ __('До') }}"
|
||||
>
|
||||
</div>
|
||||
</label>
|
||||
@else
|
||||
<label class="pc-filter-block">
|
||||
<span>{{ $filter['label'] }}</span>
|
||||
<span>{{ __($filter['label']) }}</span>
|
||||
<select name="filters[{{ $filterKey }}]">
|
||||
<option value="">Все</option>
|
||||
<option value="">{{ __('Все') }}</option>
|
||||
@foreach ($filterOptions[$filterKey] ?? [] as $option)
|
||||
@php
|
||||
$optionValue = trim((string) $option);
|
||||
@endphp
|
||||
@continue($optionValue === '')
|
||||
<option value="{{ $optionValue }}" @selected(($appliedFilters[$filterKey] ?? '') === $optionValue)>
|
||||
{{ $optionValue }}
|
||||
{{ __($optionValue) }}
|
||||
</option>
|
||||
@endforeach
|
||||
</select>
|
||||
</label>
|
||||
@endif
|
||||
@empty
|
||||
<p class="pc-muted">Для этой категории фильтры пока не заданы.</p>
|
||||
<p class="pc-muted">{{ __('Для этой категории фильтры пока не заданы.') }}</p>
|
||||
@endforelse
|
||||
<div class="pc-filter-actions">
|
||||
<button type="submit" class="pc-btn primary">Показать</button>
|
||||
<a class="pc-btn ghost" href="{{ route('catalog.category', $category) }}">Сбросить</a>
|
||||
<button type="submit" class="pc-btn primary">{{ __('Показать') }}</button>
|
||||
<a class="pc-btn ghost" href="{{ route('catalog.category', $category) }}">{{ __('Сбросить') }}</a>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
@@ -254,7 +260,7 @@
|
||||
@forelse ($products as $product)
|
||||
@include('partials.product-card', ['product' => $product])
|
||||
@empty
|
||||
<div class="pc-card">Пока нет товаров в этой категории.</div>
|
||||
<div class="pc-card">{{ __('Пока нет товаров в этой категории.') }}</div>
|
||||
@endforelse
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@@ -3,22 +3,22 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Корзина', 'url' => route('cart.index')],
|
||||
['label' => 'Данные получателя', 'url' => route('checkout.show')],
|
||||
['label' => 'Реквизиты для оплаты', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Корзина'), 'url' => route('cart.index')],
|
||||
['label' => __('Данные получателя'), 'url' => route('checkout.show')],
|
||||
['label' => __('Реквизиты для оплаты'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Реквизиты для оплаты</h2>
|
||||
<p>Переведите сумму заказа по реквизитам ниже и подтвердите оформление.</p>
|
||||
<h2>{{ __('Реквизиты для оплаты') }}</h2>
|
||||
<p>{{ __('Переведите сумму заказа по реквизитам ниже и подтвердите оформление.') }}</p>
|
||||
</div>
|
||||
|
||||
<div class="pc-cart-layout">
|
||||
<div class="pc-card">
|
||||
<h3>Данные получателя</h3>
|
||||
<h3>{{ __('Данные получателя') }}</h3>
|
||||
<p><strong>{{ $customer['customer_name'] }}</strong></p>
|
||||
<p>{{ $customer['email'] }}</p>
|
||||
@if (!empty($customer['phone']))
|
||||
@@ -26,16 +26,16 @@
|
||||
@endif
|
||||
<p>{{ $customer['address'] }}</p>
|
||||
@if (!empty($customer['comment']))
|
||||
<p>Комментарий: {{ $customer['comment'] }}</p>
|
||||
<p>{{ __('Комментарий:') }} {{ $customer['comment'] }}</p>
|
||||
@endif
|
||||
|
||||
<div class="pc-product-actions">
|
||||
<a class="pc-btn ghost" href="{{ route('checkout.show') }}">Изменить данные</a>
|
||||
<a class="pc-btn ghost" href="{{ route('checkout.show') }}">{{ __('Изменить данные') }}</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<aside class="pc-card pc-cart-summary">
|
||||
<h3>Ваш заказ</h3>
|
||||
<h3>{{ __('Ваш заказ') }}</h3>
|
||||
<div class="pc-account-orders">
|
||||
@foreach ($items as $item)
|
||||
<div class="pc-account-order">
|
||||
@@ -45,11 +45,11 @@
|
||||
@endforeach
|
||||
</div>
|
||||
<div class="pc-cart-summary-row">
|
||||
<span>Товаров</span>
|
||||
<span>{{ __('Товаров') }}</span>
|
||||
<strong>{{ $itemsCount }}</strong>
|
||||
</div>
|
||||
<div class="pc-cart-summary-row">
|
||||
<span>Итого</span>
|
||||
<span>{{ __('Итого') }}</span>
|
||||
<strong>{{ number_format($total, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>
|
||||
</div>
|
||||
</aside>
|
||||
@@ -57,13 +57,13 @@
|
||||
|
||||
@include('partials.payment-requisites', [
|
||||
'amount' => $total,
|
||||
'purpose' => 'Номер заказа будет присвоен после подтверждения',
|
||||
'purpose' => __('Номер заказа будет присвоен после подтверждения'),
|
||||
'showHelp' => true,
|
||||
])
|
||||
|
||||
<form method="post" action="{{ route('checkout.store') }}">
|
||||
@csrf
|
||||
<button class="pc-btn primary" type="submit">Подтвердить оформление заказа</button>
|
||||
<button class="pc-btn primary" type="submit">{{ __('Подтвердить оформление заказа') }}</button>
|
||||
</form>
|
||||
</section>
|
||||
@endsection
|
||||
|
||||
@@ -3,28 +3,28 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Заказ оформлен', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Заказ оформлен'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-card">
|
||||
<h2>Заказ №{{ $order->id }} успешно оформлен</h2>
|
||||
<p>Мы приняли заказ в обработку. Статус заказа: <strong>{{ $order->status }}</strong>.</p>
|
||||
<p>Способ оплаты: <strong>{{ $order->payment_method_label }}</strong>.</p>
|
||||
<p>Сумма заказа: <strong>{{ number_format($order->total, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>.</p>
|
||||
<h2>{{ __('Заказ №:number успешно оформлен', ['number' => $order->id]) }}</h2>
|
||||
<p>{{ __('Мы приняли заказ в обработку. Статус заказа:') }} <strong>{{ $order->status_label }}</strong>.</p>
|
||||
<p>{{ __('Способ оплаты:') }} <strong>{{ $order->payment_method_label }}</strong>.</p>
|
||||
<p>{{ __('Сумма заказа:') }} <strong>{{ number_format($order->total, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>.</p>
|
||||
|
||||
@include('partials.payment-requisites', [
|
||||
'amount' => $order->total,
|
||||
'purpose' => 'Заказ #' . $order->id,
|
||||
'purpose' => __('Заказ #:number', ['number' => $order->id]),
|
||||
'showHelp' => true,
|
||||
])
|
||||
|
||||
<div class="pc-product-actions">
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">Продолжить покупки</a>
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">{{ __('Продолжить покупки') }}</a>
|
||||
@auth
|
||||
<a class="pc-btn ghost" href="{{ route('account.orders.show', $order) }}">Открыть заказ</a>
|
||||
<a class="pc-btn ghost" href="{{ route('account.orders.show', $order) }}">{{ __('Открыть заказ') }}</a>
|
||||
@endauth
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@@ -3,23 +3,23 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Корзина', 'url' => route('cart.index')],
|
||||
['label' => 'Данные получателя', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Корзина'), 'url' => route('cart.index')],
|
||||
['label' => __('Данные получателя'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Данные получателя</h2>
|
||||
<p>Заполните контакты и перейдите на страницу с реквизитами для оплаты.</p>
|
||||
<h2>{{ __('Данные получателя') }}</h2>
|
||||
<p>{{ __('Заполните контакты и перейдите на страницу с реквизитами для оплаты.') }}</p>
|
||||
</div>
|
||||
|
||||
<div class="pc-cart-layout">
|
||||
<form class="pc-card pc-form" method="post" action="{{ route('checkout.prepare') }}">
|
||||
@csrf
|
||||
<label>
|
||||
Имя получателя
|
||||
{{ __('Имя получателя') }}
|
||||
<input type="text" name="customer_name" value="{{ old('customer_name', session('checkout.customer.customer_name', auth()->user()->name ?? '')) }}" required>
|
||||
</label>
|
||||
<label>
|
||||
@@ -27,22 +27,22 @@
|
||||
<input type="email" name="email" value="{{ old('email', session('checkout.customer.email', auth()->user()->email ?? '')) }}" required>
|
||||
</label>
|
||||
<label>
|
||||
Телефон
|
||||
{{ __('Телефон') }}
|
||||
<input type="text" name="phone" value="{{ old('phone', session('checkout.customer.phone')) }}">
|
||||
</label>
|
||||
<label>
|
||||
Адрес доставки
|
||||
{{ __('Адрес доставки') }}
|
||||
<textarea name="address" required>{{ old('address', session('checkout.customer.address')) }}</textarea>
|
||||
</label>
|
||||
<label>
|
||||
Комментарий к заказу
|
||||
{{ __('Комментарий к заказу') }}
|
||||
<textarea name="comment">{{ old('comment', session('checkout.customer.comment')) }}</textarea>
|
||||
</label>
|
||||
<button class="pc-btn primary" type="submit">Перейти к реквизитам</button>
|
||||
<button class="pc-btn primary" type="submit">{{ __('Перейти к реквизитам') }}</button>
|
||||
</form>
|
||||
|
||||
<aside class="pc-card pc-cart-summary">
|
||||
<h3>Ваш заказ</h3>
|
||||
<h3>{{ __('Ваш заказ') }}</h3>
|
||||
<div class="pc-account-orders">
|
||||
@foreach ($items as $item)
|
||||
<div class="pc-account-order">
|
||||
@@ -52,11 +52,11 @@
|
||||
@endforeach
|
||||
</div>
|
||||
<div class="pc-cart-summary-row">
|
||||
<span>Товаров</span>
|
||||
<span>{{ __('Товаров') }}</span>
|
||||
<strong>{{ $itemsCount }}</strong>
|
||||
</div>
|
||||
<div class="pc-cart-summary-row">
|
||||
<span>Итого</span>
|
||||
<span>{{ __('Итого') }}</span>
|
||||
<strong>{{ number_format($total, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>
|
||||
</div>
|
||||
</aside>
|
||||
|
||||
@@ -3,28 +3,28 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Сравнение', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Сравнение'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Сравнение товаров</h2>
|
||||
<h2>{{ __('Сравнение товаров') }}</h2>
|
||||
</div>
|
||||
|
||||
@if ($products->isEmpty())
|
||||
<div class="pc-card">
|
||||
<h3>Список сравнения пуст</h3>
|
||||
<p>Добавьте товары в сравнение из карточек каталога.</p>
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">Перейти в каталог</a>
|
||||
<h3>{{ __('Список сравнения пуст') }}</h3>
|
||||
<p>{{ __('Добавьте товары в сравнение из карточек каталога.') }}</p>
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">{{ __('Перейти в каталог') }}</a>
|
||||
</div>
|
||||
@else
|
||||
<div class="pc-compare-actions">
|
||||
<form method="post" action="{{ route('compare.clear') }}" data-preserve-scroll="true">
|
||||
@csrf
|
||||
@method('delete')
|
||||
<button class="pc-btn ghost" type="submit">Очистить сравнение</button>
|
||||
<button class="pc-btn ghost" type="submit">{{ __('Очистить сравнение') }}</button>
|
||||
</form>
|
||||
</div>
|
||||
|
||||
@@ -40,7 +40,7 @@
|
||||
<table class="pc-compare-table">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Характеристика</th>
|
||||
<th>{{ __('Характеристика') }}</th>
|
||||
@foreach ($products as $product)
|
||||
<th>{{ $product->name }}</th>
|
||||
@endforeach
|
||||
@@ -49,9 +49,9 @@
|
||||
<tbody>
|
||||
@foreach ($specKeys as $key)
|
||||
<tr>
|
||||
<th>{{ $specLabels[$key] ?? $key }}</th>
|
||||
<th>{{ __($specLabels[$key] ?? $key) }}</th>
|
||||
@foreach ($products as $product)
|
||||
<td>{{ data_get($product->specs, $key, '—') }}</td>
|
||||
<td>{{ __(strval(data_get($product->specs, $key, '—'))) }}</td>
|
||||
@endforeach
|
||||
</tr>
|
||||
@endforeach
|
||||
|
||||
@@ -3,21 +3,21 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Избранное', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Избранное'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Избранные товары</h2>
|
||||
<h2>{{ __('Избранные товары') }}</h2>
|
||||
</div>
|
||||
|
||||
@if ($products->isEmpty())
|
||||
<div class="pc-card">
|
||||
<h3>Список пуст</h3>
|
||||
<p>Добавьте товары в избранное из каталога или со страницы товара.</p>
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">Перейти в каталог</a>
|
||||
<h3>{{ __('Список пуст') }}</h3>
|
||||
<p>{{ __('Добавьте товары в избранное из каталога или со страницы товара.') }}</p>
|
||||
<a class="pc-btn primary" href="{{ route('catalog.index') }}">{{ __('Перейти в каталог') }}</a>
|
||||
</div>
|
||||
@else
|
||||
<div class="pc-products-grid">
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
@extends('layouts.shop')
|
||||
|
||||
@section('meta_title', 'Главная')
|
||||
@section('meta_description', 'Интернет-магазин комплектующих для ПК: процессоры, материнские платы, видеокарты, ноутбуки и периферия.')
|
||||
@section('meta_keywords', 'интернет-магазин пк, комплектующие, процессоры, видеокарты, ноутбуки')
|
||||
@section('meta_title', __('Главная'))
|
||||
@section('meta_description', __('Интернет-магазин комплектующих для ПК: процессоры, материнские платы, видеокарты, ноутбуки и периферия.'))
|
||||
@section('meta_keywords', __('интернет-магазин пк, комплектующие, процессоры, видеокарты, ноутбуки'))
|
||||
@section('meta_canonical', route('home'))
|
||||
|
||||
@section('content')
|
||||
@@ -10,62 +10,62 @@
|
||||
@include('partials.home-slider', [
|
||||
'slides' => $leftSlides,
|
||||
'sliderClass' => 'is-main',
|
||||
'fallbackTitle' => 'Собирайте ПК быстрее',
|
||||
'fallbackText' => 'Процессоры, материнские платы, видеокарты, ноутбуки и периферия в одном каталоге.',
|
||||
'fallbackTitle' => __('Собирайте ПК быстрее'),
|
||||
'fallbackText' => __('Процессоры, материнские платы, видеокарты, ноутбуки и периферия в одном каталоге.'),
|
||||
'fallbackUrl' => route('catalog.index'),
|
||||
'fallbackButton' => 'Перейти в каталог',
|
||||
'fallbackButton' => __('Перейти в каталог'),
|
||||
])
|
||||
@include('partials.home-slider', [
|
||||
'slides' => $rightSlides,
|
||||
'sliderClass' => 'is-side',
|
||||
'fallbackTitle' => 'Доставка и оплата',
|
||||
'fallbackText' => 'Узнайте сроки доставки и способы оплаты заказа.',
|
||||
'fallbackTitle' => __('Доставка и оплата'),
|
||||
'fallbackText' => __('Узнайте сроки доставки и способы оплаты заказа.'),
|
||||
'fallbackUrl' => route('pages.shipping-payment'),
|
||||
'fallbackButton' => 'Подробнее',
|
||||
'fallbackButton' => __('Подробнее'),
|
||||
])
|
||||
</section>
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Категории</h2>
|
||||
<h2>{{ __('Категории') }}</h2>
|
||||
</div>
|
||||
<div class="pc-grid pc-grid-4 pc-category-grid">
|
||||
@foreach ($categories as $category)
|
||||
<a class="pc-card pc-category-card pc-category-link" href="{{ route('catalog.category', $category) }}">
|
||||
<div class="pc-category-image" role="img" aria-label="{{ $category->name }}"></div>
|
||||
<h3 class="pc-category-title">{{ $category->name }}</h3>
|
||||
<div class="pc-category-image" role="img" aria-label="{{ __($category->name) }}"></div>
|
||||
<h3 class="pc-category-title">{{ __($category->name) }}</h3>
|
||||
</a>
|
||||
@endforeach
|
||||
</div>
|
||||
</section>
|
||||
|
||||
@include('partials.product-carousel', [
|
||||
'title' => 'Популярные товары',
|
||||
'title' => __('Популярные товары'),
|
||||
'products' => $featured,
|
||||
'emptyText' => 'Пока нет популярных товаров.',
|
||||
'emptyText' => __('Пока нет популярных товаров.'),
|
||||
])
|
||||
|
||||
@include('partials.product-carousel', [
|
||||
'title' => 'Новые товары',
|
||||
'title' => __('Новые товары'),
|
||||
'products' => $newProducts,
|
||||
'emptyText' => 'Пока нет новых товаров.',
|
||||
'emptyText' => __('Пока нет новых товаров.'),
|
||||
])
|
||||
|
||||
<section class="pc-grid pc-grid-3">
|
||||
<a class="pc-card pc-category-link" href="{{ route('pages.shipping-payment') }}">
|
||||
<div class="pc-card-meta">Сервис</div>
|
||||
<h3>Доставка и оплата</h3>
|
||||
<p>Условия доставки, способы оплаты и сроки отправки.</p>
|
||||
<div class="pc-card-meta">{{ __('Сервис') }}</div>
|
||||
<h3>{{ __('Доставка и оплата') }}</h3>
|
||||
<p>{{ __('Условия доставки, способы оплаты и сроки отправки.') }}</p>
|
||||
</a>
|
||||
<a class="pc-card pc-category-link" href="{{ route('pages.about') }}">
|
||||
<div class="pc-card-meta">Компания</div>
|
||||
<h3>О нас</h3>
|
||||
<p>Чем занимаемся и как помогаем выбрать комплектующие.</p>
|
||||
<div class="pc-card-meta">{{ __('Компания') }}</div>
|
||||
<h3>{{ __('О нас') }}</h3>
|
||||
<p>{{ __('Чем занимаемся и как помогаем выбрать комплектующие.') }}</p>
|
||||
</a>
|
||||
<a class="pc-card pc-category-link" href="{{ route('pages.contacts') }}">
|
||||
<div class="pc-card-meta">Поддержка</div>
|
||||
<h3>Контакты</h3>
|
||||
<p>Свяжитесь с нами для консультации по вашей сборке.</p>
|
||||
<div class="pc-card-meta">{{ __('Поддержка') }}</div>
|
||||
<h3>{{ __('Контакты') }}</h3>
|
||||
<p>{{ __('Свяжитесь с нами для консультации по вашей сборке.') }}</p>
|
||||
</a>
|
||||
</section>
|
||||
@endsection
|
||||
|
||||
@@ -3,22 +3,22 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Личный кабинет', 'url' => route('account')],
|
||||
['label' => 'Заказ #' . $order->id, 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Личный кабинет'), 'url' => route('account')],
|
||||
['label' => __('Заказ #:number', ['number' => $order->id]), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Заказ #{{ $order->id }}</h2>
|
||||
<p>Статус: <strong>{{ $order->status }}</strong></p>
|
||||
<p>Способ оплаты: <strong>{{ $order->payment_method_label }}</strong></p>
|
||||
<h2>{{ __('Заказ #:number', ['number' => $order->id]) }}</h2>
|
||||
<p>{{ __('Статус:') }} <strong>{{ $order->status_label }}</strong></p>
|
||||
<p>{{ __('Способ оплаты:') }} <strong>{{ $order->payment_method_label }}</strong></p>
|
||||
</div>
|
||||
|
||||
<div class="pc-grid pc-grid-2">
|
||||
<div class="pc-card">
|
||||
<h3>Состав заказа</h3>
|
||||
<h3>{{ __('Состав заказа') }}</h3>
|
||||
<div class="pc-account-orders">
|
||||
@foreach ($order->items as $item)
|
||||
<div class="pc-account-order">
|
||||
@@ -28,13 +28,13 @@
|
||||
@endforeach
|
||||
</div>
|
||||
<div class="pc-cart-summary-row">
|
||||
<span>Итого</span>
|
||||
<span>{{ __('Итого') }}</span>
|
||||
<strong>{{ number_format($order->total, 0, '.', ' ') }} {{ config('shop.currency_symbol', '₽') }}</strong>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="pc-card">
|
||||
<h3>Данные получателя</h3>
|
||||
<h3>{{ __('Данные получателя') }}</h3>
|
||||
<p><strong>{{ $order->customer_name }}</strong></p>
|
||||
<p>{{ $order->email }}</p>
|
||||
@if ($order->phone)
|
||||
@@ -44,7 +44,7 @@
|
||||
<p>{{ $order->address }}</p>
|
||||
@endif
|
||||
@if ($order->comment)
|
||||
<p>Комментарий: {{ $order->comment }}</p>
|
||||
<p>{{ __('Комментарий:') }} {{ $order->comment }}</p>
|
||||
@endif
|
||||
</div>
|
||||
</div>
|
||||
@@ -52,7 +52,7 @@
|
||||
@if (!in_array($order->status, ['paid', 'shipped', 'completed'], true))
|
||||
@include('partials.payment-requisites', [
|
||||
'amount' => $order->total,
|
||||
'purpose' => 'Заказ #' . $order->id,
|
||||
'purpose' => __('Заказ #:number', ['number' => $order->id]),
|
||||
'showHelp' => true,
|
||||
])
|
||||
@endif
|
||||
|
||||
@@ -23,9 +23,9 @@
|
||||
'@context' => 'https://schema.org',
|
||||
'@type' => 'Product',
|
||||
'name' => $product->name,
|
||||
'description' => $product->short_description ?: ($product->description ?: "Купить {$product->name} по выгодной цене."),
|
||||
'description' => __($product->short_description ?: ($product->description ?: __('Купить :product по выгодной цене.', ['product' => $product->name]))),
|
||||
'sku' => $product->sku ?: null,
|
||||
'category' => $product->category?->name,
|
||||
'category' => $product->category?->name ? __($product->category->name) : null,
|
||||
'image' => $productSchemaImages,
|
||||
'url' => route('products.show', $product),
|
||||
'offers' => [
|
||||
@@ -47,8 +47,8 @@
|
||||
@endphp
|
||||
|
||||
@section('meta_title', $product->name)
|
||||
@section('meta_description', \Illuminate\Support\Str::limit(strip_tags($product->short_description ?: ($product->description ?: "Купить {$product->name} по выгодной цене.")), 160))
|
||||
@section('meta_keywords', $product->name . ', ' . ($product->category?->name ?? 'товар') . ', купить')
|
||||
@section('meta_description', \Illuminate\Support\Str::limit(strip_tags(__($product->short_description ?: ($product->description ?: __('Купить :product по выгодной цене.', ['product' => $product->name])))), 160))
|
||||
@section('meta_keywords', __(':product, :category, купить', ['product' => $product->name, 'category' => $product->category?->name ? __($product->category->name) : __('товар')]))
|
||||
@section('meta_canonical', route('products.show', $product))
|
||||
@section('meta_image', $productImageUrl)
|
||||
@section('meta_image_alt', $product->name)
|
||||
@@ -72,9 +72,9 @@
|
||||
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Каталог', 'url' => route('catalog.index')],
|
||||
['label' => $product->category?->name ?? 'Категория', 'url' => $product->category ? route('catalog.category', $product->category) : null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Каталог'), 'url' => route('catalog.index')],
|
||||
['label' => $product->category?->name ? __($product->category->name) : __('Категория'), 'url' => $product->category ? route('catalog.category', $product->category) : null],
|
||||
['label' => $product->name, 'url' => null],
|
||||
],
|
||||
])
|
||||
@@ -96,20 +96,20 @@
|
||||
@endif
|
||||
|
||||
@if (count($productGallery) > 1)
|
||||
<div class="pc-product-thumbs" aria-label="Дополнительные изображения товара">
|
||||
<div class="pc-product-thumbs" aria-label="{{ __('Дополнительные изображения товара') }}">
|
||||
@foreach ($productGallery as $imageUrl)
|
||||
<button
|
||||
class="pc-product-thumb {{ $loop->first ? 'is-active' : '' }}"
|
||||
type="button"
|
||||
data-product-gallery-thumb
|
||||
data-image-src="{{ $imageUrl }}"
|
||||
data-image-alt="{{ $product->name }} - фото {{ $loop->iteration }}"
|
||||
aria-label="Показать фото {{ $loop->iteration }}"
|
||||
data-image-alt="{{ __(':product - фото :number', ['product' => $product->name, 'number' => $loop->iteration]) }}"
|
||||
aria-label="{{ __('Показать фото :number', ['number' => $loop->iteration]) }}"
|
||||
aria-pressed="{{ $loop->first ? 'true' : 'false' }}"
|
||||
>
|
||||
<img
|
||||
src="{{ $imageUrl }}"
|
||||
alt="{{ $product->name }} - миниатюра {{ $loop->iteration }}"
|
||||
alt="{{ __(':product - миниатюра :number', ['product' => $product->name, 'number' => $loop->iteration]) }}"
|
||||
loading="lazy"
|
||||
decoding="async"
|
||||
>
|
||||
@@ -120,10 +120,10 @@
|
||||
</div>
|
||||
<div class="pc-product-info">
|
||||
<h1>{{ $product->name }}</h1>
|
||||
<p class="pc-muted">{{ $product->short_description }}</p>
|
||||
<p class="pc-muted">{{ __($product->short_description) }}</p>
|
||||
<div class="pc-product-badges">
|
||||
@if ($product->sku)
|
||||
<span class="pc-sku">Артикул: {{ $product->sku }}</span>
|
||||
<span class="pc-sku">{{ __('Артикул:') }} {{ $product->sku }}</span>
|
||||
@endif
|
||||
</div>
|
||||
<div class="pc-product-price">
|
||||
@@ -137,22 +137,22 @@
|
||||
<form method="post" action="{{ route('cart.add', $product) }}" data-preserve-scroll="true">
|
||||
@csrf
|
||||
<button class="pc-btn primary {{ $isInCart ? 'is-active' : '' }}" type="submit">
|
||||
{{ $isInCart ? 'В корзине' : 'В корзину' }}
|
||||
{{ $isInCart ? __('В корзине') : __('В корзину') }}
|
||||
</button>
|
||||
</form>
|
||||
@else
|
||||
<button class="pc-btn primary" type="button" disabled>Нет в наличии</button>
|
||||
<button class="pc-btn primary" type="button" disabled>{{ __('Нет в наличии') }}</button>
|
||||
@endif
|
||||
<form method="post" action="{{ route('favorites.toggle', $product) }}" data-preserve-scroll="true">
|
||||
@csrf
|
||||
<button class="pc-btn ghost {{ $isFavorite ? 'is-active' : '' }}" type="submit">
|
||||
{{ $isFavorite ? 'Убрать из избранного' : 'В избранное' }}
|
||||
{{ $isFavorite ? __('Убрать из избранного') : __('В избранное') }}
|
||||
</button>
|
||||
</form>
|
||||
<form method="post" action="{{ route('compare.toggle', $product) }}" data-preserve-scroll="true">
|
||||
@csrf
|
||||
<button class="pc-btn ghost {{ $isCompared ? 'is-active' : '' }}" type="submit">
|
||||
{{ $isCompared ? 'Убрать из сравнения' : 'В сравнение' }}
|
||||
{{ $isCompared ? __('Убрать из сравнения') : __('В сравнение') }}
|
||||
</button>
|
||||
</form>
|
||||
</div>
|
||||
@@ -166,10 +166,10 @@
|
||||
<input type="radio" name="product-tabs" id="tab-payment">
|
||||
|
||||
<div class="pc-tab-labels">
|
||||
<label for="tab-specs">Характеристики</label>
|
||||
<label for="tab-desc">Описание</label>
|
||||
<label for="tab-shipping">Доставка</label>
|
||||
<label for="tab-payment">Оплата</label>
|
||||
<label for="tab-specs">{{ __('Характеристики') }}</label>
|
||||
<label for="tab-desc">{{ __('Описание') }}</label>
|
||||
<label for="tab-shipping">{{ __('Доставка') }}</label>
|
||||
<label for="tab-payment">{{ __('Оплата') }}</label>
|
||||
</div>
|
||||
|
||||
<div class="pc-tab-content">
|
||||
@@ -177,29 +177,29 @@
|
||||
<div class="pc-specs-grid">
|
||||
@forelse (($product->specs ?? []) as $key => $value)
|
||||
<div class="pc-spec-row">
|
||||
<span>{{ $specLabels[$key] ?? str_replace('_', ' ', $key) }}</span>
|
||||
<strong>{{ $value }}</strong>
|
||||
<span>{{ __($specLabels[$key] ?? str_replace('_', ' ', $key)) }}</span>
|
||||
<strong>{{ __((string) $value) }}</strong>
|
||||
</div>
|
||||
@empty
|
||||
<p class="pc-muted">Характеристики еще не добавлены.</p>
|
||||
<p class="pc-muted">{{ __('Характеристики еще не добавлены.') }}</p>
|
||||
@endforelse
|
||||
</div>
|
||||
</section>
|
||||
<section class="pc-tab-panel pc-tab-desc">
|
||||
<p class="pc-muted">{{ $product->description ?? 'Описание товара будет добавлено позже.' }}</p>
|
||||
<p class="pc-muted">{{ __($product->description ?? __('Описание товара будет добавлено позже.')) }}</p>
|
||||
</section>
|
||||
<section class="pc-tab-panel pc-tab-shipping">
|
||||
<ul class="pc-list">
|
||||
<li>Доставка курьером по городу</li>
|
||||
<li>Самовывоз из пункта выдачи</li>
|
||||
<li>Отправка по стране 1-3 дня</li>
|
||||
<li>{{ __('Доставка курьером по городу') }}</li>
|
||||
<li>{{ __('Самовывоз из пункта выдачи') }}</li>
|
||||
<li>{{ __('Отправка по стране 1-3 дня') }}</li>
|
||||
</ul>
|
||||
</section>
|
||||
<section class="pc-tab-panel pc-tab-payment">
|
||||
<ul class="pc-list">
|
||||
<li>Оплата картой онлайн</li>
|
||||
<li>Банковский перевод</li>
|
||||
<li>Рассрочка на крупные заказы</li>
|
||||
<li>{{ __('Оплата картой онлайн') }}</li>
|
||||
<li>{{ __('Банковский перевод') }}</li>
|
||||
<li>{{ __('Рассрочка на крупные заказы') }}</li>
|
||||
</ul>
|
||||
</section>
|
||||
</div>
|
||||
@@ -209,7 +209,7 @@
|
||||
@if ($related->isNotEmpty())
|
||||
<section class="pc-section">
|
||||
<div class="pc-section-title">
|
||||
<h2>Что еще посмотреть в этой категории</h2>
|
||||
<h2>{{ __('Что еще посмотреть в этой категории') }}</h2>
|
||||
</div>
|
||||
<div class="pc-products-grid">
|
||||
@foreach ($related as $item)
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
? [
|
||||
'@context' => 'https://schema.org',
|
||||
'@type' => 'SearchResultsPage',
|
||||
'name' => "Результаты поиска: {$searchQuery}",
|
||||
'name' => __('Результаты поиска: :query', ['query' => $searchQuery]),
|
||||
'url' => route('search.index', ['q' => $searchQuery]),
|
||||
'mainEntity' => [
|
||||
'@type' => 'ItemList',
|
||||
@@ -25,14 +25,14 @@
|
||||
: null;
|
||||
@endphp
|
||||
|
||||
@section('meta_title', $searchQuery !== '' ? "Поиск: {$searchQuery}" : 'Поиск товаров')
|
||||
@section('meta_title', $searchQuery !== '' ? __('Поиск: :query', ['query' => $searchQuery]) : __('Поиск товаров'))
|
||||
@section(
|
||||
'meta_description',
|
||||
$searchQuery !== ''
|
||||
? "Найденные товары по запросу «{$searchQuery}». Выберите подходящий товар и откройте подробную карточку."
|
||||
: 'Поиск товаров по наименованию: процессоры, видеокарты, материнские платы, ноутбуки и периферия.'
|
||||
? __('Найденные товары по запросу «:query». Выберите подходящий товар и откройте подробную карточку.', ['query' => $searchQuery])
|
||||
: __('Поиск товаров по наименованию: процессоры, видеокарты, материнские платы, ноутбуки и периферия.')
|
||||
)
|
||||
@section('meta_keywords', 'поиск товаров, результаты поиска, комплектующие пк, ноутбуки')
|
||||
@section('meta_keywords', __('поиск товаров, результаты поиска, комплектующие пк, ноутбуки'))
|
||||
@section('meta_canonical', route('search.index'))
|
||||
@section('meta_robots', 'noindex,follow')
|
||||
|
||||
@@ -47,20 +47,20 @@
|
||||
@section('content')
|
||||
@include('partials.breadcrumbs', [
|
||||
'items' => [
|
||||
['label' => 'Главная', 'url' => route('home')],
|
||||
['label' => 'Поиск', 'url' => null],
|
||||
['label' => __('Главная'), 'url' => route('home')],
|
||||
['label' => __('Поиск'), 'url' => null],
|
||||
],
|
||||
])
|
||||
|
||||
<section class="pc-section">
|
||||
<div class="pc-category-toolbar">
|
||||
<div class="pc-section-title">
|
||||
<h2>{{ $searchQuery !== '' ? 'Результаты поиска' : 'Поиск товаров' }}</h2>
|
||||
<h2>{{ $searchQuery !== '' ? __('Результаты поиска') : __('Поиск товаров') }}</h2>
|
||||
<p>
|
||||
@if ($searchQuery !== '')
|
||||
Запрос: "{{ $searchQuery }}"
|
||||
{{ __('Запрос: ":query"', ['query' => $searchQuery]) }}
|
||||
@else
|
||||
Введите название товара, чтобы увидеть найденные позиции.
|
||||
{{ __('Введите название товара, чтобы увидеть найденные позиции.') }}
|
||||
@endif
|
||||
</p>
|
||||
</div>
|
||||
@@ -68,12 +68,12 @@
|
||||
@if ($searchQuery !== '')
|
||||
<form class="pc-sort-form" method="get" action="{{ route('search.index') }}">
|
||||
<input type="hidden" name="q" value="{{ $searchQuery }}">
|
||||
<label for="sort">Сортировка:</label>
|
||||
<label for="sort">{{ __('Сортировка:') }}</label>
|
||||
<select id="sort" name="sort" onchange="this.form.submit()">
|
||||
<option value="newest" @selected($sort === 'newest')>Сначала новые</option>
|
||||
<option value="price_asc" @selected($sort === 'price_asc')>Сначала дешевле</option>
|
||||
<option value="price_desc" @selected($sort === 'price_desc')>Сначала дороже</option>
|
||||
<option value="name_asc" @selected($sort === 'name_asc')>По названию</option>
|
||||
<option value="newest" @selected($sort === 'newest')>{{ __('Сначала новые') }}</option>
|
||||
<option value="price_asc" @selected($sort === 'price_asc')>{{ __('Сначала дешевле') }}</option>
|
||||
<option value="price_desc" @selected($sort === 'price_desc')>{{ __('Сначала дороже') }}</option>
|
||||
<option value="name_asc" @selected($sort === 'name_asc')>{{ __('По названию') }}</option>
|
||||
</select>
|
||||
</form>
|
||||
@endif
|
||||
@@ -81,26 +81,26 @@
|
||||
|
||||
<form class="pc-search-page-form" method="get" action="{{ route('search.index') }}">
|
||||
<div class="pc-search">
|
||||
<input type="text" name="q" placeholder="Например, Ryzen 7 или RTX 4060" value="{{ $searchQuery }}">
|
||||
<input type="text" name="q" placeholder="{{ __('Например, Ryzen 7 или RTX 4060') }}" value="{{ $searchQuery }}">
|
||||
</div>
|
||||
<button class="pc-btn primary" type="submit">Найти</button>
|
||||
<button class="pc-btn primary" type="submit">{{ __('Найти') }}</button>
|
||||
@if ($searchQuery !== '')
|
||||
<a class="pc-btn ghost" href="{{ route('search.index') }}">Очистить</a>
|
||||
<a class="pc-btn ghost" href="{{ route('search.index') }}">{{ __('Очистить') }}</a>
|
||||
@endif
|
||||
</form>
|
||||
|
||||
@if ($searchQuery === '')
|
||||
<div class="pc-card">
|
||||
Введите запрос в строку поиска, чтобы открыть список найденных товаров.
|
||||
{{ __('Введите запрос в строку поиска, чтобы открыть список найденных товаров.') }}
|
||||
</div>
|
||||
@else
|
||||
<p class="pc-muted">Найдено товаров: <strong>{{ $products->total() }}</strong></p>
|
||||
<p class="pc-muted">{{ __('Найдено товаров:') }} <strong>{{ $products->total() }}</strong></p>
|
||||
|
||||
<div class="pc-products-grid">
|
||||
@forelse ($products as $product)
|
||||
@include('partials.product-card', ['product' => $product])
|
||||
@empty
|
||||
<div class="pc-card">По вашему запросу ничего не найдено.</div>
|
||||
<div class="pc-card">{{ __('По вашему запросу ничего не найдено.') }}</div>
|
||||
@endforelse
|
||||
</div>
|
||||
|
||||
|
||||
@@ -7,6 +7,7 @@ use App\Http\Controllers\Admin\ChatController as AdminChatController;
|
||||
use App\Http\Controllers\Admin\HomeSlideController as AdminHomeSlideController;
|
||||
use App\Http\Controllers\Admin\OrderController as AdminOrderController;
|
||||
use App\Http\Controllers\Admin\ProductController as AdminProductController;
|
||||
use App\Http\Controllers\LocaleController;
|
||||
use App\Http\Controllers\SitemapController;
|
||||
use App\Http\Controllers\Shop\AccountController;
|
||||
use App\Http\Controllers\Shop\AuthController;
|
||||
@@ -23,6 +24,7 @@ use App\Http\Controllers\Shop\ShopController;
|
||||
use Illuminate\Support\Facades\Route;
|
||||
|
||||
Route::get('/sitemap.xml', [SitemapController::class, 'index'])->name('sitemap');
|
||||
Route::post('/locale/{locale}', LocaleController::class)->name('locale.switch');
|
||||
Route::get('/robots.txt', function () {
|
||||
$content = implode(PHP_EOL, [
|
||||
'User-agent: *',
|
||||
|
||||
37
tests/Feature/LocaleSwitchingTest.php
Normal file
37
tests/Feature/LocaleSwitchingTest.php
Normal file
@@ -0,0 +1,37 @@
|
||||
<?php
|
||||
|
||||
namespace Tests\Feature;
|
||||
|
||||
use Tests\TestCase;
|
||||
|
||||
class LocaleSwitchingTest extends TestCase
|
||||
{
|
||||
public function test_site_uses_russian_by_default(): void
|
||||
{
|
||||
$response = $this->get('/about');
|
||||
|
||||
$response->assertOk();
|
||||
$response->assertSee('lang="ru"', false);
|
||||
$response->assertSee('pc-lang-switcher-label">Рус<', false);
|
||||
}
|
||||
|
||||
public function test_user_can_switch_site_locale_to_kazakh(): void
|
||||
{
|
||||
$response = $this->from('/about')->post('/locale/kk');
|
||||
|
||||
$response->assertRedirect('/about');
|
||||
$response->assertSessionHas('locale', 'kk');
|
||||
|
||||
$this->withSession(['locale' => 'kk'])
|
||||
->get('/about')
|
||||
->assertOk()
|
||||
->assertSee('lang="kk"', false)
|
||||
->assertSee('pc-lang-switcher-label">Қаз<', false)
|
||||
->assertSee('Басты бет');
|
||||
}
|
||||
|
||||
public function test_unsupported_locale_returns_not_found(): void
|
||||
{
|
||||
$this->post('/locale/en')->assertNotFound();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user