2023-07-28 13:22:39 +10:00
|
|
|
<!-- $o = Domain::class -->
|
2021-06-15 22:19:14 +10:00
|
|
|
@extends('layouts.app')
|
|
|
|
@section('htmlheader_title')
|
|
|
|
{{ $o->name }}
|
|
|
|
@endsection
|
|
|
|
|
|
|
|
@section('content')
|
2021-06-24 20:16:37 +10:00
|
|
|
<h1>{{ $o->name }} <small class="float-end pt-4">Last Update: {{ $o->updated_at->format('Y-m-d H:i') }}</small></h1>
|
|
|
|
|
2021-06-20 23:03:20 +10:00
|
|
|
<div class="accordion" id="accordion_homepage">
|
2021-06-19 14:40:55 +10:00
|
|
|
<!-- About -->
|
2021-06-19 11:59:01 +10:00
|
|
|
<div class="accordion-item">
|
2023-12-04 09:03:54 +11:00
|
|
|
<h3 class="accordion-header">
|
|
|
|
<span class="accordion-button" id="about" data-bs-toggle="collapse" data-bs-target="#collapse_about" aria-expanded="true" aria-controls="collapse_about">About</span>
|
|
|
|
</h3>
|
2021-06-19 11:59:01 +10:00
|
|
|
|
|
|
|
<div id="collapse_about" class="accordion-collapse collapse show" aria-labelledby="about" data-bs-parent="#accordion_homepage">
|
|
|
|
<div class="accordion-body">
|
2022-01-06 00:19:57 +11:00
|
|
|
<div class="float-end" style="max-height: 25em;" id="network_traffic"></div>
|
2021-06-19 11:59:01 +10:00
|
|
|
{!! \Illuminate\Mail\Markdown::parse($o->homepage) !!}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2021-06-19 14:40:55 +10:00
|
|
|
<!-- Echomail -->
|
2021-06-20 23:03:20 +10:00
|
|
|
<div class="accordion-item open">
|
2023-12-04 09:03:54 +11:00
|
|
|
<h3 class="accordion-header">
|
|
|
|
<span class="accordion-button collapsed" id="echoareas" data-bs-toggle="collapse" data-bs-target="#collapse_echoareas" aria-expanded="false" aria-controls="collapse_echoareas">Echo Areas</span>
|
|
|
|
</h3>
|
2021-06-19 11:59:01 +10:00
|
|
|
|
|
|
|
<div id="collapse_echoareas" class="accordion-collapse collapse" aria-labelledby="echoareas" data-bs-parent="#accordion_homepage">
|
|
|
|
<div class="accordion-body">
|
2021-08-11 23:45:30 +10:00
|
|
|
@if($o->echoareas->count())
|
|
|
|
<p>This network provides the following Echomail areas:</p>
|
2021-08-14 11:11:20 +10:00
|
|
|
<table class="table monotable w-100" id="echoarea">
|
2021-08-11 23:45:30 +10:00
|
|
|
<thead>
|
2021-08-12 00:15:58 +10:00
|
|
|
<tr>
|
2023-07-06 09:35:15 +10:00
|
|
|
<th class="w-75" colspan="4"></th>
|
2023-07-30 20:14:38 +10:00
|
|
|
<th colspan="4" class="text-center">Messages</th>
|
2021-08-12 00:15:58 +10:00
|
|
|
</tr>
|
2021-08-11 23:45:30 +10:00
|
|
|
<tr>
|
|
|
|
<th>Echoarea</th>
|
|
|
|
<th>Description</th>
|
|
|
|
<th>Last Message</th>
|
2023-07-06 09:35:15 +10:00
|
|
|
<th>Area Active</th>
|
2021-08-12 00:15:58 +10:00
|
|
|
<th class="text-end">Day</th>
|
|
|
|
<th class="text-end">Week</th>
|
|
|
|
<th class="text-end">Month</th>
|
2023-07-30 20:14:38 +10:00
|
|
|
<th class="text-end">Total</th>
|
2021-08-11 23:45:30 +10:00
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
|
|
|
|
<tbody>
|
2023-07-30 20:14:38 +10:00
|
|
|
@foreach ($o->echoarea_stats()->groupBy('id') as $oo)
|
2021-08-11 23:45:30 +10:00
|
|
|
<tr>
|
2023-10-05 22:49:57 +11:00
|
|
|
<td style="width: 15%;"><a href="{{ url('echoarea/addedit',[($x=$oo->first())->id]) }}">{{ $x->name }}</a></td>
|
2023-07-30 20:14:38 +10:00
|
|
|
<td>{{ $x->description }}</td>
|
|
|
|
<td style="width: 15%;">{{ $x->last_message ? $x->last_message->format('Y-m-d H:i') : '-' }}</td>
|
|
|
|
<td>{{ $x->active ? 'Active' : 'Archive' }}</td>
|
|
|
|
<td class="text-end">{{ number_format($oo->where('stats','day')->pop()?->count) }}</td>
|
|
|
|
<td class="text-end">{{ number_format($oo->where('stats','week')->pop()?->count) }}</td>
|
|
|
|
<td class="text-end">{{ number_format($oo->where('stats','month')->pop()?->count) }}</td>
|
2023-09-12 00:10:16 +10:00
|
|
|
<td class="text-end">{{ number_format($oo->sum('count')) }}</td>
|
2021-08-11 23:45:30 +10:00
|
|
|
</tr>
|
|
|
|
@endforeach
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2021-06-19 11:59:01 +10:00
|
|
|
@else
|
|
|
|
This network doesnt have any Echomail areas (yet). Perhaps you would like to create one?
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2021-06-19 14:40:55 +10:00
|
|
|
<!-- File areas -->
|
2021-06-19 11:59:01 +10:00
|
|
|
<div class="accordion-item">
|
2023-12-04 09:03:54 +11:00
|
|
|
<h3 class="accordion-header">
|
|
|
|
<span class="accordion-button collapsed" id="fileareas" data-bs-toggle="collapse" data-bs-target="#collapse_fileareas" aria-expanded="false" aria-controls="collapse_fileareas">File Areas</span>
|
|
|
|
</h3>
|
2021-06-19 11:59:01 +10:00
|
|
|
|
|
|
|
<div id="collapse_fileareas" class="accordion-collapse collapse" aria-labelledby="fileareas" data-bs-parent="#accordion_homepage">
|
|
|
|
<div class="accordion-body">
|
2021-08-11 23:45:30 +10:00
|
|
|
@if($o->fileareas->count())
|
|
|
|
<p>This network provides the following File areas:</p>
|
2021-08-14 11:11:20 +10:00
|
|
|
<table class="table monotable" id="filearea">
|
2021-08-11 23:45:30 +10:00
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Filearea</th>
|
|
|
|
<th>Description</th>
|
|
|
|
<th>Last File Sent</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
|
|
|
|
<tbody>
|
|
|
|
@foreach ($o->fileareas->sortBy('name') as $oo)
|
|
|
|
<tr>
|
2023-10-05 22:49:57 +11:00
|
|
|
<td style="width: 15%;"><a href="{{ url('filearea/addedit',[$oo->id]) }}">{{ $oo->name }}</a></td>
|
2021-08-11 23:45:30 +10:00
|
|
|
<td>{{ $oo->description }}</td>
|
2021-08-14 23:39:42 +10:00
|
|
|
<td style="width: 15%;">-</td>
|
2021-08-11 23:45:30 +10:00
|
|
|
</tr>
|
|
|
|
@endforeach
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2021-06-19 11:59:01 +10:00
|
|
|
@else
|
|
|
|
This network doesnt have any File areas (yet). Perhaps you would like to create one?
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2021-06-19 14:40:55 +10:00
|
|
|
<!-- Systems -->
|
2021-06-19 11:59:01 +10:00
|
|
|
<div class="accordion-item">
|
2023-12-04 09:03:54 +11:00
|
|
|
<h3 class="accordion-header">
|
|
|
|
<span class="accordion-button collapsed" id="systems" data-bs-toggle="collapse" data-bs-target="#collapse_systems" aria-expanded="false" aria-controls="collapse_systems">Systems</span>
|
|
|
|
</h3>
|
2021-06-19 11:59:01 +10:00
|
|
|
|
|
|
|
<div id="collapse_systems" class="accordion-collapse collapse" aria-labelledby="systems" data-bs-parent="#accordion_homepage">
|
|
|
|
<div class="accordion-body">
|
|
|
|
<p>The following systems are members of this network.</p>
|
2021-08-14 11:11:20 +10:00
|
|
|
<table class="table monotable" id="system">
|
2021-06-19 11:59:01 +10:00
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>System</th>
|
|
|
|
<th>Sysop</th>
|
|
|
|
<th>Location</th>
|
|
|
|
<th>Address</th>
|
2021-06-20 23:03:20 +10:00
|
|
|
<th>Last Seen</th>
|
2021-06-19 11:59:01 +10:00
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
|
|
|
|
<tbody>
|
2021-06-25 16:42:12 +10:00
|
|
|
@foreach ($o->zones->sortBy('zone_id') as $oz)
|
2021-07-26 21:21:58 +10:00
|
|
|
@foreach ($oz->addresses as $ao)
|
2021-06-20 23:03:20 +10:00
|
|
|
<tr>
|
2023-10-05 22:15:53 +11:00
|
|
|
<td><a href="{{ url('system/addedit',[$ao->system_id]) }}">{{ $ao->system->full_name($ao) }}</a> @auth<span class="float-end"><small>@if($ao->session('sespass'))<sup>{{ $ao->session('default') ? '**' : '*' }}</sup>@elseif($ao->system->setup)<sup class="success">+</sup>@endif[{{ $ao->system_id }}]</small></span>@endauth</td>
|
2021-06-20 23:03:20 +10:00
|
|
|
<td>{{ $ao->system->sysop }}</td>
|
|
|
|
<td>{{ $ao->system->location }}</td>
|
2023-04-15 20:30:11 +10:00
|
|
|
<td>{{ $ao->ftn4d }}</td>
|
2021-07-04 23:24:38 +10:00
|
|
|
<td>{{ $ao->system->last_session ? $ao->system->last_session->format('Y-m-d H:i') : '-' }}</td>
|
2021-06-20 23:03:20 +10:00
|
|
|
</tr>
|
|
|
|
@endforeach
|
2021-06-19 11:59:01 +10:00
|
|
|
@endforeach
|
|
|
|
</tbody>
|
2021-07-31 17:43:58 +10:00
|
|
|
@auth
|
|
|
|
<tfoot>
|
|
|
|
<tr>
|
2021-08-09 23:35:22 +10:00
|
|
|
<td colspan="5"><sup>**</sup>Default route <sup>*</sup>System defined here <sup class="success">+</sup>This system</td>
|
2021-07-31 17:43:58 +10:00
|
|
|
</tr>
|
|
|
|
</tfoot>
|
|
|
|
@endauth
|
2021-06-19 11:59:01 +10:00
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-19 14:40:55 +10:00
|
|
|
|
|
|
|
<!-- Sign up -->
|
|
|
|
<div class="accordion-item">
|
2023-12-04 09:03:54 +11:00
|
|
|
<h3 class="accordion-header">
|
|
|
|
<span class="accordion-button collapsed" id="signup" data-bs-toggle="collapse" data-bs-target="#collapse_signup" aria-expanded="false" aria-controls="collapse_signup">Join Network</span>
|
|
|
|
</h3>
|
2021-06-19 14:40:55 +10:00
|
|
|
|
|
|
|
<div id="collapse_signup" class="accordion-collapse collapse" aria-labelledby="signup" data-bs-parent="#accordion_homepage">
|
|
|
|
<div class="accordion-body">
|
|
|
|
@guest
|
|
|
|
To start an application to join this network please <a href="{{ url('login') }}">login</a>.
|
|
|
|
@else
|
2021-09-28 00:21:21 +10:00
|
|
|
@if($user->isMember($o))
|
2021-06-19 14:40:55 +10:00
|
|
|
@else
|
|
|
|
This website is not ready to take applications yet, check back soon!
|
|
|
|
@endif
|
|
|
|
@endguest
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-19 11:59:01 +10:00
|
|
|
</div>
|
2021-06-26 10:34:49 +10:00
|
|
|
@endsection
|
|
|
|
|
2021-11-13 17:00:08 +11:00
|
|
|
@section('page-css')
|
|
|
|
@css('datatables')
|
2021-11-26 16:16:33 +11:00
|
|
|
<style>
|
|
|
|
div#collapse_about {
|
2022-01-06 00:19:57 +11:00
|
|
|
min-height: 25em;
|
2021-11-26 16:16:33 +11:00
|
|
|
}
|
|
|
|
div#collapse_about .collapse{
|
|
|
|
min-height: 0;
|
|
|
|
}
|
|
|
|
</style>
|
2021-11-13 17:00:08 +11:00
|
|
|
@append
|
2021-06-26 10:34:49 +10:00
|
|
|
@section('page-scripts')
|
2021-11-13 17:00:08 +11:00
|
|
|
@js('datatables')
|
2021-11-26 16:16:33 +11:00
|
|
|
@js('highcharts')
|
2021-06-26 10:34:49 +10:00
|
|
|
|
|
|
|
<script type="text/javascript">
|
2021-08-14 11:11:20 +10:00
|
|
|
$(document).ready(function() {
|
|
|
|
$('table tr').click(function() {
|
|
|
|
var href = $(this).find('a').attr('href');
|
|
|
|
|
|
|
|
if (href)
|
|
|
|
window.location = href;
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#echoarea').DataTable({
|
|
|
|
paging: true,
|
|
|
|
pageLength: 25,
|
|
|
|
searching: true,
|
2021-08-14 23:39:42 +10:00
|
|
|
ordering: true,
|
2023-07-06 09:35:15 +10:00
|
|
|
order: [[3,'asc'],[1,'asc']],
|
2021-08-14 11:11:20 +10:00
|
|
|
conditionalPaging: {
|
|
|
|
style: 'fade',
|
|
|
|
speed: 500 // optional
|
2023-07-06 09:35:15 +10:00
|
|
|
},
|
|
|
|
rowGroup: {
|
|
|
|
dataSrc: [3],
|
|
|
|
},
|
|
|
|
columnDefs: [
|
|
|
|
{
|
|
|
|
targets: [3],
|
|
|
|
visible: false,
|
|
|
|
},
|
|
|
|
],
|
2021-08-14 11:11:20 +10:00
|
|
|
});
|
|
|
|
|
|
|
|
$('#filearea').DataTable({
|
|
|
|
paging: true,
|
|
|
|
pageLength: 25,
|
|
|
|
searching: true,
|
2021-08-14 23:39:42 +10:00
|
|
|
ordering: true,
|
|
|
|
order: [1,'asc'],
|
2021-08-14 11:11:20 +10:00
|
|
|
conditionalPaging: {
|
|
|
|
style: 'fade',
|
|
|
|
speed: 500 // optional
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#system').DataTable({
|
|
|
|
paging: true,
|
|
|
|
pageLength: 25,
|
|
|
|
searching: true,
|
2021-08-15 11:42:38 +10:00
|
|
|
ordering: true,
|
|
|
|
order: [],
|
2021-08-14 11:11:20 +10:00
|
|
|
conditionalPaging: {
|
|
|
|
style: 'fade',
|
|
|
|
speed: 500 // optional
|
|
|
|
},
|
|
|
|
language: {
|
|
|
|
paginate: {
|
|
|
|
previous: '<<',
|
|
|
|
next: '>>'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2021-06-26 10:34:49 +10:00
|
|
|
});
|
2021-11-26 16:16:33 +11:00
|
|
|
|
|
|
|
Highcharts.chart('network_traffic', {
|
|
|
|
chart: {
|
|
|
|
type: 'spline',
|
|
|
|
zoomType: 'x',
|
2023-06-13 20:22:40 +10:00
|
|
|
backgroundColor: '#0a0a0a',
|
2021-11-26 16:16:33 +11:00
|
|
|
resetZoomButton: {
|
|
|
|
position: {
|
2022-01-06 00:19:57 +11:00
|
|
|
align: 'left',
|
|
|
|
x: -40,
|
2021-11-26 16:16:33 +11:00
|
|
|
y: -40,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
credits: {
|
|
|
|
enabled: false
|
|
|
|
},
|
|
|
|
exporting: {
|
|
|
|
buttons: false
|
|
|
|
},
|
|
|
|
title: {
|
|
|
|
text: 'FTN Network Traffic for {{ $o->name }}'
|
|
|
|
},
|
|
|
|
xAxis: {
|
|
|
|
type: 'datetime',
|
|
|
|
title: {
|
|
|
|
text: 'Time'
|
|
|
|
},
|
|
|
|
},
|
|
|
|
yAxis: {
|
|
|
|
title: {
|
|
|
|
text: 'Echomail'
|
|
|
|
},
|
|
|
|
},
|
|
|
|
legend: {
|
2022-01-01 16:59:35 +11:00
|
|
|
align: 'right',
|
|
|
|
layout: 'vertical',
|
2022-01-06 00:19:57 +11:00
|
|
|
symbolWidth: 20,
|
2022-01-01 16:59:35 +11:00
|
|
|
floating: false,
|
|
|
|
navigation: {
|
|
|
|
arrowSize: 10
|
|
|
|
},
|
2021-11-26 16:16:33 +11:00
|
|
|
},
|
|
|
|
plotOptions: {
|
|
|
|
series: {
|
|
|
|
point: {
|
|
|
|
events: {
|
|
|
|
click: function () {
|
|
|
|
//window.location.href = this.series.options.website;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
cursor: 'pointer'
|
|
|
|
}
|
|
|
|
},
|
2024-04-20 22:03:47 +10:00
|
|
|
series: {!! $o->echoarea_total_daily()
|
|
|
|
->groupBy('name')
|
|
|
|
->transform(function($item,$key) { return [
|
|
|
|
'name'=>$key,
|
|
|
|
'dashStyle'=>'ShortDot',
|
|
|
|
'visible'=>$item->first()->show,
|
|
|
|
'data'=>$item->map(function($item) { return ['x'=>\Carbon\Carbon::createFromFormat('Y-m-d',$item->date)->timestamp,'y'=>$item->count]; })
|
|
|
|
]; })
|
|
|
|
->values() !!}
|
2021-11-26 16:16:33 +11:00
|
|
|
});
|
2021-06-26 10:34:49 +10:00
|
|
|
</script>
|
|
|
|
@append
|