Topic ID als Variable?

@tknospdr @pfaffman Ich habe schnell eine Komponente zusammengestellt, mit der Sie die Topic-ID eingeben und dorthin springen können.

Erstellen Sie eine neue Komponente und fügen Sie dies zum JS-Tab unter der Schaltfläche CSS/HTML bearbeiten hinzu[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>
        }
    );
});

Dies fügt ein Eingabefeld zur Suchseite hinzu:


Die Schaltfläche Submit dient zum Aufrufen des Topics[2]; sie hat keine Auswirkungen auf die Suchergebnisse.

Ich hoffe, das hilft!


  1. Mein erster Versuch mit FormKit, es ist wirklich cool! ↩︎

  2. Ich konnte den Text der Schaltfläche nicht ändern, da dies Lokalisierungen erfordern würde… was ein ganzes TC-Repository benötigen würde, was vielleicht übertrieben ist :person_shrugging:. ↩︎

1 „Gefällt mir“