source: branches/version-2/data/class/SC_Fpdf.php @ 17514

Revision 17514, 14.1 KB checked in by nakanishi, 13 years ago (diff)

#301 帳票出力で税込み価格が反映されていない問題の修正(homan様)

Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
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
24/*----------------------------------------------------------------------
25 * [名称] SC_Fpdf
26 * [概要] pdfファイルを表示する。
27 *----------------------------------------------------------------------
28 */
29
30require(DATA_PATH . 'pdf/japanese.php');
31define('PDF_TEMPLATE_DIR', DATA_PATH . 'pdf/');
32define('PDF_IMG_DIR', HTML_PATH. USER_DIR. USER_PACKAGE_DIR. TEMPLATE_NAME. '/img/pdf/');
33
34class SC_Fpdf {
35    function SC_Fpdf($arrData, $tpl_pdf = "template_nouhin01.pdf") {
36        $this->arrData = $arrData;
37        // デフォルトの設定
38        $this->tpl_pdf = PDF_TEMPLATE_DIR . $tpl_pdf;  // テンプレートファイル
39        $this->pdf_download = $arrData[download];      // PDFのダウンロード形式(0:表示、1:ダウンロード)
40        $this->tpl_title = $arrData['title'];
41        $this->tpl_dispmode = "real";      // 表示モード
42        $masterData = new SC_DB_MasterData_Ex();
43        $this->arrPref = $masterData->getMasterData("mtb_pref", array("pref_id", "pref_name", "rank"));
44        $this->width_cell = array(110.3,12,21.7,24.5);
45
46        $this->label_cell[] = $this->sjis_conv("商品名 / 商品コード / [ 規格 ]");
47        $this->label_cell[] = $this->sjis_conv("数量");
48        $this->label_cell[] = $this->sjis_conv("単価");
49        $this->label_cell[] = $this->sjis_conv("金額(税込)");
50
51        $this->arrMessage = array(
52          'このたびはお買上げいただきありがとうございます。',
53          '下記の内容にて納品させていただきます。',
54          'ご確認いただきますよう、お願いいたします。'
55        );
56
57        $this->pdf  = new PDF_Japanese();
58
59        // SJISフォント
60        $this->pdf->AddSJISFont();
61
62        //ページ総数取得
63        $this->pdf->AliasNbPages();
64
65        // マージン設定
66        $this->pdf->SetMargins(15, 20);
67
68        // PDFを読み込んでページ数を取得
69        $pageno = $this->pdf->setSourceFile($this->tpl_pdf);
70
71        // ページ番号よりIDを取得
72        $tplidx = $this->pdf->ImportPage(1);
73
74        // ページを追加(新規)
75        $this->pdf->AddPage();
76
77        //表示倍率(100%)
78        $this->pdf->SetDisplayMode($this->tpl_dispmode);
79
80        if(SC_Utils_Ex::sfIsInt($arrData['order_id'])) {
81          $this->disp_mode = true;
82          $order_id = $arrData['order_id'];
83        }
84
85        // テンプレート内容の位置、幅を調整 ※useTemplateに引数を与えなければ100%表示がデフォルト
86        $this->pdf->useTemplate($tplidx);
87
88        $this->setShopData();
89        $this->setMessageData();
90        $this->setOrderData();
91        $this->setEtcData();
92
93        //ロゴ画像
94        $this->pdf->Image(PDF_IMG_DIR. 'logo.png', 124, 46, 60);
95
96        $this->createPdf();
97    }
98
99    function setShopData() {
100        // ショップ情報
101
102        $objInfo = new SC_SiteInfo();
103        $arrInfo = $objInfo->data;
104
105        $this->lfText(125, 60, $arrInfo['shop_name'], 8, 'B');          //ショップ名
106        $this->lfText(125, 63, $arrInfo['law_url'], 8);          //URL
107        $this->lfText(125, 68, $arrInfo['law_company'], 8);        //会社名
108        $text = "〒 ".$arrInfo['zip01']." - ".$arrInfo['zip02'];
109        $this->lfText(125, 71, $text, 8);  //郵便番号
110        $text = $this->arrPref[$arrInfo['pref']].$arrInfo['addr01'];
111        $this->lfText(125, 74, $text, 8);  //都道府県+住所1
112        $this->lfText(125, 77, $arrInfo['addr02'], 8);          //住所2
113        $text = "TEL: ".$arrInfo['tel01']."-".$arrInfo['tel02']."-".$arrInfo['tel03']." "."FAX: ".$arrInfo['fax01']."-".$arrInfo['fax02']."-".$arrInfo['fax03'];
114        $this->lfText(125, 80, $text, 8);  //TEL・FAX
115        $text = "Email: ".$arrInfo['law_email'];
116        $this->lfText(125, 83, $text, 8);      //Email
117    }
118
119    function setMessageData() {
120        // メッセージ
121        $this->lfText(27, 70, $this->arrData['msg1'], 8);  //メッセージ1
122        $this->lfText(27, 74, $this->arrData['msg2'], 8);  //メッセージ2
123        $this->lfText(27, 78, $this->arrData['msg3'], 8);  //メッセージ3
124        $text = "作成日: ".$this->arrData['year']."年".$this->arrData['month']."月".$this->arrData['day']."日";
125        $this->lfText(158, 288, $text, 8);  //作成日
126    }
127
128    function setOrderData() {
129        $objInfo = new SC_SiteInfo();
130        $arrInfo = $objInfo->data;
131        // DBから受注情報を読み込む
132        $this->lfGetOrderData($this->arrData['order_id']);
133
134        // 購入者情報
135        $text = "〒 ".$this->arrDisp['order_zip01']." - ".$this->arrDisp['order_zip02'];
136        $this->lfText(23, 43, $text, 10); //購入者郵便番号
137        $text = $this->arrPref[$this->arrDisp['order_pref']] . $this->arrDisp['order_addr01'];
138        $this->lfText(27, 47, $text, 10); //購入者都道府県+住所1
139        $this->lfText(27, 51, $this->arrDisp['order_addr02'], 10); //購入者住所2
140        $text = $this->arrDisp['order_name01']." ".$this->arrDisp['order_name02']." 様";
141        $this->lfText(27, 59, $text, 11); //購入者氏名
142
143        // お届け先情報
144        $this->pdf->SetFont('SJIS', '', 10);
145        $text = "〒 ".$this->arrDisp['deliv_zip01']." - ".$this->arrDisp['deliv_zip02'];
146        $this->lfText(22, 128, $text, 10); //お届け先郵便番号
147        $text = $this->arrPref[$this->arrDisp['deliv_pref']] . $this->arrDisp['deliv_addr01'];
148        $this->lfText(26, 132, $text, 10); //お届け先都道府県+住所1
149        $this->lfText(26, 136, $this->arrDisp['deliv_addr02'], 10); //お届け先住所2
150        $text = $this->arrDisp['deliv_name01']." ".$this->arrDisp['deliv_name02']." 様";
151        $this->lfText(26, 140, $text, 10); //お届け先氏名
152
153        $this->lfText(144, 121, SC_Utils_Ex::sfDispDBDate($this->arrDisp['create_date']), 10); //ご注文日
154        $this->lfText(144, 131, $this->arrDisp['order_id'], 10); //注文番号
155
156        $this->pdf->SetFont('SJIS', 'B', 15);
157        $this->pdf->Cell(0, 10, $this->sjis_conv($this->tpl_title), 0, 2, 'C', 0, '');  //文書タイトル(納品書・請求書)
158        $this->pdf->Cell(0, 66, '', 0, 2, 'R', 0, '');
159        $this->pdf->Cell(5, 0, '', 0, 0, 'R', 0, '');
160        $this->pdf->Cell(67, 8, $this->sjis_conv(number_format($this->arrDisp['payment_total'])." 円"), 0, 2, 'R', 0, '');
161        $this->pdf->Cell(0, 45, '', 0, 2, '', 0, '');
162
163        $this->pdf->SetFont('SJIS', '', 9);
164
165        $monetary_unit = $this->sjis_conv("円");
166        $point_unit = $this->sjis_conv("pt");
167
168        // 購入商品情報
169        for ($i = 0; $i < count($this->arrDisp['quantity']); $i++) {
170
171          // 購入数量
172          $data[0] = $this->arrDisp['quantity'][$i];
173
174          // 税込金額(単価)
175          $data[1] = SC_Utils_Ex::sfPreTax($this->arrDisp['price'][$i], $arrInfo['tax'], $arrInfo['tax_rule']);
176
177          // 小計(商品毎)
178          $data[2] = $data[0] * $data[1];
179
180          $arrOrder[$i][0]  = $this->sjis_conv($this->arrDisp['product_name'][$i]." / ");
181          $arrOrder[$i][0] .= $this->sjis_conv($this->arrDisp['product_code'][$i]." / ");
182          if($this->arrDisp['classcategory_name1'][$i]) {
183            $arrOrder[$i][0] .= $this->sjis_conv(" [ ".$this->arrDisp['classcategory_name1'][$i]);
184            if($this->arrDisp['classcategory_name2'][$i] == "") {
185              $arrOrder[$i][0] .= " ]";
186            } else {
187              $arrOrder[$i][0] .= $this->sjis_conv(" * ".$this->arrDisp['classcategory_name2'][$i]." ]");
188            }
189          }
190          $arrOrder[$i][1]  = number_format($data[0]);
191          $arrOrder[$i][2]  = number_format($data[1]).$monetary_unit;
192          $arrOrder[$i][3]  = number_format($data[2]).$monetary_unit;
193
194        }
195
196        $arrOrder[$i][0] = "";
197        $arrOrder[$i][1] = "";
198        $arrOrder[$i][2] = "";
199        $arrOrder[$i][3] = "";
200
201        $i++;
202        $arrOrder[$i][0] = "";
203        $arrOrder[$i][1] = "";
204        $arrOrder[$i][2] = $this->sjis_conv("商品合計");
205        $arrOrder[$i][3] = number_format($this->arrDisp['subtotal']).$monetary_unit;
206
207        $i++;
208        $arrOrder[$i][0] = "";
209        $arrOrder[$i][1] = "";
210        $arrOrder[$i][2] = $this->sjis_conv("送料");
211        $arrOrder[$i][3] = number_format($this->arrDisp['deliv_fee']).$monetary_unit;
212
213        $i++;
214        $arrOrder[$i][0] = "";
215        $arrOrder[$i][1] = "";
216        $arrOrder[$i][2] = $this->sjis_conv("手数料");
217        $arrOrder[$i][3] = number_format($this->arrDisp['charge']).$monetary_unit;
218
219        $i++;
220        $arrOrder[$i][0] = "";
221        $arrOrder[$i][1] = "";
222        $arrOrder[$i][2] = $this->sjis_conv("値引き");
223        $arrOrder[$i][3] = "- ".number_format($this->arrDisp['use_point'] + $this->arrDisp['discount']).$monetary_unit;
224
225        $i++;
226        $arrOrder[$i][0] = "";
227        $arrOrder[$i][1] = "";
228        $arrOrder[$i][2] = $this->sjis_conv("請求金額");
229        $arrOrder[$i][3] = number_format($this->arrDisp['payment_total']).$monetary_unit;
230
231        $i++;
232        $arrOrder[$i][0] = "";
233        $arrOrder[$i][1] = "";
234        $arrOrder[$i][2] = "";
235        $arrOrder[$i][3] = "";
236
237        // ポイント表記
238        if ($this->arrData['disp_point'] && $this->arrDisp['customer_id']) {
239          $i++;
240          $arrOrder[$i][0] = "";
241          $arrOrder[$i][1] = "";
242          $arrOrder[$i][2] = $this->sjis_conv("利用ポイント");
243          $arrOrder[$i][3] = number_format($this->arrDisp['use_point']).$point_unit;
244
245          $i++;
246          $arrOrder[$i][0] = "";
247          $arrOrder[$i][1] = "";
248          $arrOrder[$i][2] = $this->sjis_conv("加算ポイント");
249          $arrOrder[$i][3] = number_format($this->arrDisp['add_point']).$point_unit;
250
251          $i++;
252          $arrOrder[$i][0] = "";
253          $arrOrder[$i][1] = "";
254          $arrOrder[$i][2] = $this->sjis_conv("所有ポイント");
255          $arrOrder[$i][3] = number_format($this->arrDisp['point']).$point_unit;
256        }
257
258        $this->pdf->FancyTable($this->label_cell, $arrOrder, $this->width_cell);
259    }
260
261    function setEtcData() {
262        $this->pdf->Cell(0, 10, '', 0, 1, 'C', 0, '');
263        $this->pdf->SetFont('SJIS', '', 9);
264        $this->pdf->MultiCell(0, 6, $this->sjis_conv("< 備 考 >"), 'T', 2, 'L', 0, '');  //備考
265        $this->pdf->Ln();
266        $this->pdf->SetFont('SJIS', '', 8);
267        $this->pdf->MultiCell(0, 4, $this->sjis_conv($this->arrData['etc1']."\n".$this->arrData['etc2']."\n".$this->arrData['etc3']), '', 2, 'L', 0, '');  //備考
268    }
269
270    function createPdf() {
271        // PDFをブラウザに送信
272ob_clean();
273        if($this->pdf_download == 1) {
274          $filename = "nouhinsyo-No".$this->arrData['order_id'].".pdf";
275          $this->pdf->Output($this->sjis_conv($filename), D);
276        } else {
277          $this->pdf->Output();
278        }
279
280        // 入力してPDFファイルを閉じる
281        $this->pdf->Close();
282    }
283
284    // PDF_Japanese::Text へのパーサー
285    function lfText($x, $y, $text, $size, $style = '') {
286        $text = mb_convert_encoding($text, "SJIS", CHAR_CODE);
287
288        $this->pdf->SetFont('SJIS', $style, $size);
289        $this->pdf->Text($x, $y, $text);
290    }
291
292
293    // 受注データの取得
294    function lfGetOrderData($order_id) {
295        if(SC_Utils_Ex::sfIsInt($order_id)) {
296            // DBから受注情報を読み込む
297            $objQuery = new SC_Query();
298            $where = "order_id = ?";
299            $arrRet = $objQuery->select("*", "dtb_order", $where, array($order_id));
300            #$objFormParam->setParam($arrRet[0]);
301            list($point, $total_point) = SC_Helper_DB_Ex::sfGetCustomerPoint($order_id, $arrRet[0]['use_point'], $arrRet[0]['add_point']);
302            #$objFormParam->setValue('total_point', $total_point);
303            #$objFormParam->setValue('point', $point);
304            $arrRet[0]['total_point'] = $total_point;
305            $arrRet[0]['point'] = $point;
306            $this->arrDisp = $arrRet[0];
307
308            // 受注詳細データの取得
309            $arrRet = $this->lfGetOrderDetail($order_id);
310            $arrRet = SC_Utils_Ex::sfSwapArray($arrRet);
311            $this->arrDisp = array_merge($this->arrDisp, $arrRet);
312            #$objFormParam->setParam($arrRet);
313
314            // その他支払い情報を表示
315            if($this->arrDisp["memo02"] != "") $this->arrDisp["payment_info"] = unserialize($this->arrDisp["memo02"]);
316            if($this->arrDisp["memo01"] == PAYMENT_CREDIT_ID){
317                  $this->arrDisp["payment_type"] = "クレジット決済";
318            } elseif ($this->arrDisp["memo01"] == PAYMENT_CONVENIENCE_ID) {
319                  $this->arrDisp["payment_type"] = "コンビニ決済";
320            } else {
321                  $this->arrDisp["payment_type"] = "お支払い";
322            }
323        }
324    }
325
326    // 受注詳細データの取得
327    function lfGetOrderDetail($order_id) {
328      $objQuery = new SC_Query();
329      $col = "product_id, classcategory_id1, classcategory_id2, product_code, product_name, classcategory_name1, classcategory_name2, price, quantity, point_rate";
330      $where = "order_id = ?";
331      $objQuery->setorder("classcategory_id1, classcategory_id2");
332      $arrRet = $objQuery->select($col, "dtb_order_detail", $where, array($order_id));
333      return $arrRet;
334    }
335
336    // 文字コードSJIS変換 -> japanese.phpで使用出来る文字コードはSJISのみ
337    function sjis_conv($conv_str) {
338      return (mb_convert_encoding($conv_str, "SJIS", CHAR_CODE));
339    }
340
341
342}
343?>
Note: See TracBrowser for help on using the repository browser.