一覧からCSVダウンロードを行うため、以下コードを書いたのですが、
一覧の最大表示件数が100件となっているため、100件以上のデータがある場合、
途中で切れてしまいます。
コードの追記によって、一覧の対象レコードを全件、一括でダウンロードするようにすることは、できないでしょうか?
(function () {
“use strict”;
// 一覧ビューの表示イベント
kintone.events.on(‘app.record.index.show’, function(events) {
var record = events.record;
if (events.viewName === ‘●企画検索用’) { // 一覧名判断
var $link = $(‘#download-csv’);
if ($link.length == 0) {
// ヘッダにリンクを作成
var $header = $(kintone.app.getHeaderMenuSpaceElement());
$link = $(‘<a id=“download-csv” href=“#”>CSVダウンロード</a>’);
$header.append($link);
}
// エスケープ
var escapeStr = function(value) {
return ‘"’ + (value? value.replace(/“/g, '”“'): ‘’) + '”';
};
if ((window.URL || window.webkitURL).createObjectURL == null) {
// サポートされていないブラウザ
return;
}
// CSVデータを作成
var csv = [];
var row = [‘キー’,‘企画コード’,‘企画年月’,‘受注冊数’];
csv.push(row);
for (var i = 0; i < events.records.length; i++ ) {
var record = events.records[i];
row = [];
row.push(escapeStr(record[‘キー’].value));
row.push(escapeStr(record[‘CD_KIKAKU_M’].value));
row.push(escapeStr(record[‘YM_KIKAKU_M’].value));
row.push(escapeStr(record[‘SU_JUCHU’].value));
csv.push(row);
}
// BOM付でダウンロード
var csvbuf = csv.map(function(e){return e.join(‘,’)}).join(‘\r’);
var bom = new Uint8Array([0xEF, 0xBB, 0xBF]);
var blob = new Blob([bom, csvbuf], { type: ‘text/csv’ });
var url = (window.URL || window.webkitURL).createObjectURL(blob);
var fileName = “download.csv”;
if (window.navigator.msSaveOrOpenBlob) {
// for IE
$link.unbind();
$link.click(function() {
var retVal = window.navigator.msSaveOrOpenBlob(blob, fileName);
});
} else {
$link.attr(‘download’, fileName);
$link.attr(‘href’, url);
}
});
})();