290 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			290 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Controllers;
 | |
| 
 | |
| use App\Http\Controllers\Controller;
 | |
| use Illuminate\Http\Request;
 | |
| use Illuminate\Http\Response;
 | |
| use Illuminate\Support\Facades\DB;
 | |
| use Validator;
 | |
| use App\Responses;
 | |
| use App\Helper;
 | |
| use App\Models\AItems;
 | |
| use App\Models\Users;
 | |
| use App\Models\OrdersAItems;
 | |
| use App\Models\UnitTypes;
 | |
| 
 | |
| class AItemsController extends Controller
 | |
| {
 | |
|     public function view_a_items(Request $req)
 | |
|     {
 | |
| 		$unitTypes = UnitTypes::listUnitTypes(['is_active' => UnitTypes::IS_ACTIVE, 'is_publish' => UnitTypes::IS_PUBLISH]);
 | |
| 		$data = [
 | |
| 			'unitTypes' => $unitTypes,
 | |
| 			'user' => $req->auth,
 | |
| 		];
 | |
|         return view('menu_v2.Finance.adtItems', $data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
| 	 * API
 | |
| 	 */
 | |
| 
 | |
| 	public function api_list_a_items(Request $req)
 | |
| 	{
 | |
| 		try {
 | |
| 			$now = time();
 | |
| 			$input = [];
 | |
| 			$rulesInput = [];
 | |
| 
 | |
| 			// validasi input
 | |
| 			// $isValidInput = Validator::make($input, $rulesInput);
 | |
| 			// if (!$isValidInput->passes()) {
 | |
| 			// 	$apiResp = Responses::bad_input($isValidInput->messages()->first());
 | |
| 			// 	return new Response($apiResp, $apiResp['meta']['code']);
 | |
| 			// }
 | |
| 			$filter = [];
 | |
| 
 | |
| 			if ($req->auth->role === Users::ROLE_ADMIN) {
 | |
| 				$filter['crt_type'] = AItems::CRT_TYPE_ADMIN;
 | |
| 			} else if ($req->auth->role === Users::ROLE_FINANCE) {
 | |
| 				$filter['crt_type'] = AItems::CRT_TYPE_FINANCE;
 | |
| 			} else {
 | |
| 				$filter['crt_type'] = 99;
 | |
| 			}
 | |
| 
 | |
| 			$list = AItems::listAItems($filter);
 | |
| 			foreach ($list as $key => $row) {
 | |
| 				$list[$key]->DT_RowIndex = $key + 1;
 | |
| 				$list[$key]->action = '-';
 | |
| 			}
 | |
| 
 | |
| 			$apiResp = Responses::success('success list a_items');
 | |
| 			$apiResp['count'] = count($list);
 | |
| 			$apiResp['data'] = $list;
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		} catch (\Exception $e) {
 | |
| 			$apiResp = Responses::error($e->getMessage());
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	public function api_show_a_items(Request $req, $id)
 | |
| 	{
 | |
| 		try {
 | |
| 			$now = time();
 | |
| 
 | |
| 			$input = [
 | |
| 				'id' => $id,
 | |
| 			];
 | |
| 			$rulesInput = [
 | |
| 				'id' => 'required|integer|not_in:0',
 | |
| 			];
 | |
| 
 | |
| 			// validasi input
 | |
| 			$isValidInput = Validator::make($input, $rulesInput);
 | |
| 			if (!$isValidInput->passes()) {
 | |
| 				$apiResp = Responses::bad_input($isValidInput->messages()->first());
 | |
| 				return new Response($apiResp, $apiResp['meta']['code']);
 | |
| 			}
 | |
| 
 | |
| 			$a_item = AItems::showAItemsById($id);
 | |
| 			if (count($a_item) < 1) {
 | |
| 				$apiResp = Responses::not_found('a_item not found');
 | |
| 				return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 			}
 | |
| 			
 | |
| 			$apiResp = Responses::success('success get detail a_item');
 | |
| 			$apiResp['data'] = $a_item[0];
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		} catch (\Exception $e) {
 | |
| 			$apiResp = Responses::error($e->getMessage());
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	public function api_add_a_items(Request $req)
 | |
| 	{
 | |
| 		try {
 | |
| 			$now = time();
 | |
| 
 | |
| 			$input = [
 | |
| 				'name' => $req->name,
 | |
| 				'type' => $req->type,
 | |
| 				'price' => $req->price,
 | |
| 				'status' => $req->status,
 | |
| 				'is_adm_price' => $req->is_adm_price,
 | |
| 			];
 | |
| 			$rulesInput = [
 | |
| 				'name' => 'required|string',
 | |
| 				'type' => 'required|integer|not_in:0',
 | |
| 				'price' => 'required|numeric',
 | |
| 				'status' => 'required|integer|min:0',
 | |
| 				'is_adm_price' => 'required|numeric|min:0',
 | |
| 			];
 | |
| 
 | |
| 			// validasi input
 | |
| 			$isValidInput = Validator::make($input, $rulesInput);
 | |
| 			if (!$isValidInput->passes()) {
 | |
| 				$apiResp = Responses::bad_input($isValidInput->messages()->first());
 | |
| 				return new Response($apiResp, $apiResp['meta']['code']);
 | |
| 			}
 | |
| 
 | |
| 			$uniqName = AItems::getByName($req->name);
 | |
| 			if (count($uniqName) > 0) {
 | |
| 				$apiResp = Responses::bad_request('nama additional item sudah terdata');
 | |
| 				return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 			}
 | |
| 
 | |
| 			if ($req->auth->role === Users::ROLE_ADMIN) {
 | |
| 				$crt_type = AItems::CRT_TYPE_ADMIN;
 | |
| 			} else if ($req->auth->role === Users::ROLE_FINANCE) {
 | |
| 				$crt_type = AItems::CRT_TYPE_FINANCE;
 | |
| 			} else {
 | |
| 				$crt_type = 99;
 | |
| 			}
 | |
| 
 | |
| 			DB::beginTransaction();
 | |
| 
 | |
| 			$insAItems = [
 | |
| 				'name' => $req->name,
 | |
| 				'type' => $req->type,
 | |
| 				'price' => $req->price,
 | |
| 				'is_active' => $req->status,
 | |
| 				'is_adm_price' => $req->is_adm_price,
 | |
| 				'crt' => $now,
 | |
| 				'crt_by' => $req->auth->uid,
 | |
| 				'crt_type' => $crt_type,
 | |
| 				'updt' => $now,
 | |
| 				'updt_by' => $req->auth->uid,
 | |
| 			];
 | |
| 			$id = AItems::add($insAItems);
 | |
| 
 | |
| 			$apiResp = Responses::created('success add new additional item');
 | |
| 
 | |
| 			DB::commit();
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		} catch (\Exception $e) {
 | |
| 			DB::rollBack();
 | |
| 			$apiResp = Responses::error($e->getMessage());
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	public function api_updt_a_items(Request $req, $id)
 | |
| 	{
 | |
| 		try {
 | |
| 			$now = time();
 | |
| 
 | |
| 			$input = [
 | |
| 				'id' => $id,
 | |
| 				'name' => $req->name,
 | |
| 				'type' => $req->type,
 | |
| 				'price' => $req->price,
 | |
| 				'status' => $req->status,
 | |
| 				'is_adm_price' => $req->is_adm_price,
 | |
| 			];
 | |
| 			$rulesInput = [
 | |
| 				'id' => 'required|integer|not_in:0',
 | |
| 				'name' => 'required|string',
 | |
| 				'type' => 'required|integer|not_in:0',
 | |
| 				'price' => 'required|numeric',
 | |
| 				'status' => 'required|integer|min:0',
 | |
| 				'is_adm_price' => 'required|numeric|min:0',
 | |
| 			];
 | |
| 
 | |
| 			// validasi input
 | |
| 			$isValidInput = Validator::make($input, $rulesInput);
 | |
| 			if (!$isValidInput->passes()) {
 | |
| 				$apiResp = Responses::bad_input($isValidInput->messages()->first());
 | |
| 				return new Response($apiResp, $apiResp['meta']['code']);
 | |
| 			}
 | |
| 
 | |
| 			$a_item = AItems::showAItemsById($id);
 | |
| 			if (count($a_item) < 1) {
 | |
| 				$apiResp = Responses::not_found('additional item not found');
 | |
| 				return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 			}
 | |
| 
 | |
| 			$uniqName = AItems::getByName($req->name);
 | |
| 			if (count($uniqName) > 0) {
 | |
| 				$notSameUser = 1;
 | |
| 				foreach ($uniqName as $key => $row) {
 | |
| 					if ($row->id == $id) {
 | |
| 						$notSameUser = 0;
 | |
| 					}
 | |
| 				}
 | |
| 				if ($notSameUser) {
 | |
| 					$apiResp = Responses::bad_request('nama additional item sudah terdata');
 | |
| 					return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			DB::beginTransaction();
 | |
| 
 | |
| 			$updtAItems = [
 | |
| 				'name' => $req->name,
 | |
| 				'type' => $req->type,
 | |
| 				'price' => $req->price,
 | |
| 				'is_active' => $req->status,
 | |
| 				'is_adm_price' => $req->is_adm_price,
 | |
| 				'updt' => $now,
 | |
| 				'updt_by' => $req->auth->uid,
 | |
| 			];
 | |
| 			AItems::updt($id, $updtAItems);
 | |
| 
 | |
| 			$apiResp = Responses::created('success update additional item');
 | |
| 
 | |
| 			DB::commit();
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		} catch (\Exception $e) {
 | |
| 			DB::rollBack();
 | |
| 			$apiResp = Responses::error($e->getMessage());
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	public function api_del_a_items(Request $req, $id)
 | |
| 	{
 | |
| 		try {
 | |
| 			$now = time();
 | |
| 
 | |
| 			$input = [
 | |
| 				'id' => $id,
 | |
| 			];
 | |
| 			$rulesInput = [
 | |
| 				'id' => 'required|integer|not_in:0',
 | |
| 			];
 | |
| 
 | |
| 			// validasi input
 | |
| 			$isValidInput = Validator::make($input, $rulesInput);
 | |
| 			if (!$isValidInput->passes()) {
 | |
| 				$apiResp = Responses::bad_input($isValidInput->messages()->first());
 | |
| 				return new Response($apiResp, $apiResp['meta']['code']);
 | |
| 			}
 | |
| 
 | |
| 			$a_item = AItems::showAItemsById($id);
 | |
| 			if (count($a_item) < 1) {
 | |
| 				$apiResp = Responses::not_found('additional item not found');
 | |
| 				return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 			}
 | |
| 
 | |
| 			DB::beginTransaction();
 | |
| 
 | |
| 			AItems::updt($id, [
 | |
| 				'dlt' => $now,
 | |
| 				'dlt_by' => $req->auth->uid,
 | |
| 			]);
 | |
| 
 | |
| 			DB::commit();
 | |
| 			
 | |
| 			$apiResp = Responses::success('success delete additional item');
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		} catch (\Exception $e) {
 | |
| 			DB::rollBack();
 | |
| 			$apiResp = Responses::error($e->getMessage());
 | |
| 			return (new Response($apiResp, $apiResp['meta']['code']));
 | |
| 		}
 | |
| 	}
 | |
| }
 | 
