Как привязать пользовательские поля и синхронизировать данные формы на странице значка администратора

Я пишу плагин для расширения функциональности значков. При нажатии кнопки «Сохранить» на странице администрирования значков пользовательские поля всегда принимают значения по умолчанию.

Discourse PluginOutlet

    <PluginOutlet
      @name="admin-above-badge-buttons"
      @outletArgs={{hash badge=this.buffered}}
    />

Мой код assets\javascripts\discourse\initializers\badge-avatar-frame-setup.js:

import { withPluginApi } from "discourse/lib/plugin-api";
import { ajax } from "discourse/lib/ajax";

export default {
  name: "badge-avatar-frame-setup",
  initialize() {
    withPluginApi("0.8.31", (api) => {
      api.modifyClass("model:badge", {
        pluginId: "discourse-badge-avatar-frame",
        pluginProperties: ["avatar_frame_enabled"],

        save(data = {}) {
          this.pluginProperties.forEach((prop) => {
            if (this[prop] !== undefined) {
              data[prop] = this[prop];
            }
          });
          console.log("Сохранение значка с данными:", data);
          console.log("Сохранение значка:", this);
          console.log("avatar_frame_enabled:", this.avatar_frame_enabled);
          console.log("data:", data);
          let url = "/admin/badges",
            type = "POST";

          if (this.id) {
            url += `/${this.id}`;
            type = "PUT";
          }

          return ajax(url, { type, data }).then((json) => {
            this.updateFromJson(json);
            return this;
          });
        },
      });
    });
  },
};

ссылка: Having a hard time overriding the save() function on the admin badge page

После нажатия кнопки «Сохранить» я вижу следующее в консоли:
![admin badge page after click the save button|690x464]

data:{
    "allow_title": true,
    "multiple_grant": false,
    "listable": true,
    "auto_revoke": true,
    "enabled": true,
    "show_posts": false,
    "target_posts": false,
    "name": "Новый значок",
    "description": "",
    "long_description": "",
    "icon": "angle-left",
    "image_upload_id": null,
    "image_url": null,
    "query": null,
    "badge_grouping_id": 6,
    "trigger": 0,
    "badge_type_id": 1,
    "show_in_post_header": false,
    "avatar_frame_enabled": false // всегда значение по умолчанию
}

Мой код assets\javascripts\discourse\connectors\admin-above-badge-buttons\badge-avatar-frame-settings.hbs:

{{#if this.siteSettings.avatar_frame_enabled}}
  <div class="badge-avatar-frame-settings">
    <h3>{{i18n "admin.badges.avatar_frame_settings"}}</h3>


    <div class="control-group">
      <label class="checkbox-label">
        <Input @type="checkbox" @checked={{this.avatar_frame_enabled}} />
        {{i18n "admin.badges.avatar_frame_enabled"}}
        +
        {{log @outletArgs.badge}}
        {{log @outletArgs}}
      </label>
    </div>
  </div>
{{/if}}

Вот вывод консоли:

Мой код db\migrate\20250509000000_add_avatar_fields_to_badges.rb:

class AddAvatarFieldsToBadges < ActiveRecord::Migration[6.1]
    def change
      add_column :badges, :avatar_frame_enabled, :boolean, default: false, null: false
    end
end

Нормально ли, что @outletArgs.badge возвращает значение undefined? :anxious_face_with_sweat: Что я делаю не так?
Как привязать пользовательские поля и синхронизировать данные формы на странице администрирования значков?

В данный момент у меня нет времени разбираться в этой проблеме или вспоминать, как я это делал, но в этом репозитории должна быть реализация расширения функционала сохранения значков