OrderReceptionController.php 48 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\ResponseController;
  4. use App\Http\Controllers\EncryptionController;
  5. use App\Http\Controllers\ResourcesController;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Carbon;
  8. use Illuminate\Support\Facades\DB;
  9. use Illuminate\Support\Facades\Validator;
  10. use Illuminate\Support\Facades\Storage;
  11. use Illuminate\Http\File;
  12. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  13. use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
  14. use App\Http\Controllers\FunctionsController;
  15. use Dompdf\Dompdf;
  16. class OrderReceptionController extends Controller
  17. {
  18. private $responseController;
  19. private $encController;
  20. private $resourcesController;
  21. private $functionsController;
  22. public function __construct(){
  23. $this->responseController = new ResponseController();
  24. $this->encController = new EncryptionController();
  25. $this->resourcesController = new ResourcesController();
  26. $this->functionsController = new FunctionsController();
  27. }
  28. public function getOrderReception($user, $line) {
  29. DB::beginTransaction();
  30. try {
  31. $getOrderReception = DB::table('S002V01TORCO')
  32. ->where('ORCO_NULI', '=', $line)
  33. ->where('DESP_NULI', '=', $line)
  34. ->where('DESP_ESTA', '=', 'Activo')
  35. ->where('ORCO_ESTA', '=', 'Recibido')
  36. ->orWhere('ORCO_ESTA', '=', 'Facturado')
  37. ->orWhere('ORCO_ESTA', '=', 'Devuelto')
  38. ->join('S002V01TDESP','DESP_IDDE','=','ORCO_IDDE')
  39. ->join('S002V01TLINE','LINE_IDLI','=','ORCO_IDLI')
  40. ->get([
  41. 'ORCO_NUOR',
  42. 'ORCO_ESTA',
  43. 'ORCO_INEX',
  44. 'ORCO_USRE',
  45. 'ORCO_FERE',
  46. 'ORCO_USMO',
  47. 'ORCO_FEMO',
  48. 'ORCO_FEAR',
  49. 'LINE_IDLI',
  50. 'LINE_NUPR',
  51. 'LINE_OTPR',
  52. 'LINE_OTCO',
  53. 'DESP_IDDE',
  54. 'DESP_NODE',
  55. 'DESP_NOMB',
  56. 'DESP_APPA',
  57. 'DESP_APMA',
  58. 'DESP_LADA',
  59. 'DESP_TELE',
  60. 'DESP_CORR',
  61. 'DESP_CALL',
  62. 'DESP_NUEX',
  63. 'DESP_NUIN',
  64. 'DESP_COPO',
  65. 'DESP_COLO',
  66. 'DESP_LOCA',
  67. 'DESP_MUNI',
  68. 'DESP_ENTI',
  69. 'DESP_PAIS',
  70. 'DESP_COME',
  71. 'DESP_ESTA',
  72. 'DESP_INEX',
  73. 'DESP_USRE',
  74. 'DESP_FERE',
  75. 'DESP_USMO',
  76. 'DESP_FEMO',
  77. 'DESP_FEAR',
  78. ]);
  79. } catch (\Throwable $th) {
  80. DB::rollBack();
  81. return $this->responseController->makeResponse(true, "ERR_ORDER_RECEPTION_GET000: Ocurrió un error al obtener los datos.", $th->getMessage(), 500);
  82. }
  83. DB::commit();
  84. return $this->responseController->makeResponse(false, "ÉXITO: Consulta Exitosa", $getOrderReception);
  85. }
  86. public function generateSheetDeliveryListXLS( $orderNumber, $user, $line ) {
  87. try {
  88. $idOrder = $this->encController->decrypt($orderNumber);
  89. } catch (\Throwable $th) {
  90. DB::rollBack();
  91. return $this->responseController->makeResponse(
  92. true,
  93. "ERR_ORDER_SHEET000: Ocurrió un error al obtener el número del proveedor.",
  94. $th->getMessage(),
  95. 500
  96. );
  97. }
  98. try {
  99. $user = $this->encController->decrypt($user);
  100. } catch (\Throwable $th) {
  101. DB::rollBack();
  102. return $this->responseController->makeResponse(
  103. true,
  104. "ERR_ORDER_SHEET001: Ocurrió un error al obtener el usuario.",
  105. $th->getMessage(),
  106. 500
  107. );
  108. }
  109. try {
  110. $arrOrder = (array) DB::table('S002V01TORCO')
  111. ->where('ORCO_NUOR', '=', $idOrder)
  112. ->where('ORCO_NULI', '=', $line)
  113. ->where('LINE_NULI', '=', $line)
  114. ->where('DESP_NULI', '=', $line)
  115. ->where('PROV_NULI', '=', $line)
  116. ->where('DESP_ESTA', '=', 'Activo')
  117. ->where('PROV_ESTA', '=', 'Activo')
  118. ->join('S002V01TLINE', 'LINE_IDLI', '=', 'ORCO_IDLI')
  119. ->join('S002V01TDESP', 'DESP_IDDE', '=', 'ORCO_IDDE')
  120. ->join('S002V01TPROV', 'PROV_NUPR', '=', 'LINE_NUPR')
  121. ->join('S002V01TREFI', 'REFI_CRFI', '=', 'PROV_CRFI')
  122. ->first([
  123. 'ORCO_NUOR',
  124. 'ORCO_ESTA',
  125. 'LINE_IDLI',
  126. 'LINE_OTPR',
  127. 'LINE_OTCO',
  128. 'LINE_ESTA',
  129. 'DESP_IDDE',
  130. 'DESP_NODE',
  131. 'DESP_NOMB',
  132. 'DESP_APPA',
  133. 'DESP_APMA',
  134. 'DESP_LADA',
  135. 'DESP_TELE',
  136. 'DESP_CORR',
  137. 'DESP_CALL',
  138. 'DESP_NUEX',
  139. 'DESP_NUIN',
  140. 'DESP_COPO',
  141. 'DESP_COLO',
  142. 'DESP_LOCA',
  143. 'DESP_MUNI',
  144. 'DESP_ENTI',
  145. 'DESP_PAIS',
  146. 'DESP_COME',
  147. 'PROV_NUPR',
  148. 'PROV_IDPS',
  149. 'PROV_NOCO',
  150. 'PROV_NOMB',
  151. 'PROV_APPA',
  152. 'PROV_APMA',
  153. 'PROV_CORR',
  154. 'PROV_LAD1',
  155. 'PROV_TEL1',
  156. 'PROV_LAD2',
  157. 'PROV_TEL2',
  158. 'PROV_XRFC',
  159. 'PROV_XTAX',
  160. 'PROV_TIPO',
  161. 'PROV_TICO',
  162. 'PROV_SIWE',
  163. 'PROV_MEPA',
  164. 'PROV_CALL',
  165. 'PROV_NUEX',
  166. 'PROV_NUIN',
  167. 'PROV_COPO',
  168. 'PROV_COLO',
  169. 'PROV_MUNI',
  170. 'PROV_LOCA',
  171. 'PROV_ENTI',
  172. 'PROV_PAIS',
  173. 'REFI_CRFI',
  174. 'REFI_DRFI',
  175. ]);
  176. } catch (\Throwable $th) {
  177. return $this->responseController->makeResponse(
  178. true,
  179. "ERR_ORDER_SHEET002: Ocurrió un error al obtener la información de la orden de compra.",
  180. $th->getMessage(),
  181. 500
  182. );
  183. }
  184. try {
  185. $arrArtitle = DB::table('S002V01TARSE')
  186. ->where('ARSE_NULI', '=', $line)
  187. ->where('INAR_NULI', '=', $line)
  188. ->where('CAMO_NULI', '=', $line)
  189. ->where('DEAR_NULI', '=', $line)
  190. ->where('UNID_NULI', '=', $line)
  191. ->where('ARTI_NULI', '=', $line)
  192. ->where('FAMI_NULI', '=', $line)
  193. ->where('SUBF_NULI', '=', $line)
  194. ->where('ARSE_ESTA', '=', 'Activo')
  195. ->where('INAR_ESTA', '=', 'Activo')
  196. ->where('CAMO_ESTA', '=', 'Activo')
  197. ->where('DEAR_ESTA', '=', 'Activo')
  198. ->where('UNID_ESTA', '=', 'Activo')
  199. ->where('ARTI_ESTA', '=', 'Activo')
  200. ->where('FAMI_ESTA', '=', 'Activo')
  201. ->where('SUBF_ESTA', '=', 'Activo')
  202. ->where('ARSE_IDLI', '=', $arrOrder['LINE_IDLI'])
  203. ->where('ARSE_NUPR', '=', $arrOrder['PROV_NUPR'])
  204. ->join('S002V01TINAR','INAR_IDIN','=','ARSE_IDIN')
  205. ->join('S002V01TCAMO','CAMO_COMO','=','INAR_COMO')
  206. ->join('S002V01TDEAR','DEAR_IDDE','=','INAR_IDDE')
  207. ->join('S002V01TUNID','UNID_IDUN','=','DEAR_IDUN')
  208. ->join('S002V01TARTI','ARTI_IDAR','=','DEAR_IDAR')
  209. ->join('S002V01TFAMI','FAMI_COFA','=','ARTI_COFA')
  210. ->join('S002V01TSUBF','SUBF_COSU','=','ARTI_COSU')
  211. ->get([
  212. 'ARSE_IDAS',
  213. 'ARSE_IDLI',
  214. 'ARSE_CANT',
  215. 'ARSE_PRTO',
  216. 'INAR_IDIN',
  217. 'INAR_CODI',
  218. 'INAR_MODE',
  219. 'INAR_PREC',
  220. 'INAR_MOMI',
  221. 'INAR_CARA',
  222. 'CAMO_COMO',
  223. 'CAMO_DESC',
  224. 'CAMO_DECI',
  225. 'CAMO_POVA',
  226. 'CAMO_FEIN',
  227. 'CAMO_FEFI',
  228. 'DEAR_IDDE',
  229. 'DEAR_IMAG',
  230. 'DEAR_DESC',
  231. 'DEAR_CARA',
  232. 'DEAR_COWE',
  233. 'UNID_IDUN',
  234. 'UNID_NOMB',
  235. 'UNID_ACRO',
  236. 'ARTI_IDAR',
  237. 'ARTI_CODI',
  238. 'ARTI_NOMB',
  239. 'FAMI_COFA',
  240. 'FAMI_NOFA',
  241. 'SUBF_COSU',
  242. 'SUBF_NOSU',
  243. ]);
  244. $arrArtitle = json_decode( json_encode( $arrArtitle ), true );
  245. } catch (\Throwable $th) {
  246. return $this->responseController->makeResponse(
  247. true,
  248. "ERR_ORDER_SHEET002: Ocurrió un error al obtener la información de la orden de compra.",
  249. $th->getMessage(),
  250. 500
  251. );
  252. }
  253. $spreadsheet = new Spreadsheet();
  254. $activeWorksheet = $spreadsheet->getActiveSheet()->setTitle($arrOrder['ORCO_NUOR']);
  255. $headerA1 = 'Número de orden';
  256. $contentB1 = $arrOrder['ORCO_NUOR'];
  257. $activeWorksheet->setCellValue("A1", $headerA1);
  258. $activeWorksheet->setCellValue("B1", $contentB1);
  259. $activeWorksheet->getStyle( "A1" )->getFont()->setBold(true);
  260. $headerA2 = 'Estado de la orden';
  261. $contentB2 = $arrOrder['ORCO_ESTA'];
  262. $activeWorksheet->setCellValue("A2", $headerA2);
  263. $activeWorksheet->setCellValue("B2", $contentB2);
  264. $activeWorksheet->getStyle( "A2" )->getFont()->setBold(true);
  265. $headerA3 = 'Numero de línea de solicitud';
  266. $contentB3 = $arrOrder['LINE_IDLI'];
  267. $activeWorksheet->setCellValue("A3", $headerA3);
  268. $activeWorksheet->setCellValue("B3", $contentB3);
  269. $activeWorksheet->getStyle( "A3" )->getFont()->setBold(true);
  270. $headerA4 = '';
  271. if ( !is_null( $arrOrder['LINE_OTPR'] ) && is_null( $arrOrder['LINE_OTCO'] ) ) {
  272. $headerA4 = 'Orden de Trabajo Preventivo';
  273. $contentB4 = $arrOrder['LINE_OTPR'];
  274. } else if ( is_null( $arrOrder['LINE_OTPR'] ) && !is_null( $arrOrder['LINE_OTCO'] ) ) {
  275. $headerA4 = 'Orden de Trabajo Correctivo';
  276. $contentB4 = $arrOrder['LINE_OTCO'];
  277. } else if ( is_null( $arrOrder['LINE_OTPR'] ) && is_null( $arrOrder['LINE_OTCO'] ) ) {
  278. $headerA4 = 'Orden de Trabajo';
  279. $contentB4 = 'No aplica';
  280. } else {
  281. $headerA4 = 'Orden de Trabajo';
  282. $contentB4 = 'No aplica';
  283. }
  284. $activeWorksheet->setCellValue("A4", $headerA4 );
  285. $activeWorksheet->setCellValue("B4", $contentB4 );
  286. $activeWorksheet->getStyle( "A4" )->getFont()->setBold(true);
  287. $headerA5 = 'ID Despacho';
  288. $contentB5 = $arrOrder['DESP_IDDE'];
  289. $activeWorksheet->setCellValue("A5", $headerA5 );
  290. $activeWorksheet->setCellValue("B5", $contentB5 );
  291. $activeWorksheet->getStyle( "A5" )->getFont()->setBold(true);
  292. $headerA6 = 'Despacho';
  293. $contentB6 = $arrOrder['DESP_NODE'];
  294. $activeWorksheet->setCellValue("A6", $headerA6 );
  295. $activeWorksheet->setCellValue("B6", $contentB6 );
  296. $activeWorksheet->getStyle( "A6" )->getFont()->setBold(true);
  297. $headerA7 = 'Responsable del despacho';
  298. $contentB7 = $arrOrder['DESP_NOMB'] . ' ' . $arrOrder['DESP_APPA'] . ' ' . $arrOrder['DESP_APMA'];
  299. $activeWorksheet->setCellValue("A7", $headerA7 );
  300. $activeWorksheet->setCellValue("B7", $contentB7 );
  301. $activeWorksheet->getStyle( "A7" )->getFont()->setBold(true);
  302. $headerA8 = 'Teléfono del despacho';
  303. $contentB8 = $arrOrder['DESP_LADA'] . ' ' . $arrOrder['DESP_TELE'];
  304. $activeWorksheet->setCellValue("A8", $headerA8 );
  305. $activeWorksheet->setCellValue("B8", $contentB8 );
  306. $activeWorksheet->getStyle( "A8" )->getFont()->setBold(true);
  307. $headerA9 = 'Correo electrónico del despacho';
  308. $contentB9 = $arrOrder['DESP_CORR'];
  309. $activeWorksheet->setCellValue("A9", $headerA9 );
  310. $activeWorksheet->setCellValue("B9", $contentB9 );
  311. $activeWorksheet->getStyle( "A9" )->getFont()->setBold(true);
  312. $headerA10 = 'Calle del despacho';
  313. $contentB10 = $arrOrder['DESP_CALL'];
  314. $activeWorksheet->setCellValue("A10", $headerA10 );
  315. $activeWorksheet->setCellValue("B10", $contentB10 );
  316. $activeWorksheet->getStyle( "A10" )->getFont()->setBold(true);
  317. $headerA11 = 'Número exterior';
  318. $contentB11 = $arrOrder['DESP_NUEX'];
  319. $activeWorksheet->setCellValue("A11", $headerA11 );
  320. $activeWorksheet->setCellValue("B11", $contentB11 );
  321. $activeWorksheet->getStyle( "A11" )->getFont()->setBold(true);
  322. $headerA12 = 'Número interior';
  323. if ( !is_null($arrOrder['DESP_NUIN']) ) {
  324. $contentB12 = $arrOrder['DESP_NUIN'];
  325. } else {
  326. $contentB12 = 'No aplica';
  327. }
  328. $activeWorksheet->setCellValue("A12", $headerA12 );
  329. $activeWorksheet->setCellValue("B12", $contentB12 );
  330. $activeWorksheet->getStyle( "A12" )->getFont()->setBold(true);
  331. $headerA13 = 'Código postal';
  332. $contentB13 = $arrOrder['DESP_COPO'];
  333. $activeWorksheet->setCellValue("A13", $headerA13 );
  334. $activeWorksheet->setCellValue("B13", $contentB13 );
  335. $activeWorksheet->getStyle( "A13" )->getFont()->setBold(true);
  336. $headerA14 = 'Colonia';
  337. $contentB14 = $arrOrder['DESP_COLO'];
  338. $activeWorksheet->setCellValue("A14", $headerA14 );
  339. $activeWorksheet->setCellValue("B14", $contentB14 );
  340. $activeWorksheet->getStyle( "A14" )->getFont()->setBold(true);
  341. $headerA15 = 'Localidad';
  342. if ( !is_null($arrOrder['DESP_LOCA']) && !empty($arrOrder['DESP_LOCA']) ) {
  343. $contentB15 = $arrOrder['DESP_LOCA'];
  344. } else {
  345. $contentB15 = 'No aplica';
  346. }
  347. $activeWorksheet->setCellValue("A15", $headerA15 );
  348. $activeWorksheet->setCellValue("B15", $contentB15 );
  349. $activeWorksheet->getStyle( "A15" )->getFont()->setBold(true);
  350. $headerA16 = 'Municipio';
  351. $contentB16 = $arrOrder['DESP_MUNI'];
  352. $activeWorksheet->setCellValue("A16", $headerA16 );
  353. $activeWorksheet->setCellValue("B16", $contentB16 );
  354. $activeWorksheet->getStyle( "A16" )->getFont()->setBold(true);
  355. $headerA17 = 'Entidad Federativa';
  356. $contentB17 = $arrOrder['DESP_ENTI'];
  357. $activeWorksheet->setCellValue("A17", $headerA17 );
  358. $activeWorksheet->setCellValue("B17", $contentB17 );
  359. $activeWorksheet->getStyle( "A17" )->getFont()->setBold(true);
  360. $headerA18 = 'País';
  361. $contentB18 = $arrOrder['DESP_PAIS'];
  362. $activeWorksheet->setCellValue("A18", $headerA18 );
  363. $activeWorksheet->setCellValue("B18", $contentB18 );
  364. $activeWorksheet->getStyle( "A18" )->getFont()->setBold(true);
  365. $headerA19 = 'Número de proveedor';
  366. $contentB19 = $arrOrder['PROV_NUPR'];
  367. $activeWorksheet->setCellValue("A19", $headerA19 );
  368. $activeWorksheet->setCellValue("B19", $contentB19 );
  369. $activeWorksheet->getStyle( "A19" )->getFont()->setBold(true);
  370. $headerA20 = 'Número de subcontratista';
  371. $contentB20 = $arrOrder['PROV_IDPS'];
  372. $activeWorksheet->setCellValue("A20", $headerA20 );
  373. $activeWorksheet->setCellValue("B20", $contentB20 );
  374. $activeWorksheet->getStyle( "A20" )->getFont()->setBold(true);
  375. $headerA21 = 'Nombre comercial del proveedor';
  376. $contentB21 = $arrOrder['PROV_NOCO'];
  377. $activeWorksheet->setCellValue("A21", $headerA21 );
  378. $activeWorksheet->setCellValue("B21", $contentB21 );
  379. $activeWorksheet->getStyle( "A21" )->getFont()->setBold(true);
  380. $headerA22 = 'Referencia fiscal del proveedor';
  381. $contentB22 = $arrOrder['REFI_DRFI'] . ' (' . $arrOrder['REFI_CRFI'] . ')';
  382. $activeWorksheet->setCellValue("A22", $headerA22 );
  383. $activeWorksheet->setCellValue("B22", $contentB22 );
  384. $activeWorksheet->getStyle( "A22" )->getFont()->setBold(true);
  385. $headerA23 = 'Responsable del proveedor';
  386. $contentB23 = $arrOrder['PROV_NOMB'] . ' ' . $arrOrder['PROV_APPA'] . ' ' . $arrOrder['PROV_APMA'];
  387. $activeWorksheet->setCellValue("A23", $headerA23 );
  388. $activeWorksheet->setCellValue("B23", $contentB23 );
  389. $activeWorksheet->getStyle( "A23" )->getFont()->setBold(true);
  390. $headerA24 = 'Correo electrónico del proveedor';
  391. $contentB24 = $arrOrder['PROV_CORR'];
  392. $activeWorksheet->setCellValue("A24", $headerA24 );
  393. $activeWorksheet->setCellValue("B24", $contentB24 );
  394. $activeWorksheet->getStyle( "A24" )->getFont()->setBold(true);
  395. $headerA25 = 'Teléfono del proveedor';
  396. $contentB25 = $arrOrder['PROV_LAD1'] . ' ' . $arrOrder['PROV_TEL1'];
  397. $activeWorksheet->setCellValue("A25", $headerA25 );
  398. $activeWorksheet->setCellValue("B25", $contentB25 );
  399. $activeWorksheet->getStyle( "A25" )->getFont()->setBold(true);
  400. $headerA26 = '';
  401. $contentB26 = '';
  402. if ( !is_null( $arrOrder['PROV_XRFC'] ) && is_null( $arrOrder['PROV_XRFC'] )) {
  403. $headerA26 = 'R.F.C. del proveedor';
  404. $contentB26 = $arrOrder['PROV_XRFC'];
  405. } else if ( is_null( $arrOrder['PROV_XRFC'] ) && !is_null( $arrOrder['PROV_XRFC'] )) {
  406. $headerA26 = 'TAX ID. del proveedor';
  407. $contentB26 = $arrOrder['PROV_XTAX'];
  408. } else {
  409. $headerA26 = 'R.F.C. / TAX ID';
  410. $contentB26 = 'No aplica';
  411. }
  412. $activeWorksheet->setCellValue("A26", $headerA26 );
  413. $activeWorksheet->setCellValue("B26", $contentB26 );
  414. $activeWorksheet->getStyle( "A26" )->getFont()->setBold(true);
  415. $activeWorksheet->getColumnDimension("A")->setAutoSize(true);
  416. $activeWorksheet->getColumnDimension("B")->setAutoSize(true);
  417. $arrAlphabet = $this->resourcesController->arrAlphabet;
  418. $spreadsheet->createSheet();
  419. $spreadsheet->setActiveSheetIndex(1);
  420. $activeWorksheetArtitle = $spreadsheet->getActiveSheet()->setTitle('Artículos de la orden');
  421. $arrHeaderArtitle = array(
  422. /* A */ 'ID Artículo',
  423. /* B */ 'Código del artíulo',
  424. /* C */ 'Artículo',
  425. /* D */ 'Familia',
  426. /* E */ 'Subfamilia',
  427. /* F */ 'Descripción',
  428. /* G */ 'Características',
  429. /* H */ 'Unidad',
  430. /* I */ 'Código',
  431. /* J */ 'Modelo',
  432. /* K */ 'Precio Unitario',
  433. /* L */ 'Cantidad',
  434. /* M */ 'Precio Total',
  435. /* N */ 'No. de selección',
  436. );
  437. foreach ($arrArtitle as $key => $artitle) {
  438. $key = $key + 2;
  439. $activeWorksheetArtitle->setCellValue("A".$key, $artitle['ARTI_IDAR']);
  440. $activeWorksheetArtitle->setCellValue("B".$key, $artitle['ARTI_CODI']);
  441. $activeWorksheetArtitle->setCellValue("C".$key, $artitle['ARTI_NOMB']);
  442. $activeWorksheetArtitle->setCellValue("D".$key, $artitle['FAMI_NOFA'] . ' (' . $artitle['FAMI_COFA'] . ')');
  443. $activeWorksheetArtitle->setCellValue("E".$key, $artitle['SUBF_NOSU'] . ' (' . $artitle['SUBF_COSU'] . ')');
  444. $activeWorksheetArtitle->setCellValue("F".$key, $artitle['DEAR_DESC']);
  445. $activeWorksheetArtitle->setCellValue("G".$key, $artitle['DEAR_CARA']);
  446. $activeWorksheetArtitle->setCellValue("H".$key, $artitle['UNID_NOMB'] . ' (' . $artitle['UNID_IDUN'] . ')');
  447. $activeWorksheetArtitle->setCellValue("I".$key, $artitle['INAR_CODI']);
  448. $activeWorksheetArtitle->setCellValue("J".$key, $artitle['INAR_MODE']);
  449. $activeWorksheetArtitle->setCellValue("K".$key, '$'. $artitle['INAR_PREC'] . ' ' . $artitle['CAMO_COMO'] );
  450. $activeWorksheetArtitle->setCellValue("L".$key, $artitle['ARSE_CANT']);
  451. $activeWorksheetArtitle->setCellValue("M".$key, '$'. $artitle['ARSE_PRTO'] . ' ' . $artitle['CAMO_COMO'] );
  452. $activeWorksheetArtitle->setCellValue("N".$key, $artitle['ARSE_IDAS']);
  453. }
  454. foreach ($arrHeaderArtitle as $keyHeaderArtitle => $headerArtitle) {
  455. $activeWorksheetArtitle->setCellValue( $arrAlphabet[$keyHeaderArtitle]."1", $headerArtitle);
  456. $activeWorksheetArtitle->getColumnDimension( $arrAlphabet[$keyHeaderArtitle] )->setAutoSize(true);
  457. $activeWorksheetArtitle->getStyle( $arrAlphabet[$keyHeaderArtitle]."1" )->getFont()->setBold(true);
  458. }
  459. $nuli = $this->resourcesController->formatSecuence($line, 2);
  460. $como = 'GEAD'; // Código del módulo
  461. $cldo = 'IN'; // Código de la clasificación
  462. $fecr = date('ymd'); // Fecha en la se carga el archivo
  463. try {
  464. $arrSecuence = (array) DB::table('S002V01TAFAL')
  465. ->where('AFAL_COMO', '=', $como)
  466. ->where('AFAL_CLDO', '=', $cldo)
  467. ->where('AFAL_NULI', '=', $line)
  468. ->orderBy('AFAL_NUSE', 'desc')
  469. ->first([ 'AFAL_NUSE' ]);
  470. } catch (\Throwable $th) {
  471. return $this->responseController->makeResponse(
  472. true,
  473. "ERR_PROVIDER_SHEET020: Ocurrió un error al obtener la información de la secuencia.",
  474. $th->getMessage(),
  475. 500
  476. );
  477. }
  478. $nuse = 1; // Secuencia del documento
  479. if ( !empty( $arrSecuence ) && !is_null( $arrSecuence ) ) {
  480. $nuse = intval( $arrSecuence['AFAL_NUSE'] ) + 1;
  481. }
  482. $nuse = $this->resourcesController->formatSecuence($nuse, 6);
  483. $nuve = $this->resourcesController->formatSecuence('1', 2);
  484. $noar = 'ficha_de_adquisición_' . $arrOrder['ORCO_NUOR'];
  485. $exte = 'xlsx';
  486. if ($_SERVER['SERVER_NAME'] === '192.168.100.105') {
  487. $filePath = 'C:/ITTEC/SAM/Dev/SistemaMantenimiento/sistema-mantenimiento-back/public/public_files/'; // API JEAN
  488. } else {
  489. $filePath = 'C:\inetpub\wwwroot\sam\public_files\\'; // API QA
  490. }
  491. $fileName = $nuli.'-'.$como.'-'.$cldo.'-'.$fecr.'-'.$nuse.'='.$nuve.'='.$noar.'.'.$exte;
  492. $tempFile = $filePath.$fileName;
  493. if ( file_exists( $tempFile ) ) {
  494. if ( !unlink( $tempFile ) ) {
  495. return $this->responseController->makeResponse(
  496. true,
  497. "ERR_PROVIDER_SHEET021: Ocurrió un error al eliminar el siguiente archivo: " . $tempFile,
  498. [],
  499. 500
  500. );
  501. }
  502. }
  503. try {
  504. $writer = new Xlsx($spreadsheet);
  505. ob_start();
  506. $writer->save('php://output');
  507. $base64 = base64_encode(ob_get_clean());
  508. $validate = \File::put( $tempFile, base64_decode($base64));
  509. } catch (\Throwable $th) {
  510. return $this->responseController->makeResponse(
  511. true,
  512. "ERR_PROVIDER_SHEET022: Ocurrió un error al guardar el documento.",
  513. $th->getMessage(),
  514. 500
  515. );
  516. }
  517. $ubic = Storage::putFile('files', new File($tempFile));
  518. $ubic = str_replace("/", "\\", $ubic);
  519. if ($_SERVER['SERVER_NAME'] === '192.168.100.105') {
  520. $ubic = "C:\ITTEC\SAM\Dev\SistemaMantenimiento\sistema-mantenimiento-back\storage\app\\" . $ubic;
  521. } else {
  522. $ubic = "C:\inetpub\wwwroot\sam\storage\app\\" . $ubic;
  523. }
  524. $tama = filesize($ubic);
  525. $usac = json_encode([$user]);
  526. $now = $this->functionsController->now();
  527. $currentDate = $now->toDateTimeString();
  528. try {
  529. $validateInsert = DB::table('S002V01TAFAL')->insert([
  530. 'AFAL_NULI' => $line,
  531. 'AFAL_COMO' => $como,
  532. 'AFAL_CLDO' => $cldo,
  533. 'AFAL_FECR' => $fecr,
  534. 'AFAL_NUSE' => $nuse,
  535. 'AFAL_NUVE' => $nuve,
  536. 'AFAL_NOAR' => $noar,
  537. 'AFAL_EXTE' => $exte,
  538. 'AFAL_TAMA' => $tama,
  539. 'AFAL_UBIC' => $ubic,
  540. 'AFAL_USAC' => $usac,
  541. 'AFAL_USRE' => $user,
  542. 'AFAL_FERE' => $currentDate,
  543. ]);
  544. } catch (\Throwable $th) {
  545. return $this->responseController->makeResponse(
  546. true,
  547. "ERR_PROVIDER_SHEET023: Ocurrió un error guardar los datos a la tabla final de archivos.",
  548. $th->getMessage(),
  549. 500
  550. );
  551. }
  552. if ( !$validateInsert ) {
  553. return $this->responseController->makeResponse(
  554. true,
  555. "ERR_PROVIDER_SHEET024: No se pudo guardar la ficha del proveedor en la base de datos.",
  556. [],
  557. 500
  558. );
  559. }
  560. if ($_SERVER['SERVER_NAME'] === '192.168.100.105') {
  561. $urlPublic = 'http://192.168.100.105:8000/public_files/' . $fileName;
  562. } else {
  563. $urlPublic = $this->functionsController->getApiURI().'sam/public_files/' . $fileName;
  564. }
  565. return $this->responseController->makeResponse(false, "EXITO: Modificación Exitosa", [ 'url' => $urlPublic ]);
  566. }
  567. public function generateSheetDeliveryListPDF( $orderNumber, $user, $line ) {
  568. try {
  569. $idOrder = $this->encController->decrypt($orderNumber);
  570. } catch (\Throwable $th) {
  571. DB::rollBack();
  572. return $this->responseController->makeResponse(
  573. true,
  574. "ERR_ORDER_SHEET000: Ocurrió un error al obtener el número del proveedor.",
  575. $th->getMessage(),
  576. 500
  577. );
  578. }
  579. try {
  580. $user = $this->encController->decrypt($user);
  581. } catch (\Throwable $th) {
  582. DB::rollBack();
  583. return $this->responseController->makeResponse(
  584. true,
  585. "ERR_ORDER_SHEET001: Ocurrió un error al obtener el usuario.",
  586. $th->getMessage(),
  587. 500
  588. );
  589. }
  590. try {
  591. $arrOrder = (array) DB::table('S002V01TORCO')
  592. ->where('ORCO_NUOR', '=', $idOrder)
  593. ->where('ORCO_NULI', '=', $line)
  594. ->where('LINE_NULI', '=', $line)
  595. ->where('DESP_NULI', '=', $line)
  596. ->where('PROV_NULI', '=', $line)
  597. ->where('DESP_ESTA', '=', 'Activo')
  598. ->where('PROV_ESTA', '=', 'Activo')
  599. ->join('S002V01TLINE', 'LINE_IDLI', '=', 'ORCO_IDLI')
  600. ->join('S002V01TDESP', 'DESP_IDDE', '=', 'ORCO_IDDE')
  601. ->join('S002V01TPROV', 'PROV_NUPR', '=', 'LINE_NUPR')
  602. ->join('S002V01TREFI', 'REFI_CRFI', '=', 'PROV_CRFI')
  603. ->first([
  604. 'ORCO_NUOR',
  605. 'ORCO_ESTA',
  606. 'LINE_IDLI',
  607. 'LINE_OTPR',
  608. 'LINE_OTCO',
  609. 'LINE_ESTA',
  610. 'DESP_IDDE',
  611. 'DESP_NODE',
  612. 'DESP_NOMB',
  613. 'DESP_APPA',
  614. 'DESP_APMA',
  615. 'DESP_LADA',
  616. 'DESP_TELE',
  617. 'DESP_CORR',
  618. 'DESP_CALL',
  619. 'DESP_NUEX',
  620. 'DESP_NUIN',
  621. 'DESP_COPO',
  622. 'DESP_COLO',
  623. 'DESP_LOCA',
  624. 'DESP_MUNI',
  625. 'DESP_ENTI',
  626. 'DESP_PAIS',
  627. 'DESP_COME',
  628. 'PROV_NUPR',
  629. 'PROV_IDPS',
  630. 'PROV_NOCO',
  631. 'PROV_NOMB',
  632. 'PROV_APPA',
  633. 'PROV_APMA',
  634. 'PROV_CORR',
  635. 'PROV_LAD1',
  636. 'PROV_TEL1',
  637. 'PROV_LAD2',
  638. 'PROV_TEL2',
  639. 'PROV_XRFC',
  640. 'PROV_XTAX',
  641. 'PROV_TIPO',
  642. 'PROV_TICO',
  643. 'PROV_SIWE',
  644. 'PROV_MEPA',
  645. 'PROV_CALL',
  646. 'PROV_NUEX',
  647. 'PROV_NUIN',
  648. 'PROV_COPO',
  649. 'PROV_COLO',
  650. 'PROV_MUNI',
  651. 'PROV_LOCA',
  652. 'PROV_ENTI',
  653. 'PROV_PAIS',
  654. 'REFI_CRFI',
  655. 'REFI_DRFI',
  656. ]);
  657. } catch (\Throwable $th) {
  658. return $this->responseController->makeResponse(
  659. true,
  660. "ERR_ORDER_SHEET002: Ocurrió un error al obtener la información de la orden de compra.",
  661. $th->getMessage(),
  662. 500
  663. );
  664. }
  665. try {
  666. $arrArtitle = DB::table('S002V01TARSE')
  667. ->where('ARSE_NULI', '=', $line)
  668. ->where('INAR_NULI', '=', $line)
  669. ->where('CAMO_NULI', '=', $line)
  670. ->where('DEAR_NULI', '=', $line)
  671. ->where('UNID_NULI', '=', $line)
  672. ->where('ARTI_NULI', '=', $line)
  673. ->where('FAMI_NULI', '=', $line)
  674. ->where('SUBF_NULI', '=', $line)
  675. ->where('ARSE_ESTA', '=', 'Activo')
  676. ->where('INAR_ESTA', '=', 'Activo')
  677. ->where('CAMO_ESTA', '=', 'Activo')
  678. ->where('DEAR_ESTA', '=', 'Activo')
  679. ->where('UNID_ESTA', '=', 'Activo')
  680. ->where('ARTI_ESTA', '=', 'Activo')
  681. ->where('FAMI_ESTA', '=', 'Activo')
  682. ->where('SUBF_ESTA', '=', 'Activo')
  683. ->where('ARSE_IDLI', '=', $arrOrder['LINE_IDLI'])
  684. ->where('ARSE_NUPR', '=', $arrOrder['PROV_NUPR'])
  685. ->join('S002V01TINAR','INAR_IDIN','=','ARSE_IDIN')
  686. ->join('S002V01TCAMO','CAMO_COMO','=','INAR_COMO')
  687. ->join('S002V01TDEAR','DEAR_IDDE','=','INAR_IDDE')
  688. ->join('S002V01TUNID','UNID_IDUN','=','DEAR_IDUN')
  689. ->join('S002V01TARTI','ARTI_IDAR','=','DEAR_IDAR')
  690. ->join('S002V01TFAMI','FAMI_COFA','=','ARTI_COFA')
  691. ->join('S002V01TSUBF','SUBF_COSU','=','ARTI_COSU')
  692. ->get([
  693. 'ARSE_IDAS',
  694. 'ARSE_IDLI',
  695. 'ARSE_CANT',
  696. 'ARSE_PRTO',
  697. 'INAR_IDIN',
  698. 'INAR_CODI',
  699. 'INAR_MODE',
  700. 'INAR_PREC',
  701. 'INAR_MOMI',
  702. 'INAR_CARA',
  703. 'CAMO_COMO',
  704. 'CAMO_DESC',
  705. 'CAMO_DECI',
  706. 'CAMO_POVA',
  707. 'CAMO_FEIN',
  708. 'CAMO_FEFI',
  709. 'DEAR_IDDE',
  710. 'DEAR_IMAG',
  711. 'DEAR_DESC',
  712. 'DEAR_CARA',
  713. 'DEAR_COWE',
  714. 'UNID_IDUN',
  715. 'UNID_NOMB',
  716. 'UNID_ACRO',
  717. 'ARTI_IDAR',
  718. 'ARTI_CODI',
  719. 'ARTI_NOMB',
  720. 'FAMI_COFA',
  721. 'FAMI_NOFA',
  722. 'SUBF_COSU',
  723. 'SUBF_NOSU',
  724. ]);
  725. $arrArtitle = json_decode( json_encode( $arrArtitle ), true );
  726. } catch (\Throwable $th) {
  727. return $this->responseController->makeResponse(
  728. true,
  729. "ERR_ORDER_SHEET002: Ocurrió un error al obtener la información de la orden de compra.",
  730. $th->getMessage(),
  731. 500
  732. );
  733. }
  734. $html = '<!DOCTYPE html>
  735. <html lang="en">
  736. <head>
  737. <meta charset="UTF-8">
  738. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  739. <title>Document</title>
  740. <style>
  741. body {
  742. font-family: Arial, Helvetica, sans-serif;
  743. font-size: 8pt;
  744. }
  745. .section-title {
  746. margin: 20px 0;
  747. font-size: 12pt;
  748. }
  749. table {
  750. width: 100%;
  751. font-size: 8pt;
  752. }
  753. thead tr th {
  754. text-align: start;
  755. padding: 0 16px;
  756. height: 52px;
  757. border-bottom-width: 1px;
  758. border-bottom-style: solid;
  759. border-bottom-color: #CCC;
  760. }
  761. tbody tr td {
  762. padding: 0 16px;
  763. height: 52px;
  764. border-bottom-width: 1px;
  765. border-bottom-style: solid;
  766. border-bottom-color: #CCC;
  767. }
  768. p {
  769. text-align: justify;
  770. }
  771. </style>
  772. </head>
  773. <body>
  774. <div class="item">
  775. <b>Número de Orden de Compra: </b>
  776. <span>'.$arrOrder['ORCO_NUOR'].'</span>
  777. </div>
  778. <div class="item">
  779. <b>Estado de la orden: </b>
  780. <span>'.$arrOrder['ORCO_ESTA'].'</span>
  781. </div>
  782. <div class="item">
  783. <b>Numero de línea de solicitud: </b>
  784. <span>'.$arrOrder['LINE_IDLI'].'</span>
  785. </div>
  786. ';
  787. if ( !is_null( $arrOrder['LINE_OTPR'] ) && is_null( $arrOrder['LINE_OTCO'] ) ) {
  788. $html.='<div class="item">
  789. <b>Orden de Trabajo Preventivo: </b>
  790. <span>'.$arrOrder['LINE_OTPR'].'</span>
  791. </div>';
  792. } else if ( is_null( $arrOrder['LINE_OTPR'] ) && !is_null( $arrOrder['LINE_OTCO'] ) ) {
  793. $html.='<div class="item">
  794. <b>Orden de Trabajo Correctivo: </b>
  795. <span>'.$arrOrder['LINE_OTCO'].'</span>
  796. </div>';
  797. } else if ( is_null( $arrOrder['LINE_OTPR'] ) && is_null( $arrOrder['LINE_OTCO'] ) ) {
  798. $html.='<div class="item">
  799. <b>Orden de Trabajo: </b>
  800. <span>No aplica</span>
  801. </div>';
  802. } else {
  803. $html.='<div class="item">
  804. <b>Orden de Trabajo: </b>
  805. <span>No aplica</span>
  806. </div>';
  807. }
  808. $html.='<div class="item">
  809. <b>ID Despacho: </b>
  810. <span>'.$arrOrder['DESP_IDDE'].'</span>
  811. </div>
  812. <div class="item">
  813. <b>Despacho: </b>
  814. <span>'.$arrOrder['DESP_NODE'].'</span>
  815. </div>
  816. <div class="item">
  817. <b>Responsable del despacho: </b>
  818. <span>'.$arrOrder['DESP_NOMB'] . ' ' . $arrOrder['DESP_APPA'] . ' ' . $arrOrder['DESP_APMA'].'</span>
  819. </div>
  820. <div class="item">
  821. <b>Teléfono del despacho: </b>
  822. <span>'.$arrOrder['DESP_LADA'] . ' ' . $arrOrder['DESP_TELE'].'</span>
  823. </div>
  824. <div class="item">
  825. <b>Correo electrónico del despacho: </b>
  826. <span>'.$arrOrder['DESP_CORR'].'</span>
  827. </div>
  828. <div class="item">
  829. <b>Calle del despacho: </b>
  830. <span>'.$arrOrder['DESP_CALL'].'</span>
  831. </div>
  832. <div class="item">
  833. <b>Número exterior: </b>
  834. <span>'.$arrOrder['DESP_NUEX'].'</span>
  835. </div>
  836. ';
  837. if ( !is_null($arrOrder['DESP_NUIN']) ) {
  838. $html.='<div class="item">
  839. <b>Número interior: </b>
  840. <span>'.$arrOrder['DESP_NUIN'].'</span>
  841. </div>';
  842. } else {
  843. $html.='<div class="item">
  844. <b>Número interior: </b>
  845. <span>No aplica</span>
  846. </div>';
  847. }
  848. $html.='<div class="item">
  849. <b>Código postal: </b>
  850. <span>'.$arrOrder['DESP_COPO'].'</span>
  851. </div>
  852. <div class="item">
  853. <b>Colonia: </b>
  854. <span>'.$arrOrder['DESP_COLO'].'</span>
  855. </div>
  856. ';
  857. if ( !is_null($arrOrder['DESP_LOCA']) && !empty($arrOrder['DESP_LOCA']) ) {
  858. $html.='<div class="item">
  859. <b>Localidad: </b>
  860. <span>'.$arrOrder['DESP_LOCA'].'</span>
  861. </div>';
  862. } else {
  863. $html.='<div class="item">
  864. <b>Localidad: </b>
  865. <span>No aplica</span>
  866. </div>';
  867. }
  868. $html.='<div class="item">
  869. <b>Municipio: </b>
  870. <span>'.$arrOrder['DESP_MUNI'].'</span>
  871. </div>
  872. <div class="item">
  873. <b>Entidad Federativa: </b>
  874. <span>'.$arrOrder['DESP_ENTI'].'</span>
  875. </div>
  876. <div class="item">
  877. <b>País: </b>
  878. <span>'.$arrOrder['DESP_PAIS'].'</span>
  879. </div>
  880. <div class="item">
  881. <b>Número de proveedor: </b>
  882. <span>'.$arrOrder['PROV_NUPR'].'</span>
  883. </div>
  884. <div class="item">
  885. <b>Número de subcontratista: </b>
  886. <span>'.$arrOrder['PROV_IDPS'].'</span>
  887. </div>
  888. <div class="item">
  889. <b>Nombre comercial del proveedor: </b>
  890. <span>'.$arrOrder['PROV_NOCO'].'</span>
  891. </div>
  892. <div class="item">
  893. <b>Referencia fiscal del proveedor: </b>
  894. <span>'.$arrOrder['REFI_DRFI'] . ' (' . $arrOrder['REFI_CRFI'] . ')'.'</span>
  895. </div>
  896. <div class="item">
  897. <b>Responsable del proveedor: </b>
  898. <span>'.$arrOrder['PROV_NOMB'] . ' ' . $arrOrder['PROV_APPA'] . ' ' . $arrOrder['PROV_APMA'].'</span>
  899. </div>
  900. <div class="item">
  901. <b>Correo electrónico del proveedor: </b>
  902. <span>'.$arrOrder['PROV_CORR'].'</span>
  903. </div>
  904. <div class="item">
  905. <b>Teléfono del proveedor: </b>
  906. <span>'.$arrOrder['PROV_LAD1'] . ' ' . $arrOrder['PROV_TEL1'].'</span>
  907. </div>
  908. ';
  909. if ( !is_null( $arrOrder['PROV_XRFC'] ) && is_null( $arrOrder['PROV_XRFC'] )) {
  910. $html.='<div class="item">
  911. <b>R.F.C. del proveedor: </b>
  912. <span>'.$arrOrder['PROV_XRFC'].'</span>
  913. </div>';
  914. } else if ( is_null( $arrOrder['PROV_XRFC'] ) && !is_null( $arrOrder['PROV_XRFC'] )) {
  915. $html.='<div class="item">
  916. <b>TAX ID. del proveedor: </b>
  917. <span>'.$arrOrder['PROV_XTAX'].'</span>
  918. </div>';
  919. } else {
  920. $html.='<div class="item">
  921. <b>R.F.C. / TAX ID: </b>
  922. <span>No aplica</span>
  923. </div>';
  924. }
  925. if ( !empty($arrArtitle) ) {
  926. $html.='
  927. <div style="page-break-after:always;"></div>
  928. <div class="section-title">
  929. <b>Artículos</b>
  930. </div>';
  931. $html.='<table cellspacing="0" cellpadding="0">
  932. <thead>
  933. <tr>
  934. <th>ID Artículo</th>
  935. <th>Código del artíulo</th>
  936. <th>Artículo</th>
  937. <th>Familia</th>
  938. <th>Subfamilia</th>
  939. <!-- <th>Descripción</th> -->
  940. <!-- <th>Características</th> -->
  941. <th>Unidad</th>
  942. <th>Código</th>
  943. <th>Modelo</th>
  944. <th>Precio Unitario</th>
  945. <th>Cantidad</th>
  946. <th>Precio Total</th>
  947. <th>No. de selección</th>
  948. </tr>
  949. </thead>
  950. <tbody>';
  951. foreach ($arrArtitle as $keyArtitle => $artitle) {
  952. $html.= '<tr>
  953. <td>'.$artitle['ARTI_IDAR'].'</td>
  954. <td>'.$artitle['ARTI_CODI'].'</td>
  955. <td>'.$artitle['ARTI_NOMB'].'</td>
  956. <td>'.$artitle['FAMI_NOFA'] . ' (' . $artitle['FAMI_COFA'] . ')'.'</td>
  957. <td>'.$artitle['SUBF_NOSU'] . ' (' . $artitle['SUBF_COSU'] . ')'.'</td>
  958. <!-- <td>'.$artitle['DEAR_DESC'].'</td> -->
  959. <!-- <td>'.$artitle['DEAR_CARA'].'</td> -->
  960. <td>'.$artitle['UNID_NOMB'] . ' (' . $artitle['UNID_IDUN'] . ')'.'</td>
  961. <td>'.$artitle['INAR_CODI'].'</td>
  962. <td>'.$artitle['INAR_MODE'].'</td>
  963. <td>'.'$'. $artitle['INAR_PREC'] . ' ' . $artitle['CAMO_COMO'] .'</td>
  964. <td>'.$artitle['ARSE_CANT'].'</td>
  965. <td>'.'$'. $artitle['ARSE_PRTO'] . ' ' . $artitle['CAMO_COMO'] .'</td>
  966. <td>'.$artitle['ARSE_IDAS'].'</td>
  967. </tr>';
  968. }
  969. $html.= '</tbody>
  970. </table>';
  971. }
  972. $html.='</body></html>';
  973. $nuli = $this->resourcesController->formatSecuence($line, 2);
  974. $como = 'GEAD'; // Código del módulo
  975. $cldo = 'IN'; // Código de la clasificación
  976. $fecr = date('ymd'); // Fecha en la se carga el archivo
  977. try {
  978. $arrSecuence = (array) DB::table('S002V01TAFAL')
  979. ->where('AFAL_COMO', '=', $como)
  980. ->where('AFAL_CLDO', '=', $cldo)
  981. ->where('AFAL_NULI', '=', $line)
  982. ->orderBy('AFAL_NUSE', 'desc')
  983. ->first([ 'AFAL_NUSE' ]);
  984. } catch (\Throwable $th) {
  985. return $this->responseController->makeResponse(
  986. true,
  987. "ERR_PROVIDER_SHEET020: Ocurrió un error al obtener la información de la secuencia.",
  988. $th->getMessage(),
  989. 500
  990. );
  991. }
  992. $nuse = 1; // Secuencia del documento
  993. if ( !empty( $arrSecuence ) && !is_null( $arrSecuence ) ) {
  994. $nuse = intval( $arrSecuence['AFAL_NUSE'] ) + 1;
  995. }
  996. $nuse = $this->resourcesController->formatSecuence($nuse, 6);
  997. $nuve = $this->resourcesController->formatSecuence('1', 2);
  998. $noar = 'ficha_de_adquisición_' . $arrOrder['ORCO_NUOR'];
  999. $nuli = $this->resourcesController->formatSecuence($line, 2);
  1000. $como = 'GEAD'; // Código del módulo
  1001. $cldo = 'IN'; // Código de la clasificación
  1002. $fecr = date('ymd'); // Fecha en la se carga el archivo
  1003. try {
  1004. $arrSecuence = (array) DB::table('S002V01TAFAL')
  1005. ->where('AFAL_COMO', '=', $como)
  1006. ->where('AFAL_CLDO', '=', $cldo)
  1007. ->where('AFAL_NULI', '=', $line)
  1008. ->orderBy('AFAL_NUSE', 'desc')
  1009. ->first([ 'AFAL_NUSE' ]);
  1010. } catch (\Throwable $th) {
  1011. return $this->responseController->makeResponse(
  1012. true,
  1013. "ERR_PROVIDER_SHEET020: Ocurrió un error al obtener la información de la secuencia.",
  1014. $th->getMessage(),
  1015. 500
  1016. );
  1017. }
  1018. $nuse = 1; // Secuencia del documento
  1019. if ( !empty( $arrSecuence ) && !is_null( $arrSecuence ) ) {
  1020. $nuse = intval( $arrSecuence['AFAL_NUSE'] ) + 1;
  1021. }
  1022. $nuse = $this->resourcesController->formatSecuence($nuse, 6);
  1023. $nuve = $this->resourcesController->formatSecuence('1', 2);
  1024. $noar = 'ficha_de_adquisición_' . $arrOrder['ORCO_NUOR'];
  1025. $exte = 'pdf';
  1026. if ($_SERVER['SERVER_NAME'] === '192.168.100.105') {
  1027. $filePath = 'C:/ITTEC/SAM/Dev/SistemaMantenimiento/sistema-mantenimiento-back/public/public_files/'; // API JEAN
  1028. } else {
  1029. $filePath = 'C:\inetpub\wwwroot\sam\public_files\\'; // API QA
  1030. }
  1031. $fileName = $nuli.'-'.$como.'-'.$cldo.'-'.$fecr.'-'.$nuse.'='.$nuve.'='.$noar.'.'.$exte;
  1032. $tempFile = $filePath . $fileName;
  1033. $dompdf = new Dompdf();
  1034. $dompdf ->loadHtml($html);
  1035. $dompdf->setPaper('A4', 'landscape');
  1036. $dompdf->render();
  1037. $output = $dompdf->output();
  1038. file_put_contents($tempFile, $output);
  1039. $ubic = Storage::putFile('files', new File($tempFile));
  1040. $ubic = str_replace("/", "\\", $ubic);
  1041. if ($_SERVER['SERVER_NAME'] === '192.168.100.105') {
  1042. $ubic = "C:\ITTEC\SAM\Dev\SistemaMantenimiento\sistema-mantenimiento-back\storage\app\\" . $ubic;
  1043. } else {
  1044. $ubic = "C:\inetpub\wwwroot\sam\storage\app\\" . $ubic;
  1045. }
  1046. $tama = filesize($ubic);
  1047. $usac = json_encode([$user]);
  1048. $now = $this->functionsController->now();
  1049. $currentDate = $now->toDateTimeString();
  1050. try {
  1051. $validateInsert = DB::table('S002V01TAFAL')->insert([
  1052. 'AFAL_NULI' => $line,
  1053. 'AFAL_COMO' => $como,
  1054. 'AFAL_CLDO' => $cldo,
  1055. 'AFAL_FECR' => $fecr,
  1056. 'AFAL_NUSE' => $nuse,
  1057. 'AFAL_NUVE' => $nuve,
  1058. 'AFAL_NOAR' => $noar,
  1059. 'AFAL_EXTE' => $exte,
  1060. 'AFAL_TAMA' => $tama,
  1061. 'AFAL_UBIC' => $ubic,
  1062. 'AFAL_USAC' => $usac,
  1063. 'AFAL_USRE' => $user,
  1064. 'AFAL_FERE' => $currentDate,
  1065. ]);
  1066. } catch (\Throwable $th) {
  1067. return $this->responseController->makeResponse(
  1068. true,
  1069. "ERR_PROVIDER_SHEET023: Ocurrió un error guardar los datos a la tabla final de archivos.",
  1070. $th->getMessage(),
  1071. 500
  1072. );
  1073. }
  1074. if ( !$validateInsert ) {
  1075. return $this->responseController->makeResponse(
  1076. true,
  1077. "ERR_PROVIDER_SHEET024: No se pudo guardar la ficha del proveedor en la base de datos.",
  1078. [],
  1079. 500
  1080. );
  1081. }
  1082. if ($_SERVER['SERVER_NAME'] === '192.168.100.105') {
  1083. $urlPublic = 'http://192.168.100.105:8000/public_files/' . $fileName;
  1084. } else {
  1085. $urlPublic = $this->functionsController->getApiURI().'sam/public_files/' . $fileName;
  1086. }
  1087. return $this->responseController->makeResponse(false, "EXITO: Modificación Exitosa", [ 'url' => $urlPublic ]);
  1088. }
  1089. }