バージョン選択

フォーラム

メニュー

オンライン状況

46 人のユーザが現在オンラインです。 (38 人のユーザが フォーラム を参照しています。)
登録ユーザ: 0
ゲスト: 46
もっと...

PR

デザインテンプレート EC-CUBE3.0版が登場!
広告掲載について

サイト内検索

プラグイン > その他 > 3.0.11で帳票出力プラグインをカスタマイズしたい

その他

新規スレッドを追加する

スレッド表示 | 新しいものから 前のトピック | 次のトピック | 下へ
投稿者 スレッド
LocoLoco
投稿日時: 2017/2/25 19:02
対応状況: −−−
新米
登録日: 2017/2/24
居住地:
投稿: 2
3.0.11で帳票出力プラグインをカスタマイズしたい
こちらの参考URLのように3.0.11でもカスタマイズしたいのですが、
http://xn--pbku02iq0izkz.net/ec-cube/555/

OrderPdfService.phpをどのように変更すればいいのでしょうか?
現在OrderPdfService.phpはデフォルトの状態です。

プログラムに関しては全くの素人なので、できましたらそのままコピペすれば機能するようにご教授お願いしたいです。


上記URLに記載されているコードは以下の通りです。

<?php
require(DATA_REALDIR . 'module/fpdf/fpdf.php');
require(DATA_REALDIR . 'module/fpdi/japanese.php');
define('PDF_TEMPLATE_REALDIR', TEMPLATE_ADMIN_REALDIR . 'pdf/');

class SC_Fpdf {
function SC_Fpdf($download, $title, $tpl_pdf = 'nouhinsyo1.pdf') {
// デフォルトの設定
$this->tpl_pdf = PDF_TEMPLATE_REALDIR . $tpl_pdf; // テンプレートファイル
$this->pdf_download = $download; // PDFのダウンロード形式(0:表示、1:ダウンロード)
$this->tpl_title = $title;
$this->tpl_dispmode = 'real'; // 表示モード
$masterData = new SC_DB_MasterData_Ex();
$this->arrPref = $masterData->getMasterData('mtb_pref');
$this->width_cell = array(115.3,12,21.7,22.5);

$this->label_cell[] = $this->lfConvSjis("商品名 / 商品コード / [ 規格 ]");
$this->label_cell[] = $this->lfConvSjis("数量");
$this->label_cell[] = $this->lfConvSjis("単価");
$this->label_cell[] = $this->lfConvSjis("金額(税込)");

$this->arrMessage = array(
'このたびはお買上げいただきありがとうございます。',
'下記の内容にて納品させていただきます。',
'ご確認くださいますよう、お願いいたします。'
);

$this->pdf = new PDF_Japanese();

// SJISフォント
$this->pdf->AddSJISFont();
$this->pdf->SetFont('SJIS');

//ページ総数取得
$this->pdf->AliasNbPages();

// マージン設定
$this->pdf->SetMargins(15, 20);

// PDFを読み込んでページ数を取得
$pageno = $this->pdf->setSourceFile($this->tpl_pdf);
}

function setData($arrData) {
$this->arrData = $arrData;

// ページ番号よりIDを取得
$tplidx = $this->pdf->ImportPage(1);

// ページを追加(新規)
$this->pdf->AddPage();

//表示倍率(100%)
$this->pdf->SetDisplayMode($this->tpl_dispmode);

if (SC_Utils_Ex::sfIsInt($arrData['order_id'])) {
$this->disp_mode = true;
$order_id = $arrData['order_id'];
}

// テンプレート内容の位置、幅を調整 ※useTemplateに引数を与えなければ100%表示がデフォルト
$this->pdf->useTemplate($tplidx);

$this->setShopData();
$this->setMessageData();
$this->setOrderData();
$this->setEtcData();

}

function setShopData() {
// ショップ情報

$objDb = new SC_Helper_DB_Ex();
$arrInfo = $objDb->sfGetBasisData();

$this->lfText(125, 15, $arrInfo['shop_name'], 8, 'B'); //ショップ名
$this->lfText(125, 18, $arrInfo['law_url'], 8); //URL
$this->lfText(125, 23, $arrInfo['law_company'], 8); //会社名
$text = "〒 ".$arrInfo['law_zip01']." - ".$arrInfo['law_zip02'];
$this->lfText(125, 26, $text, 8); //郵便番号
$text = $this->arrPref[$arrInfo['law_pref']].$arrInfo['law_addr01'];
$this->lfText(125, 29, $text, 8); //都道府県+住所1
$this->lfText(125, 32, $arrInfo['law_addr02'], 8); //住所2

$text = "TEL: ".$arrInfo['law_tel01']."-".$arrInfo['law_tel02']."-".$arrInfo['law_tel03'];
//FAX番号が存在する場合、表示する
if (strlen($arrInfo['law_fax01']) > 0) {
$text .= " FAX: ".$arrInfo['law_fax01']."-".$arrInfo['law_fax02']."-".$arrInfo['law_fax03'];
}
$this->lfText(125, 36, $text, 8); //TEL・FAX

if ( strlen($arrInfo['law_email']) > 0 ) {
$text = "Email: ".$arrInfo['law_email'];
$this->lfText(125, 39, $text, 8); //Email
}

//ロゴ画像
// $logo_file = PDF_TEMPLATE_REALDIR . 'logo.png';
// $this->pdf->Image($logo_file, 124, 46, 40);
}

function setMessageData() {
// メッセージ
$this->lfText(23, 35, $this->arrData['msg1'], 9); //メッセージ1
$this->lfText(23, 39, $this->arrData['msg2'], 9); //メッセージ2
$this->lfText(23, 43, $this->arrData['msg3'], 9); //メッセージ3
$text = "作成日: ".$this->arrData['year']."年".$this->arrData['month']."月".$this->arrData['day']."日";
$this->lfText(130, 288, $text, 8); //作成日
}

function setOrderData() {
// DBから受注情報を読み込む
$this->lfGetOrderData($this->arrData['order_id']);

//納品書タイトル
$this->pdf->SetFont('', 'B', 10);
$this->pdf->Cell(0, -15, $this->lfConvSjis($this->tpl_title), 0, 2, 'a', 0, ''); //文書タイトル(納品書・請求書)
$this->pdf->Cell(0, 45, '', 0, 2, 'R', 0, '');
$this->pdf->Cell(5, 0, '', 0, 0, 'R', 0, '');


// 購入者情報
$text = $this->arrDisp['order_kana01']." ".$this->arrDisp['order_kana02'];
$this->lfText(18, 20, $text, 8); //購入者フリガナ(会社名)
$text = $this->arrDisp['order_name01']." ".$this->arrDisp['order_name02']." 様";
$this->lfText(18, 25, $text, 10); //購入者氏名



// お届け先情報
$this->pdf->SetFontSize(10);
// $this->lfText(25, 94, SC_Utils_Ex::sfDispDBDate($this->arrDisp['create_date']), 10); //ご注文日
// $this->lfText(25, 135, $this->arrDisp['order_id'], 10); //注文番号

// 届先情報 <ここから>
$objShip = new SC_Helper_Purchase_Ex();
$this->arrShip = $objShip->getShippings($this->arrDisp['order_id']);

$y = 76; // お届け先開始y軸位置

$count = count($this->arrShip);
$i = 0; // 配列のindex
$j = 0; // 届け先取り出し数

do {
if ($j == $count) {
break;
}
if ($this->arrShip[$i]['shipping_id'] != "") {
$y += $j * 4 * 3; // 届け先 * 高さ * 要素数


$y += 4;
$text = "〒". $this->arrShip[$i]['shipping_zip01']. "-" . $this->arrShip[$i]['shipping_zip02'];
$this->lfText(20, $y, $text, 9);


$y += 4;
$text = $this->arrShip[$i]['shipping_addr01'].$this->arrShip[$i]['shipping_addr02'];
$this->lfText(20, $y, $text, 9);

$y += 4;
$text = "TEL:" . $this->arrShip[$i]['shipping_tel01']. "-" . $this->arrShip[$i]['shipping_tel02']. "-" . $this->arrShip[$i]['shipping_tel03'];
$this->lfText(20, $y+1, $text, 11);

$y += 4;
$text = $this->arrShip[$i]['shipping_name01']. " " .$this->arrShip[$i]['shipping_name02'] . " 様";
$this->lfText(20, $y+2, $text, 9);

$y += 4;
$text = "【お届け時間】:".$this->arrShip[$i]['shipping_time'] ." " .substr($this->arrShip[$i]["shipping_date"],5,2) . "/" . substr($this->arrShip[$i]["shipping_date"],8,2);
$this->lfText(130, 90, $text, 9);


$j += 1;
}

$i += 1;
} while (true);
// <ここまで>

$text = "【ご注文日】:".SC_Utils_Ex::sfDispDBDate($this->arrDisp['create_date']);
$this->lfText(130, 75, $text, 9); //ご注文日

$text = "【注文番号】:".$this->arrDisp['order_id'];
$this->lfText(130, 80, $text, 9); //注文番号

$text = "【支払方法】:".$this->arrDisp['payment_method'];
$this->lfText(130, 85, $text, 9); //お支払方法

$text = "【お客様のご要望】:".$this->arrDisp['message'];
$size=65;
for($i=0;$i<=mb_strlen($text,"utf-8")/$size;$i++){$result=mb_substr($text,$i*$size,$size,"utf-8")."\r\n";
$this->lfText(15, 100+($i*3), $result, 8);
}
$text =$this->arrDisp['note'];
$size=65;
for($i=0;$i<=mb_strlen($text,"utf-8")/$size;$i++){$result=mb_substr($text,$i*$size,$size,"utf-8")."\r\n";
$this->lfText(15, 106+($i*3), $result, 8);
}



$this->pdf->SetFont('', 'B', 15);
$this->pdf->Cell(60, 10, $this->lfConvSjis(number_format($this->arrDisp['payment_total'])." 円"), 0, 2, 'R', 0, '');//総合金額
$this->pdf->Cell(0, 50, '', 0, 2, '', 0, ''); //商品ブロックの位置情報

$this->pdf->SetFontSize(8);

$monetary_unit = $this->lfConvSjis("円");
$point_unit = $this->lfConvSjis('Pt');
$kosu = 0;


// 購入商品情報
for ($i = 0; $i < count($this->arrDisp['quantity']); $i++) {

// 購入数量
$data[0] = $this->arrDisp['quantity'][$i];
$kosu = $kosu+$this->arrDisp['quantity'][$i];

// 税込金額(単価)
$data[1] = SC_Helper_DB_Ex::sfCalcIncTax($this->arrDisp['price'][$i]);

// 小計(商品毎)
$data[2] = $data[0] * $data[1];

$arrOrder[$i][0] = $this->lfConvSjis($this->arrDisp['product_name'][$i]." / ");
if ($this->arrDisp['classcategory_name1'][$i]) {
$arrOrder[$i][0] .= $this->lfConvSjis(" [ ".$this->arrDisp['classcategory_name1'][$i]);
if ($this->arrDisp['classcategory_name2'][$i] == "") {
$arrOrder[$i][0] .= " ]";
} else {
$arrOrder[$i][0] .= $this->lfConvSjis(" * ".$this->arrDisp['classcategory_name2'][$i]." ]");
}
}
$arrOrder[$i][1] = number_format($data[0]);
$arrOrder[$i][2] = number_format($data[1]).$monetary_unit;
$arrOrder[$i][3] = number_format($data[2]).$monetary_unit;

}

$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = "";
$arrOrder[$i][3] = "";

$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = $kosu;
$arrOrder[$i][2] = $this->lfConvSjis("商品合計");
$arrOrder[$i][3] = number_format($this->arrDisp['subtotal']).$monetary_unit;

$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = $this->lfConvSjis("送料");
$arrOrder[$i][3] = number_format($this->arrDisp['deliv_fee']).$monetary_unit;

$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = $this->lfConvSjis("手数料");
$arrOrder[$i][3] = number_format($this->arrDisp['charge']).$monetary_unit;

$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = $this->lfConvSjis("値引き");
$arrOrder[$i][3] = "- ".number_format(($this->arrDisp['use_point'] * POINT_VALUE) + $this->arrDisp['discount']).$monetary_unit;

$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = $this->lfConvSjis("請求金額");
$arrOrder[$i][3] = number_format($this->arrDisp['payment_total']).$monetary_unit;

// ポイント表記
if ($this->arrData['disp_point'] && $this->arrDisp['customer_id']) {
$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = "";
$arrOrder[$i][3] = "";

$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = $this->lfConvSjis("利用ポイント");
$arrOrder[$i][3] = number_format($this->arrDisp['use_point']).$point_unit;

$i++;
$arrOrder[$i][0] = "";
$arrOrder[$i][1] = "";
$arrOrder[$i][2] = $this->lfConvSjis("加算ポイント");
$arrOrder[$i][3] = number_format($this->arrDisp['add_point']).$point_unit;
}

$this->pdf->FancyTable($this->label_cell, $arrOrder, $this->width_cell);
}

function setEtcData() {
/* $this->pdf->Cell(0, 10, '', 0, 1, 'C', 0, '');
$this->pdf->SetFontSize(9);
$this->pdf->MultiCell(0, 6, $this->lfConvSjis("< 備 考 >"), 'T', 2, 'L', 0, ''); //備考
$this->pdf->Ln();
$this->pdf->SetFontSize(8);
$this->pdf->MultiCell(0, 4, $this->lfConvSjis($this->arrData['etc1']."\n".$this->arrData['etc2']."\n".$this->arrData['etc3']), '', 2, 'L', 0, ''); //備考*/
}

function createPdf() {
// PDFをブラウザに送信
ob_clean();
if ($this->pdf_download == 1) {
if ($this->pdf->PageNo() == 1) {
$filename = "nouhinsyo-No".$this->arrData['order_id'].".pdf";
} else {
$filename = "nouhinsyo.pdf";
}
$this->pdf->Output($this->lfConvSjis($filename), 'D');
} else {
$this->pdf->Output();
}

// 入力してPDFファイルを閉じる
$this->pdf->Close();
}

// PDF_Japanese::Text へのパーサー
function lfText($x, $y, $text, $size = 0, $style = '') {
// 退避
$bak_font_style = $this->pdf->FontStyle;
$bak_font_size = $this->pdf->FontSizePt;

$this->pdf->SetFont('', $style, $size);
$this->pdf->Text($x, $y, $this->lfConvSjis($text));

// 復元
$this->pdf->SetFont('', $bak_font_style, $bak_font_size);
}

// 受注データの取得
function lfGetOrderData($order_id) {
if(SC_Utils_Ex::sfIsInt($order_id)) {
// DBから受注情報を読み込む
$objQuery = new SC_Query_Ex();
$where = "order_id = ?";
$arrRet = $objQuery->select("*", "dtb_order", $where, array($order_id));
$this->arrDisp = $arrRet[0];
list($point) = SC_Helper_Customer_Ex::sfGetCustomerPoint($order_id, $arrRet[0]['use_point'], $arrRet[0]['add_point']);
$this->arrDisp['point'] = $point;

// 受注詳細データの取得
$arrRet = $this->lfGetOrderDetail($order_id);
$arrRet = SC_Utils_Ex::sfSwapArray($arrRet);
$this->arrDisp = array_merge($this->arrDisp, $arrRet);

// その他支払い情報を表示
if($this->arrDisp["memo02"] != "") $this->arrDisp["payment_info"] = unserialize($this->arrDisp["memo02"]);
$this->arrDisp["payment_type"] = "お支払い";
}
}

// 受注詳細データの取得
function lfGetOrderDetail($order_id) {
$objQuery = new SC_Query_Ex();
$col = "product_id, product_class_id, product_code, product_name, classcategory_name1, classcategory_name2, price, quantity, point_rate";
$where = "order_id = ?";
$objQuery->setOrder("order_detail_id");
$arrRet = $objQuery->select($col, "dtb_order_detail", $where, array($order_id));
return $arrRet;
}

// 文字コードSJIS変換 -> japanese.phpで使用出来る文字コードはSJIS-winのみ
function lfConvSjis($conv_str) {
return mb_convert_encoding($conv_str, "SJIS-win", CHAR_CODE);
}

}
?>
aoki.u
投稿日時: 2017/2/25 19:55
対応状況: −−−
常連
登録日: 2017/2/19
居住地:
投稿: 52
Re: 3.0.11で帳票出力プラグインをカスタマイズしたい
OrderPdfService.phpを覗くと

$this->lfText(25, 125, $orderDate , 10);のようなコードがたくさんありますよね。

lfTextメソッドを見ればわかるように、第1引数がエックス座標、第2引数がワイ座標ですので、これを1つ1つ調整していくしかないです。


----------------
ECCUBE3系のインテグレートパートナーとして
カスタマイズやプラグイン開発に専念しています。
ぜひご相談ください。

yuh
投稿日時: 2017/2/26 1:23
対応状況: −−−
登録日: 2013/1/9
居住地: 大阪
投稿: 1347
Re: 3.0.11で帳票出力プラグインをカスタマイズしたい
出したい帳票のイメージがあると思うので、それを元にインテグレートパートナーに調整の依頼を出した方がよろしいかと思います。


----------------
ec-cube2系の速度UPしてみました。(商品数:100万件)
http://speedtest2.ec-lab.net/products/list.php?category_id=15
ec-cube2系最速!(自称)

LocoLoco
投稿日時: 2017/2/26 19:42
対応状況: −−−
新米
登録日: 2017/2/24
居住地:
投稿: 2
Re: 3.0.11で帳票出力プラグインをカスタマイズしたい
yuh様

お返事ありがとうございます。

大幅に変えたい場合はインテグレートパートナーに依頼したほうがよさそうですね。

まず以下のコードだけでも把握したいのでご教授願えませんでしょうか。

 ・購入者電話番号
 ・選択された配送希望日時
 ・選択された決済手段

とりあえずこの3つを拾えるようになれば大丈夫です。
どうぞよろしくお願い致します。
スレッド表示 | 新しいものから 前のトピック | 次のトピック | トップ

 



ログイン


EC-CUBEペイメント

統計情報

総メンバー数は19,528名です
総投稿数は81,841件です

投稿数ランキング

1
seasoft
7331
2
AMUAMU
2712
3
nanasess
1623
4
yuh
1347
5
red
1057
6
fukap
907
7
shutta
827
8 ramrun 789
9
tsuji
782
10
umebius
671
11
tao_s
646
12 sumida 638
13
homan
633
14 karin 609
15
468
579
16 DELIGHT 571
17
patapata
502
18
flealog
483
19 tonton 436
20
ecbg
387


ネットショップの壺

EC-CUBEガイドブック
Copyright© LOCKON CO.,LTD. All Rights Reserved.