ドロップダウンワークフローリストはSpreadJSで利用可能なドロップダウンの一つで、ユーザーはスタイルで定義されたワークフロー項目を簡単に選択できます。
SpreadJSでは、9種類の組み込みドロップダウンメニューを使用でき、これはワークフローリストの機能を提供します。ワークフローリストを開く前に、セルのスタイルでオプションデータを設定する必要があります。
次のようなコードでワークフローリストドロップダウンを使用できます:
ワークフローリストのオプションは、次のような構造に従う必要があります:
var spreadNS = GC.Spread.Sheets;
window.onload = function () {
var spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss"));
initSpread(spread);
};
function initSpread(spread) {
var sheet = spread.getSheet(0);
sheet.suspendPaint();
// -------------------- WorkFlow ---------------------
let style = new GC.Spread.Sheets.Style();
style.cellButtons = [
{
imageType: GC.Spread.Sheets.ButtonImageType.dropdown,
command: "openWorkflowList",
useButtonStyle: true,
}
];
style.dropDowns = [
{
type: GC.Spread.Sheets.DropDownType.workflowList,
option: {
items: [
{ value: "新規", transitions: [1] },
{ value: "オープン",transitions: [0,2,3,5] },
{ value: "対応中", transitions: [1, 3, 5] },
{ value: "解決", transitions: [5, 4] },
{ value: "再オープン",transitions: [5, 3, 2] },
{ value: "クローズ", transitions: [4] },
]
}
}
];
sheet.setText(4, 4, "進捗ステータス");
sheet.setStyle(5, 4, style);
sheet.setColumnWidth(4, 110, GC.Spread.Sheets.SheetArea.viewport);
sheet.resumePaint();
spread.commandManager().execute({cmd:"openWorkflowList",row:5,col:4,sheetName:"Sheet1"});
}
<!doctype html>
<html style="height:100%;font-size:14px;">
<head>
<meta name="spreadjs culture" content="ja-jp" />
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" type="text/css" href="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets/styles/gc.spread.sheets.excel2013white.css">
<script src="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets/dist/gc.spread.sheets.all.min.js" type="text/javascript"></script>
<script src="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets-resources-ja/dist/gc.spread.sheets.resources.ja.min.js" type="text/javascript"></script>
<script src="$DEMOROOT$/spread/source/js/license.js" type="text/javascript"></script>
<script src="app.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body>
<div class="sample-tutorial">
<div id="ss" style="width:100%; height: 100%"></div>
</div>
</body>
</html>
.sample-tutorial {
position: relative;
height: 100%;
overflow: hidden;
}
body {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
}