Cambios en la API del plugin Discourse: Uso de api.registerValueTransformer para addPostMenuButton y component:topic-list

Hola, estoy usando la versión 3.2.0.beta4-dev para el desarrollo local y la versión 0.8.7 de la API de plugins para el desarrollo de plugins. Sin embargo, debido a cambios recientes en Discourse, las funciones addPostMenuButton y component:topic-list han sido modificadas.

¿Cómo puedo usar api.registerValueTransformer para estas funciones de la API? Además, ¿qué versión de la API de plugins debo usar para que coincida con 3.2.0.beta4-dev para garantizar la compatibilidad con api.registerValueTransformer?

Aquí está mi código para addPostMenuButton:

api.addPostMenuButton("togglePostButton", (model) => {
  const siteSettings = api.container.lookup("site-settings:main");
  const posts = siteSettings.posts;
  const array_of_posts = posts.split("|");
  const postId = model.id;
  const postIdstr = postId.toString();
  const isPost = array_of_posts.includes(postIdstr);

  return {
    action: "togglePost",
    position: "first",
    className: isPost
      ? "button.topic_hidden custom-class-hidden"
      : "button.topic_visible custom-class-visible",
    icon: isPost ? "far-eye-slash" : "far-eye",
    title: isPost ? "Hide Post" : "Show Post",
  };
});

Y aquí está mi código para component:topic-list:

api.modifyClass("component:topic-list", {
  pluginId: "post-toggle",
  didInsertElement: function () {
    this._super();
    const topics = this.topics;
    for (let key in topics) {
      if (topics.hasOwnProperty(key)) {
        let newTopicLatest = [];
        const topic_id = topics[key].id;
        const topic_posters = topics[key].posters;

        topic_posters.forEach((poster) => {
          if (poster && poster.extras !== null && poster.extras.includes("latest")) {
            newTopicLatest = poster["description"].split(",");
          }
        });

        let userListLatest = newTopicLatest;
        if (userListLatest.length > 1 && userListLatest[0] === "Original Poster") {
          userListLatest = userListLatest.slice(1);
          userListLatest[0] = userListLatest[0].trim();
        }

        let i = 0;
        const element = $('tr[data-topic-id="' + topic_id + '"]').find(
          "a[data-user-card]"
        );

        if (element.length > 0) {
          element.each(function () {
            const poster_inside = topic_posters[i];
            if (poster_inside !== undefined && Object.keys(poster_inside).length !== 0) {
              const userElement = $(this);
              if (!userListLatest.includes(poster_inside.user.id.toString())) {
                userElement.hide();
              }
            }
            i++;
          });
        }
      }
    }
  }
});

¿Alguien puede ayudarme con esto?

Actualicé mi Discourse de desarrollo local a la versión 3.5.0.beta2-dev y la versión de la API del plugin es 2.1.1. ¿Cómo puedo usar api.registerValueTransformer para las funciones addPostMenuButton y component:topic-list?

¿Has leído el Tema?: Upcoming post menu changes - How to prepare themes and plugins

3 Me gusta

Sí, he leído sobre ese tema, implementé cambios basados en las actualizaciones de la nueva API de complementos y también descubrí component:topic-list.

1 me gusta

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.