Server IP : 66.29.132.124 / Your IP : 3.138.134.149 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/book24.ng/vendor/kalnoy/nestedset/src/ |
Upload File : |
<?php namespace Kalnoy\Nestedset; use Illuminate\Database\Eloquent\Builder as EloquentBuilder; use Illuminate\Database\Eloquent\Collection as EloquentCollection; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\Relation; use Illuminate\Database\Query\Builder; use InvalidArgumentException; abstract class BaseRelation extends Relation { /** * @var QueryBuilder */ protected $query; /** * @var NodeTrait|Model */ protected $parent; /** * The count of self joins. * * @var int */ protected static $selfJoinCount = 0; /** * AncestorsRelation constructor. * * @param QueryBuilder $builder * @param Model $model */ public function __construct(QueryBuilder $builder, Model $model) { if ( ! NestedSet::isNode($model)) { throw new InvalidArgumentException('Model must be node.'); } parent::__construct($builder, $model); } /** * @param Model $model * @param $related * * @return bool */ abstract protected function matches(Model $model, $related); /** * @param QueryBuilder $query * @param Model $model * * @return void */ abstract protected function addEagerConstraint($query, $model); /** * @param $hash * @param $table * @param $lft * @param $rgt * * @return string */ abstract protected function relationExistenceCondition($hash, $table, $lft, $rgt); /** * @param EloquentBuilder $query * @param EloquentBuilder $parent * @param array $columns * * @return mixed */ public function getRelationExistenceQuery(EloquentBuilder $query, EloquentBuilder $parent, $columns = [ '*' ] ) { $query = $this->getParent()->replicate()->newScopedQuery()->select($columns); $table = $query->getModel()->getTable(); $query->from($table.' as '.$hash = $this->getRelationCountHash()); $query->getModel()->setTable($hash); $grammar = $query->getQuery()->getGrammar(); $condition = $this->relationExistenceCondition( $grammar->wrapTable($hash), $grammar->wrapTable($table), $grammar->wrap($this->parent->getLftName()), $grammar->wrap($this->parent->getRgtName())); return $query->whereRaw($condition); } /** * Initialize the relation on a set of models. * * @param array $models * @param string $relation * * @return array */ public function initRelation(array $models, $relation) { return $models; } /** * Get a relationship join table hash. * * @param bool $incrementJoinCount * @return string */ public function getRelationCountHash($incrementJoinCount = true) { return 'nested_set_'.($incrementJoinCount ? static::$selfJoinCount++ : static::$selfJoinCount); } /** * Get the results of the relationship. * * @return mixed */ public function getResults() { return $this->query->get(); } /** * Set the constraints for an eager load of the relation. * * @param array $models * * @return void */ public function addEagerConstraints(array $models) { // The first model in the array is always the parent, so add the scope constraints based on that model. // @link https://github.com/laravel/framework/pull/25240 // @link https://github.com/lazychaser/laravel-nestedset/issues/351 optional($models[0])->applyNestedSetScope($this->query); $this->query->whereNested(function (Builder $inner) use ($models) { // We will use this query in order to apply constraints to the // base query builder $outer = $this->parent->newQuery()->setQuery($inner); foreach ($models as $model) { $this->addEagerConstraint($outer, $model); } }); } /** * Match the eagerly loaded results to their parents. * * @param array $models * @param EloquentCollection $results * @param string $relation * * @return array */ public function match(array $models, EloquentCollection $results, $relation) { foreach ($models as $model) { $related = $this->matchForModel($model, $results); $model->setRelation($relation, $related); } return $models; } /** * @param Model $model * @param EloquentCollection $results * * @return Collection */ protected function matchForModel(Model $model, EloquentCollection $results) { $result = $this->related->newCollection(); foreach ($results as $related) { if ($this->matches($model, $related)) { $result->push($related); } } return $result; } }