Інтеграція
Інтегруйте можливості sCommerce у ваш код, використовуючи наведені нижче приклади.
Дерево підкатегорій
Для отримання потрібної категорії разом з підкатегоріями використовуйте метод для рекурсивної
побудови дерева категорій sCommerce::getTreeActiveCategories(evo()->documentIdentifier, 10).
Цей метод поверне шукану категорію разом з рекурсивно побудованими підкатегоріями.
Глибина вкладеності залежить від параметра $dept (типово 10). Якщо встановлено пакет sLang,
автоматично застосовується поточна локаль, а третім аргументом можна передати перелік TV.
Seiger\sCommerce\Models\sCategory {#1902 ▼
#connection: "default"
#table: "site_content"
...
#attributes: array:37 [▼
"id" => "50"
"type" => "document"
...
"subcategories" => EvolutionCMS\Extensions\Collection {#1889 ▼
#items: array:4 [▼
0 => Seiger\sCommerce\Models\sCategory {#1888 ▼
#connection: "default"
#table: "site_content"
...
#attributes: array:37 [▶]
#original: array:36 [▶]
...
}
1 => Seiger\sCommerce\Models\sCategory {#1886 ▶}
2 => Seiger\sCommerce\Models\sCategory {#1884 ▶}
3 => Seiger\sCommerce\Models\sCategory {#1882 ▶}
]
#escapeWhenCastingToString: false
}
]
#original: array:36 [▶]
...
}
Виклик методу getTreeActiveCategories()
namespace EvolutionCMS\Main\Controllers;
use Seiger\sCommerce\Facades\sCommerce;
class CategoryController extends BaseController
{
public function render()
{
parent::render();
...
$this->data['category'] = sCommerce::getTreeActiveCategories(
evo()->documentIdentifier,
10,
['menu_main', 'menu_footer'] // опційно: перелік TV
);
...
}
}
Аргументи методу getTreeActiveCategories()
З наведеного вище прикладу:
evo()->documentIdentifier - ID категорії, для якої потрібно отримати дані. Тип number integer.
10 - Глибина вкладеності для отримання підкатегорій. Тип number integer. Типово 10.
['menu_main', 'menu_footer'] (опційно) – Масив із назвами TV, які потрібно додати до кожної категорії (працює, якщо встановлено sLang). Типово порожній масив.
Застосування результату виклику getTreeActiveCategories()
Нижче наведено приклад використання результату виклику методу getTreeActiveCategories() в Blade шаблоні.
...
<section>
<h1>{% raw %}{{$category->pagetitle}}{% endraw %}</h1>
{% raw %}{!!$category->content!!}{% endraw %}
</section>
@if($category->subcategories->count())
@foreach($category->subcategories as $subcategory)
<section>
<h2>{% raw %}{{$subcategory->pagetitle}}{% endraw %}</h2>
<p>{% raw %}{{$subcategory->introtext}}{% endraw %}</p>
</section>
@endforeach
@endif
Товари з а категорією
Для отримання всіх товарів, пов'язаних з поточною категорією, достатньо викликати пов'язані моделі товарів так:
...
use Seiger\sCommerce\Models\sCategory;
...
$category = sCategory::find(evo()->documentIdentifier);
$products = $category->products()->count(); // Кількість товарів
$products = $category->products; // Список товарів
Товари категорії та підкатегорії
Для відображення всіх товарів кореневої категорії та її пов'язаних підкатегорій,
потрібно використовувати метод getCategoryProducts().
Виклик методу getCategoryProducts()
namespace EvolutionCMS\Main\Controllers;
use Seiger\sCommerce\Facades\sCommerce;
class CategoryController extends BaseController
{
public function render()
{
parent::render();
...
$products = sCommerce::getCategoryProducts(evo()->documentIdentifier, 'base', 10);
...
}
}
Аргументи методу getCategoryProducts()
З наведеного вище прикладу:
Цей метод можна викликати без аргументів. В цьому випадку буде повернено список товарів, де кореневою категорією буде поточна категорія. Якщо використовується багатомовність, то дані текстових полів будуть представлені поточною мовою. Глибина вкладеності підкатегорій буде 10.
evo()->documentIdentifier - ID кореневої категорії, для якої потрібно отримати дані.
Тип number integer або null. За замовчуванням null.
'base' - Мова для відображення полів товару. Рядок коду мови або null. За замовчуванням null.
10 - Глибина вкладеності для отримання підкатегорій. Тип number integer. За замовчуванням 10.
Результат виклику getCategoryProducts()
Illuminate\Database\Eloquent\Collection {#1422 ▼
#items: array:3 [▼
0 => Seiger\sCommerce\Models\sProduct {#1359 ▼
#connection: "default"
#table: "s_products"
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
+preventsLazyLoading: false
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#escapeWhenCastingToString: false
#attributes: array:35 [▶]
#original: array:35 [▶]
#changes: []
#casts: []
#classCastCache: []
#attributeCastCache: []
#dateFormat: null
#appends: array:2 [▶]
#dispatchesEvents: []
#observables: []
#relations: []
#touches: []
+timestamps: true
+usesUniqueIds: false
#hidden: []
#visible: []
#fillable: []
#guarded: array:1 [▶]
}
1 => Seiger\sCommerce\Models\sProduct {#1421 ▶}
2 => Seiger\sCommerce\Models\sProduct {#1370 ▶}
]
#escapeWhenCastingToString: false
}
Атрибут товару
Ви можете отримати значення атрибута товару, передавши його ключ.
Результат виклику attribute()
Seiger\sCommerce\Models\sAttribute {#1663 ▼
#connection: "default"
#table: "s_attributes"
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
+preventsLazyLoading: false
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#escapeWhenCastingToString: false
#attributes: array:11 [▼
"id" => "1"
"published" => "1"
"asfilter" => "1"
"position" => "0"
"type" => "3"
"alias" => "brand"
"helptext" => "Brand"
"created_at" => "2024-11-25 20:55:13"
"updated_at" => "2024-11-25 20:58:37"
"value" => "leon"
"label" => "Leon"
]
#original: array:13 [▶]
#changes: []
#casts: []
#classCastCache: []
#attributeCastCache: []
#dateFormat: null
#appends: []
#dispatchesEvents: []
#observables: []
#relations: array:1 [▶]
#touches: []
+timestamps: true
+usesUniqueIds: false
#hidden: []
#visible: []
#fillable: []
#guarded: array:1 [▶]
}
Приклад виклику attribute()
<?php namespace EvolutionCMS\Main\Controllers;
...
class SCommerceProductController extends BaseController
{
public function render()
{
parent::render();
$product = evo()->documentObject['product'];
$brand = $product->attribute('brand');
dd($brand);
...
}
...
}
Представлення атрибута в blade
<div class="item-brand">
@lang('Brand'): <a href="@makeUrl(sCommerce::config('basic.catalog_root'))?brand={{$product->attribute('brand')?->value ?? ''}}">
{{$product->attribute('brand')?->label ?? ''}}
</a>
</div>