HEX
Server: Microsoft-IIS/8.5
System: Windows NT YDAWBH120 6.3 build 9600 (Windows Server 2012 R2 Standard Edition) AMD64
User: tentjecom_web (0)
PHP: 7.4.14
Disabled: NONE
Upload Files
File: D:/HostingSpaces/SBogers10/conmeq.komma.pro/app/Komma/Shop/Products/Product/ProductTranslation.php
<?php
namespace App\Komma\Shop\Products\Product;

use App\Komma\Kms\Core\AbstractTranslationModel;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Laravel\Scout\Searchable;
use TeamTNT\TNTSearch\Indexer\TNTIndexer;

/**
 * App\Komma\Shop\Products\Product\ProductTranslation
 *
 * @property-read \App\Komma\Globalization\Languages\Models\Language $language
 * @property-read \App\Komma\Shop\Products\Product\Product $translatable
 * @mixin \Eloquent
 * @property int $id
 * @property int $product_id
 * @property string $slug
 * @property string $name
 * @property string $subtitle
 * @property string $description
 * @property string $meta_title
 * @property string $meta_description
 * @property string $language_id
 * @property \Carbon\Carbon|null $created_at
 * @property \Carbon\Carbon|null $updated_at
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereCreatedAt($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereDescription($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereLanguageId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereMetaDescription($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereMetaTitle($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereName($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereProductId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereSlug($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation wheresubtitle($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereUpdatedAt($value)
 * @property string $subname
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereSubname($value)
 * @property string $video
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation newModelQuery()
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation newQuery()
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation query()
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Komma\Shop\Products\Product\ProductTranslation whereVideo($value)
 */
class ProductTranslation extends AbstractTranslationModel
{
    protected $fillable = ['slug', 'title', 'description', 'meta_title', 'meta_description', 'language_id', 'product_id'];

    use Searchable;

    public function searchableAs()
    {
        return 'products_translation_index';
    }

    public function toSearchableArray()
    {
        //Split name on space and create an array sorted descending by keyword candidate length
        $keywordCandidates = explode(' ', $this->name);
        $keywordCandidatesByLength = [];
        foreach($keywordCandidates as $keywordCandidate) $keywordCandidatesByLength[mb_strlen($keywordCandidate)] = $keywordCandidate;
        krsort($keywordCandidatesByLength);
        $keys = array_keys($keywordCandidatesByLength);
        $flk = (count($keywordCandidatesByLength) >= 1 && $keys[0] >= 4 && !is_numeric($keywordCandidatesByLength[$keys[0]])) ? $keywordCandidatesByLength[$keys[0]]: '';
        $slk = (count($keywordCandidatesByLength) >= 2 && $keys[1] >= 4 && !is_numeric($keywordCandidatesByLength[$keys[1]])) ? $keywordCandidatesByLength[$keys[1]]: '';
        $tlk = (count($keywordCandidatesByLength) >= 3 && $keys[2] >= 4 && !is_numeric($keywordCandidatesByLength[$keys[2]])) ? $keywordCandidatesByLength[$keys[2]]: '';


        $searchable = [
            'id' => $this->id,
//            'flk' => $flk, //First longest keyword
//            'slk' => $slk, //Second longest keyword
//            'tlk' => $tlk, //Third longest keyword
            'flk_trigrams' => (new TNTIndexer)->buildTrigrams($flk), //Tri gram is an n-gram of 3 letters.
//            'slk_trigrams' => (new TNTIndexer)->buildTrigrams($slk),
//            'tlk_trigrams' => (new TNTIndexer)->buildTrigrams($tlk),
            'active' => $this->active,
            'name' => $this->name,
//            'description' => $this->description,
        ];

        return $searchable;
    }

    public function translatable(): BelongsTo
    {
        return $this->BelongsTo(Product::class, 'product_id');
    }
}