ID do tópico como uma variável?

@tknospdr @pfaffman Criei rapidamente um componente que permite inserir o ID do tópico e ir até ele.

Crie um novo componente e adicione isto à aba JS sob o botão Editar CSS/HTML[1]:

import { apiInitializer } from "discourse/lib/api";
import Component from '@glimmer/component';
import { action } from "@ember/object";
import Form from "discourse/components/form";
import DiscourseURL from "discourse/lib/url";

export default apiInitializer((api) => {
    api.renderBeforeWrapperOutlet("full-page-search-filters",
        class GoToTopic extends Component {
            @action
            handleSubmit(data) {
                DiscourseURL.routeTo(`/t/${data.id}`);
            }

            <template>
                <div class="topic-id-go-to" style="margin-top: 1em;">
                    <Form @onSubmit={{this.handleSubmit}} as |form|>

                      <form.Field @name="id" @title="Topic id" as |field|>
                        <field.Input @type="number" @validation="required" />
                      </form.Field>

                      <form.Submit />
                    </Form>
                </div>
            </template>
        }
    );
});

Isto adiciona um campo de entrada à página de Pesquisa:


O botão Submit serve para ir ao tópico[2]; ele não afeta os resultados da pesquisa.

Espero que ajude!


  1. Minha primeira vez usando FormKit, é muito legal! ↩︎

  2. Não consegui mudar o texto do botão, pois isso exigiria locais… que precisariam de um repositório TC completo, o que pode ser exagero :person_shrugging:. ↩︎

1 curtida