source: branches/version-2_12-multilang/data/class/SC_Fpdf.php @ 22205

Revision 22205, 12.9 KB checked in by m_uehara, 11 years ago (diff)

#2004 郵便番号を2カラムから1カラムに変更しました。

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
RevLine 
[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]30define('PDF_TEMPLATE_REALDIR', TEMPLATE_ADMIN_REALDIR . 'pdf/');
[17182]31
[21826]32class 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
[22100]44        $this->label_cell[] = t('SC_Fpdf_001');
45        $this->label_cell[] = t('SC_Fpdf_002');
46        $this->label_cell[] = t('SC_Fpdf_003');
47        $this->label_cell[] = t('SC_Fpdf_004');
[17182]48
49        $this->arrMessage = array(
[22100]50            t('SC_Fpdf_014'),
51            t('SC_Fpdf_015'),
52            t('SC_Fpdf_016')
[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        // 郵便番号
[22205]108//        $text = '〒 ' . $arrInfo['law_zip01'] . ' - ' . $arrInfo['law_zip02'];
109        $text = '〒 ' . $arrInfo['law_zipcode'];
[21719]110        $this->lfText(125, 71, $text, 8);
111        // 都道府県+所在地
112        $text = $this->arrPref[$arrInfo['law_pref']] . $arrInfo['law_addr01'];
113        $this->lfText(125, 74, $text, 8);
114        $this->lfText(125, 77, $arrInfo['law_addr02'], 8);
[18043]115
[21515]116        $text = 'TEL: '.$arrInfo['law_tel01'].'-'.$arrInfo['law_tel02'].'-'.$arrInfo['law_tel03'];
[18097]117        //FAX番号が存在する場合、表示する
[17909]118        if (strlen($arrInfo['law_fax01']) > 0) {
[21515]119            $text .= ' FAX: '.$arrInfo['law_fax01'].'-'.$arrInfo['law_fax02'].'-'.$arrInfo['law_fax03'];
[17305]120        }
[17182]121        $this->lfText(125, 80, $text, 8);  //TEL・FAX
[17305]122
[21442]123        if (strlen($arrInfo['law_email']) > 0) {
[21514]124            $text = 'Email: '.$arrInfo['law_email'];
[17305]125            $this->lfText(125, 83, $text, 8);      //Email
126        }
[18016]127
128        //ロゴ画像
[19807]129        $logo_file = PDF_TEMPLATE_REALDIR . 'logo.png';
[21358]130        $this->Image($logo_file, 124, 46, 40);
[17182]131    }
132
133    function setMessageData() {
134        // メッセージ
135        $this->lfText(27, 70, $this->arrData['msg1'], 8);  //メッセージ1
136        $this->lfText(27, 74, $this->arrData['msg2'], 8);  //メッセージ2
137        $this->lfText(27, 78, $this->arrData['msg3'], 8);  //メッセージ3
[22030]138        $tokens = array(
139            'T_YEAR' => $this->arrData['year'],
140            'T_MONTH' => $this->arrData['month'],
141            'T_DAY' => $this->arrData['day']
142        );
[22100]143        $text = t('SC_Fpdf_017', $tokens);
[17182]144        $this->lfText(158, 288, $text, 8);  //作成日
145    }
146
147    function setOrderData() {
[21926]148        $arrOrder = array();
[17182]149        // DBから受注情報を読み込む
150        $this->lfGetOrderData($this->arrData['order_id']);
151
152        // 購入者情報
[22205]153//        $text = '〒 '.$this->arrDisp['order_zip01'].' - '.$this->arrDisp['order_zip02'];
154        $text = '〒 '.$this->arrDisp['order_zipcode'];
[17182]155        $this->lfText(23, 43, $text, 10); //購入者郵便番号
156        $text = $this->arrPref[$this->arrDisp['order_pref']] . $this->arrDisp['order_addr01'];
157        $this->lfText(27, 47, $text, 10); //購入者都道府県+住所1
158        $this->lfText(27, 51, $this->arrDisp['order_addr02'], 10); //購入者住所2
[21515]159        $text = $this->arrDisp['order_name01'].' '.$this->arrDisp['order_name02'].' 様';
[17182]160        $this->lfText(27, 59, $text, 11); //購入者氏名
161
162        // お届け先情報
[21358]163        $this->SetFont('SJIS', '', 10);
[20013]164        $this->lfText(25, 125, SC_Utils_Ex::sfDispDBDate($this->arrDisp['create_date']), 10); //ご注文日
165        $this->lfText(25, 135, $this->arrDisp['order_id'], 10); //注文番号
[17182]166
[21358]167        $this->SetFont('Gothic', 'B', 15);
[21826]168        $this->Cell(0, 10, $this->tpl_title, 0, 2, 'C', 0, '');  //文書タイトル(納品書・請求書)
[21358]169        $this->Cell(0, 66, '', 0, 2, 'R', 0, '');
170        $this->Cell(5, 0, '', 0, 0, 'R', 0, '');
171        $this->SetFont('SJIS', 'B', 15);
[22030]172        $tokens = array(
173            'T_PRICE' => number_format($this->arrDisp['payment_total']),
[22100]174            'T_UNIT' => t('SC_Fpdf_019')
[22030]175        );
[22100]176        $this->Cell(67, 8, t('SC_Fpdf_018', $tokens), 0, 2, 'R', 0, '');
[21358]177        $this->Cell(0, 45, '', 0, 2, '', 0, '');
[17182]178
[21358]179        $this->SetFont('SJIS', '', 8);
[17182]180
[22100]181        $monetary_unit = t('SC_Fpdf_019');
182        $point_unit = t('SC_Fpdf_020');
[17182]183
184        // 購入商品情報
185        for ($i = 0; $i < count($this->arrDisp['quantity']); $i++) {
186
[18097]187            // 購入数量
188            $data[0] = $this->arrDisp['quantity'][$i];
[17182]189
[18097]190            // 税込金額(単価)
[19680]191            $data[1] = SC_Helper_DB_Ex::sfCalcIncTax($this->arrDisp['price'][$i]);
[17182]192
[18097]193            // 小計(商品毎)
194            $data[2] = $data[0] * $data[1];
[17182]195
[21826]196            $arrOrder[$i][0]  = $this->arrDisp['product_name'][$i].' / ';
197            $arrOrder[$i][0] .= $this->arrDisp['product_code'][$i].' / ';
[18097]198            if ($this->arrDisp['classcategory_name1'][$i]) {
[21826]199                $arrOrder[$i][0] .= ' [ '.$this->arrDisp['classcategory_name1'][$i];
[21514]200                if ($this->arrDisp['classcategory_name2'][$i] == '') {
201                    $arrOrder[$i][0] .= ' ]';
[18097]202                } else {
[21826]203                    $arrOrder[$i][0] .= ' * '.$this->arrDisp['classcategory_name2'][$i].' ]';
[18097]204                }
[17182]205            }
[18097]206            $arrOrder[$i][1]  = number_format($data[0]);
207            $arrOrder[$i][2]  = number_format($data[1]).$monetary_unit;
208            $arrOrder[$i][3]  = number_format($data[2]).$monetary_unit;
[17182]209
210        }
211
[21514]212        $arrOrder[$i][0] = '';
213        $arrOrder[$i][1] = '';
214        $arrOrder[$i][2] = '';
215        $arrOrder[$i][3] = '';
[17182]216
217        $i++;
[21514]218        $arrOrder[$i][0] = '';
219        $arrOrder[$i][1] = '';
[22100]220        $arrOrder[$i][2] = t('SC_Fpdf_005');
[17182]221        $arrOrder[$i][3] = number_format($this->arrDisp['subtotal']).$monetary_unit;
222
223        $i++;
[21514]224        $arrOrder[$i][0] = '';
225        $arrOrder[$i][1] = '';
[22100]226        $arrOrder[$i][2] = t('SC_Fpdf_006');
[17182]227        $arrOrder[$i][3] = number_format($this->arrDisp['deliv_fee']).$monetary_unit;
228
229        $i++;
[21514]230        $arrOrder[$i][0] = '';
231        $arrOrder[$i][1] = '';
[22100]232        $arrOrder[$i][2] = t('SC_Fpdf_007');
[17182]233        $arrOrder[$i][3] = number_format($this->arrDisp['charge']).$monetary_unit;
234
235        $i++;
[21514]236        $arrOrder[$i][0] = '';
237        $arrOrder[$i][1] = '';
[22100]238        $arrOrder[$i][2] = t('SC_Fpdf_008');
[21514]239        $arrOrder[$i][3] = '- '.number_format(($this->arrDisp['use_point'] * POINT_VALUE) + $this->arrDisp['discount']).$monetary_unit;
[17182]240
241        $i++;
[21514]242        $arrOrder[$i][0] = '';
243        $arrOrder[$i][1] = '';
[22100]244        $arrOrder[$i][2] = t('SC_Fpdf_009');
[17182]245        $arrOrder[$i][3] = number_format($this->arrDisp['payment_total']).$monetary_unit;
246
247        // ポイント表記
248        if ($this->arrData['disp_point'] && $this->arrDisp['customer_id']) {
[18097]249            $i++;
[21514]250            $arrOrder[$i][0] = '';
251            $arrOrder[$i][1] = '';
252            $arrOrder[$i][2] = '';
253            $arrOrder[$i][3] = '';
[17182]254
[18097]255            $i++;
[21514]256            $arrOrder[$i][0] = '';
257            $arrOrder[$i][1] = '';
[22100]258            $arrOrder[$i][2] = t('SC_Fpdf_010');
[18097]259            $arrOrder[$i][3] = number_format($this->arrDisp['use_point']).$point_unit;
[17182]260
[18097]261            $i++;
[21514]262            $arrOrder[$i][0] = '';
263            $arrOrder[$i][1] = '';
[22100]264            $arrOrder[$i][2] = t('SC_Fpdf_011');
[18097]265            $arrOrder[$i][3] = number_format($this->arrDisp['add_point']).$point_unit;
[17182]266        }
267
[21358]268        $this->FancyTable($this->label_cell, $arrOrder, $this->width_cell);
[17182]269    }
270
[22058]271    /**
272     * 備考の出力を行う
273     *
274     * @param string $str 入力文字列
275     * @return string 変更後の文字列
276     */
[17182]277    function setEtcData() {
[21358]278        $this->Cell(0, 10, '', 0, 1, 'C', 0, '');
279        $this->SetFont('Gothic', 'B', 9);
[22100]280        $this->MultiCell(0, 6, t('SC_Fpdf_012'), 'T', 2, 'L', 0, '');  //備考
[21358]281        $this->SetFont('SJIS', '', 8);
[22058]282        $text = SC_Utils_Ex::rtrim($this->arrData['etc1'] . "\n" . $this->arrData['etc2'] . "\n" . $this->arrData['etc3']);
283        $this->MultiCell(0, 4, $text, '', 2, 'L', 0, '');
[17182]284    }
285
286    function createPdf() {
287        // PDFをブラウザに送信
[18097]288        ob_clean();
289        if ($this->pdf_download == 1) {
[21358]290            if ($this->PageNo() == 1) {
[21515]291                $filename = 'nouhinsyo-No'.$this->arrData['order_id'].'.pdf';
[18097]292            } else {
[21514]293                $filename = 'nouhinsyo.pdf';
[18097]294            }
[21358]295            $this->Output($this->lfConvSjis($filename), 'D');
[17182]296        } else {
[21358]297            $this->Output();
[17182]298        }
299
300        // 入力してPDFファイルを閉じる
[21358]301        $this->Close();
[17182]302    }
303
304    // PDF_Japanese::Text へのパーサー
[21024]305    function lfText($x, $y, $text, $size = 0, $style = '') {
306        // 退避
[21358]307        $bak_font_style = $this->FontStyle;
308        $bak_font_size = $this->FontSizePt;
[17182]309
[21358]310        $this->SetFont('', $style, $size);
[21826]311        $this->Text($x, $y, $text);
[21024]312
313        // 復元
[21358]314        $this->SetFont('', $bak_font_style, $bak_font_size);
[17182]315    }
316
317    // 受注データの取得
318    function lfGetOrderData($order_id) {
[21441]319        if (SC_Utils_Ex::sfIsInt($order_id)) {
[17182]320            // DBから受注情報を読み込む
[21750]321            $objQuery =& SC_Query_Ex::getSingletonInstance();
[21514]322            $where = 'order_id = ?';
323            $arrRet = $objQuery->select('*', 'dtb_order', $where, array($order_id));
[17182]324            $this->arrDisp = $arrRet[0];
[19864]325            list($point) = SC_Helper_Customer_Ex::sfGetCustomerPoint($order_id, $arrRet[0]['use_point'], $arrRet[0]['add_point']);
[18097]326            $this->arrDisp['point'] = $point;
[17182]327
328            // 受注詳細データの取得
329            $arrRet = $this->lfGetOrderDetail($order_id);
330            $arrRet = SC_Utils_Ex::sfSwapArray($arrRet);
331            $this->arrDisp = array_merge($this->arrDisp, $arrRet);
332
333            // その他支払い情報を表示
[21684]334            if ($this->arrDisp['memo02'] != '') {
335                $this->arrDisp['payment_info'] = unserialize($this->arrDisp['memo02']);
336            }
[22100]337            $this->arrDisp['payment_type'] = t('SC_Fpdf_013');
[17182]338        }
339    }
340
341    // 受注詳細データの取得
342    function lfGetOrderDetail($order_id) {
[21750]343        $objQuery =& SC_Query_Ex::getSingletonInstance();
[21514]344        $col = 'product_id, product_class_id, product_code, product_name, classcategory_name1, classcategory_name2, price, quantity, point_rate';
345        $where = 'order_id = ?';
[21481]346        $objQuery->setOrder('order_detail_id');
347        $arrRet = $objQuery->select($col, 'dtb_order_detail', $where, array($order_id));
[18097]348        return $arrRet;
[17182]349    }
350}
Note: See TracBrowser for help on using the repository browser.