|
Apache/2.4.41 (Ubuntu) Linux vmi616275.contaboserver.net 5.4.0-84-generic #94-Ubuntu SMP Thu Aug 26 20:27:37 UTC 2021 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) server ip : 62.171.164.128 | your ip : 127.0.0.1 safemode OFF > / home / Mirasvit / Search / Index / Mirasvit / Kb / Article / |
Filename | /home/Mirasvit/Search/Index/Mirasvit/Kb/Article/Index.php |
Size | 3.29 kb |
Permission | rwxr-xr-x |
Owner | root : root |
Create time | 01-Jul-2024 20:52 |
Last modified | 06-Apr-2021 18:06 |
Last accessed | 22-Aug-2025 06:11 |
Actions | edit | rename | delete | download (gzip) |
View | text | code | image |
<?php
/**
* Mirasvit
*
* This source file is subject to the Mirasvit Software License, which is available at https://mirasvit.com/license/.
* Do not edit or add to this file if you wish to upgrade the to newer versions in the future.
* If you wish to customize this module for your needs.
* Please refer to http://www.magentocommerce.com for more information.
*
* @category Mirasvit
* @package mirasvit/module-search-ultimate
* @version 2.0.25
* @copyright Copyright (C) 2021 Mirasvit (https://mirasvit.com/)
*/
declare(strict_types=1);
namespace Mirasvit\Search\Index\Mirasvit\Kb\Article;
use Magento\Framework\App\ObjectManager;
use Magento\Framework\Data\Collection;
use Mirasvit\Search\Model\Index\AbstractIndex;
class Index extends AbstractIndex
{
public function getName(): string
{
return 'Mirasvit / Knowledge Base';
}
public function getIdentifier(): string
{
return 'mirasvit_kb_article';
}
public function getAttributes(): array
{
return [
'name' => __('Name'),
'text' => __('Content'),
'tags' => __('Tags'),
'meta_title' => __('Meta Title'),
'meta_keywords' => __('Meta Keywords'),
'meta_description' => __('Meta Description'),
];
}
public function getPrimaryKey(): string
{
return 'article_id';
}
public function buildSearchCollection(): Collection
{
if (!class_exists('Mirasvit\Kb\Model\ResourceModel\Article\CollectionFactory')) {
return [];
}
$collectionFactory = ObjectManager::getInstance()
->create('Mirasvit\Kb\Model\ResourceModel\Article\CollectionFactory');
$collection = $collectionFactory->create();
$this->context->getSearcher()->joinMatches($collection, 'main_table.article_id');
return $collection;
}
public function getIndexableDocuments(int $storeId, array $entityIds = null, int $lastEntityId = null, int $limit = 100): array
{
$collectionFactory = $this->context->getObjectManager()
->create('Mirasvit\Kb\Model\ResourceModel\Article\CollectionFactory');
$collection = $collectionFactory->create()
->addStoreIdFilter($storeId)
->addFieldToFilter('main_table.is_active', 1);
$articleTagTable = $collection->getResource()->getTable('mst_kb_article_tag');
$tagTable = $collection->getResource()->getTable('mst_kb_tag');
$collection->getSelect()->joinLeft(
['article_tags' => $articleTagTable],
"main_table.article_id = article_tags.at_article_id",
[]
);
$collection->getSelect()->joinLeft(
['tag' => $tagTable],
"article_tags.at_tag_id = tag.tag_id",
['tags' => new \Zend_Db_Expr('group_concat(tag.name)')]
);
if ($entityIds) {
$collection->addFieldToFilter('main_table.article_id', ['in' => $entityIds]);
}
$collection->addFieldToFilter('main_table.article_id', ['gt' => $lastEntityId])
->setPageSize($limit)
->setOrder('main_table.article_id');
$collection->getSelect()->group('main_table.article_id');
return $collection->toArray()['items'];
}
}
/**
* Mirasvit
*
* This source file is subject to the Mirasvit Software License, which is available at https://mirasvit.com/license/.
* Do not edit or add to this file if you wish to upgrade the to newer versions in the future.
* If you wish to customize this module for your needs.
* Please refer to http://www.magentocommerce.com for more information.
*
* @category Mirasvit
* @package mirasvit/module-search-ultimate
* @version 2.0.25
* @copyright Copyright (C) 2021 Mirasvit (https://mirasvit.com/)
*/
declare(strict_types=1);
namespace Mirasvit\Search\Index\Mirasvit\Kb\Article;
use Magento\Framework\App\ObjectManager;
use Magento\Framework\Data\Collection;
use Mirasvit\Search\Model\Index\AbstractIndex;
class Index extends AbstractIndex
{
public function getName(): string
{
return 'Mirasvit / Knowledge Base';
}
public function getIdentifier(): string
{
return 'mirasvit_kb_article';
}
public function getAttributes(): array
{
return [
'name' => __('Name'),
'text' => __('Content'),
'tags' => __('Tags'),
'meta_title' => __('Meta Title'),
'meta_keywords' => __('Meta Keywords'),
'meta_description' => __('Meta Description'),
];
}
public function getPrimaryKey(): string
{
return 'article_id';
}
public function buildSearchCollection(): Collection
{
if (!class_exists('Mirasvit\Kb\Model\ResourceModel\Article\CollectionFactory')) {
return [];
}
$collectionFactory = ObjectManager::getInstance()
->create('Mirasvit\Kb\Model\ResourceModel\Article\CollectionFactory');
$collection = $collectionFactory->create();
$this->context->getSearcher()->joinMatches($collection, 'main_table.article_id');
return $collection;
}
public function getIndexableDocuments(int $storeId, array $entityIds = null, int $lastEntityId = null, int $limit = 100): array
{
$collectionFactory = $this->context->getObjectManager()
->create('Mirasvit\Kb\Model\ResourceModel\Article\CollectionFactory');
$collection = $collectionFactory->create()
->addStoreIdFilter($storeId)
->addFieldToFilter('main_table.is_active', 1);
$articleTagTable = $collection->getResource()->getTable('mst_kb_article_tag');
$tagTable = $collection->getResource()->getTable('mst_kb_tag');
$collection->getSelect()->joinLeft(
['article_tags' => $articleTagTable],
"main_table.article_id = article_tags.at_article_id",
[]
);
$collection->getSelect()->joinLeft(
['tag' => $tagTable],
"article_tags.at_tag_id = tag.tag_id",
['tags' => new \Zend_Db_Expr('group_concat(tag.name)')]
);
if ($entityIds) {
$collection->addFieldToFilter('main_table.article_id', ['in' => $entityIds]);
}
$collection->addFieldToFilter('main_table.article_id', ['gt' => $lastEntityId])
->setPageSize($limit)
->setOrder('main_table.article_id');
$collection->getSelect()->group('main_table.article_id');
return $collection->toArray()['items'];
}
}