Dashboard sipadu mbip
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

MemoController.php 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. <?php
  2. namespace App\Http\Controllers\Main;
  3. use Illuminate\Http\Request;
  4. use App\Http\Controllers\Controller;
  5. use Illuminate\Support\Facades\Auth;
  6. use LynX39\LaraPdfMerger\Facades\PdfMerger;
  7. use Carbon\Carbon;
  8. use Validator;
  9. use PDF;
  10. use App\Model\Staff;
  11. use App\Model\StaffDetail;
  12. use App\Model\Module\Department;
  13. use App\Model\Module\Roles;
  14. use App\Model\Module\Attachment;
  15. use App\Model\Module\Faulty;
  16. use App\Model\Module\Memo;
  17. use App\Model\Module\History;
  18. use App\Model\Module\SubHistory;
  19. use App\Model\Module\Compound;
  20. use App\Model\Module\ConfidentialFile;
  21. use App\Jobs\UpdateCompoundPrice;
  22. class MemoController extends Controller
  23. {
  24. public function requestAddMemo(Request $request) {
  25. $id = Auth::guard('sadmin')->id();
  26. $user = Staff::with('StaffDetail')->find($id);
  27. if($request->jenis_memo == "Tambahan" || $request->jenis_memo == "Potongan"){
  28. if($request->has('tawaran')){
  29. if (preg_match("/^100+%$|[0-9]+%/", $request->get('tawaran'))){
  30. }else{
  31. return redirect()->back()->withInput()->with('error_msg', '<strong>Tidak Berjaya!</strong> Sila isikan ruangan tawaran dengan format yang betul');
  32. }
  33. }else{
  34. return redirect()->back()->withInput()->with('error_msg', '<strong>Tidak Berjaya!</strong> Sila isikan ruangan tawaran sekiranya anda memilih memo jenis potongan mahupun tambahan');
  35. }
  36. }
  37. $validator = Validator::make($request->all(), [
  38. 'attachment.*' => 'mimes:pdf|max:2048',
  39. ]);
  40. if ($validator->fails()) {
  41. return redirect()->back()->withInput()->withErrors($validator);
  42. }
  43. $sahkan = '';
  44. if($user->StaffDetail->roles_access == "Ketua Jabatan"){
  45. $sahkan = $user->_id;
  46. }
  47. $compound = Compound::with('ConfidentialFile')->where('kpd', $request->kpd)->first();
  48. if($compound->ConfidentialFile->modul != '-'){
  49. $modul = Roles::where('kod', $compound->modul)->first();
  50. $now = Carbon::now();
  51. $gDate = $now->format('F Y');
  52. if($request->hasfile('attachment')){
  53. $memo = Memo::create([
  54. 'itkod' => '-',
  55. 'modul' => $compound->modul,
  56. 'jenis_memo' => $request->get('jenis_memo'),
  57. 'no_rujukan' => $request->get('no_rujukan'),
  58. 'tawaran_kompaun' => $request->get('tawaran'),
  59. 'tarikh_mula' => $request->get('tarikh_mula'),
  60. 'tarikh_akhir' => $request->get('tarikh_akhir'),
  61. 'dikeluarkan' => $user->_id,
  62. 'disahkan' => $sahkan,
  63. 'jenis_data' => 'pdf',
  64. 'subjek' => $request->get('subjek'),
  65. 'penerangan' => $request->get('penerangan'),
  66. 'created_at' => $now,
  67. ]);
  68. $compound->ConfidentialFile->memo()->attach($memo);
  69. $this->dispatch(new UpdateCompoundPrice($request->kpd));
  70. $historyData = [
  71. 'tarikh_kumpulan' => $gDate,
  72. ];
  73. $subHistory = [
  74. 'no_siri' => $compound->ConfidentialFile->no_siri,
  75. 'tajuk' => "Penambahan Memo[ ".$request->get('no_rujukan')." ] : ".$request->get('subjek'),
  76. 'huraian' => $request->get('penerangan'),
  77. ];
  78. $groupByDate = History::where('tarikh_kumpulan', $gDate)->first();
  79. if(!empty($groupByDate)){
  80. $groupByDate->subhistory()->create($subHistory);
  81. $compound->ConfidentialFile->history()->attach($groupByDate);
  82. }else{
  83. $history = History::create($historyData);
  84. $history->subhistory()->create($subHistory);
  85. $compound->ConfidentialFile->history()->attach($history);
  86. }
  87. $upload = [];
  88. foreach($request->file('attachment') as $f){
  89. $upload[] = [
  90. 'name' => 'file[]',
  91. 'contents' => fopen( $f->getPathname(), 'r' ),
  92. 'filename' => $f->getClientOriginalName()
  93. ];
  94. }
  95. $upload[] = [
  96. 'name' => 'no_siri',
  97. 'contents' => $compound->ConfidentialFile->no_siri,
  98. ];
  99. $upload [] = [
  100. 'name' => 'type',
  101. 'contents' => 'mbip'
  102. ];
  103. $client = new \GuzzleHttp\Client();
  104. $result = $client->request('POST', 'https://files.sipadu.my/api/upload/file/memo/pdf', [
  105. 'multipart' => $upload
  106. ]);
  107. $response = json_decode($result->getBody()->getContents());
  108. if($response->success == true){
  109. foreach ($response->data as $key => $d) {
  110. $attach = new Attachment();
  111. $attach->path = $d;
  112. $memo->attachment()->save($attach);
  113. }
  114. }else if($response->success == false){
  115. return redirect()->back()->with('error_msg', '<strong>Gagal!</strong> memuatnaik pdf');
  116. }
  117. return redirect()->back()->with('success_msg', '<strong>Berjaya!</strong> Simpan rekod memo di kategori modul <strong>('.$modul->name.')</strong>');
  118. }else{
  119. $memo = Memo::create([
  120. 'itkod' => '-',
  121. 'modul' => $compound->modul,
  122. 'jenis_memo' => $request->get('jenis_memo'),
  123. 'no_rujukan' => $request->get('no_rujukan'),
  124. 'tawaran_kompaun' => $request->get('tawaran'),
  125. 'tarikh_mula' => $request->get('tarikh_mula'),
  126. 'tarikh_akhir' => $request->get('tarikh_akhir'),
  127. 'dikeluarkan' => $user->_id,
  128. 'disahkan' => $sahkan,
  129. 'jenis_data' => 'manual',
  130. 'subjek' => $request->get('subjek'),
  131. 'penerangan' => $request->get('penerangan'),
  132. 'created_at' => $now,
  133. ]);
  134. $compound->ConfidentialFile->memo()->attach($memo);
  135. $this->dispatch(new UpdateCompoundPrice($request->kpd));
  136. $historyData = [
  137. 'tarikh_kumpulan' => $gDate,
  138. ];
  139. $subHistory = [
  140. 'no_siri' => $compound->ConfidentialFile->no_siri,
  141. 'tajuk' => "Penambahan Memo[ ".$request->get('no_rujukan')." ] : ".$request->get('subjek'),
  142. 'huraian' => $request->get('penerangan'),
  143. ];
  144. $groupByDate = History::where('tarikh_kumpulan', $gDate)->first();
  145. if(!empty($groupByDate)){
  146. $groupByDate->subhistory()->create($subHistory);
  147. $compound->ConfidentialFile->history()->attach($groupByDate);
  148. }else{
  149. $history = History::create($historyData);
  150. $history->subhistory()->create($subHistory);
  151. $compound->ConfidentialFile->history()->attach($history);
  152. }
  153. return redirect()->back()->with('success_msg', '<strong>Berjaya!</strong> Simpan rekod memo di kategori modul <strong>('.$modul->name.')</strong>');
  154. }
  155. }
  156. }
  157. public function requestEditMemo(Request $request) {
  158. $id = Auth::guard('sadmin')->id();
  159. $user = Staff::with('StaffDetail')->find($id);
  160. if($request->jenis_memo == "Tambahan" || $request->jenis_memo == "Potongan"){
  161. if($request->has('tawaran')){
  162. if (preg_match("/^100+%$|[0-9]+%/", $request->get('tawaran'))){
  163. }else{
  164. return redirect()->back()->withInput()->with('error_msg', '<strong>Tidak Berjaya!</strong> Sila isikan ruangan tawaran dengan format yang betul');
  165. }
  166. }else{
  167. return redirect()->back()->withInput()->with('error_msg', '<strong>Tidak Berjaya!</strong> Sila isikan ruangan tawaran sekiranya anda memilih memo jenis potongan mahupun tambahan');
  168. }
  169. }
  170. $sahkan = '';
  171. if($user->StaffDetail->roles_access == "Ketua Jabatan"){
  172. $sahkan = $user->_id;
  173. }
  174. $compound = Compound::with('ConfidentialFile')->where('kpd', $request->kpd)->first();
  175. $memo = Memo::where('_id', $request->memo_id)->first();
  176. if(!empty($memo)){
  177. $now = Carbon::now();
  178. $gDate = $now->format('F Y');
  179. if($request->hasfile('attachment')){
  180. $uploadNew = false;
  181. if($memo->jenis_data == "pdf"){
  182. foreach ($memo->Attachment as $m) {
  183. $m->forceDelete();
  184. }
  185. $uploadNew = true;
  186. }else if($memo->jenis_data == "manual"){
  187. $uploadNew = true;
  188. }
  189. if($uploadNew == true){
  190. $memo->jenis_memo = $request->get('jenis_memo');
  191. $memo->no_rujukan = $request->get('no_rujukan');
  192. $memo->tawaran_kompaun = $request->get('tawaran');
  193. $memo->tarikh_mula = $request->get('tarikh_mula');
  194. $memo->tarikh_akhir = $request->get('tarikh_akhir');
  195. $memo->jenis_data = 'pdf';
  196. $memo->subjek = $request->get('subjek');
  197. $memo->penerangan = $request->get('penerangan');
  198. $memo->disahkan = $sahkan;
  199. $memo->save();
  200. $this->dispatch(new UpdateCompoundPrice($request->kpd));
  201. $historyData = [
  202. 'tarikh_kumpulan' => $gDate,
  203. ];
  204. $subHistory = [
  205. 'no_siri' => $compound->ConfidentialFile->no_siri,
  206. 'tajuk' => "Kemaskini Memo[ ".$request->get('no_rujukan')." ] : ".$request->get('subjek'),
  207. 'huraian' => $request->get('penerangan'),
  208. ];
  209. $groupByDate = History::where('tarikh_kumpulan', $gDate)->first();
  210. if(!empty($groupByDate)){
  211. $groupByDate->subhistory()->create($subHistory);
  212. $compound->ConfidentialFile->history()->attach($groupByDate);
  213. }else{
  214. $history = History::create($historyData);
  215. $history->subhistory()->create($subHistory);
  216. $compound->ConfidentialFile->history()->attach($history);
  217. }
  218. $upload = [];
  219. foreach($request->file('attachment') as $f){
  220. $upload[] = [
  221. 'name' => 'file[]',
  222. 'contents' => fopen( $f->getPathname(), 'r' ),
  223. 'filename' => $f->getClientOriginalName()
  224. ];
  225. }
  226. $upload[] = [
  227. 'name' => 'no_siri',
  228. 'contents' => $compound->ConfidentialFile->no_siri,
  229. ];
  230. $upload [] = [
  231. 'name' => 'type',
  232. 'contents' => 'mbip'
  233. ];
  234. $client = new \GuzzleHttp\Client();
  235. $result = $client->request('POST', 'https://files.sipadu.my/api/upload/file/memo/pdf', [
  236. 'multipart' => $upload
  237. ]);
  238. $response = json_decode($result->getBody()->getContents());
  239. if($response->success == true){
  240. foreach ($response->data as $key => $d) {
  241. $attach = new Attachment();
  242. $attach->path = $d;
  243. $memo->attachment()->save($attach);
  244. }
  245. }else if($response->success == false){
  246. return redirect()->back()->with('error_msg', '<strong>Gagal!</strong> memuatnaik pdf');
  247. }
  248. return redirect()->back()->with('success_msg', '<strong>Berjaya!</strong> Kemaskini rekod memo <strong>('.$memo->no_rujukan.')</strong>. Untuk berkuat serta merta, sila sahkan semula memo nie jika perlu.');
  249. }
  250. }else{
  251. $memo->jenis_memo = $request->get('jenis_memo');
  252. $memo->no_rujukan = $request->get('no_rujukan');
  253. $memo->tawaran_kompaun = $request->get('tawaran');
  254. $memo->tarikh_mula = $request->get('tarikh_mula');
  255. $memo->tarikh_akhir = $request->get('tarikh_akhir');
  256. $memo->jenis_data = 'manual';
  257. $memo->subjek = $request->get('subjek');
  258. $memo->penerangan = $request->get('penerangan');
  259. $memo->disahkan = $sahkan;
  260. $memo->save();
  261. $this->dispatch(new UpdateCompoundPrice($request->kpd));
  262. $historyData = [
  263. 'tarikh_kumpulan' => $gDate,
  264. ];
  265. $subHistory = [
  266. 'no_siri' => $compound->ConfidentialFile->no_siri,
  267. 'tajuk' => "Kemaskini Memo[ ".$request->get('no_rujukan')." ] : ".$request->get('subjek'),
  268. 'huraian' => $request->get('penerangan'),
  269. ];
  270. $groupByDate = History::where('tarikh_kumpulan', $gDate)->first();
  271. if(!empty($groupByDate)){
  272. $groupByDate->subhistory()->create($subHistory);
  273. $compound->ConfidentialFile->history()->attach($groupByDate);
  274. }else{
  275. $history = History::create($historyData);
  276. $history->subhistory()->create($subHistory);
  277. $compound->ConfidentialFile->history()->attach($history);
  278. }
  279. return redirect()->back()->with('success_msg', '<strong>Berjaya!</strong> Kemaskini rekod memo <strong>('.$memo->no_rujukan.')</strong>. Untuk berkuat serta merta, sila sahkan semula memo nie jika perlu.');
  280. }
  281. }
  282. }
  283. }