Files
masimmo.pl/modules/creativeelements/includes/widgets/product-grid.php
2024-11-20 09:09:44 +01:00

356 lines
11 KiB
PHP

<?php
/**
* Creative Elements - live Theme & Page Builder
*
* @author WebshopWorks
* @copyright 2019-2023 WebshopWorks.com
* @license One domain support license
*/
namespace CE;
defined('_PS_VERSION_') or exit;
class WidgetProductGrid extends WidgetProductBase
{
public function getName()
{
return 'product-grid';
}
public function getTitle()
{
return __('Product Grid');
}
public function getIcon()
{
return 'eicon-posts-grid';
}
public function getKeywords()
{
return ['shop', 'store', 'product', 'grid', 'listing', 'featured', 'prices drop', 'new', 'best seller', 'related', 'recently viewed', 'brand'];
}
protected function _registerControls()
{
$this->startControlsSection(
'section_grid_settings',
[
'label' => __('Product Grid'),
]
);
$this->addControl(
'skin',
[
'label' => __('Miniature'),
'type' => ControlsManager::SELECT,
'options' => $this->getSkinOptions(),
'default' => 'product',
]
);
$this->registerListingControls('num_of_prods');
$this->addResponsiveControl(
'columns',
[
'label' => __('Columns'),
'type' => ControlsManager::NUMBER,
'min' => 1,
'default' => 4,
'tablet_default' => 3,
'mobile_default' => 1,
'selectors' => [
'{{WRAPPER}} .elementor-product-grid' => '-ms-grid-columns: repeat({{VALUE}}, minmax(0, 1fr)); grid-template-columns: repeat({{VALUE}}, minmax(0, 1fr));',
],
'separator' => 'before',
]
);
$this->endControlsSection();
$this->registerMiniatureSections();
$this->registerHeadingStyleSection();
$this->startControlsSection(
'section_style_product',
[
'label' => __('Product Box'),
'tab' => ControlsManager::TAB_STYLE,
]
);
$this->addResponsiveControl(
'product_column_gap',
[
'label' => __('Columns Gap'),
'type' => ControlsManager::SLIDER,
'size_units' => ['px', 'em'],
'range' => [
'px' => [
'max' => 100,
],
],
'selectors' => [
'{{WRAPPER}} .elementor-product-grid' => 'grid-column-gap: {{SIZE}}{{UNIT}};',
],
]
);
$this->addResponsiveControl(
'product_row_gap',
[
'label' => __('Rows Gap'),
'type' => ControlsManager::SLIDER,
'size_units' => ['px', 'em'],
'range' => [
'px' => [
'max' => 100,
],
],
'selectors' => [
'{{WRAPPER}} .elementor-product-grid' => 'grid-row-gap: {{SIZE}}{{UNIT}};',
],
]
);
$product_selector = '{{WRAPPER}} .elementor-product-grid > *';
$product_selector_hover = '{{WRAPPER}} .elementor-product-grid > :hover';
$this->addResponsiveControl(
'product_padding',
[
'label' => __('Padding'),
'type' => ControlsManager::DIMENSIONS,
'size_units' => ['px', 'em'],
'range' => [
'px' => [
'min' => 0,
'max' => 50,
],
],
'selectors' => [
$product_selector => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}} !important;',
],
]
);
$this->addControl(
'product_border_width',
[
'label' => __('Border Width'),
'type' => ControlsManager::DIMENSIONS,
'size_units' => ['px'],
'range' => [
'px' => [
'min' => 0,
'max' => 50,
],
],
'selectors' => [
$product_selector => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}; border-style: solid;',
],
]
);
$this->addControl(
'product_border_radius',
[
'label' => __('Border Radius'),
'type' => ControlsManager::DIMENSIONS,
'size_units' => ['px', '%'],
'selectors' => [
$product_selector => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->startControlsTabs('product_style_tabs');
$this->startControlsTab(
'product_style_normal',
[
'label' => __('Normal'),
]
);
$this->addControl(
'product_border_color',
[
'label' => __('Border Color'),
'type' => ControlsManager::COLOR,
'selectors' => [
$product_selector => 'border-color: {{VALUE}};',
],
]
);
$this->addControl(
'product_bg_color',
[
'label' => __('Background Color'),
'type' => ControlsManager::COLOR,
'selectors' => [
'{{WRAPPER}} .elementor-product-miniature' => 'background: {{VALUE}};',
],
'condition' => [
'skin' => 'custom',
],
]
);
$this->addGroupControl(
GroupControlBoxShadow::getType(),
[
'name' => 'product_box_shadow',
'selector' => $product_selector,
]
);
$this->endControlsTab();
$this->startControlsTab(
'product_style_hover',
[
'label' => __('Hover'),
]
);
$this->addControl(
'product_border_color_hover',
[
'label' => __('Border Color'),
'type' => ControlsManager::COLOR,
'selectors' => [
$product_selector_hover => 'border-color: {{VALUE}};',
],
]
);
$this->addControl(
'product_bg_color_hover',
[
'label' => __('Background Color'),
'type' => ControlsManager::COLOR,
'selectors' => [
'{{WRAPPER}} .elementor-product-miniature:hover' => 'background-color: {{VALUE}};',
],
'condition' => [
'skin' => 'custom',
],
]
);
$this->addGroupControl(
GroupControlBoxShadow::getType(),
[
'name' => 'product_box_shadow_hover',
'selector' => $product_selector_hover,
]
);
$this->endControlsTab();
$this->endControlsTabs();
$this->endControlsSection();
$this->registerMiniatureStyleSections();
}
protected function getHtmlWrapperClass()
{
return parent::getHtmlWrapperClass() . ' elementor-widget-heading elementor-widget-product-box';
}
protected function render()
{
if (empty($this->context->currency->id)) {
return;
}
$settings = $this->getSettingsForDisplay();
$listing = $settings['listing'];
if ($settings['randomize'] && in_array($listing, ['category', 'viewed', 'products', 'related'])) {
$settings['order_by'] = 'rand';
}
$settings['related_id'] = $settings['related_product_id'];
$products = $this->getProducts(
$listing,
$settings['order_by'],
$settings['order_dir'],
$settings['num_of_prods'] ?: 8,
in_array($listing, ['category', 'related', 'manufacturer', 'supplier']) ? $settings["{$listing}_id"] : 0,
$settings['products']
);
if (empty($products)) {
return;
}
$ld_json = [
'@context' => 'https://schema.org',
'@type' => 'ItemList',
'itemListElement' => [],
];
if (!empty($settings['heading'])) {
$this->addRenderAttribute('heading', 'class', 'elementor-heading-title');
$this->addInlineEditingAttributes('heading');
printf(
'<%1$s %2$s>%3$s</%1$s>',
$settings['heading_size'],
$this->getRenderAttributeString('heading'),
$settings['heading']
);
}
if ('custom' === $settings['skin']) {
// BC fix
$settings['qv_icon_align'] = $this->getSettings('qv_icon_align');
$settings['atc_icon_align'] = $this->getSettings('atc_icon_align');
echo '<div class="elementor-product-grid">';
foreach ($products as $i => &$product) {
$ld_json['itemListElement'][] = [
'@type' => 'ListItem',
'position' => $i,
'name' => $product['name'],
'url' => $product['url'],
];
echo $this->fetchMiniature($settings, $product);
}
echo '</div>';
} else {
if (!$tpl = $this->getSkinTemplate($settings['skin'])) {
return;
}
// Store product temporary if exists
isset($this->context->smarty->tpl_vars['product']) && $tmp = $this->context->smarty->tpl_vars['product'];
echo '<div class="elementor-product-grid">';
foreach ($products as $i => &$product) {
$ld_json['itemListElement'][] = [
'@type' => 'ListItem',
'position' => $i,
'name' => $product['name'],
'url' => $product['url'],
];
$this->context->smarty->assign('product', $product);
echo $this->context->smarty->fetch($tpl);
}
echo '</div>';
// Restore product if exists
isset($tmp) && $this->context->smarty->tpl_vars['product'] = $tmp;
}
echo '<script type="application/ld+json">' . json_encode($ld_json) . '</script>';
}
}