テキストフィールドを動的に追加できますか

プリヤG

チャットボットで、ユーザーからの入力を受け取るアダプティブカード(jsonを使用)を作成しました。ユーザーが挿入フィールドをクリックするたびに、ユーザーが新しいテキストフィールドを追加できるボタンを追加したいと思います。(つまり、ユーザーは挿入ボタンをクリックして、教育の詳細(学校、大学など)を入力できます)

これはアダプティブカードで実現できますか?

私も知りたかったのですが、アダプティブカードは他の言語(jsonを除く)で設計できますか?

カイル・デラニー

これを行う最も簡単な方法はAction.ShowCard次のとおりです。

{
  "type": "AdaptiveCard",
  "body": [
    {
      "type": "Input.Text",
      "placeholder": "Placeholder 1",
      "id": "text1"
    }
  ],
  "actions": [
    {
      "type": "Action.ShowCard",
      "title": "Add field",
      "card": {
        "type": "AdaptiveCard",
        "body": [
          {
            "type": "Input.Text",
            "placeholder": "Placeholder 2",
            "id": "text2"
          }
        ],
        "actions": [
          {
            "type": "Action.ShowCard",
            "title": "Add field",
            "card": {
              "type": "AdaptiveCard",
              "body": [
                {
                  "type": "Input.Text",
                  "placeholder": "Placeholder 3",
                  "id": "text3"
                }
              ],
              "actions": [
                {
                  "type": "Action.ShowCard",
                  "title": "Add field",
                  "card": {
                    "type": "AdaptiveCard",
                    "body": [
                      {
                        "type": "Input.Text",
                        "placeholder": "Placeholder 4",
                        "id": "text4"
                      }
                    ],
                    "$schema": "http://adaptivecards.io/schemas/adaptive-card.json"
                  }
                }
              ],
              "$schema": "http://adaptivecards.io/schemas/adaptive-card.json"
            }
          }
        ],
        "$schema": "http://adaptivecards.io/schemas/adaptive-card.json"
      }
    }
  ],
  "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
  "version": "1.0"
}

ネストされたカード

見た目が気に入らないかもしれませんが、別の方法があります。Microsoft Teamsではメッセージを更新できるため、送信アクションに応じて、より多くの入力フィールドでカードを更新できます。まず、カードのアクティビティを更新できるように、カードの状態を保存する方法が必要になります。C#では、次のように状態プロパティアクセサーを宣言できます。

public IStatePropertyAccessor<Dictionary<string, (string ActivityId, int InputCount)>> InputCardStateAccessor { get; internal set; }

次に、次のようにインスタンス化できます。

InputCardStateAccessor = _conversationState.CreateProperty<Dictionary<string, (string, int)>>("cardState");

Node.jsでは、何も宣言する必要はありませんが、次のようにインスタンス化できます。

this.inputCardState = this.conversationState.createProperty('cardState');

カードを最初に送信するときとカードを更新するときに使用できる、一貫した方法でカードを生成する必要があります。C#でAdaptiveCardsNuGetパッケージを使用しています。

public static IActivity GenerateAdaptiveCardActivityWithInputs(int inputCount, object valueObject)
{
    var cardData = JObject.FromObject(valueObject);
    var cardId = Convert.ToString(cardData[KEYCARDID]);

    var card = new AdaptiveCard(new AdaptiveSchemaVersion(1, 0))
    {
        Body = Enumerable.Range(0, inputCount).Select(i =>
        {
            var inputId = $"text{i}";

            return new AdaptiveTextInput
            {
                Id = inputId,
                Value = Convert.ToString(cardData[inputId]),
            };
        }).ToList<AdaptiveElement>(),
        Actions = new List<AdaptiveAction>
        {
            new AdaptiveSubmitAction
            {
                Title = "Add field",
                Data = new Dictionary<string, string>
                {
                    { KEYCARDID, cardId },
                    { KEYSUBMITACTIONID, ACTIONSUBMITADDFIELD },
                },
            },
            new AdaptiveSubmitAction
            {
                Title = "Submit",
            },
        },
    };

    return MessageFactory.Attachment(new Attachment(AdaptiveCard.ContentType, content: JObject.FromObject(card)));
}

Node.js:

generateAdaptiveCardActivityWithInputs(inputCount, cardData) {
    var cardId = cardData[KEYCARDID];
    var body = [];

    for (let i = 0; i < inputCount; i++) {
        var inputId = `text${i}`;
        body.push({
            type: "Input.Text",
            id: inputId,
            value: cardData[inputId]
        });
    }

    var card = {
        type: "AdaptiveCard",
        $schema: "http://adaptivecards.io/schemas/adaptive-card.json",
        version: "1.0",
        body,
        actions: [
            {
                type: "Action.Submit",
                title: "Add field",
                data: {
                    [KEYCARDID]: cardId,
                    [KEYSUBMITACTIONID]: ACTIONSUBMITADDFIELD
                },
            },
            {
                type: "Action.Submit",
                title: "Submit",
            }
        ]
    };

    return MessageFactory.attachment(CardFactory.adaptiveCard(card));
}

この機能を使用すると、最初はC#で次のようにカードを送信できます。

var inputCount = 1;
var cardId = Guid.NewGuid().ToString();
var reply = GenerateAdaptiveCardActivityWithInputs(inputCount, new Dictionary<string, string> { { KEYCARDID, cardId } });
var response = await turnContext.SendActivityAsync(reply, cancellationToken);
var dict = await InputCardStateAccessor.GetAsync(turnContext, () => new Dictionary<string, (string, int)>(), cancellationToken);

dict[cardId] = (response.Id, inputCount);

Node.js:

var inputCount = 1;
var cardId = Date.now().toString();
var reply = this.generateAdaptiveCardActivityWithInputs(inputCount, { [KEYCARDID]: cardId });
var response = await turnContext.sendActivity(reply);
var dict = await this.inputCardState.get(turnContext, {});
dict[cardId] = {
    activityId: response.id,
    inputCount: inputCount
};
await this.inputCardState.set(turnContext, dict);

また、C#で次のようなカードの「フィールドの追加」送信アクションに応じてカードを更新できます。

private async Task AddFieldAsync(ITurnContext turnContext, CancellationToken cancellationToken)
{
    var activity = turnContext.Activity;

    if (activity.ChannelId == Channels.Msteams)
    {
        var value = JObject.FromObject(activity.Value);
        var cardId = Convert.ToString(value[KEYCARDID]);
        var dict = await InputCardStateAccessor.GetAsync(turnContext, () => new Dictionary<string, (string, int)>(), cancellationToken);

        if (dict.TryGetValue(cardId, out var cardInfo))
        {
            var update = GenerateAdaptiveCardActivityWithInputs(++cardInfo.InputCount, value);

            update.Id = cardInfo.ActivityId;
            update.Conversation = activity.Conversation;

            await turnContext.UpdateActivityAsync(update, cancellationToken);

            dict[cardId] = cardInfo;
        }
    }
}

Node.js:

async addField(turnContext) {
    var activity = turnContext.activity;

    if (activity.channelId == 'msteams') {
        var value = activity.value;
        var cardId = value[KEYCARDID];
        var dict = await this.inputCardState.get(turnContext, {});
        var cardInfo = dict[cardId];

        if (cardInfo) {
            var update = this.generateAdaptiveCardActivityWithInputs(++cardInfo.inputCount, value);

            update.id = cardInfo.activityId;
            update.conversation = activity.conversation;
            update.serviceUrl = activity.serviceUrl;

            dict[cardId] = cardInfo;

            await this.inputCardState.set(turnContext, dict);
            await turnContext.updateActivity(update);
        }
    }
}

更新されたカード

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

分類Dev

テキストフィールドからUITableViewに全体を追加して、自動的に入力します

分類Dev

テキストフィールドにハイフンを自動的に追加しますが、テキストフィールドを編集できません(電話番号のマスキング)

分類Dev

動的にangularjsでテキストフィールドを追加および削除します

分類Dev

フォームのテキスト フィールドとラベルを動的に追加または削除する

分類Dev

Elasticsearch:テキストフィールドでfielddataを有効にすることを回避できますか?

分類Dev

テキスト フィールドを動的に追加または削除し、単一の行に挿入します

分類Dev

動的に追加されたテキストフィールドIOSを削除する

分類Dev

テキストフィールドjavafxにリスナーを追加できませんでした

分類Dev

Excel-キーボードを使用して範囲入力フィールドのテキストカーソルを移動できますか?

分類Dev

特定の選択値に従ってjs-GRIDテキストフィールドを自動的に設定できますか?

分類Dev

Androidアプリケーションにテキストフィールドを追加できません

分類Dev

xcodeに動的ラベルとテキスト入力フィールドを追加するにはどうすればよいですか?

分類Dev

Angularテンプレートリファレンスを使用して動的テキストフィールドに動的な値を追加します

分類Dev

シングルリンクリストに追加するときに、フィールドでオブジェクトを自動的に並べ替えますか?

分類Dev

テキストフィールドにChildを追加するにはどうすればよいですか?

分類Dev

Spring WebclientでマルチパートフォームのテキストフィールドにContent-Dispositionファイル名を使用できますか?

分類Dev

tkinterに動的に追加されたテキストフィールドの値を取得する方法はありますか?

分類Dev

テキストフィールド付きのラジオボタンを自動選択しますか?

分類Dev

テキストフィールドに画像を追加する方法

分類Dev

テキストフィールドに署名を追加する-itexsharp

分類Dev

この関数にテキストフィールド値を追加します

分類Dev

動的テキストフィールドから文字を削除します

分類Dev

テキストフィールドからtableViewに新しいセルを追加します

分類Dev

iOSのテキストフィールドからコードを実行できますか?

分類Dev

ツールバーにソロテキストフィールドを追加できないことを確認します

分類Dev

テキスト フィールドを動的に変更します。Angular.js

分類Dev

excellは、通常のテキストとしてコピーできるテンプレートにフィールドを配置できますか?

分類Dev

EditTextフィールドからAndroidStudioのさまざまなTextViewにテキストを追加するにはどうすればよいですか?

分類Dev

最近の3つの投稿のリストをWordpressエディターのデフォルトテキストに動的に出力できますか?

Related 関連記事

  1. 1

    テキストフィールドからUITableViewに全体を追加して、自動的に入力します

  2. 2

    テキストフィールドにハイフンを自動的に追加しますが、テキストフィールドを編集できません(電話番号のマスキング)

  3. 3

    動的にangularjsでテキストフィールドを追加および削除します

  4. 4

    フォームのテキスト フィールドとラベルを動的に追加または削除する

  5. 5

    Elasticsearch:テキストフィールドでfielddataを有効にすることを回避できますか?

  6. 6

    テキスト フィールドを動的に追加または削除し、単一の行に挿入します

  7. 7

    動的に追加されたテキストフィールドIOSを削除する

  8. 8

    テキストフィールドjavafxにリスナーを追加できませんでした

  9. 9

    Excel-キーボードを使用して範囲入力フィールドのテキストカーソルを移動できますか?

  10. 10

    特定の選択値に従ってjs-GRIDテキストフィールドを自動的に設定できますか?

  11. 11

    Androidアプリケーションにテキストフィールドを追加できません

  12. 12

    xcodeに動的ラベルとテキスト入力フィールドを追加するにはどうすればよいですか?

  13. 13

    Angularテンプレートリファレンスを使用して動的テキストフィールドに動的な値を追加します

  14. 14

    シングルリンクリストに追加するときに、フィールドでオブジェクトを自動的に並べ替えますか?

  15. 15

    テキストフィールドにChildを追加するにはどうすればよいですか?

  16. 16

    Spring WebclientでマルチパートフォームのテキストフィールドにContent-Dispositionファイル名を使用できますか?

  17. 17

    tkinterに動的に追加されたテキストフィールドの値を取得する方法はありますか?

  18. 18

    テキストフィールド付きのラジオボタンを自動選択しますか?

  19. 19

    テキストフィールドに画像を追加する方法

  20. 20

    テキストフィールドに署名を追加する-itexsharp

  21. 21

    この関数にテキストフィールド値を追加します

  22. 22

    動的テキストフィールドから文字を削除します

  23. 23

    テキストフィールドからtableViewに新しいセルを追加します

  24. 24

    iOSのテキストフィールドからコードを実行できますか?

  25. 25

    ツールバーにソロテキストフィールドを追加できないことを確認します

  26. 26

    テキスト フィールドを動的に変更します。Angular.js

  27. 27

    excellは、通常のテキストとしてコピーできるテンプレートにフィールドを配置できますか?

  28. 28

    EditTextフィールドからAndroidStudioのさまざまなTextViewにテキストを追加するにはどうすればよいですか?

  29. 29

    最近の3つの投稿のリストをWordpressエディターのデフォルトテキストに動的に出力できますか?

ホットタグ

アーカイブ