2016-03-25 01:18:05 -07:00
< ? php
namespace App\Http\Controllers ;
use App\Helpers\Helper ;
use App\Models\Accessory ;
use App\Models\Actionlog ;
use App\Models\Company ;
use App\Models\Setting ;
use App\Models\User ;
2016-05-12 21:01:31 -07:00
use Carbon\Carbon ;
2016-03-25 01:18:05 -07:00
use Config ;
use DB ;
use Input ;
use Lang ;
use Mail ;
use Redirect ;
use Slack ;
use Str ;
use View ;
use Auth ;
2016-03-25 15:24:12 -07:00
use Request ;
2016-08-02 00:54:38 -07:00
use Gate ;
2016-03-25 01:18:05 -07:00
2016-04-12 19:24:02 -07:00
/** This controller handles all actions related to Accessories for
2016-04-07 13:21:09 -07:00
* the Snipe - IT Asset Management application .
*
* @ version v1 . 0
2016-03-25 01:18:05 -07:00
*/
class AccessoriesController extends Controller
{
/**
* Returns a view that invokes the ajax tables which actually contains
* the content for the accessories listing , which is generated in getDatatable .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ see AccessoriesController :: getDatatable () method that generates the JSON response
* @ since [ v1 . 0 ]
* @ return View
*/
2016-03-25 15:24:12 -07:00
public function getIndex ( Request $request )
2016-03-25 01:18:05 -07:00
{
return View :: make ( 'accessories/index' );
}
/**
* Returns a view with a form to create a new Accessory .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ return View
*/
2016-03-25 15:24:12 -07:00
public function getCreate ( Request $request )
2016-03-25 01:18:05 -07:00
{
// Show the page
return View :: make ( 'accessories/edit' )
-> with ( 'accessory' , new Accessory )
2016-08-16 18:49:54 -07:00
-> with ( 'category_list' , Helper :: categoryList ( 'accessory' ))
-> with ( 'company_list' , Helper :: companyList ())
-> with ( 'location_list' , Helper :: locationsList ())
-> with ( 'manufacturer_list' , Helper :: manufacturerList ());
2016-03-25 01:18:05 -07:00
}
/**
* Validate and save new Accessory from form post
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ return Redirect
*/
2016-03-25 15:24:12 -07:00
public function postCreate ( Request $request )
2016-03-25 01:18:05 -07:00
{
// create a new model instance
$accessory = new Accessory ();
// Update the accessory data
2016-08-16 18:49:54 -07:00
$accessory -> name = e ( Input :: get ( 'name' ));
$accessory -> category_id = e ( Input :: get ( 'category_id' ));
$accessory -> location_id = e ( Input :: get ( 'location_id' ));
$accessory -> min_amt = e ( Input :: get ( 'min_amt' ));
2016-03-25 01:18:05 -07:00
$accessory -> company_id = Company :: getIdForCurrentUser ( Input :: get ( 'company_id' ));
$accessory -> order_number = e ( Input :: get ( 'order_number' ));
2016-08-16 18:49:54 -07:00
$accessory -> manufacturer_id = e ( Input :: get ( 'manufacturer_id' ));
2016-03-25 01:18:05 -07:00
if ( e ( Input :: get ( 'purchase_date' )) == '' ) {
$accessory -> purchase_date = null ;
} else {
$accessory -> purchase_date = e ( Input :: get ( 'purchase_date' ));
}
if ( e ( Input :: get ( 'purchase_cost' )) == '0.00' ) {
$accessory -> purchase_cost = null ;
} else {
2016-09-28 08:58:16 -07:00
$accessory -> purchase_cost = Helper :: ParseFloat ( e ( Input :: get ( 'purchase_cost' )));
2016-03-25 01:18:05 -07:00
}
2016-08-16 18:49:54 -07:00
$accessory -> qty = e ( Input :: get ( 'qty' ));
$accessory -> user_id = Auth :: user () -> id ;
2016-03-25 01:18:05 -07:00
// Was the accessory created?
if ( $accessory -> save ()) {
// Redirect to the new accessory page
2016-04-28 21:06:41 -07:00
return redirect () -> to ( " admin/accessories " ) -> with ( 'success' , trans ( 'admin/accessories/message.create.success' ));
2016-03-25 01:18:05 -07:00
}
2016-04-28 21:06:41 -07:00
return redirect () -> back () -> withInput () -> withErrors ( $accessory -> getErrors ());
2016-03-25 01:18:05 -07:00
}
/**
* Return view for the Accessory update form , prepopulated with existing data
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return View
*/
2016-03-25 15:24:12 -07:00
public function getEdit ( Request $request , $accessoryId = null )
2016-03-25 01:18:05 -07:00
{
// Check if the accessory exists
if ( is_null ( $accessory = Accessory :: find ( $accessoryId ))) {
// Redirect to the blogs management page
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.does_not_exist' ));
2016-03-25 01:18:05 -07:00
} elseif ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
return View :: make ( 'accessories/edit' , compact ( 'accessory' ))
2016-09-27 19:07:30 -07:00
-> with ( 'category_list' , erper :: categoryList ( 'accessory' ))
2016-08-16 18:49:54 -07:00
-> with ( 'company_list' , Helper :: companyList ())
-> with ( 'location_list' , Helper :: locationsList ())
-> with ( 'manufacturer_list' , Helper :: manufacturerList ());
2016-03-25 01:18:05 -07:00
}
/**
* Save edited Accessory from form post
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return Redirect
*/
2016-03-25 15:24:12 -07:00
public function postEdit ( Request $request , $accessoryId = null )
2016-03-25 01:18:05 -07:00
{
2016-08-16 18:49:54 -07:00
// Check if the accessory exists
2016-03-25 01:18:05 -07:00
if ( is_null ( $accessory = Accessory :: find ( $accessoryId ))) {
2016-08-16 18:49:54 -07:00
// Redirect to the accessory index page
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.does_not_exist' ));
2016-03-25 01:18:05 -07:00
} elseif ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
// Update the accessory data
$accessory -> name = e ( Input :: get ( 'name' ));
if ( e ( Input :: get ( 'location_id' )) == '' ) {
$accessory -> location_id = null ;
} else {
2016-08-16 18:49:54 -07:00
$accessory -> location_id = e ( Input :: get ( 'location_id' ));
2016-03-25 01:18:05 -07:00
}
2016-08-16 18:49:54 -07:00
$accessory -> min_amt = e ( Input :: get ( 'min_amt' ));
2016-03-25 01:18:05 -07:00
$accessory -> category_id = e ( Input :: get ( 'category_id' ));
$accessory -> company_id = Company :: getIdForCurrentUser ( Input :: get ( 'company_id' ));
2016-08-16 18:49:54 -07:00
$accessory -> manufacturer_id = e ( Input :: get ( 'manufacturer_id' ));
2016-03-25 01:18:05 -07:00
$accessory -> order_number = e ( Input :: get ( 'order_number' ));
if ( e ( Input :: get ( 'purchase_date' )) == '' ) {
$accessory -> purchase_date = null ;
} else {
$accessory -> purchase_date = e ( Input :: get ( 'purchase_date' ));
}
if ( e ( Input :: get ( 'purchase_cost' )) == '0.00' ) {
$accessory -> purchase_cost = null ;
} else {
$accessory -> purchase_cost = e ( Input :: get ( 'purchase_cost' ));
}
$accessory -> qty = e ( Input :: get ( 'qty' ));
2016-08-16 18:49:54 -07:00
// Was the accessory updated?
2016-03-25 01:18:05 -07:00
if ( $accessory -> save ()) {
2016-08-16 18:49:54 -07:00
// Redirect to the updated accessory page
2016-04-28 21:06:41 -07:00
return redirect () -> to ( " admin/accessories " ) -> with ( 'success' , trans ( 'admin/accessories/message.update.success' ));
2016-03-25 01:18:05 -07:00
}
2016-04-28 21:06:41 -07:00
return redirect () -> back () -> withInput () -> withErrors ( $accessory -> getErrors ());
2016-03-25 01:18:05 -07:00
}
/**
* Delete the given accessory .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return Redirect
*/
2016-03-25 15:24:12 -07:00
public function getDelete ( Request $request , $accessoryId )
2016-03-25 01:18:05 -07:00
{
// Check if the blog post exists
if ( is_null ( $accessory = Accessory :: find ( $accessoryId ))) {
// Redirect to the blogs management page
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.not_found' ));
2016-03-25 01:18:05 -07:00
} elseif ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
if ( $accessory -> hasUsers () > 0 ) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.assoc_users' , array ( 'count' => $accessory -> hasUsers ())));
2016-03-25 01:18:05 -07:00
} else {
$accessory -> delete ();
// Redirect to the locations management page
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'success' , trans ( 'admin/accessories/message.delete.success' ));
2016-03-25 01:18:05 -07:00
}
}
/**
* Returns a view that invokes the ajax table which contains
* the content for the accessory detail view , which is generated in getDataView .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ see AccessoriesController :: getDataView () method that generates the JSON response
* @ since [ v1 . 0 ]
* @ return View
*/
2016-03-25 15:24:12 -07:00
public function getView ( Request $request , $accessoryID = null )
2016-03-25 01:18:05 -07:00
{
$accessory = Accessory :: find ( $accessoryID );
if ( isset ( $accessory -> id )) {
if ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
} else {
return View :: make ( 'accessories/view' , compact ( 'accessory' ));
}
} else {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/accessories/message.does_not_exist' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-04-28 21:06:41 -07:00
return redirect () -> route ( 'accessories' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
}
/**
* Return the form to checkout an Accessory to a user .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return View
*/
2016-03-25 15:24:12 -07:00
public function getCheckout ( Request $request , $accessoryId )
2016-03-25 01:18:05 -07:00
{
// Check if the accessory exists
if ( is_null ( $accessory = Accessory :: find ( $accessoryId ))) {
// Redirect to the accessory management page with error
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.not_found' ));
2016-03-25 01:18:05 -07:00
} elseif ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
// Get the dropdown of users and then pass it to the checkout view
2016-04-07 05:03:14 -07:00
$users_list = Helper :: usersList ();
2016-03-25 01:18:05 -07:00
return View :: make ( 'accessories/checkout' , compact ( 'accessory' )) -> with ( 'users_list' , $users_list );
}
/**
* Save the Accessory checkout information .
*
* If Slack is enabled and / or asset acceptance is enabled , it will also
* trigger a Slack message and send an email .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return Redirect
*/
2016-03-25 15:24:12 -07:00
public function postCheckout ( Request $request , $accessoryId )
2016-03-25 01:18:05 -07:00
{
// Check if the accessory exists
if ( is_null ( $accessory = Accessory :: find ( $accessoryId ))) {
// Redirect to the accessory management page with error
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.user_not_found' ));
2016-03-25 01:18:05 -07:00
} elseif ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
if ( ! $user = User :: find ( Input :: get ( 'assigned_to' ))) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.not_found' ));
2016-03-25 01:18:05 -07:00
}
// Update the accessory data
$accessory -> assigned_to = e ( Input :: get ( 'assigned_to' ));
$accessory -> users () -> attach ( $accessory -> id , array (
'accessory_id' => $accessory -> id ,
2016-05-12 21:01:31 -07:00
'created_at' => Carbon :: now (),
'user_id' => Auth :: user () -> id ,
2016-03-25 01:18:05 -07:00
'assigned_to' => e ( Input :: get ( 'assigned_to' ))));
2016-09-06 19:39:42 -07:00
$logaction = $accessory -> logCheckout ( e ( Input :: get ( 'note' )));
2016-03-25 01:18:05 -07:00
2016-06-21 06:41:05 -07:00
$admin_user = Auth :: user ();
2016-03-25 01:18:05 -07:00
$settings = Setting :: getSettings ();
if ( $settings -> slack_endpoint ) {
$slack_settings = [
'username' => $settings -> botname ,
'channel' => $settings -> slack_channel ,
'link_names' => true
];
$client = new \Maknz\Slack\Client ( $settings -> slack_endpoint , $slack_settings );
try {
$client -> attach ([
'color' => 'good' ,
'fields' => [
[
'title' => 'Checked Out:' ,
2016-09-06 19:39:42 -07:00
'value' => 'Accessory <' . config ( 'app.url' ) . '/admin/accessories/' . $accessory -> id . '/view' . '|' . $accessory -> name . '> checked out to <' . config ( 'app.url' ) . '/admin/users/' . $user -> id . '/view|' . $user -> fullName () . '> by <' . config ( 'app.url' ) . '/admin/users/' . $admin_user -> id . '/view' . '|' . $admin_user -> fullName () . '>.'
2016-03-25 01:18:05 -07:00
],
[
'title' => 'Note:' ,
2016-09-06 19:39:42 -07:00
'value' => e ( Input :: get ( 'note' ))
2016-03-25 01:18:05 -07:00
],
]
]) -> send ( 'Accessory Checked Out' );
} catch ( Exception $e ) {
}
}
$accessory_user = DB :: table ( 'accessories_users' ) -> where ( 'assigned_to' , '=' , $accessory -> assigned_to ) -> where ( 'accessory_id' , '=' , $accessory -> id ) -> first ();
$data [ 'log_id' ] = $logaction -> id ;
$data [ 'eula' ] = $accessory -> getEula ();
$data [ 'first_name' ] = $user -> first_name ;
$data [ 'item_name' ] = $accessory -> name ;
$data [ 'checkout_date' ] = $logaction -> created_at ;
$data [ 'item_tag' ] = '' ;
$data [ 'expected_checkin' ] = '' ;
$data [ 'note' ] = $logaction -> note ;
$data [ 'require_acceptance' ] = $accessory -> requireAcceptance ();
if (( $accessory -> requireAcceptance () == '1' ) || ( $accessory -> getEula ())) {
Mail :: send ( 'emails.accept-accessory' , $data , function ( $m ) use ( $user ) {
$m -> to ( $user -> email , $user -> first_name . ' ' . $user -> last_name );
2016-09-20 07:20:10 -07:00
$m -> replyTo ( config ( 'mail.reply_to.address' ), config ( 'mail.reply_to.name' ));
2016-09-26 14:13:07 -07:00
$m -> subject ( trans ( 'mail.Confirm_accessory_delivery' ));
2016-03-25 01:18:05 -07:00
});
}
// Redirect to the new accessory page
2016-04-28 21:06:41 -07:00
return redirect () -> to ( " admin/accessories " ) -> with ( 'success' , trans ( 'admin/accessories/message.checkout.success' ));
2016-03-25 01:18:05 -07:00
}
/**
* Check the accessory back into inventory
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return View
**/
2016-03-25 15:24:12 -07:00
public function getCheckin ( Request $request , $accessoryUserId = null , $backto = null )
2016-03-25 01:18:05 -07:00
{
// Check if the accessory exists
if ( is_null ( $accessory_user = DB :: table ( 'accessories_users' ) -> find ( $accessoryUserId ))) {
// Redirect to the accessory management page with error
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.not_found' ));
2016-03-25 01:18:05 -07:00
}
$accessory = Accessory :: find ( $accessory_user -> accessory_id );
if ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
} else {
return View :: make ( 'accessories/checkin' , compact ( 'accessory' )) -> with ( 'backto' , $backto );
}
}
/**
* Check in the item so that it can be checked out again to someone else
*
* @ uses Accessory :: checkin_email () to determine if an email can and should be sent
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return Redirect
**/
2016-03-25 15:24:12 -07:00
public function postCheckin ( Request $request , $accessoryUserId = null , $backto = null )
2016-03-25 01:18:05 -07:00
{
// Check if the accessory exists
if ( is_null ( $accessory_user = DB :: table ( 'accessories_users' ) -> find ( $accessoryUserId ))) {
// Redirect to the accessory management page with error
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'admin/accessories/message.not_found' ));
2016-03-25 01:18:05 -07:00
}
$accessory = Accessory :: find ( $accessory_user -> accessory_id );
if ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( 'admin/accessories' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
2016-09-06 19:39:42 -07:00
$logaction = $accessory -> logCheckin ( e ( Input :: get ( 'note' )));
2016-03-25 15:24:12 -07:00
$return_to = e ( $accessory_user -> assigned_to );
2016-03-25 01:18:05 -07:00
$admin_user = Auth :: user ();
// Was the accessory updated?
if ( DB :: table ( 'accessories_users' ) -> where ( 'id' , '=' , $accessory_user -> id ) -> delete ()) {
$settings = Setting :: getSettings ();
if ( $settings -> slack_endpoint ) {
$slack_settings = [
2016-03-25 15:24:12 -07:00
'username' => e ( $settings -> botname ),
'channel' => e ( $settings -> slack_channel ),
2016-03-25 01:18:05 -07:00
'link_names' => true
];
$client = new \Maknz\Slack\Client ( $settings -> slack_endpoint , $slack_settings );
try {
$client -> attach ([
'color' => 'good' ,
'fields' => [
[
'title' => 'Checked In:' ,
2016-09-06 19:39:42 -07:00
'value' => class_basename ( strtoupper ( $logaction -> item_type )) . ' <' . config ( 'app.url' ) . '/admin/accessories/' . e ( $accessory -> id ) . '/view' . '|' . e ( $accessory -> name ) . '> checked in by <' . config ( 'app.url' ) . '/admin/users/' . e ( $admin_user -> id ) . '/view' . '|' . e ( $admin_user -> fullName ()) . '>.'
2016-03-25 01:18:05 -07:00
],
[
'title' => 'Note:' ,
'value' => e ( $logaction -> note )
],
]
]) -> send ( 'Accessory Checked In' );
} catch ( Exception $e ) {
}
}
if ( ! is_null ( $accessory_user -> assigned_to )) {
$user = User :: find ( $accessory_user -> assigned_to );
}
$data [ 'log_id' ] = $logaction -> id ;
2016-03-25 15:24:12 -07:00
$data [ 'first_name' ] = e ( $user -> first_name );
$data [ 'item_name' ] = e ( $accessory -> name );
$data [ 'checkin_date' ] = e ( $logaction -> created_at );
2016-03-25 01:18:05 -07:00
$data [ 'item_tag' ] = '' ;
2016-03-25 15:24:12 -07:00
$data [ 'note' ] = e ( $logaction -> note );
2016-03-25 01:18:05 -07:00
if (( $accessory -> checkin_email () == '1' )) {
Mail :: send ( 'emails.checkin-asset' , $data , function ( $m ) use ( $user ) {
$m -> to ( $user -> email , $user -> first_name . ' ' . $user -> last_name );
2016-09-20 07:20:10 -07:00
$m -> replyTo ( config ( 'mail.reply_to.address' ), config ( 'mail.reply_to.name' ));
2016-09-26 14:13:07 -07:00
$m -> subject ( trans ( 'mail.Confirm_Accessory_Checkin' ));
2016-03-25 01:18:05 -07:00
});
}
if ( $backto == 'user' ) {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( " admin/users/ " . $return_to . '/view' ) -> with ( 'success' , trans ( 'admin/accessories/message.checkin.success' ));
2016-03-25 01:18:05 -07:00
} else {
2016-04-28 21:06:41 -07:00
return redirect () -> to ( " admin/accessories/ " . $accessory -> id . " /view " ) -> with ( 'success' , trans ( 'admin/accessories/message.checkin.success' ));
2016-03-25 01:18:05 -07:00
}
}
// Redirect to the accessory management page with error
2016-04-28 21:06:41 -07:00
return redirect () -> to ( " admin/accessories " ) -> with ( 'error' , trans ( 'admin/accessories/message.checkin.error' ));
2016-03-25 01:18:05 -07:00
}
2016-03-28 22:51:49 -07:00
/**
* Generates the JSON response for accessories listing view .
*
* Example :
* {
* " actions " : " (links to available actions) " ,
* " category " : " (link to category) " ,
* " companyName " : " My Company " ,
* " location " : " My Location " ,
* " min_amt " : 2 ,
* " name " : " (link to accessory),
* " numRemaining " : 6 ,
* " order_number " : null ,
* " purchase_cost " : " 0.00 " ,
* " purchase_date " : null ,
* " qty " : 7
* },
*
* The names of the fields in the returns JSON correspond directly to the the
* names of the fields in the bootstrap - tables in the view .
*
* For debugging , see at / api / accessories / list
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return string JSON containing accessories and their associated atrributes .
**/
2016-03-25 15:24:12 -07:00
public function getDatatable ( Request $request )
2016-03-25 01:18:05 -07:00
{
2016-07-25 19:46:29 -07:00
$accessories = Company :: scopeCompanyables ( Accessory :: select ( 'accessories.*' ) -> with ( 'category' , 'company' ))
2016-03-25 01:18:05 -07:00
-> whereNull ( 'accessories.deleted_at' );
if ( Input :: has ( 'search' )) {
2016-03-25 15:24:12 -07:00
$accessories = $accessories -> TextSearch ( e ( Input :: get ( 'search' )));
2016-03-25 01:18:05 -07:00
}
if ( Input :: has ( 'offset' )) {
$offset = e ( Input :: get ( 'offset' ));
} else {
$offset = 0 ;
}
if ( Input :: has ( 'limit' )) {
$limit = e ( Input :: get ( 'limit' ));
} else {
$limit = 50 ;
}
$allowed_columns = [ 'name' , 'min_amt' , 'order_number' , 'purchase_date' , 'purchase_cost' , 'companyName' , 'category' ];
$order = Input :: get ( 'order' ) === 'asc' ? 'asc' : 'desc' ;
2016-03-25 15:24:12 -07:00
$sort = in_array ( Input :: get ( 'sort' ), $allowed_columns ) ? e ( Input :: get ( 'sort' )) : 'created_at' ;
2016-03-25 01:18:05 -07:00
switch ( $sort ) {
case 'category' :
$accessories = $accessories -> OrderCategory ( $order );
break ;
case 'companyName' :
$accessories = $accessories -> OrderCompany ( $order );
break ;
default :
$accessories = $accessories -> orderBy ( $sort , $order );
break ;
}
$accessCount = $accessories -> count ();
$accessories = $accessories -> skip ( $offset ) -> take ( $limit ) -> get ();
$rows = array ();
foreach ( $accessories as $accessory ) {
2016-08-02 00:54:38 -07:00
$actions = '<nobr>' ;
if ( Gate :: allows ( 'accessories.checkout' )) {
$actions .= '<a href="' . route ( 'checkout/accessory' ,
$accessory -> id ) . '" style="margin-right:5px;" class="btn btn-info btn-sm" ' . (( $accessory -> numRemaining () > 0 ) ? '' : ' disabled' ) . '>' . trans ( 'general.checkout' ) . '</a>' ;
}
if ( Gate :: allows ( 'accessories.edit' )) {
$actions .= '<a href="' . route ( 'update/accessory' ,
$accessory -> id ) . '" class="btn btn-warning btn-sm" style="margin-right:5px;"><i class="fa fa-pencil icon-white"></i></a>' ;
}
if ( Gate :: allows ( 'accessories.delete' )) {
$actions .= '<a data-html="false" class="btn delete-asset btn-danger btn-sm" data-toggle="modal" href="' . route ( 'delete/accessory' ,
$accessory -> id ) . '" data-content="' . trans ( 'admin/accessories/message.delete.confirm' ) . '" data-title="' . trans ( 'general.delete' ) . ' ' . htmlspecialchars ( $accessory -> name ) . '?" onClick="return false;"><i class="fa fa-trash icon-white"></i></a>' ;
}
$actions .= '</nobr>' ;
2016-03-25 01:18:05 -07:00
$company = $accessory -> company ;
$rows [] = array (
'name' => '<a href="' . url ( 'admin/accessories/' . $accessory -> id ) . '/view">' . $accessory -> name . '</a>' ,
'category' => ( $accessory -> category ) ? ( string ) link_to ( 'admin/settings/categories/' . $accessory -> category -> id . '/view' , $accessory -> category -> name ) : '' ,
2016-03-25 15:24:12 -07:00
'qty' => e ( $accessory -> qty ),
'order_number' => e ( $accessory -> order_number ),
'min_amt' => e ( $accessory -> min_amt ),
'location' => ( $accessory -> location ) ? e ( $accessory -> location -> name ) : '' ,
'purchase_date' => e ( $accessory -> purchase_date ),
2016-08-16 18:47:53 -07:00
'purchase_cost' => Helper :: formatCurrencyOutput ( $accessory -> purchase_cost ),
2016-03-25 01:18:05 -07:00
'numRemaining' => $accessory -> numRemaining (),
'actions' => $actions ,
2016-08-16 18:49:54 -07:00
'companyName' => is_null ( $company ) ? '' : e ( $company -> name ),
'manufacturer' => $accessory -> manufacturer ? ( string ) link_to ( '/admin/settings/manufacturers/' . $accessory -> manufacturer_id . '/view' , $accessory -> manufacturer -> name ) : ''
2016-03-25 01:18:05 -07:00
);
}
$data = array ( 'total' => $accessCount , 'rows' => $rows );
return $data ;
}
/**
* Generates the JSON response for accessory detail view .
*
* Example :
* < code >
* {
* " rows " : [
* {
* " actions " : " (link to available actions) " ,
* " name " : " (link to user) "
* }
* ],
* " total " : 1
* }
* </ code >
*
* The names of the fields in the returns JSON correspond directly to the the
* names of the fields in the bootstrap - tables in the view .
*
* For debugging , see at / api / accessories / $accessoryID / view
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ param int $accessoryId
* @ return string JSON containing accessories and their associated atrributes .
**/
2016-03-25 15:24:12 -07:00
public function getDataView ( Request $request , $accessoryID )
2016-03-25 01:18:05 -07:00
{
$accessory = Accessory :: find ( $accessoryID );
if ( ! Company :: isCurrentUserHasAccess ( $accessory )) {
return [ 'total' => 0 , 'rows' => []];
}
$accessory_users = $accessory -> users ;
$count = $accessory_users -> count ();
$rows = array ();
foreach ( $accessory_users as $user ) {
2016-08-02 00:54:38 -07:00
$actions = '' ;
if ( Gate :: allows ( 'accessories.checkin' )) {
$actions .= '<a href="' . route ( 'checkin/accessory' ,
$user -> pivot -> id ) . '" class="btn btn-info btn-sm">Checkin</a>' ;
}
if ( Gate :: allows ( 'users.view' )) {
$name = ( string ) link_to ( '/admin/users/' . $user -> id . '/view' , e ( $user -> fullName ()));
} else {
$name = e ( $user -> fullName ());
}
2016-03-25 01:18:05 -07:00
$rows [] = array (
2016-08-02 00:54:38 -07:00
'name' => $name ,
2016-03-25 01:18:05 -07:00
'actions' => $actions
);
}
$data = array ( 'total' => $count , 'rows' => $rows );
return $data ;
}
}