Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

remove global scope from relation in laravel

7 project and i have this global scope for Voucher_detale model

<?php
namespace App\Scopes;
use Illuminate\Database\Eloquent\Scope;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
class getVouchers implements Scope
{
    public function apply(Builder $builder, Model $model)
    {
        $builder->where('vouchers_detale_state', '=', 1);
    }
}

and i have Voucher model and it has hasMany inside this is the code'

public function getDetales()
{
    return $this->hasMany('App\Vouchers_detale','vouchers_detale_voucher_id','id')->withTrashed();
}

inside the blade i have this code

@foreach($voucher['getDetales'] as $v)
<tr class='table-warning'>
    <td>
        <a href='/{{$path}}/Vouchers_detales/{{$v["id"]}}'>{{$v['vouchers_detale_user_id']}}</a>

        <div class='selected d-print-none'>
            @foreach($v->getUpdate as $update)
                <span style='color:black'>{{$update['update_history_old_amount']}}</span>
                {{$update['created_at']}}
                {{$update['getUserData']['user_name']}}
                <hr />
            @endforeach
        </div>
    </td>
    <td>{{$v['getUserData']['user_name']}}</td>
    @if($v['vouchers_detale_amount'] > 0)
        <td>{{$v['vouchers_detale_amount']}}</td>
        <td></td>
        @php $total_debt +=  $v['vouchers_detale_amount'] @endphp
    @else
        <td></td>
        <td>{{$v['vouchers_detale_amount'] * -1}}</td>
        @php $total_credit += $v['vouchers_detale_amount'] * -1 @endphp
    @endif
    <td>{{$v['vouchers_detale_desc']}}</td>
</tr>
@endforeach

now how can i ignore the global scope in the foreach i tried this

@foreach($voucher['getDetales']->withoutGlobalScopes() as $v)

i gat this error

Method Illuminate\Database\Eloquent\Collection::withoutGlobalScopes does not exist.

how can i ignore global scope come from relation in foreach thanks

like image 497
Awar Pulldozer Avatar asked Oct 25 '18 10:10

Awar Pulldozer


1 Answers

never mind i just created a new relation

public function getDetalesWithout()
{
    return $this->hasMany('App\Vouchers_detale','vouchers_detale_voucher_id','id')->withTrashed()->withoutGlobalScope('App\Scopes\getVouchers');
}

thanks

like image 96
Awar Pulldozer Avatar answered Oct 01 '22 07:10

Awar Pulldozer