2016-01-24 02:30:03 +00:00
{{ -- Copyright ( c ) 2015 - 2016 Dane Everitt < dane @ daneeveritt . com > -- }}
2016-01-20 20:56:40 +00:00
2016-01-24 02:30:03 +00:00
{{ -- Permission is hereby granted , free of charge , to any person obtaining a copy -- }}
{{ -- of this software and associated documentation files ( the " Software " ), to deal -- }}
{{ -- in the Software without restriction , including without limitation the rights -- }}
{{ -- to use , copy , modify , merge , publish , distribute , sublicense , and / or sell -- }}
{{ -- copies of the Software , and to permit persons to whom the Software is -- }}
{{ -- furnished to do so , subject to the following conditions : -- }}
2016-01-20 20:56:40 +00:00
2016-01-24 02:30:03 +00:00
{{ -- The above copyright notice and this permission notice shall be included in all -- }}
{{ -- copies or substantial portions of the Software . -- }}
2016-01-20 20:56:40 +00:00
2016-01-24 02:30:03 +00:00
{{ -- THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR -- }}
{{ -- IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY , -- }}
{{ -- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT . IN NO EVENT SHALL THE -- }}
{{ -- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM , DAMAGES OR OTHER -- }}
{{ -- LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR OTHERWISE , ARISING FROM , -- }}
{{ -- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -- }}
{{ -- SOFTWARE . -- }}
2015-12-06 18:58:49 +00:00
@ extends ( 'layouts.master' )
@ section ( 'title' )
Viewing Server : {{ $server -> name }}
@ endsection
@ section ( 'scripts' )
@ parent
2016-02-06 20:06:43 +00:00
{ !! Theme :: css ( 'css/metricsgraphics.css' ) !! }
2016-09-16 19:48:17 +00:00
{ !! Theme :: css ( 'css/jquery.terminal.css' ) !! }
2016-02-06 20:06:43 +00:00
{ !! Theme :: js ( 'js/d3.min.js' ) !! }
{ !! Theme :: js ( 'js/metricsgraphics.min.js' ) !! }
2016-02-26 04:57:53 +00:00
{ !! Theme :: js ( 'js/async.min.js' ) !! }
2016-09-16 19:48:17 +00:00
{ !! Theme :: js ( 'js/jquery.mousewheel-min.js' ) !! }
{ !! Theme :: js ( 'js/jquery.terminal-0.11.6.min.js' ) !! }
{ !! Theme :: js ( 'js/unix_formatting.js' ) !! }
2015-12-06 18:58:49 +00:00
@ endsection
@ section ( 'content' )
2016-01-04 21:48:22 +00:00
< div class = " col-md-12 " >
2016-01-03 05:28:33 +00:00
< ul class = " nav nav-tabs tabs_with_panel " id = " config_tabs " >
2016-09-16 19:48:17 +00:00
< li class = " active " >< a href = " #console " data - toggle = " tab " > {{ trans ( 'server.index.control' ) }} </ a ></ li >
2016-01-09 03:30:21 +00:00
@ can ( 'view-allocation' , $server ) < li >< a href = " #allocation " data - toggle = " tab " > {{ trans ( 'server.index.allocation' ) }} </ a ></ li >@ endcan
2016-01-03 05:28:33 +00:00
</ ul >
2015-12-06 18:58:49 +00:00
< div class = " tab-content " >
2016-01-03 05:28:33 +00:00
< div class = " tab-pane active " id = " console " >
< div class = " panel panel-default " >
< div class = " panel-heading " ></ div >
< div class = " panel-body " >
< div class = " row " >
< div class = " col-md-12 " >
2016-09-16 19:48:17 +00:00
< div id = " terminal " ></ div >
2016-01-03 05:28:33 +00:00
</ div >
2016-09-16 19:48:17 +00:00
< div class = " col-md-12 " style = " text-align:center; " >
2016-01-03 05:28:33 +00:00
< hr />
2016-01-18 05:56:09 +00:00
@ can ( 'power-start' , $server ) < button class = " btn btn-success btn-sm disabled " data - attr = " power " data - action = " start " > Start </ button >@ endcan
@ can ( 'power-restart' , $server ) < button class = " btn btn-primary btn-sm disabled " data - attr = " power " data - action = " restart " > Restart </ button >@ endcan
@ can ( 'power-stop' , $server ) < button class = " btn btn-danger btn-sm disabled " data - attr = " power " data - action = " stop " > Stop </ button >@ endcan
@ can ( 'power-kill' , $server ) < button class = " btn btn-danger btn-sm disabled " data - attr = " power " data - action = " kill " >< i class = " fa fa-ban " data - toggle = " tooltip " data - placement = " top " title = " Kill Running Process " ></ i ></ button >@ endcan
< button class = " btn btn-primary btn-sm " data - toggle = " modal " data - target = " #pauseConsole " id = " pause_console " >< small >< i class = " fa fa-pause fa-fw " ></ i ></ small ></ button >
< div id = " pw_resp " style = " display:none;margin-top: 15px; " ></ div >
2016-01-03 05:28:33 +00:00
</ div >
</ div >
< div class = " row " >
< div class = " col-md-12 " id = " stats_players " >
< h3 > Active Players </ h3 >< hr />
< div id = " players_notice " class = " alert alert-info " >
< i class = " fa fa-spinner fa-spin " ></ i > Waiting for response from server ...
</ div >
< span id = " toggle_players " style = " display:none; " >
< p class = " text-muted " > No players are online .</ p >
</ span >
</ div >
2015-12-06 18:58:49 +00:00
</ div >
</ div >
</ div >
</ div >
2016-01-09 03:30:21 +00:00
@ can ( 'view-allocation' , $server )
2016-01-09 03:22:57 +00:00
< div class = " tab-pane " id = " allocation " >
< div class = " panel panel-default " >
< div class = " panel-heading " ></ div >
< div class = " panel-body " >
< div class = " alert alert-info " > Below is a listing of all avaliable IPs and Ports for your service . To change the default connection address for your server , simply click on the one you would like to make default below .</ div >
< ul class = " nav nav-pills nav-stacked " id = " conn_options " >
@ foreach ( $allocations as $allocation )
2016-08-31 20:03:37 +00:00
< li role = " presentation " @ if ( $allocation -> id === $server -> allocation ) class = " active " @ endif >
< a href = " #/set-connnection/ { { $allocation->ip }}: { { $allocation->port }} " data - action = " set-connection " data - connection = " { { $allocation->ip }}: { { $allocation->port }} " > {{ $allocation -> ip_alias }}
< span class = " badge " > {{ $allocation -> port }} </ span >
@ if ( $allocation -> ip !== $allocation -> ip_alias ) < small >< span class = " pull-right " > Alias for {{ $allocation -> ip }} </ span ></ small >@ endif
</ a >
</ li >
2016-01-09 03:22:57 +00:00
@ endforeach
</ ul >
</ div >
2015-12-06 18:58:49 +00:00
</ div >
</ div >
2016-01-09 03:22:57 +00:00
@ endcan
2015-12-06 18:58:49 +00:00
</ div >
2016-02-06 20:06:43 +00:00
< div class = " panel panel-default " style = " margin-top:-22px; " >
< div class = " panel-heading " ></ div >
< div class = " panel-body " >
< div class = " row " >
< div class = " col-md-12 " >
< h4 class = " text-center " > Memory Usage ( MB ) </ h4 >
< div class = " col-md-12 " id = " chart_memory " style = " height:250px; " ></ div >
</ div >
</ div >
< div class = " row " style = " margin-top:15px; " >
< div class = " col-md-12 " >
< h4 class = " text-center " > CPU Usage ( % Total ) < small >< a href = " # " data - action = " show-all-cores " > toggle cores </ a ></ small ></ h4 >
< div class = " col-md-12 " id = " chart_cpu " style = " height:250px; " ></ div >
</ div >
</ div >
</ div >
2016-01-03 05:28:33 +00:00
</ div >
2015-12-06 18:58:49 +00:00
</ div >
< div class = " modal fade " id = " pauseConsole " tabindex = " -1 " role = " dialog " aria - labelledby = " PauseConsole " aria - hidden = " true " >
< div class = " modal-dialog " >
< div class = " modal-content " >
< div class = " modal-header " >
< button type = " button " class = " close " data - dismiss = " modal " aria - hidden = " true " >& times ; </ button >
2016-09-16 19:48:17 +00:00
< h4 class = " modal-title " id = " PauseConsole " > ScrollStop & trade ; </ h4 >
2015-12-06 18:58:49 +00:00
</ div >
< div class = " modal-body " >
< div class = " row " >
< div class = " col-md-12 " >
2016-09-16 19:48:17 +00:00
< div id = " paused_console " style = " height: 300px; overflow-x: scroll; " ></ div >
2015-12-06 18:58:49 +00:00
</ div >
</ div >
</ div >
< div class = " modal-footer " >
< button type = " button " class = " btn btn-default " data - dismiss = " modal " > {{ trans ( 'strings.close' ) }} </ button >
</ div >
</ div >
</ div >
</ div >
2016-01-09 00:54:06 +00:00
@ if ( $server -> a_serviceFile === 'minecraft' )
< script src = " { { route('server.js', [ $server->uuidShort , 'minecraft/eula.js']) }} " ></ script >
@ endif
2015-12-06 18:58:49 +00:00
< script >
$ ( window ) . load ( function () {
$ ( '[data-toggle="tooltip"]' ) . tooltip ();
2016-09-16 19:48:17 +00:00
var initialStatusSent = false ;
var currentStatus = 0 ;
var terminal = $ ( '#terminal' ) . terminal ( function ( command , term ) {
@ can ( 'power-start' , $server )
if ( currentStatus === 0 && ( command === 'start' || command === 'boot' )) {
powerToggleServer ( 'start' );
}
@ endcan
@ can ( 'send-command' , $server )
if ( currentStatus === 0 && ! ( command === 'start' || command === 'boot' )) {
term . error ( 'Server is currently off, type `start` or `boot` to start server.' );
}
if ( currentStatus !== 0 && command !== '' ) {
$ . ajax ({
type : 'POST' ,
headers : {
'X-Access-Token' : '{{ $server->daemonSecret }}' ,
'X-Access-Server' : '{{ $server->uuid }}'
},
contentType : 'application/json; charset=utf-8' ,
url : '{{ $node->scheme }}://{{ $node->fqdn }}:{{ $node->daemonListen }}/server/command' ,
timeout : 10000 ,
data : JSON . stringify ({ command : command })
}) . fail ( function ( jqXHR ) {
console . error ( jqXHR );
var error = 'An error occured while trying to process this request.' ;
if ( typeof jqXHR . responseJSON !== 'undefined' && typeof jqXHR . responseJSON . error !== 'undefined' ) {
error = jqXHR . responseJSON . error ;
}
term . error ( error );
});
}
@ else
term . error ( 'You do not have permission to send commands to this server.' );
@ endcan
}, {
greetings : '' ,
name : '{{ $server->uuid }}' ,
height : 400 ,
2016-09-17 23:13:19 +00:00
exit : false ,
2016-09-16 19:48:17 +00:00
prompt : '{{$server->name}}@{{ $server->uuidShort }}:~$ ' ,
onBlur : function ( terminal ) {
return false ;
}
});
2015-12-06 18:58:49 +00:00
2016-02-06 20:06:43 +00:00
var showOnlyTotal = true ;
$ ( '[data-action="show-all-cores"]' ) . click ( function ( event ) {
event . preventDefault ();
showOnlyTotal = ! showOnlyTotal ;
$ ( '#chart_cpu' ) . empty ();
});
2016-01-02 02:35:50 +00:00
// -----------------+
// Charting Methods |
// -----------------+
2016-02-06 20:06:43 +00:00
var memoryGraphSettings = {
data : [{
'date' : new Date (),
'memory' : - 1
}],
full_width : true ,
full_height : true ,
right : 40 ,
target : document . getElementById ( 'chart_memory' ),
x_accessor : 'date' ,
y_accessor : 'memory' ,
2016-02-26 04:57:53 +00:00
animate_on_load : false ,
2016-02-06 20:06:43 +00:00
y_rug : true ,
area : false ,
};
2016-01-02 02:35:50 +00:00
2016-02-06 20:06:43 +00:00
var cpuGraphData = [
[{
'date' : new Date (),
'cpu' : - 1
2016-01-02 02:35:50 +00:00
}]
2016-02-06 20:06:43 +00:00
];
var cpuGraphSettings = {
data : cpuGraphData ,
legend : [ 'Total' , 'C0' , 'C1' , 'C2' , 'C3' , 'C4' , 'C5' , 'C6' , 'C7' ],
2016-01-02 02:35:50 +00:00
colors : [
2016-02-06 20:06:43 +00:00
'#113F8C' ,
2016-01-02 02:35:50 +00:00
'#00A1CB' ,
'#01A4A4' ,
'#61AE24' ,
'#D0D102' ,
'#D70060' ,
'#E54028' ,
'#F18D05' ,
'#616161' ,
'#32742C' ,
],
2016-02-06 20:06:43 +00:00
right : 40 ,
full_width : true ,
full_height : true ,
target : document . getElementById ( 'chart_cpu' ),
x_accessor : 'date' ,
y_accessor : 'cpu' ,
aggregate_rollover : true ,
missing_is_hidden : true ,
2016-02-26 04:57:53 +00:00
animate_on_load : false ,
2016-02-06 20:06:43 +00:00
area : false ,
};
2016-01-02 02:35:50 +00:00
2016-02-06 20:06:43 +00:00
MG . data_graphic ( memoryGraphSettings );
MG . data_graphic ( cpuGraphSettings );
2016-01-02 02:35:50 +00:00
2015-12-06 18:58:49 +00:00
// Socket Recieves New Server Stats
2016-01-24 06:24:41 +00:00
var activeChartArrays = [];
2016-01-02 02:35:50 +00:00
socket . on ( 'proc' , function ( proc ) {
2016-02-06 20:06:43 +00:00
var curDate = new Date ();
if ( typeof memoryGraphSettings . data [ 0 ][ 20 ] !== 'undefined' || memoryGraphSettings . data [ 0 ][ 0 ] . memory === - 1 ) {
memoryGraphSettings . data [ 0 ] . shift ();
}
if ( typeof cpuGraphData [ 0 ][ 20 ] !== 'undefined' || cpuGraphData [ 0 ][ 0 ] . cpu === - 1 ) {
cpuGraphData [ 0 ] . shift ();
}
memoryGraphSettings . data [ 0 ] . push ({
'date' : curDate ,
'memory' : parseInt ( proc . data . memory . total / ( 1024 * 1024 ))
});
cpuGraphData [ 0 ] . push ({
'date' : curDate ,
'cpu' : ({{ $server -> cpu }} > 0 ) ? parseFloat ((( proc . data . cpu . total / {{ $server -> cpu }}) * 100 ) . toFixed ( 3 ) . toString ()) : proc . data . cpu . total
});
2016-01-02 02:35:50 +00:00
2016-02-26 04:57:53 +00:00
async . waterfall ([
function ( callback ) {
// Remove blank values from listing
var activeCores = [];
async . forEachOf ( proc . data . cpu . cores , function ( inner , i , eachCallback ) {
if ( proc . data . cpu . cores [ i ] > 0 ) {
activeCores . push ( proc . data . cpu . cores [ i ]);
}
return eachCallback ();
}, function () {
return callback ( null , activeCores );
2016-02-06 20:06:43 +00:00
});
2016-02-26 04:57:53 +00:00
},
function ( active , callback ) {
var modifedActiveCores = { '0' : 0 };
async . forEachOf ( active , function ( inner , i , eachCallback ) {
if ( i > 7 ) {
modifedActiveCores [ '0' ] = modifedActiveCores [ '0' ] + active [ i ];
} else {
if ( activeChartArrays . indexOf ( i ) < 0 ) activeChartArrays . push ( i );
modifedActiveCores [ i ] = active [ i ];
}
return eachCallback ();
}, function () {
return callback ( null , modifedActiveCores );
});
},
function ( modified , callback ) {
async . forEachOf ( activeChartArrays , function ( inner , i , eachCallback ) {
if ( typeof cpuGraphData [( i + 1 )] === 'undefined' ) {
cpuGraphData [( i + 1 )] = [{
'date' : curDate ,
'cpu' : ({{ $server -> cpu }} > 0 ) ? parseFloat (((( modified [ i ] || 0 ) / {{ $server -> cpu }}) * 100 ) . toFixed ( 3 ) . toString ()) : modified [ i ] || null
}];
} else {
if ( typeof cpuGraphData [( i + 1 )][ 20 ] !== 'undefined' ) cpuGraphData [( i + 1 )] . shift ();
cpuGraphData [( i + 1 )] . push ({
'date' : curDate ,
'cpu' : ({{ $server -> cpu }} > 0 ) ? parseFloat (((( modified [ i ] || 0 ) / {{ $server -> cpu }}) * 100 ) . toFixed ( 3 ) . toString ()) : modified [ i ] || null
});
}
return eachCallback ();
}, function () {
return callback ();
});
},
function ( callback ) {
cpuGraphSettings . data = ( showOnlyTotal === true ) ? cpuGraphData [ 0 ] : cpuGraphData ;
return callback ();
},
], function () {
MG . data_graphic ( memoryGraphSettings );
MG . data_graphic ( cpuGraphSettings );
});
2015-12-06 18:58:49 +00:00
});
// Socket Recieves New Query
socket . on ( 'query' , function ( data ){
if ( $ ( '#players_notice' ) . is ( ':visible' )){
$ ( '#players_notice' ) . hide ();
$ ( '#toggle_players' ) . show ();
}
2016-02-26 04:57:31 +00:00
if ( typeof data [ 'data' ] !== 'undefined' && typeof data [ 'data' ] . players !== 'undefined' && data [ 'data' ] . players . length !== 0 ){
2015-12-06 18:58:49 +00:00
$ ( '#toggle_players' ) . html ( '' );
$ . each ( data [ 'data' ] . players , function ( id , d ) {
$ ( '#toggle_players' ) . append ( '<code>' + d . name + '</code>,' );
});
} else {
$ ( '#toggle_players' ) . html ( '<p class=\'text-muted\'>No players are currently online.</p>' );
}
});
// New Console Data Recieved
socket . on ( 'console' , function ( data ) {
2016-09-16 19:48:17 +00:00
terminal . echo ( data . line );
2015-12-06 18:58:49 +00:00
});
// Update Listings on Initial Status
socket . on ( 'initial_status' , function ( data ) {
2016-09-16 19:48:17 +00:00
currentStatus = data . status ;
console . log ( data . status );
2015-12-06 18:58:49 +00:00
if ( data . status !== 0 ) {
$ . ajax ({
type : 'GET' ,
headers : {
'X-Access-Token' : '{{ $server->daemonSecret }}' ,
'X-Access-Server' : '{{ $server->uuid }}'
},
2016-01-01 23:08:15 +00:00
url : '{{ $node->scheme }}://{{ $node->fqdn }}:{{ $node->daemonListen }}/server/log' ,
2015-12-06 18:58:49 +00:00
timeout : 10000
}) . done ( function ( data ) {
2016-09-16 19:48:17 +00:00
terminal . echo ( data );
}) . fail ( function () {
terminal . error ( 'Unable to load initial server log, try reloading the page.' );
2015-12-06 18:58:49 +00:00
});
}
updateServerPowerControls ( data . status );
updatePlayerListVisibility ( data . status );
});
// Update Listings on Status
socket . on ( 'status' , function ( data ) {
2016-09-16 19:48:17 +00:00
currentStatus = data . status ;
2015-12-06 18:58:49 +00:00
updateServerPowerControls ( data . status );
updatePlayerListVisibility ( data . status );
});
// Load Paused Console with Live Console Data
$ ( '#pause_console' ) . click ( function (){
2016-09-16 19:48:17 +00:00
$ ( '#paused_console' ) . html ( $ ( '#terminal' ) . html ());
2015-12-06 18:58:49 +00:00
});
function updatePlayerListVisibility ( data ) {
// Server is On or Starting
2015-12-31 22:55:42 +00:00
if ( data !== 0 ) {
2015-12-06 18:58:49 +00:00
$ ( '#stats_players' ) . show ();
} else {
$ ( '#stats_players' ) . hide ();
}
}
2016-01-03 05:28:33 +00:00
2016-01-09 03:36:57 +00:00
@ can ( 'set-allocation' , $server )
2016-01-03 20:15:14 +00:00
// Send Request
$ ( '[data-action="set-connection"]' ) . click ( function ( event ) {
event . preventDefault ();
var element = $ ( this );
if ( element . hasClass ( 'active' )) {
return ;
}
$ . ajax ({
method : 'POST' ,
url : '/server/{{ $server->uuidShort }}/ajax/set-connection' ,
data : {
connection : element . data ( 'connection' )
},
headers : {
'X-CSRF-TOKEN' : '{{ csrf_token() }}'
}
}) . done ( function ( data ) {
2016-01-09 03:36:57 +00:00
swal ({
type : 'success' ,
title : '' ,
text : data
});
2016-01-03 20:15:14 +00:00
$ ( '#conn_options' ) . find ( 'li.active' ) . removeClass ( 'active' );
element . parent () . addClass ( 'active' );
}) . fail ( function ( jqXHR ) {
console . error ( jqXHR );
2016-01-09 03:36:57 +00:00
var respError ;
2016-01-03 20:15:14 +00:00
if ( typeof jqXHR . responseJSON . error === 'undefined' || jqXHR . responseJSON . error === '' ) {
2016-01-09 03:36:57 +00:00
respError = 'An error occured while attempting to perform this action.' ;
2016-01-03 20:15:14 +00:00
} else {
2016-01-09 03:36:57 +00:00
respError = jqXHR . responseJSON . error ;
2016-01-03 20:15:14 +00:00
}
2016-01-09 03:36:57 +00:00
swal ({
type : 'error' ,
title : 'Whoops!' ,
text : respError
});
2016-01-03 20:15:14 +00:00
});
});
@ endcan
2016-01-18 05:56:09 +00:00
var can_run = true ;
function updateServerPowerControls ( data ) {
// Server is On or Starting
if ( data == 1 || data == 2 ) {
$ ( '[data-attr="power"][data-action="start"]' ) . addClass ( 'disabled' );
$ ( '[data-attr="power"][data-action="stop"], [data-attr="power"][data-action="restart"]' ) . removeClass ( 'disabled' );
} else {
$ ( '[data-attr="power"][data-action="start"]' ) . removeClass ( 'disabled' );
$ ( '[data-attr="power"][data-action="stop"], [data-attr="power"][data-action="restart"]' ) . addClass ( 'disabled' );
2015-12-06 18:58:49 +00:00
}
2016-01-18 05:56:09 +00:00
if ( data !== 0 ) {
$ ( '[data-attr="power"][data-action="kill"]' ) . removeClass ( 'disabled' );
} else {
$ ( '[data-attr="power"][data-action="kill"]' ) . addClass ( 'disabled' );
}
}
2015-12-06 18:58:49 +00:00
2016-01-18 05:56:09 +00:00
$ ( '[data-attr="power"]' ) . click ( function ( event ) {
event . preventDefault ();
var action = $ ( this ) . data ( 'action' );
var killConfirm = false ;
if ( action === 'kill' ) {
swal ({
type : 'warning' ,
title : '' ,
text : 'This operation will not save your server data gracefully. You should only use this if your server is failing to respond to normal stop commands.' ,
showCancelButton : true ,
allowOutsideClick : true ,
closeOnConfirm : true ,
confirmButtonText : 'Kill Server' ,
confirmButtonColor : '#d9534f'
}, function () {
setTimeout ( function () {
powerToggleServer ( 'kill' );
}, 100 );
2016-01-09 03:54:30 +00:00
});
2016-01-18 05:56:09 +00:00
} else {
powerToggleServer ( action );
2016-01-09 03:54:30 +00:00
}
2016-01-18 05:56:09 +00:00
});
function powerToggleServer ( action ) {
$ . ajax ({
type : 'PUT' ,
headers : {
'X-Access-Token' : '{{ $server->daemonSecret }}' ,
'X-Access-Server' : '{{ $server->uuid }}'
},
contentType : 'application/json; charset=utf-8' ,
data : JSON . stringify ({
action : action
}),
url : '{{ $node->scheme }}://{{ $node->fqdn }}:{{ $node->daemonListen }}/server/power' ,
timeout : 10000
}) . fail ( function ( jqXHR ) {
var error = 'An error occured while trying to process this request.' ;
if ( typeof jqXHR . responseJSON !== 'undefined' && typeof jqXHR . responseJSON . error !== 'undefined' ) {
error = jqXHR . responseJSON . error ;
}
swal ({
type : 'error' ,
title : 'Whoops!' ,
text : error
});
});
}
2015-12-06 18:58:49 +00:00
});
$ ( document ) . ready ( function () {
$ ( '.server-index' ) . addClass ( 'active' );
});
</ script >
@ endsection