| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822 |
- <?php
- /*
- Desarrollador: Ing. Jean Jairo Benitez Meza
- Ultima Modificación: 11/04/2023
- Módulo: Gestión de Adquisiciones
- */
- namespace App\Http\Controllers;
- use App\Http\Controllers\Controller;
- use App\Http\Controllers\ResponseController;
- use App\Http\Controllers\EncryptionController;
- use App\Http\Controllers\ResourcesController;
- use Illuminate\Http\Request;
- use Illuminate\Support\Carbon;
- use Illuminate\Support\Facades\DB;
- use Illuminate\Support\Facades\Validator;
- use Illuminate\Database\Query\JoinClause;
- use Illuminate\Support\Facades\Storage;
- use \Mpdf\Mpdf as PDF;
- class OrderController extends Controller {
- private $responseController;
- private $encController;
- private $resourcesController;
- public function __construct(){
- $this->responseController = new ResponseController();
- $this->encController = new EncryptionController();
- $this->resourcesController = new ResourcesController();
- }
- public function getOrders($line) {
- try {
- $arrOrders = DB::table('S002V01TORCO')
- ->where('ORCO_NULI', '=', $line)
- ->where('DESP_NULI', '=', $line)
- ->where('PROV_NULI', '=', $line)
- ->where('LINE_NULI', '=', $line)
- ->where('MEPA_NULI', '=', $line)
- ->join('S002V01TDESP', 'DESP_IDDE', '=', 'ORCO_NUDE')
- ->join('S002V01TPROV', 'PROV_NUPR', '=', 'ORCO_NUPR')
- ->join('S002V01TLINE', 'LINE_NUOR', '=', 'ORCO_NUOR')
- ->join('S002V01TMEPA', 'MEPA_IDME', '=', 'ORCO_IDME')
- ->get([
- 'ORCO_NUOR', // Número de Orden
- 'PROV_NUPR', // Número de Proveedor
- 'PROV_NOCO', // Nombre Comercial del Proveedor
- 'DESP_IDDE', // Número de Despacho
- 'DESP_NOMB', // Nombre del Despacho
- 'LINE_IDLI', // Identificador de línea de solicitud de compra
- // 'LINE_DESC', // Descripción de la línea de solicitud de compra
- 'MEPA_IDME', // Métodos de Pago
- 'MEPA_NOMB', // Nombre del método de pago
- 'ORCO_COST', // Costo Total
- 'ORCO_MONE', // Moneda
- // 'ORCO_PROP', // Proposito
- // 'ORCO_ACTI', // Actividad
- 'ORCO_PROY', // Proyecto
- 'ORCO_ESTA', // Estado
- 'ORCO_USRE', // Usuario Registra
- 'ORCO_FERE', // Fecha Registra
- 'ORCO_USMO', // Usuario Modifica
- 'ORCO_FEMO', // Fecha Modifica
- ]);
- } catch ( \Throwable $th ) {
- return $this->responseController->makeResponse(true, "ERR_ORDER_GET000: Ocurrió un error al momento de obtener las órdenes de compra.", $th->getMessage(), 500);
- }
- return $this->responseController->makeResponse(false, "ÉXITO: Consulta Exitosa", $arrOrders);
- }
- // Se crea una orden de compra
- public function createOrder(Request $request){
- $validator = Validator::make($request->all(), [
- 'NUMERO_SOLICITUD' => 'required|string',
- 'NUMERO_LINEA' => 'required|string',
- 'USUARIO' => 'required|string',
- 'ARR_ORDENES' => 'required|array',
- ]);
- if ($validator->fails()) {
- return $this->responseController->makeResponse(
- true,
- "ERR_ORDER_REG000: Se encontraron uno o más errores.",
- $this->responseController->makeErrors($validator->errors()->messages()),
- 401
- );
- }
- DB::beginTransaction();
- $requestData = $request->all();
- try {
- $user = $this->encController->decrypt($requestData['USUARIO']);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_REG001: Ocurrió un error al obtener el usuario.", [], 500);
- }
- foreach ($requestData['ARR_ORDENES'] as $keyOrders => $orders) {
- $validator = Validator::make($orders, [
- 'NUMERO_PROVEEDOR' => 'required|string',
- 'PROVEEDOR' => 'required|string',
- 'PRECIO_TOTAL' => 'required|integer',
- 'MONEDA' => 'required|string',
- 'DESPACHO' => 'required|integer',
- 'PROYECTO' => 'required|string',
- // 'PROPOSITO' => 'required|string',
- // 'ACTIVIDAD' => '',
- ]);
- if ($validator->fails()) {
- return $this->responseController->makeResponse(
- true,
- "ERR_ORDER_REG002: Se encontraron uno o más errores.",
- $this->responseController->makeErrors($validator->errors()->messages()),
- 401
- );
- }
- $arrInsert = [
- 'ORCO_NUPR' => $orders['NUMERO_PROVEEDOR'],
- 'ORCO_NUDE' => $orders['DESPACHO'],
- 'ORCO_IDLI' => $requestData['NUMERO_SOLICITUD'],
- 'ORCO_COST' => $orders['PRECIO_TOTAL'],
- 'ORCO_MONE' => $orders['MONEDA'],
- // 'ORCO_PROP' => $orders['PROPOSITO'],
- // 'ORCO_ACTI' => $orders['ACTIVIDAD'] === '' ? null : $orders['ACTIVIDAD'],
- 'ORCO_PROY' => $orders['PROYECTO'] === '' || $orders['PROYECTO'] === 'NA' ? null : $orders['PROYECTO'],
- 'ORCO_NULI' => $requestData['NUMERO_LINEA'],
- 'ORCO_USRE' => $user,
- 'ORCO_FERE' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- 'ORCO_FEAR' => DB::raw('CURRENT_TIMESTAMP'),
- ];
- try {
- $orderNumber = DB::table('S002V01TORCO')->insertGetId($arrInsert);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_REG003: Ocurrió un error al momento de insertar los datos en la base de datos.", $th->getMessage(), 500);
- }
- if ( !$orderNumber ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_REG004: Ocurrió un error al insertar los datos en la base de datos.", [], 500);
- }
- $arrUpdate = [
- 'LINE_ESTA' => 'En OC',
- 'LINE_USMO' => $user,
- 'LINE_FEMO' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- 'LINE_FEAR' => DB::raw('CURRENT_TIMESTAMP'),
- ];
- try {
- $validateInsert = DB::table('S002V01TLINE')
- ->where('LINE_IDLI', '=', $requestData['NUMERO_SOLICITUD'])
- ->where('LINE_NULI', '=', $requestData['NUMERO_LINEA'])
- ->update($arrUpdate);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_REG005: Ocurrió un error al momento de insertar los datos en la base de datos.", [], 500);
- }
- if ( !$validateInsert ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_REG006: Ocurrió un error al insertar los datos en la base de datos.", [], 500);
- }
- $arrInsertState = [
- 'HIOR_NUOR' => $orderNumber,
- 'HIOR_POEN' => 10,
- 'HIOR_NULI' => $requestData['NUMERO_LINEA'],
- 'HIOR_USRE' => $user,
- 'HIOR_FERE' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- 'HIOR_FEAR' => DB::raw('CURRENT_TIMESTAMP'),
- ];
- try {
- $validateInsertUpdate = DB::table('S002V01THIOR')->insert($arrInsertState);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_REG007: Ocurrió un error al momento de insertar los datos en el historial de estados.", [], 500);
- }
- if ( !$validateInsertUpdate ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_REG008: Ocurrió un error al insertar los datos del historial en la base de datos.", [], 500);
- }
- }
- DB::commit();
- return $this->responseController->makeResponse(false, "ÉXITO: Generación de Órdenes Exitosas");
- }
- public function getOrderByNumber($order, $provider, $line){
- try {
- $order = $this->encController->decrypt($order);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_GET000: Ocurrió un error al obtener el usuario.", [], 500);
- }
- try {
- $provider = $this->encController->decrypt($provider);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDER_GET001: Ocurrió un error al obtener el usuario.", [], 500);
- }
- try {
- $orders = DB::table('S002V01TORCO')
- ->where('ORCO_NUOR', '=', $order)
- ->where('ORCO_NUPR', '=', $provider)
- ->where('ORCO_NULI', '=', $line)
- ->where('DESP_NULI', '=', $line)
- ->where('PROV_NULI', '=', $line)
- ->where('LINE_NULI', '=', $line)
- ->where('MEPA_NULI', '=', $line)
- ->where('ORCO_ESTA', '=', 'Activo')
- ->where('DESP_ESTA', '=', 'Activo')
- ->where('PROV_ESTA', '=', 'Activo')
- ->where('LINE_ESTA', '=', 'Activo')
- ->where('MEPA_ESTA', '=', 'Activo')
- ->join('S002V01TDESP', 'DESP_IDDE', '=', 'ORCO_NUDE')
- ->join('S002V01TPROV', 'PROV_NUPR', '=', 'ORCO_NUPR')
- ->join('S002V01TLINE', 'LINE_IDLI', '=', 'ORCO_IDLI')
- ->join('S002V01TMEPA', 'MEPA_IDME', '=', 'LINE_IDME')
- ->first([
- 'ORCO_NUOR', // Número de Orden
- 'PROV_NUPR', // Número de Proveedor
- 'PROV_NOCO', // Nombre Comercial del Proveedor
- 'DESP_IDDE', // Número de Despacho
- 'DESP_NOMB', // Nombre del Despacho
- 'DESP_CALL', // Calle
- 'DESP_NUEX', // Número Exterior
- 'DESP_NUIN', // Número Interior
- 'DESP_COPO', // Código Postal
- 'DESP_COLO', // Colonia
- 'DESP_MUNI', // Municipio
- 'DESP_ENTI', // Entidad
- 'DESP_PAIS', // Pais
- 'LINE_IDLI', // Identificador de línea de solicitud de compra
- // 'LINE_DESC', // Descripción de la línea de solicitud de compra
- 'LINE_IDME', // Métodos de Pago
- 'MEPA_NOMB', // Nombre del método de pago
- 'ORCO_COST', // Costo Total
- 'ORCO_MONE', // Moneda
- // 'ORCO_PROP', // Proposito
- // 'ORCO_ACTI', // Actividad
- 'ORCO_PROY', // Proyecto
- 'ORCO_ESTA', // Estado
- 'ORCO_USRE', // Usuario Registra
- 'ORCO_FERE', // Fecha Registra
- 'ORCO_USMO', // Usuario Modifica
- 'ORCO_FEMO', // Fecha Modifica
- ]);
- } catch ( \Throwable $th ) {
- return $this->responseController->makeResponse(
- true,
- "ERR_ORDER_GET002: Ocurrió un error al momento de obtener las órdenes de compra.",
- $th->getMessage(),
- 500
- );
- }
- if ( !empty($orders) ) {
- try {
- $arrArtitleSelected = DB::table('S002V01TARSE')
- ->where('ARSE_IDLI', '=', $orders->LINE_IDLI)
- ->where('ARSE_NUPR', '=', $provider)
- ->where('ARSE_NULI', '=', $line)
- ->where('ARTI_NULI', '=', $line)
- ->where('INAR_NULI', '=', $line)
- ->where('DEAR_NULI', '=', $line)
- ->where('ARSE_ESTA', '=', 'Activo')
- ->where('ARTI_ESTA', '=', 'Activo')
- ->where('INAR_ESTA', '=', 'Activo')
- ->where('DEAR_ESTA', '=', 'Activo')
- ->join('S002V01TARTI', 'ARTI_IDAR', '=', 'ARSE_IDAR')
- ->join('S002V01TINAR', 'INAR_IDIN', '=', 'ARSE_IDIN')
- ->join('S002V01TDEAR', 'DEAR_IDDE', '=', 'INAR_IDDE')
- ->get([
- 'ARSE_IDAS', // Identificador de artículos seleccionados
- 'ARTI_IDAR', // Identificador del artículo
- 'ARTI_IDFA', // Identificador de la familia
- 'ARTI_IDSU', // Identificador de la subfamilia
- 'ARTI_CODI', // Código del artículo
- 'ARTI_NOMB', // Nombre del artículo
- 'ARSE_NUPR', // Número de Identificador del Proveedor
- 'ARSE_IDIN', // Número de Identificador de Información
- 'ARSE_CANT', // Cantidad seleccionada
- 'ARSE_PRTO', // Precio total
- 'ARSE_USRE', // Usuario registra
- 'ARSE_FERE', // Fecha registra
- 'ARSE_USMO', // Usuario modifica
- 'ARSE_FEMO', // Fecha modifica
- 'INAR_CODI', // Código del artículo
- 'INAR_MODE', // Modelo del artículo
- 'INAR_MONE', // Moneda
- 'INAR_PREC', // Precio
- 'INAR_CARA', // Características
- 'DEAR_IDDE', // Identificador de la descripción del artículo
- 'DEAR_DESC', // Descripción del artículo
- 'DEAR_CARA', // Características del proveedor
- 'DEAR_COWE', // Compra Web
- 'DEAR_IMAG', // Imágen del artículo
- 'DEAR_IDUN', // Identificador de la unidad
- 'DEAR_NUPR', // Número del Proveedor
- 'DEAR_IDAR', // Identificador del artícul
- ]);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(
- true,
- "ERR_ORDER_GET003: Ocurrió un error al momento de obtener la información de la línea de solicitud de compra",
- $th->getMessage(),
- 500
- );
- }
- $arrArtitleSelected = json_decode(json_encode($arrArtitleSelected), true);
- foreach ($arrArtitleSelected as $key => $artitleSelected) {
- $artitleSelected['DEAR_IMAG'] = json_decode($artitleSelected['DEAR_IMAG']);
- // $artitleSelected['DEAR_IMAG'] = json_decode($artitleSelected['DEAR_IMAG']);
- $arrArtitleSelected[$key] = $artitleSelected;
- }
- $orders->PRODUCTS = $arrArtitleSelected;
- try {
- $arrStateOrder = DB::table('S002V01THIOR')
- ->where('HIOR_NUOR', '=', $order)
- ->where('HIOR_ESTA', '=', 'Activo')
- ->where('HIOR_NULI', '=', $line)
- ->get([
- 'HIOR_IDHO', // Identificador del historial de órdenes
- 'HIOR_NUOR', // Número de orden de compra
- 'HIOR_ESOR', // Estado de la orden
- 'HIOR_EVI1', // Evidencia 1
- 'HIOR_EVI2', // Evidencia 2
- 'HIOR_DESC', // Descripción
- 'HIOR_POEN', // Porcentaje de entrega
- 'HIOR_USRE', // Usuario entrega
- 'HIOR_FERE', // Fecha entrega
- 'HIOR_USMO', // Usuario modifica
- 'HIOR_FEMO', // Fecha modifica
- ]);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(
- true,
- "ERR_ORDER_GET004: Ocurrió un error al momento de obtener la información del historial de orden de compra",
- $th->getMessage(),
- 500
- );
- }
- $orders->STATES = $arrStateOrder;
- }
- return $this->responseController->makeResponse(false, "ÉXITO: Consulta Exitosa", $orders);
- }
- public function getHistoryStateOrder($order, $line) {
- try {
- $objHistoryState = DB::table('S002V01THIOR')
- ->where('HIOR_NUOR', '=', $order)
- ->where('HIOR_NULI', '=', $line)
- ->where('HIOR_ESTA', '=', 'Activo')
- ->first([
- 'HIOR_IDHO', // Identificador de la historia de la orden
- 'HIOR_ESOR', // Estado de la orden
- 'HIOR_DESC', // Descripción del estado de la orden
- 'HIOR_EVI1', // Evidencia 1
- 'HIOR_EVI2', // Evidencia 2
- 'HIOR_POEN', // Porcentaje de entrega
- ]);
- } catch (\Throwable $th) {
- //throw $th;
- }
- }
- public function updateStateHistory(Request $request) {
- $validator = Validator::make($request->all(), [
- 'ESTADO' => 'required|string',
- 'DESCRIPCION' => 'required|string',
- 'EVIDENCIA1' => 'required|string',
- 'NOMBRE_IMAGEN1' => 'string',
- // 'EVIDENCIA2' => 'string',
- // 'NOMBRE_IMAGEN2' => 'string',
- 'PORCENTAJE' => 'required|integer',
- 'NUMERO_ORDEN' => 'required|string',
- 'NUMERO_LINEA' => 'required|string',
- 'USUARIO' => 'required|string',
- ]);
- if ($validator->fails()) {
- return $this->responseController->makeResponse(
- true,
- "ERR_ORDERSTATE_REG000: Se encontraron uno o más errores.",
- $this->responseController->makeErrors($validator->errors()->messages()),
- 401
- );
- }
- DB::beginTransaction();
- $requestData = $request->all();
- $imageEvidence1 = null;
- $arrResponseImage = $this->resourcesController->saveImage( $requestData['EVIDENCIA1'], '/app/public/GEAD', $requestData['NOMBRE_IMAGEN1'], $requestData['NUMERO_LINEA'] );
- if ( $arrResponseImage['error'] ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, $arrResponseImage['msg'], $arrResponseImage['response'], 500);
- }
- $imageEvidence1 = $arrResponseImage['response'];
- $imageEvidence2 = null;
- if ( $requestData['EVIDENCIA2'] != '' && $requestData['EVIDENCIA2'] != null ) {
- $arrResponseImage = $this->resourcesController->saveImage( $requestData['EVIDENCIA2'], '/app/public/GEAD', $requestData['NOMBRE_IMAGEN2'], $requestData['NUMERO_LINEA'] );
- if ( $arrResponseImage['error'] ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, $arrResponseImage['msg'], $arrResponseImage['response'], 500);
- }
- $imageEvidence2 = $arrResponseImage['response'];
- }
- try {
- $user = $this->encController->decrypt($requestData['USUARIO']);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDERSTATE_REG001: Ocurrió un error al obtener el usuario.", [], 500);
- }
- $arrInsert = [
- 'HIOR_NUOR' => $requestData['NUMERO_ORDEN'],
- 'HIOR_ESOR' => $requestData['ESTADO'],
- 'HIOR_DESC' => $requestData['DESCRIPCION'],
- 'HIOR_EVI1' => $imageEvidence1,
- 'HIOR_EVI2' => $imageEvidence2,
- 'HIOR_POEN' => $requestData['PORCENTAJE'],
- 'HIOR_NULI' => $requestData['NUMERO_LINEA'],
- 'HIOR_USRE' => $user,
- 'HIOR_FERE' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- 'HIOR_FEAR' => DB::raw('CURRENT_TIMESTAMP'),
- ];
- try {
- $validateInsert = DB::table('S002V01THIOR')->insert($arrInsert);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDERSTATE_REG002: Ocurrió un error al momento de insertar los datos.", [], 500);
- }
- if ( !$validateInsert ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDERSTATE_REG003: No se pudo insertar los datos a la tabla.", [], 500);
- }
- $arrUpdate = [
- 'ORCO_ESTA' => $requestData['ESTADO'],
- 'ORCO_USMO' => $user,
- 'ORCO_FEMO' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- ];
- try {
- $validateUpdate = DB::table('S002V01TORCO')
- ->where('ORCO_NUOR', '=', $requestData['NUMERO_ORDEN'])
- ->where('ORCO_NULI', '=', $requestData['NUMERO_LINEA'])
- ->update($arrUpdate);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_ORDERSTATE_REG004: Ocurrió un error al momento de modificar los datos.", [], 500);
- }
- if ( !$validateUpdate ) {
- DB::rollBack();
- return $this->responseController->makeRespÑonse(true, "ERR_ORDERSTATE_REG005: No se pudo modificar los datos a la tabla.", [], 500);
- }
- DB::commit();
- return $this->responseController->makeResponse(false, "ÉXITO: Modificación de Estado Exitoso");
- }
- public function reorderArtitles(Request $request) {
- $validator = Validator::make($request->all(), [
- 'ORDEN' => 'required|string',
- 'DESCRIPCION' => 'required|string',
- 'USUARIO' => 'required|string',
- 'NUMERO_LINEA' => 'required|string',
- ]);
- if ($validator->fails()) {
- return $this->responseController->makeResponse(
- true,
- "ERR_REORDER_REG000: Se encontraron uno o más errores.",
- $this->responseController->makeErrors($validator->errors()->messages()),
- 401
- );
- }
- DB::beginTransaction();
- $requestData = $request->all();
- try {
- $user = $this->encController->decrypt($requestData['USUARIO']);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG001: Ocurrió un error al obtener el usuario.", [], 500);
- }
- try {
- $order = $this->encController->decrypt($requestData['ORDEN']);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG002: Ocurrió un error al obtener el número de orden.", [], 500);
- }
- try {
- $idRegisterLine = DB::table('S002V01TLINE')->insertGetId([
- // 'LINE_DESC' => $request['DESCRIPCION'],
- 'LINE_NULI' => $request['NUMERO_LINEA'],
- 'LINE_USRE' => $user,
- 'LINE_FERE' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- 'LINE_FEAR' => DB::raw('CURRENT_TIMESTAMP')
- ]);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG003: Ocurrió un error al hacer la inserción en la base.", $th->getMessage(), 500);
- }
- if ( !$idRegisterLine ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG004: Ocurrió un error al hacer la inserción en la base.", [], 500);
- }
- try {
- $arrArtitles = DB::table('S002V01TORCO')
- ->where('ORCO_NUOR', '=', $order)
- ->join('S002V01TARSE', function (JoinClause $join) {
- $join->on('ARSE_IDLI', '=', 'ORCO_IDLI')
- ->on('ARSE_NUPR', '=', 'ORCO_NUPR');
- })
- ->get([
- 'ARSE_IDAR', // Identificador del artículo
- 'ARSE_NUPR', // Número del proveedor
- 'ARSE_IDIN', // Identificador de la información del artículo
- 'ARSE_CANT', // Cantidad
- 'ARSE_PRTO', // Precio total
- ]);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG005: No se pudo obtener la información de la orden.", $th->getMessage(), 500);
- }
- if ( $arrArtitles->isEmpty() ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG006: La orden no tiene artículos.", [], 500);
- }
- foreach ($arrArtitles as $keyArtitle => $artitle) {
- try {
- $validateInsert = DB::table('S002V01TARSE')->insert([
- 'ARSE_IDAS' => $keyArtitle + 1,
- 'ARSE_IDLI' => $idRegisterLine,
- 'ARSE_IDAR' => $artitle->ARSE_IDAR,
- 'ARSE_NUPR' => $artitle->ARSE_NUPR,
- 'ARSE_IDIN' => $artitle->ARSE_IDIN,
- 'ARSE_CANT' => $artitle->ARSE_CANT,
- 'ARSE_PRTO' => $artitle->ARSE_PRTO,
- 'ARSE_NULI' => $request['NUMERO_LINEA'],
- 'ARSE_USRE' => $user,
- 'ARSE_FERE' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- 'ARSE_FEAR' => DB::raw('CURRENT_TIMESTAMP')
- ]);
- } catch (\Throwable $th) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG007: Ocurrió un error al hacer la inserción en la base.", $th->getMessage(), 500);
- }
- if ( !$validateInsert ) {
- DB::rollBack();
- return $this->responseController->makeResponse(true, "ERR_REORDER_REG008: Ocurrió un error al hacer la inserción en la base.", [], 500);
- }
- }
- DB::commit();
- return $this->responseController->makeResponse(false, "ÉXITO: Artículos Reordenados Exitosamente");
- }
- public function generateSheetAcquisition($encOrderNumber, $encUser, $line) {
- try {
- $orderNumber = $this->encController->decrypt($encOrderNumber);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG000: Ocurrió un error al obtener la ordens.", $th->getMessage(), 500);
- }
- try {
- $user = $this->encController->decrypt($encUser);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG001: Ocurrió un error al obtener la ordens.", $th->getMessage(), 500);
- }
- try {
- $getOrder = DB::table('S002V01TORCO')
- ->where('ORCO_NUOR', '=', $orderNumber)
- ->where('ORCO_NULI', '=', $line)
- ->where('PROV_NULI', '=', $line)
- ->where('DESP_NULI', '=', $line)
- ->where('LINE_NULI', '=', $line)
- ->where('MEPA_NULI', '=', $line)
- ->where('ORCO_ESTA', '=', 'Activo')
- ->where('PROV_ESTA', '=', 'Activo')
- ->where('DESP_ESTA', '=', 'Activo')
- ->where('LINE_ESTA', '=', 'Activo')
- ->where('MEPA_ESTA', '=', 'Activo')
- ->join('S002V01TPROV', 'PROV_NUPR', '=', 'ORCO_NUPR')
- ->join('S002V01TDESP', 'DESP_IDDE', '=', 'ORCO_NUDE')
- ->join('S002V01TLINE', 'LINE_IDLI', '=', 'ORCO_IDLI')
- ->join('S002V01TMEPA', 'MEPA_IDME', '=', 'LINE_IDME')
- ->first([
- 'ORCO_NUOR', // Número de Orden
- 'ORCO_COST', // Costo Total
- 'ORCO_MONE', // Moneda
- 'ORCO_PROY', // Proyecto
- 'ORCO_ESTA', // Estado
- 'ORCO_USRE', // Usuario Registra
- 'ORCO_FERE', // Fecha Registra
- 'ORCO_USMO', // Usuario Modifica
- 'ORCO_FEMO', // Fecha Modifica
- // ------------------------------------------------------
- 'PROV_NUPR', // Número de proveedor
- 'PROV_NOCO', // Nombre comercial del proveedor
- 'PROV_NOMB', // Nombre del proveedor
- 'PROV_APPA', // Apellido paterno del proveedor
- 'PROV_APMA', // Apellido materno del proveedor
- 'PROV_CORR', // Correo
- 'PROV_LAD1', // Lada 1
- 'PROV_TEL1', // Teléfono 1
- 'PROV_LAD2', // Lada 2
- 'PROV_TEL2', // Teléfono 2
- 'PROV_XRFC', // R.F.C.
- 'PROV_XTAX', // T.A.X ID
- 'PROV_GIRO', // Giro empresarial
- 'PROV_TIPO', // Tipo de proveedor
- 'PROV_SIWE', // Sitio web del proveedor
- 'PROV_MEPA', // Método de pago del proveedor
- // ------------------------------------------------------
- 'DESP_IDDE', // Número de despacho
- 'DESP_NOMB', // Nombre del despacho
- 'DESP_CALL', // Calle
- 'DESP_NUEX', // Número exterior
- 'DESP_NUIN', // Número interor
- 'DESP_COPO', // Código Postal
- 'DESP_COLO', // Colonia
- 'DESP_MUNI', // Municipio
- 'DESP_ENTI', // Entidad
- 'DESP_PAIS', // Pais
- // ------------------------------------------------------
- 'LINE_IDLI', // Número de línea de solicitud
- // 'LINE_DESC', // Descripción
- 'LINE_IDME', // Método de pago
- 'LINE_COME', // Comentarios
- // ------------------------------------------------------
- 'MEPA_NOMB',
- ]);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG002: Ocurrió un error al obtener la información.", $th->getMessage(), 500);
- }
- $getOrder = (array) $getOrder;
- try {
- $getStateOrder = DB::table('S002V01THIOR')
- ->where('HIOR_NUOR', '=', $getOrder['ORCO_NUOR'])
- ->where('HIOR_NULI', '=', $line)
- ->get([
- 'HIOR_IDHO', //
- 'HIOR_NUOR', //
- 'HIOR_ESOR', //
- 'HIOR_DESC', //
- 'HIOR_EVI1', //
- 'HIOR_EVI2', //
- 'HIOR_POEN', //
- 'HIOR_ESTA', //
- 'HIOR_NULI', //
- 'HIOR_INEX', //
- 'HIOR_USRE', //
- 'HIOR_FERE', //
- 'HIOR_USMO', //
- 'HIOR_FEMO', //
- ]);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG003: Ocurrió un error al obtener la información.", $th->getMessage(), 500);
- }
- $mpdf = new PDF( [
- 'mode' => 'utf-8',
- 'format' => 'A4',
- 'margin_header' => '3',
- 'margin_top' => '20',
- 'margin_bottom' => '20',
- 'margin_footer' => '2',
- ]);
- $mpdf->SetHTMLHeader('
- <div style="display:flex; align-items: center; text-align: right;">
- <img src="" width="100">
- </div>
- ');
-
- $mpdf->WriteHTML('<b>Número de Orden:</b> '.$getOrder['ORCO_NUOR'] );
- $mpdf->WriteHTML('<b>Costo Total:</b> $'.$getOrder['ORCO_COST'].' '.$getOrder['ORCO_MONE']);
- if ($getOrder['ORCO_PROY'] != null) {
- $mpdf->WriteHTML('<b>Proyecto:</b> '.$getOrder['ORCO_PROY']);
- }
- $mpdf->WriteHTML('<b>Estado:</b> '.$getOrder['ORCO_ESTA']);
-
- $htmlTable = '<br><table border="1"><thead><tr>
- <th>Número de Estado</th>
- <th>Estado de la Orden</th>
- <th>Descripción</th>
- <th>Porcentaje</th>
- <th>Usuario de Registro</th>
- <th>Fecha de Registro</th>
- </tr></thead><tbody>';
- foreach ($getStateOrder as $key => $stateOrder) {
- $stateOrder = (array) $stateOrder;
- $htmlTable .= '<tr>';
- $htmlTable .= '<td>'.$stateOrder['HIOR_IDHO'].'</td>';
- $htmlTable .= '<td>'.$stateOrder['HIOR_ESOR'].'</td>';
- $htmlTable .= '<td>'.$stateOrder['HIOR_DESC'].'</td>';
- $htmlTable .= '<td>'.$stateOrder['HIOR_POEN'].'%</td>';
- $htmlTable .= '<td>'.$stateOrder['HIOR_USRE'].'</td>';
- $htmlTable .= '<td>'.$stateOrder['HIOR_FERE'].'</td>';
- $htmlTable .= '</tr>';
- }
- $htmlTable .= '</tbody></table>';
- $mpdf->WriteHTML($htmlTable);
- $mpdf->WriteHTML('<hr>');
- $mpdf->WriteHTML('<b>Número de Solicitud de Compra:</b> '.$getOrder['LINE_IDLI']);
- // $mpdf->WriteHTML('<b>Descripción '.$getOrder['LINE_DESC']);
- $mpdf->WriteHTML('<b>Método de Pago:</b> '.$getOrder['MEPA_NOMB']);
- $mpdf->WriteHTML('<b>Comentarios:</b> '.$getOrder['LINE_COME']);
- $mpdf->WriteHTML('<hr>');
- $mpdf->WriteHTML('<b>Número de Proveedor:</b> '.$getOrder['PROV_NUPR']);
- $mpdf->WriteHTML('<b>Nombre Comercial:</b> '.$getOrder['PROV_NOCO']);
- $mpdf->WriteHTML('<b>Nombre:</b> '.$getOrder['PROV_NOMB'].' '.$getOrder['PROV_APPA'].' '.$getOrder['PROV_APMA']);
- $mpdf->WriteHTML('<b>Correo:</b> '.$getOrder['PROV_CORR']);
- $mpdf->WriteHTML('<b>Teléfono Principal:</b> +'.$getOrder['PROV_LAD1'].' '.$getOrder['PROV_TEL1']);
- if ($getOrder['PROV_TEL2'] != null) {
- $mpdf->WriteHTML('<b>Teléfono Secundario:</b> +'.$getOrder['PROV_LAD2'].' '.$getOrder['PROV_TEL2']);
- }
- if ($getOrder['PROV_XRFC'] != null) {
- $mpdf->WriteHTML('<b>R.F.C:</b> '.$getOrder['PROV_XRFC']);
- }
- if ($getOrder['PROV_XTAX'] != null) {
- $mpdf->WriteHTML('<b>TAX ID:</b> '.$getOrder['PROV_XTAX']);
- }
- $mpdf->WriteHTML('<b>Giro Empresarial:</b> '.$getOrder['PROV_GIRO']);
- $mpdf->WriteHTML('<b>Tipo de Proveedor:</b> '.$getOrder['PROV_TIPO']);
- $mpdf->WriteHTML('<b>Sitio '.$getOrder['PROV_SIWE']);
- $mpdf->WriteHTML('<hr>');
- $mpdf->WriteHTML('<b>Número de Despacho:</b> '.$getOrder['DESP_IDDE']);
- $mpdf->WriteHTML('<b>Nombre del Despacho:</b> '.$getOrder['DESP_NOMB']);
- $mpdf->WriteHTML('<b>Dirección:</b> '.$getOrder['DESP_CALL'].', '.$getOrder['DESP_NUEX'].''.$getOrder['DESP_NUIN'].', '.$getOrder['DESP_COPO'].', '.$getOrder['DESP_COLO'].', '.
- $getOrder['DESP_MUNI'].', '.$getOrder['DESP_ENTI'].', '.$getOrder['DESP_PAIS']);
-
- $contentFile = $mpdf->Output('', "S");
- $base64File = base64_encode($contentFile);
- try {
- $arrResponse = $this->resourcesController->saveDocument($base64File, 'GEAD','FICHA_ADQUISICION_'.$getOrder['ORCO_NUOR'].'.pdf','IN',$line);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG004: Ocurrió un error al obtener la información.", $th->getMessage(), 500);
- }
- if ($arrResponse['error']) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG005: Ocurrió un error al obtener la información.", [], 500);
- }
- try {
- $validateInsert = DB::table('S002V01TDOOR')->insert([
- 'DOOR_NUOR' => $getOrder['ORCO_NUOR'],
- 'DOOR_CODO' => $arrResponse['response'],
- 'DOOR_DESC' => 'Ficha',
- 'DOOR_TIPO' => 'IN',
- 'DOOR_NULI' => $line,
- 'DOOR_USRE' => $user,
- 'DOOR_FERE' => Carbon::now()->timezone('America/Mazatlan')->toDateTimeString(),
- 'DOOR_FEAR' => DB::raw('CURRENT_TIMESTAMP'),
- ]);
- } catch (\Throwable $th) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG006: Ocurrió un error al ingresar la ficha.", $th->getMessage(), 500);
- }
- if (!$validateInsert) {
- return $this->responseController->makeResponse(true, "ERR_GENERATE_SHEET_REG007: No se pudo ingresar la ficha.", [], 500);
- }
- return $this->responseController->makeResponse(false, "ÉXITO: Ficha Exitosa", $arrResponse['response']);
- }
- }
|