0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

rex0220 印刷屋プラグイン

Last updated at Posted at 2025-02-24

「印刷屋プラグイン」は、HTMLやCSSで作成した帳票をPDFファイルとして生成できるプラグインです。
レコードの詳細画面や一覧画面からスムーズに帳票を作成し、PDFの保存・ダウンロードが可能です。

概要

見積書や請求書、レコード一覧などを PDF ファイルに作成するプラグインです。
HTMLとCSSを活用し、柔軟な帳票レイアウトを実現します。
ノーコードとは真逆のコードだらけのプラグインです。

主な機能
・ 個別帳票の作成(レコード詳細画面から1件ずつPDFを生成)
・ 個別帳票の一括処理(一覧画面で複数レコードをまとめて処理)
・ 複数レコードを1つの帳票に統合(一覧画面で選択したデータを1つのPDFにまとめる)
・ ボタンの表示条件設定(特定の条件で帳票作成ボタンの表示を制御)
・ 画像ファイルの表示(帳票内に画像を挿入可能)
・ QRコードの表示(URLや文字列をQRコードに変換して表示)
・ kintone グラフの埋め込み用タグ対応(帳票内に画像へ変換して表示)
・ PDFの保存・ダウンロード(PDFを添付ファイル項目に保存、または直接ダウンロード)
・ PDF作成時のレコード更新(PDF生成時に特定のレコード項目を自動更新)

※注意事項
印刷屋プラグインは、PCのブラウザー上で PDF ファイルを作成するため、PC環境(OS、ブラウザー、フォント等)により作成される PDF に影響があります。

印刷屋プラグインの使用例

今後追加する予定

帳票作成例

2025-02-25_00h46_57.png

2025-02-27_00h10_20.png

2025-03-05_10h52_56.png

2025-02-25_00h47_13.png

2025-02-27_13h00_18.png

2025-02-25_01h50_47.png

  • カード形式の作成例

2025-02-25_01h54_49.png

  • 複数レコードをまとめた作成例

2025-02-25_01h48_35.png

2025-02-27_21h16_24.png

2025-02-28_00h06_37.png

2025-02-28_08h54_23.png

2025-02-28_11h39_20.png

2025-02-28_20h43_18.png

2025-03-01_11h49_24.png

2025-03-01_14h21_45.png

PDF 作成手順

添付ファイルに PDF を保存する設定での手順です。

詳細画面

  • PDF 作成手順
    • 詳細画面で、「見積書」ボタンクリック
    • 見積書プレビュー画面で確認し、「見積書」ボタンクリック
    • 添付ファイル項目(見積書ファイル)に PDF が保存される
      • プラグイン設定により、レコードに保存かダウンロードを指定
    • 詳細画面で、見積書ファイルの PDF ファイルをダウンロードし確認

2025-02-25_00h51_09.png

一覧画面

  • PDF 作成手順
    • 一覧画面で、対象レコードを選択して「見積書」ボタンクリック
    • ダイアログでレコード数を確認し、「実行」ボタンクリック
    • 添付ファイル項目(見積書ファイル)に PDF が保存される

2025-02-25_01h03_24.png

印刷屋プラグインの PDF 作成のしくみ

  • HTML, CSS, 計算処理で作成された帳票をブラウザー上に表示
  • ブラウザー上の帳票を画像として取得
  • PDF に、画像として帳票を追加
  • PDF ファイルとして、レコードの添付ファイルに追加、またはダウンロード

※PDFの帳票は画像として設定されるため、テキスト情報は PDF にありません。

印刷屋プラグイン設定

  • プラグイン有効
  • 行制御
  • 多言語
  • 画面
    • ボタンを表示する詳細画面、一覧画面を指定
  • レコード選択
    • 一覧画面でレコード選択を指定
  • メニュー: ボタンをメニュー形式で表示
    • メニューボタンを有効にする
  • メニューボタン: メニューに表示する名称を設定
  • 共通CSS: 帳票に共通CSSを適用する
  • 共通CSS: 共通CSSの設定
  • ゲスト: ゲストスペースで、ゲストユーザーを定義
  • ボタン名: 帳票作成のボタン名
  • 概要: 帳票作成時のダイアログで表示
  • 備考: メモ用
  • 一覧: 一覧画面のレコードを対象にして、帳票を作成
  • HTML: 帳票の HTML, CSS を設定
  • 更新項目: 帳票作成時に更新する項目を指定

2025-02-25_01h11_25.png

メニュー

メニュー欄をチェックしたボタンがまとめて表示されます。
帳票の種類が多いときに、ご利用ください。

2025-02-25_09h43_19.png

2025-02-25_09h38_51.png

共通CSS

汎用的に使うCSS を設定します。
table, card, common, invoice が設定されます。
よく使うクラスを追加設定できます。
同じクラス名の属性を定義した場合、あとから設定された方が有効。
ただし、!important を指定した場合は、そちらが優先される。

編集エリアが小さいので、CSS の編集はエディターを使って、コピペをお勧めします。

  • 初期化: 既定の共通CSSに戻す
  • NAME: 名称
  • DESC: メモ用
  • CSS: CSS
    • table: 表形式
    • card: カード形式
    • common: 右寄せなどの汎用的なクラス
    • invoice: 請求書等のクラス

2025-02-25_01h41_53.png

HTML

帳票を作成する HTML, CSS と 計算式を設定します。
編集エリアが小さいので、編集はエディターを使って、コピペをお勧めします。

  • ページサイズ: A1-A5, B1-B5, Letter, Legal, Tabloid
  • 向き: 縦・横
  • 解像度: 96 dpi / 150 dpi
  • ファイル: PDF を保存する添付ファイル項目を指定。指定が無ければダウンロード
    • 同一レコードで、同じ帳票を作成すると添付ファイル項目にPDFファイルを追加
    • テーブル内添付ファイル項目を指定した場合
      • 添付ファイルが無い最終行にPDFファイルを追加
      • 最終行に添付ファイルがある場合は、テーブル行を追加してPDFファイルを追加
  • 設定名: 識別用
  • 備考: メモ用
  • CSS: 帳票に適用するCSS
    • 帳票には、共通CSSと帳票別に設定されたCSSを適用
  • HTML: 帳票に適用するHTMLテンプレート
  • 計算式: 帳票に適用する計算式
    • ボタン表示条件: 
    • ファイル名: PDFのファイル名

2025-02-25_01h22_30.png

更新項目

PDF 作成時に更新する項目を指定します。

  • 備考: メモ用
  • 計算式: 更新内容を指定

2025-02-25_01h31_51.png

ページの考え方

class="rex0220-pcraft-page"で、囲まれた部分を1ページとして扱います。
class="rex0220-pcraft-page"を増やすと、ページを追加できます。
ページ内で、いろいろタグを指定して、帳票を組み立てます。
計算式のループ処理で、ページ数を増やすこともできます。

※class="rex0220-pcraft-page"からはみ出した部分は、PDF化の対象外になります。

1ページ.html
<div class="rex0220-pcraft-page">
Hello world
</div>
  • A5横サイズの設定

2025-02-25_11h00_20.png

  • 2ページの設定例
2ページ.html
<div class="rex0220-pcraft-page">
Hello world(1page)
</div>
<div class="rex0220-pcraft-page">
Hello world(2page)
</div>

2025-02-25_11h03_20.png

  • style 指定例
.html
<div class="rex0220-pcraft-page">
  <span style="color:red; font-size:32px;">Hello world</span>
</div>

2025-02-25_11h12_49.png

  • class 指定例
.css
.custom-blue {
  color: blue;
  font-size: 64px;
}
.html
<div class="rex0220-pcraft-page">
  <span class="custom-blue">Hello world</span>
</div>

2025-02-25_11h20_08.png

  • 計算式のループ処理による複数ページ

"A-PAGE","B-PAGE","C-PAGE"のページをARRAY_MAP関数のループ処理で作成

.js
TAGS_HTML(
  ARRAY_MAP(ARRAY("A-PAGE","B-PAGE","C-PAGE"),xx,
    PAGE_HTML(
       TAG("div", xx)
    )
  )
)

※参考 rex0220 印刷屋プラグイン ループ処理で複数ページを生成

生成される html

.html
<div class="rex0220-pcraft-page">
    <div>A-PAGE</div>
</div>
<div class="rex0220-pcraft-page">
    <div>B-PAGE</div>
</div>
<div class="rex0220-pcraft-page">
    <div>C-PAGE</div>
</div>

2025-02-25_18h19_56.png

複数設定の結合

複数ページを別々に設定して、結合することが出来ます。
なお CSS は、個別に設定しても複数ページ全体に適用されます・

2025-02-26_00h57_24.png

ページ番号・ページ数

ページ番号・ページ数は、#{&p/&n} で指定できます。
"rex0220-pcraft-page"クラスでページをカウントして、#{}で囲まれた &p をページ番号、&n をページ数に置き換えます。

.html
<div class="rex0220-pcraft-page">
    <div class="custom-blue">
        Hello world (page #{&p/&n})
    </div>
    <div>TEST1</div>
</div>
<div class="rex0220-pcraft-page">
    <div class="custom-blue">
        Hello world (page #{&p/&n})
    </div>
    <div>TEST2</div>
</div>

2025-02-26_00h45_02.png

画像ファイルの表示(fileKey 指定)

html に #{&f(nnnn...) で、添付ファイルの fileKey を指定することで、画像を表示できます。
帳票に合わせて、width 等で大きさを指定します。
他のアプリの添付ファイルも fileKey を指定することで表示できます。

<img src="#{&f(nnnn...)}>

2025-02-26_09h01_33.png

.css
.custom-blue {
  color: blue;
  font-size: 32px;
}
.custom-image {
  width:300px;
}
.html
<div class="rex0220-pcraft-page">
    <div class="custom-blue">添付ファイルの画像</div>
    <img class="custom-image" src="#{&f(20250225231826FA160C409E7046218B41929C02088738177)}">
</div>
  • 画像を読み込めない時の表示

間違った添付ファイルの fileKey を指定したり、読み込めない場合は、下記のような画像を表示します。
※ゲストスペース内アプリで、ゲストスペース外アプリの添付ファイルは、読み込めません。

2025-02-26_09h18_25.png

.js
<div class="rex0220-pcraft-page">
    <div class="custom-blue">ゲストスペース内 添付ファイルの画像</div>
    <img class="custom-image" src="#{&f(20250225231826FA160C409E7046218B41929C02088738177)}">
    <div class="custom-blue">ゲストスペース外 添付ファイルの画像</div>
    <img class="custom-image" src="#{&f(2025012113294151BDBB6048DF4A7985DCE6C4709DD326217)}">
</div>

fileKey の確認方法

計算式プラグインの計算式ツールで、添付ファイルを指定して実行すると、実行結果欄に表示されます。

  • 添付ファイル 指定

2025-02-26_09h35_34.png

  • IMGSRC(添付ファイル) 指定

IMGSRC 関数を利用すると、#{&f(nnnn...) 形式で表示されます。

2025-02-26_09h43_34.png

画像ファイルの表示(IMGSRC 関数指定)

レコード内の画像ファイルを、IMGSRC 関数で指定できます。

  • IMGSRC(fieldcode[,pos])
    画像表示用に添付ファイルの fileKey を返す
    • fieldcode: 添付ファイル
    • pos: 画像位置(-1は、最終画像)
      • pos を指定しない場合は、最初の画像ファイルの fileKey を取得

2025-02-26_09h50_28.png

.html
<div class="rex0220-pcraft-page">
    <div class="custom-blue">添付ファイルの画像 IMGSRC 関数版</div>
    <img class="custom-image" src="${IMGSRC(添付ファイル)}">
</div>

画像ファイルの表示(BASE64形式版)

社印等で小さな画像ファイルであれば、BASE64形式に変換して、HTML に直接指定することが出来ます。
※プラグイン設定の最大容量が、256KB なので、それを超えるような指定はできません。
※BASE64 :バイナリデータ(画像や音声など)を文字列(テキストデータ)に変換するエンコード方式 です。

2025-02-26_10h28_23.png

.html
<div class="rex0220-pcraft-page">
    <div class="custom-blue">画像 BASE64 版</div>
    <img class="custom-image" src="">
</div>

QRコードの表示

#{&q()} で、囲んだテキストを QRコード画像に変換します。
img タグの src に指定すると、QRコードのイメージになります。

<img src="#{&q(abc)"}>

名称を google 検索する URL の例

ARRAY("QR", "<img src='#{&q(" & URL("https","www.google.com/search?q="&名称) & ")}'>", "value-image")

kintone グラフ埋め込みタグ対応

HTML 内にグラフ埋め込みタグ対応(iframe) があれば、iframe 表示を待って、画像化してHTML内に追加します。
CSS の指定は、普通の img タグへの適用でOKです。

2025-02-26_17h59_48.png

.pcraft-graph-title {
  font-size:32px;
}
.pcraft-graph1 img {
  width: 50%;
}
.pcraft-graph2 img {
  width: 100%;
}
<div class="rex0220-pcraft-page">
    <div class="pcraft-graph-title">グラフテスト</div>
    <div class="pcraft-graph1">
        <iframe width="800" height="600" frameborder="0"
            src="https://xxxxxxx.cybozu.com/k/guest/15/1688/report/portlet?report=11251214&amp;chartType=pie&amp;title=1"></iframe>
    </div>

    <div class="pcraft-graph2">
        <iframe width="800" height="600" frameborder="0"
            src="https://xxxxxxx.cybozu.com/k/guest/15/1688/report/portlet?report=11251220&amp;chartType=column&amp;stackType=clustered&amp;title=1"></iframe>
    </div>
</div>

プレビュー画面・PDF化の処理概要

PDF化のしくみを知っていると、問題発生時に対応しやすくなります。

  • CSS : 共通CSSと個別CSSを合わせて、HTMLの HEAD 部に追加
    • ID="rex0220-pcraft-page-style"
    • PDF作成・キャンセル後に追加した CSS は削除
  • HTML: 
    • HTML 指定の計算式部分"${}"を実行
    • 計算式指定を実行
      • HTMLで指定された部分は、$html の変数に文字列として設定されるので、それに対して文字列変更や追加を行う
      • HTML 指定が無い場合は、HTML全体を関数で生成する
    • #{} で、指定されたページ・画像指定を変換
      • ID="rex0220-pcraft-page-style"で囲まれた部分をページ単位として処理
        • #{&p/&n}: ページ番号、ページ数として変換
        • #{&f(nnn...)): nnnn... の部分を fileKey として、ファイル取得し、BASE64変換して img タグの src に設定
    • html 内に iframe があれば、iframe の表示を待って画像化
  • PDF:
    • プレビュー画面で表示されている"rex0220-pcraft-page"をページ単位として取得し画像化
    • PDF にページとして、各画像を追加
    • 作成した PDF を設定により、レコードに反映またはダウンロード

見積書の設定例

帳票の設定方法としては、「HTML+計算式で設定」と「計算式のみで設定」があります。
HTMLについては、HTML テンプレートという扱いになります。
ただし、表形式のように行数が不定な場合は、計算式で生成します。

「HTML+計算式で設定」と「計算式のみで設定」は、とりあえず試行錯誤して扱いやすい方を選んでください。

CSSは、共通CSSの"pcraft-inv-header"を利用しており、個別のCSSはありません。
文字の大きさや背景色の変更等が必要な場合は、個別CSSを設定してください。

全体の構成や社印の位置指定などについては、下記をご覧ください。
参考:rex0220 印刷屋プラグイン 見積書の HTML,CSS について

HTML+計算式で設定

見積のヘッダー部とフッター部はHTML。明細行は、計算式で生成という組み合わせ

2025-02-25_09h59_23.png

\${宛名}のように、\${}で囲まれた部分は、計算式として処理されます。

  • ${宛名}:「宛名」の値に置換
  • ${FVAL(合計金額)}: 「合計金額」をFVAL 関数で、「¥」付きのカンマ区切りで表示
    • 「¥」付きやカンマ区切りは、項目の設定に従う
  • ${DATE_FORMAT(見積有効期限,"YYYY年M月D日")}: "YYYY年M月D日"形式で見積有効期限を表示
  • <img class="pcraft-inv-seal" : 社印イメージは、データ(data:image)で指定
    • kintone の添付ファイル項目の画像を指定することも可能
      • #{&f(nnnn...)}: nnnn... は、ファイルキー(fileFey)
  • ##table##: 計算式で表形式に置換するため識別するため"##table##"とする
    • html,REPLACE(html, "##table##", table)
  • ##備考##: 文字列複数行は、brタグに変換して改行させるが、HTMLテンプレート内で変換するとタグがエスケープされて"<br>"が表示されるため、計算式側で変換させる
    • html,REPLACE(html, "##備考##", FVAL(備考))
.html
<div class="rex0220-pcraft-page">
    <div class="pcraft-inv-header">見積書</div>
    <div class="pcraft-inv-info">
        <div class="pcraft-inv-left">
            <p>${宛名} 御中</p><br>
            <p class="pcraft-inv-estimate-amount">見積金額:<span>${FVAL(合計金額)}</span></p>
            <p class="pcraft-inv-validity">見積の有効期限: ${DATE_FORMAT(見積有効期限,"YYYY年M月D日")}</p>
        </div>
        <div class="pcraft-inv-right">
            <p>見積書番号: ${見積番号}</p>
            <p>発行日: ${DATE_FORMAT(見積日,"YYYY年M月D日")}</p>
            <p>株式会社サンプルサンプルサンプル</p>
            <p>開発 太郎</p>
            <img class="pcraft-inv-seal"  width="250" height="120" src="data:image/svg+xml;charset=utf8,%20%3Csvg%20class%3D%22pcraft-inv-seal%22%20width%3D%22250%22%20height%3D%22120%22%20viewBox%3D%220%200%20250%20120%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%20%3Crect%20x%3D%2210%22%20y%3D%2210%22%20width%3D%22230%22%20height%3D%22100%22%20rx%3D%2220%22%20ry%3D%2220%22%20stroke%3D%22red%22%20stroke-width%3D%225%22%20fill%3D%22none%22%2F%3E%20%3Ctext%20x%3D%22125%22%20y%3D%2250%22%20font-family%3D%22Arial%2C%20sans-serif%22%20font-size%3D%2234%22%20font-weight%3D%22bold%22%20text-anchor%3D%22middle%22%20fill%3D%22red%22%3E%E6%A0%AA%E5%BC%8F%E4%BC%9A%E7%A4%BE%3C%2Ftext%3E%20%3Ctext%20x%3D%22125%22%20y%3D%2290%22%20font-family%3D%22Arial%2C%20sans-serif%22%20font-size%3D%2234%22%20font-weight%3D%22bold%22%20text-anchor%3D%22middle%22%20fill%3D%22red%22%3E%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%3C%2Ftext%3E%20%3C%2Fsvg%3E">
        </div>
    </div>
    ##table##
    <div class="pcraft-inv-summary-section">
        <div class="pcraft-inv-remarks-section">
            <strong>備考:</strong><br>
            <span>##備考##</span>
        </div>
        <div class="pcraft-inv-total-section">
            <table>
                <tr>
                    <th>小計</th>
                    <td>${FVAL(小計金額)}</td>
                </tr>
                <tr>
                    <th>消費税 (10%)</th>
                    <td>${FVAL(消費税)}</td>
                </tr>
                <tr>
                    <th><strong>合計</strong></th>
                    <td><strong>${FVAL(合計金額)}</strong></td>
                </tr>
            </table>
        </div>
    </div>
</div>

HTMLで指定された内容は、「$html」という変数に設定されるので、それを文字列として必要な変換を行います。
※REPLACE 関数で置換している例

テーブルの生成.js
LET(
  table, TABLE_HTML(見積明細,
    OPT("pref","pcraft-inv-item-"),
    ARRAY("#",ROWNO(見積明細)+1),
    商品名,数量,単価,金額
  ),
  html,$html,
  html,REPLACE(html, "##table##", table),
  html,REPLACE(html, "##備考##",  FVAL(備考)),
  html
)

計算式のみで設定

「HTML+計算式で設定」と同じ内容を計算式で指定した例です。
結果的に、同じ構造を持つ html を生成します。

2025-02-25_10h01_30.png

.js
PAGE_HTML(
  TAG("div", ATTR("class", "pcraft-inv-header"), "見積書"),

  TAG("div", ATTR("class", "pcraft-inv-info"),

    // header left
    TAG("div", ATTR("class", "pcraft-inv-left"),
      TAG("p", 宛名 & " 御中"), VTAG("br"),
      TAG("p", ATTR("class", "pcraft-inv-estimate-amount"), "見積金額:", TAG("span", FVAL(合計金額))),
      TAG("p", ATTR("class", "pcraft-inv-validity"),
        "見積の有効期限: " & DATE_FORMAT(見積有効期限, "YYYY年M月D日")
      )
    ),

    // header right
    TAG("div", ATTR("class", "pcraft-inv-right"),
      TAG("p", "見積書番号: " & 見積番号),
      TAG("p", "発行日: " & DATE_FORMAT(見積日, "YYYY年M月D日")),
      TAG("p", "株式会社サンプルサンプルサンプル"),
      TAG("p", "開発 太郎"),
      VTAG("img", ATTR("class", "pcraft-inv-seal", "width", "250", "height", "120", "src", "data:image/svg+xml;charset=utf8,%20%3Csvg%20class%3D%22pcraft-inv-seal%22%20width%3D%22250%22%20height%3D%22120%22%20viewBox%3D%220%200%20250%20120%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%20%3Crect%20x%3D%2210%22%20y%3D%2210%22%20width%3D%22230%22%20height%3D%22100%22%20rx%3D%2220%22%20ry%3D%2220%22%20stroke%3D%22red%22%20stroke-width%3D%225%22%20fill%3D%22none%22%2F%3E%20%3Ctext%20x%3D%22125%22%20y%3D%2250%22%20font-family%3D%22Arial%2C%20sans-serif%22%20font-size%3D%2234%22%20font-weight%3D%22bold%22%20text-anchor%3D%22middle%22%20fill%3D%22red%22%3E%E6%A0%AA%E5%BC%8F%E4%BC%9A%E7%A4%BE%3C%2Ftext%3E%20%3Ctext%20x%3D%22125%22%20y%3D%2290%22%20font-family%3D%22Arial%2C%20sans-serif%22%20font-size%3D%2234%22%20font-weight%3D%22bold%22%20text-anchor%3D%22middle%22%20fill%3D%22red%22%3E%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%3C%2Ftext%3E%20%3C%2Fsvg%3E"))
    )
  ),

  // table
  TABLE_HTML(見積明細,
    OPT("pref", "pcraft-inv-item-"),
    ARRAY("#", ROWNO(見積明細) + 1),
    商品名, 数量, 単価, 金額
  ),

  // summary
  TAG("div", ATTR("class", "pcraft-inv-summary-section"),
    // 備考
    TAG("div", ATTR("class", "pcraft-inv-remarks-section"),
      TAG("strong", "備考:"), VTAG("br"),
      TAG("span", HTML(FVAL(備考)))
    ),
    // 合計
    TAG("div", ATTR("class", "pcraft-inv-total-section"),
      TAG("table",
        TAG("tbody",
          TAG("tr", TAG("th", "小計"), TAG("td", FVAL(小計金額))),
          TAG("tr", TAG("th", "消費税 (10%)"), TAG("td", FVAL(消費税))),
          TAG("tr", TAG("th", TAG("strong", "合計")), TAG("td", TAG("strong", FVAL(合計金額))))
        )
      )
    )
  )
)

注意事項

  • 既に、JavaScript によるカスタマイズを行っているアプリの場合、処理が競合して、エラーになる場合があります。その場合は、該当するアプリでプラグインの使用を中止してください。
0
1
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?