Files
Archive/retro/atomcms/app/Nova/Lenses/ClonedUsers.php

110 lines
3.2 KiB
PHP

<?php
namespace App\Nova\Lenses;
use Laravel\Nova\Fields\Text;
use Laravel\Nova\Lenses\Lens;
use Laravel\Nova\Fields\Avatar;
use Illuminate\Support\Facades\DB;
use Illuminate\Database\Query\Builder;
use Laravel\Nova\Http\Requests\LensRequest;
use Laravel\Nova\Http\Requests\NovaRequest;
class ClonedUsers extends Lens
{
/**
* The columns that should be searched.
*
* @var array
*/
public static $search = [];
/**
* Get the query builder / paginator for the lens.
*
* @param \Laravel\Nova\Http\Requests\LensRequest $request
* @param \Illuminate\Database\Eloquent\Builder $query
* @return mixed
*/
public static function query(LensRequest $request, $query)
{
return $request->withOrdering($request->withFilters(
$query->whereExists(fn (Builder $subQuery) => $subQuery->select(DB::raw(1))
->from('users as u2')
->where(fn (Builder $conditonQuery) => $conditonQuery
->whereColumn('u2.ip_register', 'users.ip_register')
->orWhereColumn('u2.ip_register', 'users.ip_current')
->orWhereColumn('u2.ip_current', 'users.ip_register')
->orWhereColumn('u2.ip_current', 'users.ip_current'))
->whereColumn('users.id', '<>', 'u2.id')
->whereColumn('users.id', '>', DB::raw("(SELECT MIN(u3.id) FROM users u3 WHERE u3.ip_register = users.ip_register OR u3.ip_register = users.ip_current OR u3.ip_current = users.ip_register OR u3.ip_current = users.ip_current)"))
)
));
}
/**
* Get the fields available to the lens.
*
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
* @return array
*/
public function fields(NovaRequest $request)
{
return [
...$request->newResourceWith($this->resource)->fields($request),
Text::make('Parent Account', fn () => DB::table('users as u2')
->where(fn (Builder $query) => $query->where('u2.ip_register', $this->ip_register)
->orWhere('u2.ip_register', $this->ip_current)
->orWhere('u2.ip_current', $this->ip_register)
->orWhere('u2.ip_current', $this->ip_current))
->orderBy('u2.id', 'asc')
->value('u2.username')
),
];
}
/**
* Get the cards available on the lens.
*
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
* @return array
*/
public function cards(NovaRequest $request)
{
return [];
}
/**
* Get the filters available for the lens.
*
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
* @return array
*/
public function filters(NovaRequest $request)
{
return [];
}
/**
* Get the actions available on the lens.
*
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
* @return array
*/
public function actions(NovaRequest $request)
{
return parent::actions($request);
}
/**
* Get the URI key for the lens.
*
* @return string
*/
public function uriKey()
{
return 'cloned-users';
}
}