@if(($x=\App\Models\Domain::active() ->select('domains.*') ->join('zones',['zones.domain_id'=>'domains.id']) ->whereIn('zone_id',$o->sessions->pluck('zone_id')) ->get())->count()) <form class="row g-0 needs-validation" method="post" action="{{ url('ftn/system/filearea',$o->id) }}" novalidate> @csrf <div class="row pt-0"> <div class="col-12"> <div class="greyframe titledbox shadow0xb0"> <div class="row"> <!-- Select Domain --> <div class="col-3"> <label for="domain_id" class="form-label">Network</label> <div class="input-group has-validation"> <span class="input-group-text"><i class="bi bi-hash"></i></span> <select class="form-select @error('domain_id') is-invalid @enderror" id="filearea_domain_id" name="domain_id" required> <option></option> @foreach($x as $do) <option value="{{ $do->id }}" @if(old('domain_id') == $do->id)selected @endif>{{ $do->id }} <small>({{ $do->name }})</small></option> @endforeach </select> <span class="invalid-feedback" role="alert"> @error('domain_id') {{ $message }} @enderror </span> </div> </div> <!-- Select Address --> <div class="col-3"> <div class="d-none" id="filearea_address-select"> <label for="filearea_address_id" class="form-label">Address</label> <div class="input-group"> <span class="input-group-text"><i class="bi bi-hash"></i></span> <select class="form-select" id="filearea_address_id" name="address_id" required> <option></option> </select> </div> </div> </div> <!-- Summary of Addresses --> <div class="offset-3 col-3" id="filearea-summary"> <table class="table monotable"> <thead> <tr> <th>Network</th> <th class="text-end">Areas</th> </tr> </thead> <tbody> @foreach ($o->fileareas()->with(['domain'])->get()->groupBy('domain_id') as $oo) <tr> <td>{{ $oo->first()->domain->name }}</td> <td class="text-end">{{ $oo->count() }}</td> </tr> @endforeach </tbody> </table> </div> </div> <div class="row"> <div class="col-12 d-none" id="filearea-select"></div> </div> </div> </div> </div> </form> @endif @section('page-scripts') <script type="text/javascript" src="{{ asset('plugin/checkboxes/jquery.checkboxes-1.2.2.min.js') }}"></script> <script type="text/javascript"> $(document).ready(function() { $('#filearea_domain_id').on('change',function() { if (! $(this).val()) { $('#filearea-summary').removeClass('d-none'); $('#filearea_address-select').addClass('d-none'); return; } else { $('#filearea_address-select').removeClass('d-none'); } var item = this; icon = $(item).parent().find('i'); $.ajax({ type: 'POST', data: {domain_id: $(item).val()}, beforeSend: function() { icon.addClass('spinner-grow spinner-grow-sm'); }, success: function(data) { icon.removeClass('spinner-grow spinner-grow-sm'); $('#filearea_address_id') .empty() .append($('<option>')) .append(data.map(function(item) { return $('<option>').val(item.id).text(item.value); })); }, error: function(e) { icon.removeClass('spinner-grow spinner-grow-sm'); if (e.status != 412) alert('That didnt work? Please try again....'); }, url: '{{ url('system/address',[$o->id]) }}', cache: false }) }); $('#filearea_address_id').on('change',function() { if (! $(this).val()) { $('#filearea-summary').removeClass('d-none'); $('#filearea-select').addClass('d-none'); return; } if ($('#filearea-select').hasClass('d-none')) { $('#filearea-select').removeClass('d-none'); $('#filearea-summary').addClass('d-none'); } var item = this; icon = $(item).parent().find('i'); $.ajax({ type: 'GET', data: {address_id: $(item).val()}, beforeSend: function() { icon.addClass('spinner-grow spinner-grow-sm'); }, success: function(data) { icon.removeClass('spinner-grow spinner-grow-sm'); $('#filearea-select').empty().append(data); $('#fileareas').checkboxes('range',true); }, error: function(e) { icon.removeClass('spinner-grow spinner-grow-sm'); if (e.status != 412) alert('That didnt work? Please try again....'); }, url: '{{ url('ftn/system/filearea',[$o->id]) }}', cache: false }) }); }); </script> @append