[18233] | 1 | <?php |
---|
[17182] | 2 | /* |
---|
| 3 | * This file is part of EC-CUBE |
---|
| 4 | * |
---|
[21867] | 5 | * Copyright(c) 2000-2012 LOCKON CO.,LTD. All Rights Reserved. |
---|
[17182] | 6 | * |
---|
| 7 | * http://www.lockon.co.jp/ |
---|
| 8 | * |
---|
| 9 | * This program is free software; you can redistribute it and/or |
---|
| 10 | * modify it under the terms of the GNU General Public License |
---|
| 11 | * as published by the Free Software Foundation; either version 2 |
---|
| 12 | * of the License, or (at your option) any later version. |
---|
| 13 | * |
---|
| 14 | * This program is distributed in the hope that it will be useful, |
---|
| 15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
| 16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
| 17 | * GNU General Public License for more details. |
---|
| 18 | * |
---|
| 19 | * You should have received a copy of the GNU General Public License |
---|
| 20 | * along with this program; if not, write to the Free Software |
---|
| 21 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
---|
| 22 | */ |
---|
| 23 | |
---|
[21826] | 24 | /** |
---|
| 25 | * PDF 納品書を出力する |
---|
| 26 | * |
---|
| 27 | * TODO ページクラスとすべき要素を多々含んでいるように感じる。 |
---|
[17182] | 28 | */ |
---|
| 29 | |
---|
[19807] | 30 | define('PDF_TEMPLATE_REALDIR', TEMPLATE_ADMIN_REALDIR . 'pdf/'); |
---|
[17182] | 31 | |
---|
[21826] | 32 | class SC_Fpdf extends SC_Helper_FPDI { |
---|
[21767] | 33 | function __construct($download, $title, $tpl_pdf = 'nouhinsyo1.pdf') { |
---|
[21358] | 34 | $this->FPDF(); |
---|
[17182] | 35 | // デフォルトの設定 |
---|
[19807] | 36 | $this->tpl_pdf = PDF_TEMPLATE_REALDIR . $tpl_pdf; // テンプレートファイル |
---|
[17305] | 37 | $this->pdf_download = $download; // PDFのダウンロード形式(0:表示、1:ダウンロード) |
---|
| 38 | $this->tpl_title = $title; |
---|
[20538] | 39 | $this->tpl_dispmode = 'real'; // 表示モード |
---|
[17182] | 40 | $masterData = new SC_DB_MasterData_Ex(); |
---|
[19773] | 41 | $this->arrPref = $masterData->getMasterData('mtb_pref'); |
---|
[17182] | 42 | $this->width_cell = array(110.3,12,21.7,24.5); |
---|
| 43 | |
---|
[21826] | 44 | $this->label_cell[] = '商品名 / 商品コード / [ 規格 ]'; |
---|
| 45 | $this->label_cell[] = '数量'; |
---|
| 46 | $this->label_cell[] = '単価'; |
---|
| 47 | $this->label_cell[] = '金額(税込)'; |
---|
[17182] | 48 | |
---|
| 49 | $this->arrMessage = array( |
---|
[18097] | 50 | 'このたびはお買上げいただきありがとうございます。', |
---|
| 51 | '下記の内容にて納品させていただきます。', |
---|
[19945] | 52 | 'ご確認くださいますよう、お願いいたします。' |
---|
[17182] | 53 | ); |
---|
| 54 | |
---|
| 55 | // SJISフォント |
---|
[21358] | 56 | $this->AddSJISFont(); |
---|
| 57 | $this->SetFont('SJIS'); |
---|
[17182] | 58 | |
---|
| 59 | //ページ総数取得 |
---|
[21358] | 60 | $this->AliasNbPages(); |
---|
[17182] | 61 | |
---|
| 62 | // マージン設定 |
---|
[21358] | 63 | $this->SetMargins(15, 20); |
---|
[17182] | 64 | |
---|
| 65 | // PDFを読み込んでページ数を取得 |
---|
[21926] | 66 | $this->pageno = $this->setSourceFile($this->tpl_pdf); |
---|
[17305] | 67 | } |
---|
[17182] | 68 | |
---|
[17305] | 69 | function setData($arrData) { |
---|
| 70 | $this->arrData = $arrData; |
---|
| 71 | |
---|
[17182] | 72 | // ページ番号よりIDを取得 |
---|
[21358] | 73 | $tplidx = $this->ImportPage(1); |
---|
[17182] | 74 | |
---|
| 75 | // ページを追加(新規) |
---|
[21358] | 76 | $this->AddPage(); |
---|
[17182] | 77 | |
---|
| 78 | //表示倍率(100%) |
---|
[21358] | 79 | $this->SetDisplayMode($this->tpl_dispmode); |
---|
[17182] | 80 | |
---|
[18097] | 81 | if (SC_Utils_Ex::sfIsInt($arrData['order_id'])) { |
---|
| 82 | $this->disp_mode = true; |
---|
[17182] | 83 | } |
---|
| 84 | |
---|
| 85 | // テンプレート内容の位置、幅を調整 ※useTemplateに引数を与えなければ100%表示がデフォルト |
---|
[21358] | 86 | $this->useTemplate($tplidx); |
---|
[17182] | 87 | |
---|
| 88 | $this->setShopData(); |
---|
| 89 | $this->setMessageData(); |
---|
| 90 | $this->setOrderData(); |
---|
| 91 | $this->setEtcData(); |
---|
[18295] | 92 | |
---|
[17182] | 93 | } |
---|
| 94 | |
---|
| 95 | function setShopData() { |
---|
| 96 | // ショップ情報 |
---|
[18043] | 97 | |
---|
[20013] | 98 | $objDb = new SC_Helper_DB_Ex(); |
---|
| 99 | $arrInfo = $objDb->sfGetBasisData(); |
---|
[17182] | 100 | |
---|
[21719] | 101 | // ショップ名 |
---|
| 102 | $this->lfText(125, 60, $arrInfo['shop_name'], 8, 'B'); |
---|
| 103 | // URL |
---|
| 104 | $this->lfText(125, 63, $arrInfo['law_url'], 8); |
---|
| 105 | // 会社名 |
---|
| 106 | $this->lfText(125, 68, $arrInfo['law_company'], 8); |
---|
| 107 | // 郵便番号 |
---|
| 108 | $text = '〒 ' . $arrInfo['law_zip01'] . ' - ' . $arrInfo['law_zip02']; |
---|
| 109 | $this->lfText(125, 71, $text, 8); |
---|
| 110 | // 都道府県+所在地 |
---|
| 111 | $text = $this->arrPref[$arrInfo['law_pref']] . $arrInfo['law_addr01']; |
---|
| 112 | $this->lfText(125, 74, $text, 8); |
---|
| 113 | $this->lfText(125, 77, $arrInfo['law_addr02'], 8); |
---|
[18043] | 114 | |
---|
[21515] | 115 | $text = 'TEL: '.$arrInfo['law_tel01'].'-'.$arrInfo['law_tel02'].'-'.$arrInfo['law_tel03']; |
---|
[18097] | 116 | //FAX番号が存在する場合、表示する |
---|
[17909] | 117 | if (strlen($arrInfo['law_fax01']) > 0) { |
---|
[21515] | 118 | $text .= ' FAX: '.$arrInfo['law_fax01'].'-'.$arrInfo['law_fax02'].'-'.$arrInfo['law_fax03']; |
---|
[17305] | 119 | } |
---|
[17182] | 120 | $this->lfText(125, 80, $text, 8); //TEL・FAX |
---|
[17305] | 121 | |
---|
[21442] | 122 | if (strlen($arrInfo['law_email']) > 0) { |
---|
[21514] | 123 | $text = 'Email: '.$arrInfo['law_email']; |
---|
[17305] | 124 | $this->lfText(125, 83, $text, 8); //Email |
---|
| 125 | } |
---|
[18016] | 126 | |
---|
| 127 | //ロゴ画像 |
---|
[19807] | 128 | $logo_file = PDF_TEMPLATE_REALDIR . 'logo.png'; |
---|
[21358] | 129 | $this->Image($logo_file, 124, 46, 40); |
---|
[17182] | 130 | } |
---|
| 131 | |
---|
| 132 | function setMessageData() { |
---|
| 133 | // メッセージ |
---|
| 134 | $this->lfText(27, 70, $this->arrData['msg1'], 8); //メッセージ1 |
---|
| 135 | $this->lfText(27, 74, $this->arrData['msg2'], 8); //メッセージ2 |
---|
| 136 | $this->lfText(27, 78, $this->arrData['msg3'], 8); //メッセージ3 |
---|
[21515] | 137 | $text = '作成日: '.$this->arrData['year'].'年'.$this->arrData['month'].'月'.$this->arrData['day'].'日'; |
---|
[17182] | 138 | $this->lfText(158, 288, $text, 8); //作成日 |
---|
| 139 | } |
---|
| 140 | |
---|
| 141 | function setOrderData() { |
---|
[21926] | 142 | $arrOrder = array(); |
---|
[17182] | 143 | // DBから受注情報を読み込む |
---|
| 144 | $this->lfGetOrderData($this->arrData['order_id']); |
---|
| 145 | |
---|
| 146 | // 購入者情報 |
---|
[21515] | 147 | $text = '〒 '.$this->arrDisp['order_zip01'].' - '.$this->arrDisp['order_zip02']; |
---|
[17182] | 148 | $this->lfText(23, 43, $text, 10); //購入者郵便番号 |
---|
| 149 | $text = $this->arrPref[$this->arrDisp['order_pref']] . $this->arrDisp['order_addr01']; |
---|
| 150 | $this->lfText(27, 47, $text, 10); //購入者都道府県+住所1 |
---|
| 151 | $this->lfText(27, 51, $this->arrDisp['order_addr02'], 10); //購入者住所2 |
---|
[21515] | 152 | $text = $this->arrDisp['order_name01'].' '.$this->arrDisp['order_name02'].' 様'; |
---|
[17182] | 153 | $this->lfText(27, 59, $text, 11); //購入者氏名 |
---|
| 154 | |
---|
| 155 | // お届け先情報 |
---|
[21358] | 156 | $this->SetFont('SJIS', '', 10); |
---|
[20013] | 157 | $this->lfText(25, 125, SC_Utils_Ex::sfDispDBDate($this->arrDisp['create_date']), 10); //ご注文日 |
---|
| 158 | $this->lfText(25, 135, $this->arrDisp['order_id'], 10); //注文番号 |
---|
[17182] | 159 | |
---|
[21358] | 160 | $this->SetFont('Gothic', 'B', 15); |
---|
[21826] | 161 | $this->Cell(0, 10, $this->tpl_title, 0, 2, 'C', 0, ''); //文書タイトル(納品書・請求書) |
---|
[21358] | 162 | $this->Cell(0, 66, '', 0, 2, 'R', 0, ''); |
---|
| 163 | $this->Cell(5, 0, '', 0, 0, 'R', 0, ''); |
---|
| 164 | $this->SetFont('SJIS', 'B', 15); |
---|
[21826] | 165 | $this->Cell(67, 8, number_format($this->arrDisp['payment_total']).' 円', 0, 2, 'R', 0, ''); |
---|
[21358] | 166 | $this->Cell(0, 45, '', 0, 2, '', 0, ''); |
---|
[17182] | 167 | |
---|
[21358] | 168 | $this->SetFont('SJIS', '', 8); |
---|
[17182] | 169 | |
---|
[21826] | 170 | $monetary_unit = '円'; |
---|
| 171 | $point_unit = 'Pt'; |
---|
[17182] | 172 | |
---|
| 173 | // 購入商品情報 |
---|
| 174 | for ($i = 0; $i < count($this->arrDisp['quantity']); $i++) { |
---|
| 175 | |
---|
[18097] | 176 | // 購入数量 |
---|
| 177 | $data[0] = $this->arrDisp['quantity'][$i]; |
---|
[17182] | 178 | |
---|
[18097] | 179 | // 税込金額(単価) |
---|
[19680] | 180 | $data[1] = SC_Helper_DB_Ex::sfCalcIncTax($this->arrDisp['price'][$i]); |
---|
[17182] | 181 | |
---|
[18097] | 182 | // 小計(商品毎) |
---|
| 183 | $data[2] = $data[0] * $data[1]; |
---|
[17182] | 184 | |
---|
[21826] | 185 | $arrOrder[$i][0] = $this->arrDisp['product_name'][$i].' / '; |
---|
| 186 | $arrOrder[$i][0] .= $this->arrDisp['product_code'][$i].' / '; |
---|
[18097] | 187 | if ($this->arrDisp['classcategory_name1'][$i]) { |
---|
[21826] | 188 | $arrOrder[$i][0] .= ' [ '.$this->arrDisp['classcategory_name1'][$i]; |
---|
[21514] | 189 | if ($this->arrDisp['classcategory_name2'][$i] == '') { |
---|
| 190 | $arrOrder[$i][0] .= ' ]'; |
---|
[18097] | 191 | } else { |
---|
[21826] | 192 | $arrOrder[$i][0] .= ' * '.$this->arrDisp['classcategory_name2'][$i].' ]'; |
---|
[18097] | 193 | } |
---|
[17182] | 194 | } |
---|
[18097] | 195 | $arrOrder[$i][1] = number_format($data[0]); |
---|
| 196 | $arrOrder[$i][2] = number_format($data[1]).$monetary_unit; |
---|
| 197 | $arrOrder[$i][3] = number_format($data[2]).$monetary_unit; |
---|
[17182] | 198 | |
---|
| 199 | } |
---|
| 200 | |
---|
[21514] | 201 | $arrOrder[$i][0] = ''; |
---|
| 202 | $arrOrder[$i][1] = ''; |
---|
| 203 | $arrOrder[$i][2] = ''; |
---|
| 204 | $arrOrder[$i][3] = ''; |
---|
[17182] | 205 | |
---|
| 206 | $i++; |
---|
[21514] | 207 | $arrOrder[$i][0] = ''; |
---|
| 208 | $arrOrder[$i][1] = ''; |
---|
[21826] | 209 | $arrOrder[$i][2] = '商品合計'; |
---|
[17182] | 210 | $arrOrder[$i][3] = number_format($this->arrDisp['subtotal']).$monetary_unit; |
---|
| 211 | |
---|
| 212 | $i++; |
---|
[21514] | 213 | $arrOrder[$i][0] = ''; |
---|
| 214 | $arrOrder[$i][1] = ''; |
---|
[21826] | 215 | $arrOrder[$i][2] = '送料'; |
---|
[17182] | 216 | $arrOrder[$i][3] = number_format($this->arrDisp['deliv_fee']).$monetary_unit; |
---|
| 217 | |
---|
| 218 | $i++; |
---|
[21514] | 219 | $arrOrder[$i][0] = ''; |
---|
| 220 | $arrOrder[$i][1] = ''; |
---|
[21826] | 221 | $arrOrder[$i][2] = '手数料'; |
---|
[17182] | 222 | $arrOrder[$i][3] = number_format($this->arrDisp['charge']).$monetary_unit; |
---|
| 223 | |
---|
| 224 | $i++; |
---|
[21514] | 225 | $arrOrder[$i][0] = ''; |
---|
| 226 | $arrOrder[$i][1] = ''; |
---|
[21826] | 227 | $arrOrder[$i][2] = '値引き'; |
---|
[21514] | 228 | $arrOrder[$i][3] = '- '.number_format(($this->arrDisp['use_point'] * POINT_VALUE) + $this->arrDisp['discount']).$monetary_unit; |
---|
[17182] | 229 | |
---|
| 230 | $i++; |
---|
[21514] | 231 | $arrOrder[$i][0] = ''; |
---|
| 232 | $arrOrder[$i][1] = ''; |
---|
[21826] | 233 | $arrOrder[$i][2] = '請求金額'; |
---|
[17182] | 234 | $arrOrder[$i][3] = number_format($this->arrDisp['payment_total']).$monetary_unit; |
---|
| 235 | |
---|
| 236 | // ポイント表記 |
---|
| 237 | if ($this->arrData['disp_point'] && $this->arrDisp['customer_id']) { |
---|
[18097] | 238 | $i++; |
---|
[21514] | 239 | $arrOrder[$i][0] = ''; |
---|
| 240 | $arrOrder[$i][1] = ''; |
---|
| 241 | $arrOrder[$i][2] = ''; |
---|
| 242 | $arrOrder[$i][3] = ''; |
---|
[17182] | 243 | |
---|
[18097] | 244 | $i++; |
---|
[21514] | 245 | $arrOrder[$i][0] = ''; |
---|
| 246 | $arrOrder[$i][1] = ''; |
---|
[21826] | 247 | $arrOrder[$i][2] = '利用ポイント'; |
---|
[18097] | 248 | $arrOrder[$i][3] = number_format($this->arrDisp['use_point']).$point_unit; |
---|
[17182] | 249 | |
---|
[18097] | 250 | $i++; |
---|
[21514] | 251 | $arrOrder[$i][0] = ''; |
---|
| 252 | $arrOrder[$i][1] = ''; |
---|
[21826] | 253 | $arrOrder[$i][2] = '加算ポイント'; |
---|
[18097] | 254 | $arrOrder[$i][3] = number_format($this->arrDisp['add_point']).$point_unit; |
---|
[17182] | 255 | } |
---|
| 256 | |
---|
[21358] | 257 | $this->FancyTable($this->label_cell, $arrOrder, $this->width_cell); |
---|
[17182] | 258 | } |
---|
| 259 | |
---|
| 260 | function setEtcData() { |
---|
[21358] | 261 | $this->Cell(0, 10, '', 0, 1, 'C', 0, ''); |
---|
| 262 | $this->SetFont('Gothic', 'B', 9); |
---|
[21826] | 263 | $this->MultiCell(0, 6, '< 備 考 >', 'T', 2, 'L', 0, ''); //備考 |
---|
[21358] | 264 | $this->Ln(); |
---|
| 265 | $this->SetFont('SJIS', '', 8); |
---|
[21826] | 266 | $this->MultiCell(0, 4, $this->arrData['etc1']."\n".$this->arrData['etc2']."\n".$this->arrData['etc3'], '', 2, 'L', 0, ''); //備考 |
---|
[17182] | 267 | } |
---|
| 268 | |
---|
| 269 | function createPdf() { |
---|
| 270 | // PDFをブラウザに送信 |
---|
[18097] | 271 | ob_clean(); |
---|
| 272 | if ($this->pdf_download == 1) { |
---|
[21358] | 273 | if ($this->PageNo() == 1) { |
---|
[21515] | 274 | $filename = 'nouhinsyo-No'.$this->arrData['order_id'].'.pdf'; |
---|
[18097] | 275 | } else { |
---|
[21514] | 276 | $filename = 'nouhinsyo.pdf'; |
---|
[18097] | 277 | } |
---|
[21358] | 278 | $this->Output($this->lfConvSjis($filename), 'D'); |
---|
[17182] | 279 | } else { |
---|
[21358] | 280 | $this->Output(); |
---|
[17182] | 281 | } |
---|
| 282 | |
---|
| 283 | // 入力してPDFファイルを閉じる |
---|
[21358] | 284 | $this->Close(); |
---|
[17182] | 285 | } |
---|
| 286 | |
---|
| 287 | // PDF_Japanese::Text へのパーサー |
---|
[21024] | 288 | function lfText($x, $y, $text, $size = 0, $style = '') { |
---|
| 289 | // 退避 |
---|
[21358] | 290 | $bak_font_style = $this->FontStyle; |
---|
| 291 | $bak_font_size = $this->FontSizePt; |
---|
[17182] | 292 | |
---|
[21358] | 293 | $this->SetFont('', $style, $size); |
---|
[21826] | 294 | $this->Text($x, $y, $text); |
---|
[21024] | 295 | |
---|
| 296 | // 復元 |
---|
[21358] | 297 | $this->SetFont('', $bak_font_style, $bak_font_size); |
---|
[17182] | 298 | } |
---|
| 299 | |
---|
| 300 | // 受注データの取得 |
---|
| 301 | function lfGetOrderData($order_id) { |
---|
[21441] | 302 | if (SC_Utils_Ex::sfIsInt($order_id)) { |
---|
[17182] | 303 | // DBから受注情報を読み込む |
---|
[21750] | 304 | $objQuery =& SC_Query_Ex::getSingletonInstance(); |
---|
[21514] | 305 | $where = 'order_id = ?'; |
---|
| 306 | $arrRet = $objQuery->select('*', 'dtb_order', $where, array($order_id)); |
---|
[17182] | 307 | $this->arrDisp = $arrRet[0]; |
---|
[19864] | 308 | list($point) = SC_Helper_Customer_Ex::sfGetCustomerPoint($order_id, $arrRet[0]['use_point'], $arrRet[0]['add_point']); |
---|
[18097] | 309 | $this->arrDisp['point'] = $point; |
---|
[17182] | 310 | |
---|
| 311 | // 受注詳細データの取得 |
---|
| 312 | $arrRet = $this->lfGetOrderDetail($order_id); |
---|
| 313 | $arrRet = SC_Utils_Ex::sfSwapArray($arrRet); |
---|
| 314 | $this->arrDisp = array_merge($this->arrDisp, $arrRet); |
---|
| 315 | |
---|
| 316 | // その他支払い情報を表示 |
---|
[21684] | 317 | if ($this->arrDisp['memo02'] != '') { |
---|
| 318 | $this->arrDisp['payment_info'] = unserialize($this->arrDisp['memo02']); |
---|
| 319 | } |
---|
[21514] | 320 | $this->arrDisp['payment_type'] = 'お支払い'; |
---|
[17182] | 321 | } |
---|
| 322 | } |
---|
| 323 | |
---|
| 324 | // 受注詳細データの取得 |
---|
| 325 | function lfGetOrderDetail($order_id) { |
---|
[21750] | 326 | $objQuery =& SC_Query_Ex::getSingletonInstance(); |
---|
[21514] | 327 | $col = 'product_id, product_class_id, product_code, product_name, classcategory_name1, classcategory_name2, price, quantity, point_rate'; |
---|
| 328 | $where = 'order_id = ?'; |
---|
[21481] | 329 | $objQuery->setOrder('order_detail_id'); |
---|
| 330 | $arrRet = $objQuery->select($col, 'dtb_order_detail', $where, array($order_id)); |
---|
[18097] | 331 | return $arrRet; |
---|
[17182] | 332 | } |
---|
| 333 | } |
---|