/** * Execute the job. * * @return void */ public function handle() { //dd($this->req); try { \DB::begintransaction(); $gr = data_spbm::create(['no_surat_jalan' => $this->req['sj'], 'tgl_terima_barang' => $this->req['tgl_terima'], 'tgl_periksa_barang' => $this->req['tgl_periksa'], 'id_kirim' => $this->req['pengiriman'], 'keterangan' => $this->req['keterangan'], 'id_po' => $this->req['id_po'], 'pemeriksa1' => $this->req['pemeriksa1'], 'pemeriksa2' => $this->req['pemeriksa2'], 'nm_pengirim' => $this->req['nm_pengirim'], 'titipan' => $this->req['titipan'], 'id_karyawan' => \Me::data()->id_karyawan]); $statuspo = []; foreach ($this->req['id_po_item'] as $i => $id_po_item) { if (!empty($this->req['qty_lg'])) { $qty = \Format::convertSatuan($this->req['id_barang'][$i], $this->req['id_satuan'][$i], $this->req['id_satuan_default'][$i]) * $this->req['qty_lg'][$i]; data_spbm_item::create(['id_spbm' => $gr->id_spbm, 'id_barang' => $this->req['id_barang'][$i], 'bonus' => $this->req['bonus'][$i], 'id_satuan' => $this->req['id_satuan'][$i], 'qty_lg' => $this->req['qty_lg'][$i], 'qty' => $qty, 'merek' => $this->req['merek'][$i], 'barang_sesuai' => $this->req['barang_sesuai'][$i], 'keterangan' => $this->req['kets'][$i], 'tgl_exp' => $this->req['tgl_exp'][$i], 'sisa' => $qty]); // Perubahan Status Item PO if ($this->req['bonus'][$i] == 0) { $itempo = data_po_item::find($this->req['id_po_item'][$i]); if ($this->req['qty_lg'][$i] >= $this->req['req_qty'][$i]) { $itempo->status = 3; $itempo->qty = $itempo->qty - $this->req['qty_lg'][$i]; $itempo->save(); // Perubahan status PRQ $count = data_prq_item::where('id_prq', $itempo->id_prq)->where('status', 1)->count(); if ($count == 0) { data_prq::find($itempo->id_prq)->update(['status' => 3]); } } else { $statuspo[] = 1; $itempo->status = 2; $itempo->qty = $itempo->qty - $this->req['qty_lg'][$i]; $itempo->save(); } } // Log Stok data_log_barang::create(['id_barang' => $this->req['id_barang'][$i], 'qty' => $qty, 'keterangan' => 'Good Receive', 'id_gudang' => 0, 'kondisi' => 1, 'tipe' => 2, 'id_parent' => $gr->id_spbm, 'id_karyawan' => \Me::data()->id_karyawan]); // Udate Stok ke data barang $b = data_barang::find($this->req['id_barang'][$i]); $b->in = $b->in + $qty; $b->save(); } } // Merubah Status PO $po = data_po::find($this->req['id_po']); if (count($statuspo) > 0) { $po->update(['status' => 2]); } else { $po->update(['status' => 3]); } $format = 'GR-'; $gr->no_spbm = $format . \Format::code($gr->id_spbm); $gr->save(); \Loguser::create('Membuat Permohonan Barang Masuk dengan No. ' . $gr->no_spbm); \DB::commit(); return ['label' => 'seccess', 'err' => 'PO berhasil diproses! dengan No. ' . $gr->no_spbm]; } catch (\Exception $e) { \DB::rollback(); return ['label' => 'danger', 'err' => $e->getMessage()]; } }
public function getPrintexcel(Request $req) { $kd_barang = data_barang::where('id_barang', $req->barang)->select('kode')->first(); $gudang = ref_gudang::find($req->gudang); \Excel::create('Kartu_Stok_' . str_replace('-', '_', str_slug($gudang->nm_gudang)) . '_' . $kd_barang->kode . '_' . date('d_F_Y'), function ($excel) use($req) { if ($req->barang == 0) { return redirect()->back()->withNotif(['label' => 'danger', 'err' => 'Item tidak ditemukan!']); } $items = []; // Data Barang $barang = data_item_gudang::join('data_barang', 'data_barang.id_barang', '=', 'data_item_gudang.id_barang')->join('ref_satuan', 'ref_satuan.id_satuan', '=', 'data_barang.id_satuan')->where('data_item_gudang.status', 1)->where('data_item_gudang.id_gudang', $req->gudang)->where('data_item_gudang.id_barang', $req->barang)->where('data_barang.tipe', $req->tipe)->select('data_barang.nm_barang', 'data_barang.kode', 'data_item_gudang.in', 'data_item_gudang.out', 'ref_satuan.nm_satuan')->first(); if ($barang == null) { return redirect()->back()->withNotif(['label' => 'danger', 'err' => 'Item tidak ditemukan!']); } //Sisa per priode $sisapriode = data_log_barang::sisapriode($req->all())->get(); //dd($sisapriode); $sisa = 0; foreach ($sisapriode as $sp) { if ($sp->kondisi == 1) { $sisa += $sp->qty; } else { $sisa -= $sp->qty; } } $lastsisa = $sisa; // Log stok $logs = data_log_barang::kartostokbyitem($req->all())->get(); foreach ($logs as $item) { if ($item->tipe == 1) { $parent = data_skb::find($item->id_parent); } else { if ($item->tipe == 2) { //$parent = data_spbm::find($item->id_parent); $parent = data_spbm::join('data_spbm_item', 'data_spbm_item.id_spbm', '=', 'data_spbm.id_spbm')->where('data_spbm_item.id_barang', $req->barang)->where('data_spbm.id_spbm', $item->id_parent)->select('data_spbm.*', 'data_spbm_item.tgl_exp')->first(); } else { if ($item->tipe == 3) { $parent = data_penyesuaian_stok::find($item->id_parent); } else { if ($item->tipe == 4) { $parent = data_retur::find($item->id_parent); } else { if ($item->tipe == 5) { $parent = data_retur::find($item->id_parent); } } } } } if ($item->kondisi == 1) { $lastsisa += $item->qty; } else { $lastsisa -= $item->qty; } $items[] = ['tipe' => $item->tipe, 'parent' => $parent, 'kondisi' => $item->kondisi, 'qty' => $item->qty, 'sisa' => $lastsisa, 'oleh' => $item->nm_depan . ' ' . $item->nm_belakang]; } $jenis = [1 => 'SKB', 2 => 'Good Receive', 3 => 'Penyesuaian', 4 => 'Retur Gudang', 5 => 'Retur Pembelian']; // Parameters $params = ''; foreach ($req->all() as $par => $val) { if ($par != '_token') { $params .= $par . '=' . $val . '&'; } } $param = rtrim($params, '&'); $gudang = ref_gudang::find($req->gudang); $data = ['barang' => $barang, 'items' => $items, 'req' => $req, 'jenis' => $jenis, 'param' => $params, 'gudang' => $gudang]; $excel->sheet('New sheet', function ($sheet) use($data) { $sheet->loadView('Print.Pengadaan.SubGudang.Excel', $data); }); })->export('xlsx'); }
public function getPrint($id = 0) { if (empty($id) || !is_numeric($id)) { return redirect('/gr')->withNotif(['label' => 'danger', 'err' => 'Maaf, tidak ditemukan !']); } $gr = data_spbm::byid($id)->first(); if ($gr == null) { return redirect('/gr')->withNotif(['label' => 'danger', 'err' => 'Maaf, tidak ditemukan !']); } $items = data_spbm_item::bygr($id)->get(); $kirim = [1 => 'Dikirim oleh Supplier', 2 => 'Dikirim Oleh Ekspedisi', 3 => 'Diambil Oleh Onkologi']; return view("Print.Pembelian.GR.printGR", ['items' => $items, 'gr' => $gr, 'kirim' => $kirim]); }
public function getPrintpdf(Request $req) { $day = \Format::selisih_hari($req->dari, $req->sampai); if ($day > 31) { return redirect()->back()->withNotif(['label' => 'danger', 'err' => 'Pencarian tidak boleh lebih dari 30 hari!']); } if ($req->barang == 0) { return redirect()->back()->withNotif(['label' => 'danger', 'err' => 'Item tidak ditemukan!']); } $items = []; // Data Barang $barang = data_barang::join('ref_satuan', 'ref_satuan.id_satuan', '=', 'data_barang.id_satuan')->where('id_barang', $req->barang)->select('data_barang.*', 'ref_satuan.nm_satuan')->first(); //Sisa per priode $sisapriode = data_log_barang::sisapriode($req->all())->get(); //dd($sisapriode); $sisa = 0; foreach ($sisapriode as $sp) { if ($sp->kondisi == 1) { $sisa += $sp->qty; } else { $sisa -= $sp->qty; } } $lastsisa = $barang->stok_awal + $sisa; $aftersisa = $lastsisa; // Log stok $logs = data_log_barang::kartostokbyitem($req->all())->get(); foreach ($logs as $item) { if ($item->tipe == 1) { $parent = data_skb::find($item->id_parent); } else { if ($item->tipe == 2) { $parent = data_spbm::find($item->id_parent); } else { if ($item->tipe == 3) { $parent = data_penyesuaian_stok::find($item->id_parent); } else { if ($item->tipe == 4) { $parent = data_retur::find($item->id_parent); } else { if ($item->tipe == 5) { $parent = data_retur::find($item->id_parent); } } } } } if ($item->kondisi == 1) { $lastsisa += $item->qty; } else { $lastsisa -= $item->qty; } $items[] = ['tipe' => $item->tipe, 'parent' => $parent, 'kondisi' => $item->kondisi, 'qty' => $item->qty, 'sisa' => $lastsisa, 'oleh' => $item->nm_depan . ' ' . $item->nm_belakang]; } $jenis = [1 => 'SKB', 2 => 'Good Receive', 3 => 'Penyesuaian', 4 => 'Retur Gudang', 5 => 'Retur Pembelian']; $r = array('barang' => $barang, 'items' => $items, 'req' => $req, 'lastsisa' => $aftersisa, 'jenis' => $jenis); $pdf = PDF::loadView('Print.Pengadaan.KartuStok.pdfKS', $r); return $pdf->stream(); //$file = 'KartuStok-'.date('Y-m-d').'.pdf'; //return $pdf->download($file); }
public function getPrintgr(Request $req) { $items = data_spbm::with(['rekap' => function ($query) { $query->join('data_barang', 'data_barang.id_barang', '=', 'data_spbm_item.id_barang')->join('ref_satuan', 'data_barang.id_satuan', '=', 'ref_satuan.id_satuan'); }])->rekapspbm($req->all())->get(); return view('Print.Transaksi.GR', ['items' => $items, 'req' => $req]); }