コードを記載して出力を設定する

直接プログラミングのコードを記載して出力を設定することができます。

  • プログラミングのコードを使用することで、オーダーの変数に直接アクセスすることができ、数値計算などをすることができます。 オーダー変数の一覧を参照してください。

  • 日付の計算をするために、以下の関数を用意しています。

    const dateCalculate = (
      dateStr: string | Date,
      num: number,
      format?: string
    ) => {
      const d = dayjs(dateStr);
      if (!d.isValid()) return "";
      d.add(num, "day");
      return d.add(num, "day").format(format || "YYYY-MM-DD");
    };

    日付の計算、フォーマットにはday.jsを使用していますので、日付のフォーマットはこちらを参照してください。

  • 例えば、以下のように記載することができます。
    数字を変更することで、+x日、-x日を計算することができます。

    // 配送希望日から計算する
      dateCalculate(order.date, -5, "YYYY/MM/DD")
    // 今日の日付から計算する
      dateCalculate(new Date(), 5, "YYYY/MM/DD")

    アプリの設定画面

  • プログラムがエラーになった場合は、空の文字列("")を出力します。(何も表示されません。) エラーとなった場合はgoogle chromeのコンソールなどに出力されます。

    • 以下のURLから検証環境でテストできます。(変数などを使ってコードを検証することができます。)
      https://playcode.io/1921690

サンプルコード

  1. 配送希望日から出荷日を求める。(生鮮食品など)

    dateCalculate(order.date, -5, "YYYY/MM/DD")

    配送地域などによって出荷日が異なる場合は 「3. 注文内容から出力値を変更」 を使用してください。

  2. 配送希望日が ”指定しない” の時に配送地域ごとに最短日のお届け予定日をセットする。
    (複雑な条件となるため、即時関数を使用します。条件分岐は適宜修正をお願いします。)

      (() => {
        const address = order.shippingAddress.formattedArea;
        const format = 'YYYY/MM/DD';
        if (address.includes('北海道')) {
          return dateCalculate(new Date(), 4, format);
        } else if (address.includes('青森県')) {
          return dateCalculate(new Date(), 3, format);
        } else if (address.includes('沖縄県')) {
          return dateCalculate(new Date(), 5, format);
        } else if (
          address.includes('福岡県') ||
          address.includes('佐賀県') ||
          address.includes('長崎県') ||
          address.includes('熊本県') ||
          address.includes('大分県') ||
          address.includes('宮崎県')
        ) {
          return dateCalculate(new Date(), 3, format);
        } else {
          return dateCalculate(new Date(), 2, format);
        }
      })()

  1. 品名1と品名2に購入された商品名をそれぞれ出力する。

    // 1番目の商品
    order.lineItems[0]?.title
    // 2番目の商品
    order.lineItems[1]?.title

  2. 合計金額から送料を引いた金額を表示する

    order.currentTotalPriceSet.shopMoney.amount-order.totalShippingPriceSet.shopMoney.amount

  3. お届け先電話番号をハイフン入り(-) の文字列に変換する。(エクセルでの文字化け対策)

    (()=>{
      const tel = order.shippingAddress.phone?.replace("+81","0")
          if (/^0[789]0\d{8}$/.test(tel)) {
              return tel.replace(/(\d{3})(\d{4})(\d{4})/, "$1-$2-$3");
          } else if (/^0\d{9,10}$/.test(tel)) {
              return tel.replace(/(\d{4})(\d{2})(\d{4})/, "$1-$2-$3");
          } else {
              return tel;
          }
      })()

  4. ご依頼主電話番号をハイフン入り(-) の文字列に変換する。(エクセルでの文字化け対策)

    (()=>{
    const tel = order.billingAddress.phone?.replace("+81","0")
        if (/^0[789]0\d{8}$/.test(tel)) {
            return tel.replace(/(\d{3})(\d{4})(\d{4})/, "$1-$2-$3");
        } else if (/^0\d{9,10}$/.test(tel)) {
            return tel.replace(/(\d{4})(\d{2})(\d{4})/, "$1-$2-$3");
        } else {
            return tel;
        }
    })()

←注文CSV出力に戻る

インストール
テックブログ