18
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

プリザンター(Pleasanter)Advent Calendar 2021

Day 19

Pleasanterのレコード情報をPDFにして出力してみた

Last updated at Posted at 2021-12-18

はじめに

Pleasanterのレコード情報をPDFにして確認したい、PDFにする必要がある、そんな方々向けの記事です。

使用するライブラリ

今回は「pdfmake」と呼ばれるJavaScriptのライブラリを使用してPDFを生成します。

準備

pdfmake

GitHubからクローンします。
https://github.com/bpampuch/pdfmake

buildディレクトリ配下にある
・pdfmake.min.js
・vfs_fonts.js
を使用します。
image.png

カスタムフォント

デフォルトフォントがRobotoのため、日本語対応しておりません。
日本語を使用したい場合は別途フォント(○○.ttf)の準備が必要です。
example/fontディレクトリ配下にあるフォントを退避し、準備したフォントを配置します。

準備した日本語フォントを使用してjsに変換します。
クローンした中にpackage.jsonが入っているので、パッケージをインストールします。

npm install

gruntを使用して上記vfs_fonts.jsファイルを生成します。
※gruntについては各自の環境で用意をお願いいたします。

npm install -g grunt-cli
npm install grunt grunt-text-replace grunt-browserify grunt-contrib-uglify grunt-dump-dir grunt-contrib-concat
grunt dump_dir

※Gruntfile.jsは下記ページを参考になりそうです。
https://github.com/naoa/pdfmake/blob/master/Gruntfile.js

Pleasanter

なんといってもPleasanterがないと始まらないので、下記ページからダウンロードします。
https://github.com/Implem/Implem.Pleasanter.NetCore/releases

導入手順

お手元の環境に合わせてPleasanterをインスールします。
https://pleasanter.org/manual?category=0090_0105

PDF生成スクリプト

画像表示

下記ページを参考に表示させます。
https://pdfmake.github.io/docs/0.1/document-definition-object/images/

{
    image: 'data:image/jpeg;base64,...encodedContent...',
    width: 150
},

あらかじめ決まった画像を表示したい

別途Base64に変換したものを指定する必要があります。

//Base64変換サンプル
using Microsoft.Extensions.Configuration;
IConfiguration configuration = new ConfigurationBuilder()
    .SetBasePath(Directory.GetCurrentDirectory())
    .AddJsonFile("appsettings.json", true, true)
    .Build();
IConfigurationSection section = configuration.GetSection("PathInfo");
var outputFile = string.Format("{0}.txt", DateTime.Now.ToString("yyyyMMdd-HHmmss"));
var bytes = File.ReadAllBytes(section["TargetFile"]);
var base64String = Convert.ToBase64String(bytes);
File.WriteAllText(section["OutputFolder"] + outputFile, base64String);
{
    "PathInfo": {
        "TargetFile": "C:\\work\\base64\\input\\test.png",
        "OutputFolder": "C:\\work\\base64\\output\\"
    }
}

レコードに登録された添付画像を表示したい

Pleasanterの添付ファイル情報は下記APIで取得可能です。
https://pleasanter.org/manual/api-attachment-get

// 添付ファイル情報取得サンプル
let guid = $('#Results_DescriptionA').val().replace('![image](/binaries/', '').replace('/show)', '');
let requestData = {
    ApiVersion: 1.1,
};
let url = `${location.origin}/api/binaries/${guid}/get`;
let base64;
$.ajax({
    type: 'post',
    url: url,
    data: requestData,
    async: false,
})
    .done((res) => {
        console.log(JSON.stringify(res));
        base64 = res.Response.Base64;
    })
    .fail((res) => {
        console.log(res);
    });

サンプルスクリプト

$p.events.on_editor_load = () => {
    if ($p.siteId() !== $p.id()) {
        $('#MainCommands').append('<button id="PDFButton" class="button button-icon open-dialog ui-button ui-corner-all ui-widget" type="button"><span class="ui-button-icon ui-icon ui-icon-document"></span><span class="ui-button-icon-space"></span>印刷</button>');
    }
};

$(document).on('click', '#PDFButton', () => {
    pdfMake.createPdf(createContent()).open();
});

function createContent() {
    pdfMake.fonts = {
        IPAgothicP: {
            normal: 'ipagp.ttf',
            bold: 'ipagp.ttf',
            italics: 'ipagp.ttf',
            bolditalics: 'ipagp.ttf'
        }
    };
    var defaultStyle = {
        font: 'IPAgothicP'
    };
    let title = $('#Results_Title').val();
    let base64 = getBase64($('#Results_DescriptionA').val().replace('![image](/binaries/', '').replace('/show)', ''));

    return {
        content: [
            {
                text: 'PDFサンプル',
                style: {
                    fontSize: 18,
                    bold: true
                }
            },
            {
                text: title,
                style: {
                    fontSize: 16,
                    bold: true
                }
            },
            {
                image: `data:image/jpeg;base64,${base64}`,
                width: 300
            }
        ],
        defaultStyle: defaultStyle
    };
}

function getBase64(guid) {
    let requestData = {
        ApiVersion: 1.1,
    };
    let url = `${location.origin}/api/binaries/${guid}/get`;
    let base64;
    $.ajax({
        type: 'post',
        url: url,
        data: requestData,
        async: false,
    })
        .done((res) => {
            console.log(JSON.stringify(res));
            base64 = res.Response.Base64;
        })
        .fail((res) => {
            console.log(res);
        });
    return base64;
}

スクリプト設定

プリザンターの拡張スクリプト機能を使用してPDF出力をしてみます。

スクリプトはPleasanterのデータベース(Implem.Pleasanter)にあるExtensionsテーブルへ入れます。
・ExtensionType:拡張機能の種類(Script、Sql、Styleなど)
・ExtensionName:名前
・ExtensionSettings:拡張機能の設定(機能させるサイトIDの指定など)
・Body:ファイル内容

image.png

登録が完了したら、プリザンターを再起動します。

PDF出力

画面下部の「印刷」ボタンをクリックします。
image.png

サンプルPDFの表示です。※すごくシンプルですが。。。
image.png

おわりに

今後、プリザンターのレコード情報をPDFで欲しいなと思う場面があった際、こんな感じでできたなと思いだして試してみていただけると嬉しいです。

18
5
0

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
18
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?