productManagementDb = new ProductManagement();
}
public function insertProduct($data)
{
// 取得參數
// 調用資料庫(或者其他業務邏輯)
$res = $this->productManagementDb->insert($data);
// 整理返回值並返回
return $res;
}
public function deleteProductByBatchNo($del_batch_no)
{
// 取得參數
// 調用資料庫(或者其他業務邏輯)
$this->productManagementDb
->where('batch_no', '<=', $del_batch_no . ' 23:59:59')
->delete();
// 整理返回值並返回
return true;
}
public function getProductDetail($brand_no, $batch_no, $g_id)
{
// 取得參數
// 調用資料庫(或者其他業務邏輯)
$res = $this->productManagementDb
->select([
'm_status',
'm_comment',
])
->where('brand_no', $brand_no)
->where('batch_no', $batch_no)
->where('g_id', (int)$g_id)
->get()
->toArray();
// 整理返回值並返回
return $res[0] ?? [
'm_status' => '',
'm_comment' => '',
];
}
public function updateProduct($brand_no, $batch_no, $g_id, $m_status, $m_comment)
{
// 取得參數
// 調用資料庫(或者其他業務邏輯)
$this->productManagementDb
->where('brand_no', $brand_no)
->where('batch_no', $batch_no)
->where('g_id', (int)$g_id)
->update([
'm_status' => $m_status,
'm_comment' => $m_comment,
]);
// 整理返回值並返回
return true;
}
public function getProdocts(
&$cnt = 0,
$orderColumn,
$orderDir,
$start,
$length,
$searchValue,
$brand_no,
$batch_no,
$g_title,
$g_description,
$m_comment,
$m_status
)
{
// 調用資料庫(或者其他業務邏輯)
// 選欄位
// 選欄位
$mStatusStr = '';
foreach (GeneralConst::$mStatusMap as $k => $v) {
$mStatusStr .= ' when \'' . $k . '\' then \'' . $v['ANAME'] . '\'';
}
$products = $this->productManagementDb
->select([
'serno',
'g_id',
\DB::raw('concat(\'\', g_title, \'\') as g_title'),
\DB::raw('concat(\'\') as g_description'),
\DB::raw('concat(\'
\') as g_image_link'),
'g_price',
'g_sale_price',
\DB::raw("(case m_status $mStatusStr end) as m_status"),
'm_comment',
]);
// 過濾搜尋條件
$products = $products
->where('brand_no', '=', $brand_no)
->where('batch_no', '=', $batch_no)
->where('g_title', 'LIKE', '%' . $g_title . '%')
->where('g_description', 'LIKE', '%' . $g_description . '%')
->where('m_comment', 'LIKE', '%' . $m_comment . '%')
->where('m_status', '=', $m_status);
// 取總筆數
$cnt = $products->count();
// 排序
$products = $products
->orderByRaw((int)$orderColumn . ' ' . $orderDir);
// 分頁
$products = $products
->skip($start)->take($length);
// 實際取資料
$result = $products
->get()
->toArray();
// 整理返回值並返回
return $result;
}
public function getEndpointProdocts($brand_no, $batch_no)
{
$products = $this->productManagementDb
->select([
'g_id',
'g_title',
'g_description',
'g_link',
'g_image_link',
'g_condition',
'g_availability',
'g_price',
'g_sale_price',
'g_brand',
'g_google_product_category',
'g_product_type',
'g_custom_label_0',
]);
// 過濾搜尋條件
$products = $products
->where('brand_no', '=', $brand_no)
->where('batch_no', '=', $batch_no)
->whereIn('m_status', [GeneralConst::MSTATUS_PASS, GeneralConst::MSTATUS_WARNING]);
// 實際取資料
$result = $products
->get()
->toArray();
// 整理返回值並返回
return $result;
}
public function getExportProdocts($param)
{
// 調用資料庫(或者其他業務邏輯)
// 選欄位
$mStatusStr = '';
foreach (GeneralConst::$mStatusMap as $k => $v) {
$mStatusStr .= ' when \'' . $k . '\' then \'' . $v['ANAME'] . '\'';
}
$brand_no = $param['brand_no'] ?? '';
$batch_no = $param['batch_no'] ?? '';
$products = $this->productManagementDb
->select([
'serno',
'g_id',
'g_title',
'g_description',
'g_link',
'g_image_link',
'g_price',
'g_sale_price',
\DB::raw("(case m_status $mStatusStr end) as m_status"),
'm_comment',
]);
// 過濾搜尋條件
$products = $products
->where('brand_no', '=', $brand_no)
->where('batch_no', '=', $batch_no)
->whereIn('m_status', [GeneralConst::MSTATUS_WARNING, GeneralConst::MSTATUS_DISAPPROVED]);
$products = $products
->get()
->toArray();
// 整理返回值並返回
return $products;
}
public function downloadExcel($titles = [], $datas = [], $fileName = 'simple')
{
$spreadsheet = new Spreadsheet();
ini_set('memory_limit', '1024M');
ini_set("max_execution_time", "600");
$spreadsheet->getActiveSheet()
->fromArray(
$titles, // The data to set
null, // Array values with this value will not be set
'A1' // Top left coordinate of the worksheet range where we want to set these values (default is A1)
);
$spreadsheet->getActiveSheet()
->fromArray(
$datas, // The data to set
null, // Array values with this value will not be set
'A2' // Top left coordinate of the worksheet range where we want to set these values (default is A1)
);
// Redirect output to a client’s web browser (Xlsx)
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="' . $fileName . '.xlsx"');
header('Cache-Control: max-age=0');
// If you're serving to IE 9, then the following may be needed
header('Cache-Control: max-age=1');
// If you're serving to IE over SSL, then the following may be needed
header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
header('Pragma: public'); // HTTP/1.0
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
$writer->save('php://output');
exit;
}
public function getBrands()
{
$brands = [];
foreach (GeneralConst::$brandMap as $k => $v) {
$brands[] = [
'id' => $k,
'brandName' => $v['NS'],
'brandLabel' => $v['LB'],
];
}
return $brands;
}
public function getBatchs()
{
$ret = $this->productManagementDb
->select([
'batch_no',
\DB::raw("max(m_status) as m_status"),
])
->groupBy('batch_no')
->orderBy('batch_no', 'desc')
->get()
->toArray();
// 正在抓的批次號需要去除
if (Redis::get('TLW_0_XML')) {
array_shift($ret);
}
return $ret;
}
public function getMStatuss()
{
$mstatuss = [];
foreach (GeneralConst::$mStatusMap as $k => $v) {
$mstatuss[] = [
'id' => $k,
'mstatusName' => $v['ANAME'],
];
}
return $mstatuss;
}
}