FROM CACHE - jp_header
解決済

cart-template.liquidに入れた独自項目について

orange_ec
Shopify Partner
3 0 0

cart-template.liquidに独自のアンケート項目を

https://ui-elements-generator.myshopify.com/pages/cart-attribute

から作成してフォーム内に入れました。管理画面でも確認が出来たのですが、そこから
外部の在庫連動システム(ネクストエンジン)の備考欄への取り込みが出来ません。

ネクストエンジンに問い合わせをしたところ現在のデータ形式は

--------------------
[note_attributes] => Array
(
[0] => stdClass Object
(
[name] => attributes[deliverytime]
[value] => 平日
)
--------------------

になっているが、ネクストエンジンでは

--------------------
[note_attributes] => Array
(
[deliverytime] => stdClass Object
(
[name] => attributes[deliverytime]
[value] => 平日
)
--------------------

でないとデータを取り込めないとの回答でした。

stdClass Objectの[0]を変更できる箇所や方法はありますでしょうか。

1 件の受理された解決策
junichiokamura
Community Manager
1200 280 506

成功

すいません、確認したいのですが、ネクストエンジンさんがおっしゃっているデータ形式とは、どのレベルでの形式でしょうか?

お見受けしたところ、共有されているログは、JavaScriptやPHPなどのプログラミング言語の展開形式で書かれているものですので、この情報だけですと正確なデータ形式が分かりません。

ネクストエンジンさんが、note_attributesを取得しているのが、REST APIなのか、GraphQLなのか、Webhookなのか確認いただき、これらのAPIやWebhookでのフォーマットで提示していただかないと対応は難しいと思います。

ちなみに私の方で、同様のコードをテーマに入れてREST APIでOrderのデータを参照した時のデータ構造は以下です。

 

        "note_attributes": [
            {
                "name": "Your name",
                "value": "NAMENAME"
            },
            {
                "name": "Your birth date",
                "value": "20011\/11\/11"
            }
        ],

 


1点、現時点で気になるのは、ラジオボックスを使われているので、同じ名前のname(name="attributes['deliverytime']")が複数あるので、それが他の連携できているマーチャントと差異があるのかもしれません。

Senior Partner Solutions Engineer

元の投稿で解決策を見る

4件の返信4

junichiokamura
Community Manager
1200 280 506

UI generstorで作って実際テーマに貼り付けたコードはどういったものでしょうか?それによってnote attributes の構造は変わるかと思います。

APIで、note_attributesを変更する方法はありますが、ちょっと大袈裟ですよね。。

https://shopify.dev/docs/admin-api/rest/reference/orders/order#update-2020-07

 

Senior Partner Solutions Engineer
orange_ec
Shopify Partner
3 0 0

ご返信有難うございます。実際にカートに貼ったのは下記になります。

----ここから----
<p class="cart-attribute__field">
<label>■修理品の集荷ご希望日</label><br>
<input type="radio" name="attributes['deliverytime']" value="最短※現在●/●"{% if cart.attributes['deliverytime'] == "最短※現在●/●になります" %} checked{% endif %}> <span>最短※現在●/●になります</span><br>
<input type="radio" name="attributes['deliverytime']" value="平日"{% if cart.attributes['deliverytime'] == "平日" %} checked{% endif %}> <span>平日</span><br>
<input type="radio" name="attributes['deliverytime']" value="土日"{% if cart.attributes['deliverytime'] == "土日" %} checked{% endif %}> <span>土日</span><br>
<input type="radio" name="attributes['deliverytime']" value="その他"{% if cart.attributes['deliverytime'] == "その他※下記に希望をお書き下さい。" %} checked{% endif %}> <span>その他※下記に希望をお書き下さい。</span><br>
</p>
----ここまで----

[0] => stdClass Object

[deliverytime] => stdClass Object
に変更する方法はありますでしょうか。

アプリでもその部分を変更出来そうなものが見当たらず
何度も申し訳ありません。よろしくお願いいたします。

junichiokamura
Community Manager
1200 280 506

成功

すいません、確認したいのですが、ネクストエンジンさんがおっしゃっているデータ形式とは、どのレベルでの形式でしょうか?

お見受けしたところ、共有されているログは、JavaScriptやPHPなどのプログラミング言語の展開形式で書かれているものですので、この情報だけですと正確なデータ形式が分かりません。

ネクストエンジンさんが、note_attributesを取得しているのが、REST APIなのか、GraphQLなのか、Webhookなのか確認いただき、これらのAPIやWebhookでのフォーマットで提示していただかないと対応は難しいと思います。

ちなみに私の方で、同様のコードをテーマに入れてREST APIでOrderのデータを参照した時のデータ構造は以下です。

 

        "note_attributes": [
            {
                "name": "Your name",
                "value": "NAMENAME"
            },
            {
                "name": "Your birth date",
                "value": "20011\/11\/11"
            }
        ],

 


1点、現時点で気になるのは、ラジオボックスを使われているので、同じ名前のname(name="attributes['deliverytime']")が複数あるので、それが他の連携できているマーチャントと差異があるのかもしれません。

Senior Partner Solutions Engineer
orange_ec
Shopify Partner
3 0 0

ネクストエンジンに確認をし「note_attributesを取得について REST API より取得」と回答を得ました。

回答と別途にif cart.attributesの後にdeliverytimeを入れることでお蔭様で回避出来ました。
(現時点でネクストエンジンの備考欄にshopifyから受け付けるのは希望時間帯の1項目のみでした)

丁寧な回答を日本語で頂き大変助かりました。有難うございました。