Laravel 5:目录元素在 hasMany 关系中按名称排序

问题描述 投票:0回答:2

我需要按关系 langs() 对文件夹 ($data['contents']) 进行排序,其中 lang_id == 1 我该怎么做?谢谢。

在模型文件夹中:

class Folder extends Model
{
    protected $fillable = ['active', 'date', 'path', 'slug'];

    public function langs()
    {
        return $this->hasMany('App\Models\LangFolder');
    }

}

在模型 LangFolder 中:

class LangFolder extends Model
{
    protected $fillable = ['folder_id', 'lang_id', 'name', 'description'];

    public function folder()
    {
        return $this->belongsTo('App\Models\Folder');
    }
}

在控制器中:

public function folders()
{
    // Sort folders ($data['contents']) by relationship langs() where lang_id == 1

    $data['folders'] = Folder::all();
    $data['langs'] = Lang::all();

    $directory = 'library/';
    $elements =  array_diff(scandir($directory), array('..', '.'));

    foreach($elements as $element) {
        if (is_dir($directory . '/' . $element)) {
            $content_element = Folder::where('slug', $element)->first();
            $data['contents'][] = $content_element;
        }
    }

    return view('web.library.index', compact('data'));
}
php laravel sorting directory relationship
2个回答
0
投票

如果要从关系中排序,则必须使用

Collection
而不是
Eloquent
,例如:

$orderedLangs = $folder->langs->sortBy('lang_id');

0
投票

我终于将关系的字段“名称”添加到数组中,并将数组转换为集合,然后按“名称”排序,不区分大小写。也许还有另一种更清洁的解决方案。这有效:

控制器:

    foreach($elements as $element){
            if(is_dir($directory.'/'.$element)){
                $content_element = Folder::where('slug', $element)->first();
                $contenidos[] = $content_element;
            }else{
                $data['documents'][] = Document::where('path', $directory.'/'.$element)->first();
            }
        }

   foreach($contenidos as $contenido){
        foreach($contenido->langs as $lang){
            if($lang->lang_id == '1'){
                $contenido->name = $lang->name;
            }
        }
        $data['contents'][]= $contenido;
    }

$data['contents']=collect($data['contents'])->sortBy('name', SORT_NATURAL|SORT_FLAG_CASE);
© www.soinside.com 2019 - 2024. All rights reserved.