api.decorateWidget - come posso trovare i nomi dei template?

Non potrai utilizzare decorateWidget() su una plugin outlet. Prova qualcosa di simile a questo:

<script type="text/discourse-plugin" version="0.8.42">
    const h = require("virtual-dom").h;
    api.createWidget("user-card-custom-field", {
      html(attrs) {
        const userCustomFields = attrs.user.custom_fields;
        if (userCustomFields.user_field_4) {
            return h('span.poster-user-field', userCustomFields.user_field_4);
        }
      }
    });
</script>

<script type="text/x-handlebars" data-template-name="/connectors/user-card-post-names/user-card-custom-field">
    {{mount-widget widget="user-card-custom-field" args=(hash user=user)}}
</script>

mount-widget passa l’oggetto user disponibile dalla plugin outlet nel core e lo rende disponibile negli attributi del widget user-card-custom-field che abbiamo creato.

Assicurati di aver aggiunto user_field_4 alle tue impostazioni del sito “campi personalizzati utente pubblici” o “campi personalizzati utente dello staff”, a seconda delle necessità.

Modifica

Inoltre, a meno che tu non debba fare qualcosa di particolarmente speciale, dovresti essere in grado di evitare completamente i widget e utilizzare semplicemente la plugin outlet:

<script type="text/x-handlebars" data-template-name="/connectors/user-card-post-names/user-card-custom-field">
  {{#if user.custom_fields.user_field_1}}
    <span class="poster-user-field">{{user.custom_fields.user_field_1}}</span>
  {{/if}}
</script>
8 Mi Piace