ドロップダウン時刻ピッカー

ドロップダウン時刻ピッカーはSpreadJSのドロップダウンで、JavaScriptコードでstyleプロパティを使用して定義することができます。 このドロップダウンは、開発者が最小値、最大値、ステップで指定した異なる時間の選択方法を提供します。 これにより、開発者はワークブックに時刻ピッカーを簡単に追加することができ、ユーザー入力フォームを作成する際に便利です。 以下のスプレッドシートは、タイムピッカーで時間を表示する2つの異なる方法の例を示しています。

説明
app.js
index.html
styles.css

ドロップダウン時刻ピッカーはSpreadJSで利用可能なドロップダウンの一つで、ユーザーはスタイルで定義された時刻ピッカーにより時間を簡単に選択できます。

SpreadJSには9種類のドロップダウンが用意されています。このデモでは時刻ピッカーの使い方を紹介しています。

次のようなコードでドロップダウン時刻ピッカーを使用できます:

    // ドロップダウンアイコンをクリックして時刻ピッカーを開きます。 
    var timePickerStyle = new GC.Spread.Sheets.Style();
    timePickerStyle.cellButtons = [
          {
              imageType: GC.Spread.Sheets.ButtonImageType.dropdown,
              command: "openTimePicker",
              useButtonStyle: true,
          }
      ];
      timePickerStyle.dropDowns = [
          {
              type: GC.Spread.Sheets.DropDownType.timePicker,
              option: {
                  min: { hour: 8 },
                  max: { hour: 19 },
                  step: { minute: 30 },
                  formatString: "h:mm AM/PM",
              }
          }
      ];
      sheet.setText(1, 5, "Time Picker");
      sheet.setStyle(2, 5, timePickerStyle);

      // ドロップダウンボタンをクリックではなく、コマンドで時刻ピッカーを開きます。
      spread.commandManager().execute({cmd:"openTimePicker",row:2,col:5,sheetName:"Sheet1"});

以下のオプションを設定することで、時刻ピッカーをカスタマイズできます:

  • max: ITimePickerValue : 時刻ピッカーが表示できる最大値。値には時、分、秒の属性が必要です。
  • min: ITimePickerValue : 時刻ピッカーが表示できる最小値。値には時、分、秒の属性が必要です。
  • setp: ITimePickerValue : 時刻ピッカーが時刻表示をステップできる値。
  • formatString: string : 時間項目の書式を指定します。
  • height: number : 時刻ピッカーのサイズを指定します。
ドロップダウン時刻ピッカーはSpreadJSで利用可能なドロップダウンの一つで、ユーザーはスタイルで定義された時刻ピッカーにより時間を簡単に選択できます。 SpreadJSには9種類のドロップダウンが用意されています。このデモでは時刻ピッカーの使い方を紹介しています。 次のようなコードでドロップダウン時刻ピッカーを使用できます: 以下のオプションを設定することで、時刻ピッカーをカスタマイズできます: max: ITimePickerValue : 時刻ピッカーが表示できる最大値。値には時、分、秒の属性が必要です。 min: ITimePickerValue : 時刻ピッカーが表示できる最小値。値には時、分、秒の属性が必要です。 setp: ITimePickerValue : 時刻ピッカーが時刻表示をステップできる値。 formatString: string : 時間項目の書式を指定します。 height: number : 時刻ピッカーのサイズを指定します。
var spreadNS = GC.Spread.Sheets; window.onload = function () { var spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss")); initSpread(spread); }; function createPickerStyle(option) { var timePickerStyle = new GC.Spread.Sheets.Style(); timePickerStyle.cellButtons = [ { imageType: GC.Spread.Sheets.ButtonImageType.dropdown, command: "openTimePicker", useButtonStyle: true, } ]; timePickerStyle.dropDowns = [ { type: GC.Spread.Sheets.DropDownType.timePicker, option: option } ]; return timePickerStyle; } function initSpread(spread) { var sheet = spread.getSheet(0); sheet.suspendPaint(); sheet.setText(1, 3, "Time Picker"); sheet.setStyle(2, 3, createPickerStyle({ min: { hour: 8 }, max: { hour: 19 }, step: { minute: 30 }, formatString: "h:mm AM/PM", })); sheet.setText(1, 7, "Time Picker"); sheet.setStyle(2, 7, createPickerStyle({ min: { hour: 5 }, max: { hour: 20 }, step: { minute: 30 }, formatString: "h:mm:ss", height: 350 })); sheet.resumePaint(); spread.commandManager().execute({ cmd: "openTimePicker", row: 2, col: 3, 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; }