mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-25 18:16:51 +02:00 
			
		
		
		
	Add location delete support
This commit is contained in:
		
							parent
							
								
									861af87e93
								
							
						
					
					
						commit
						21a95a5d0e
					
				| @ -27,9 +27,28 @@ class LocationsController extends Controller | |||||||
|         ]); |         ]); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function postView(Request $request) |     public function deleteLocation(Request $request, $id) | ||||||
|     { |     { | ||||||
|         $location = Models\Location::findOrFail($request->input('location_id')); |         $model = Models\Location::select( | ||||||
|  |             'locations.id', | ||||||
|  |             DB::raw('(SELECT COUNT(*) FROM nodes WHERE nodes.location = locations.id) as a_nodeCount'), | ||||||
|  |             DB::raw('(SELECT COUNT(*) FROM servers WHERE servers.node IN (SELECT nodes.id FROM nodes WHERE nodes.location = locations.id)) as a_serverCount') | ||||||
|  |         )->where('id', $id)->first(); | ||||||
|  | 
 | ||||||
|  |         if (!$model) { | ||||||
|  |             return response()->json([ | ||||||
|  |                 'error' => 'No location with that ID exists on the system.' | ||||||
|  |             ], 404); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if ($model->a_nodeCount > 0 || $model->a_serverCount > 0) { | ||||||
|  |             return response()->json([ | ||||||
|  |                 'error' => 'You cannot remove a location that is currently assigned to a node or server.' | ||||||
|  |             ], 422); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         $model->delete(); | ||||||
|  |         return response('', 204); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -216,6 +216,9 @@ class AdminRoutes { | |||||||
|                 'as' => 'admin.locations', |                 'as' => 'admin.locations', | ||||||
|                 'uses' => 'Admin\LocationsController@getIndex' |                 'uses' => 'Admin\LocationsController@getIndex' | ||||||
|             ]); |             ]); | ||||||
|  |             $router->delete('/{id}', [ | ||||||
|  |                 'uses' => 'Admin\LocationsController@deleteLocation' | ||||||
|  |             ]); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|         // API Routes
 |         // API Routes
 | ||||||
|  | |||||||
| @ -18,15 +18,19 @@ | |||||||
|                 <th>Description</th> |                 <th>Description</th> | ||||||
|                 <th class="text-center">Nodes</th> |                 <th class="text-center">Nodes</th> | ||||||
|                 <th class="text-center">Servers</th> |                 <th class="text-center">Servers</th> | ||||||
|  |                 <th class="text-center"></th> | ||||||
|  |                 <th class="text-center"></th> | ||||||
|             </tr> |             </tr> | ||||||
|         </thead> |         </thead> | ||||||
|         <tbody> |         <tbody> | ||||||
|             @foreach ($locations as $location) |             @foreach ($locations as $location) | ||||||
|                 <tr> |                 <tr> | ||||||
|                     <td><a href="#/edit/{{ $location->id }}" data-action="edit" data-location="{{ $location->id }}"><code>{{ $location->short }}</code></td> |                     <td><code>{{ $location->short }}</code></td> | ||||||
|                     <td>{{ $location->long }}</td> |                     <td>{{ $location->long }}</td> | ||||||
|                     <td class="text-center">{{ $location->a_nodeCount }}</td> |                     <td class="text-center">{{ $location->a_nodeCount }}</td> | ||||||
|                     <td class="text-center">{{ $location->a_serverCount }}</td> |                     <td class="text-center">{{ $location->a_serverCount }}</td> | ||||||
|  |                     <td class="text-center"><a href="#edit"><i class="fa fa-wrench" data-action="edit" data-id="{{ $location->id }}" data-short="{{ $location->short }}" data-long="{{ $location->long }}"></i></a></td> | ||||||
|  |                     <td class="text-center"><a href="#delete" class="text-danger" data-action="delete" data-id="{{ $location->id }}"><i class="fa fa-trash-o"></i></a></td> | ||||||
|                 </tr> |                 </tr> | ||||||
|             @endforeach |             @endforeach | ||||||
|         </tbody> |         </tbody> | ||||||
| @ -34,10 +38,51 @@ | |||||||
|     <div class="row"> |     <div class="row"> | ||||||
|         <div class="col-md-12 text-center">{!! $locations->render() !!}</div> |         <div class="col-md-12 text-center">{!! $locations->render() !!}</div> | ||||||
|     </div> |     </div> | ||||||
|  |     <div class="well"> | ||||||
|  |         <div class="row"> | ||||||
|  |             <div class="col-md-12"> | ||||||
|  |                 <button class="btn btn-sm btn-success" id="addNewLocation">Add New Location</button> | ||||||
|  |             </div> | ||||||
|  |         </div> | ||||||
|  |     </div> | ||||||
| </div> | </div> | ||||||
| <script> | <script> | ||||||
| $(document).ready(function () { | $(document).ready(function () { | ||||||
|     $('#sidebar_links').find("a[href='/admin/locations']").addClass('active'); |     $('#sidebar_links').find("a[href='/admin/locations']").addClass('active'); | ||||||
|  |     $('[data-action="delete"]').click(function (event) { | ||||||
|  |         event.preventDefault(); | ||||||
|  |         var self = $(this); | ||||||
|  |         swal({ | ||||||
|  |             type: 'warning', | ||||||
|  |             title: '', | ||||||
|  |             text: 'Do you really want to delete this location?', | ||||||
|  |             showCancelButton: true, | ||||||
|  |             closeOnConfirm: false, | ||||||
|  |             showLoaderOnConfirm: true | ||||||
|  |         }, function () { | ||||||
|  |             $.ajax({ | ||||||
|  |                 method: 'DELETE', | ||||||
|  |                 url: '{{ route('admin.locations') }}/' + self.data('id'), | ||||||
|  |                 headers: { | ||||||
|  |                     'X-CSRF-TOKEN': '{{ csrf_token() }}' | ||||||
|  |                 } | ||||||
|  |             }).done(function () { | ||||||
|  |                 swal({ | ||||||
|  |                     type: 'success', | ||||||
|  |                     title: '', | ||||||
|  |                     text: 'Location was successfully deleted.' | ||||||
|  |                 }); | ||||||
|  |                 self.parent().parent().slideUp(); | ||||||
|  |             }).fail(function (jqXHR) { | ||||||
|  |                 console.error(jqXHR); | ||||||
|  |                 swal({ | ||||||
|  |                     type: 'error', | ||||||
|  |                     title: 'Whoops!', | ||||||
|  |                     text: (typeof jqXHR.responseJSON !== 'undefined') ? jqXHR.responseJSON.error : 'An error occured while processing this request.' | ||||||
|  |                 }); | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
| @endsection | @endsection | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dane Everitt
						Dane Everitt