Einstellungen erscheinen nicht

Hi everyone, I’m getting started on developing things for Discourse, and I’m working on a theme component.
Link: GitHub - NateDhaliwal/discourse-persistent-banner: A theme component for Discourse that cannot be closed by the user.

When putting it on Theme Creator, the settings don’t appear, even though I have a settings.yml. Any ideas?

1 „Gefällt mir“

Do you see any error messages at theme creator?

I think you have to use the same quotation marks at the beginning and end.

This could also be a problem. I would try default: ""

Maybe you want to add “block” to the choices. Otherwise you have to use the revert button to choose that again.

2 „Gefällt mir“

Whoops, just realised I was clicking on ‘Create new’ instead of importing it…
But now, when I try using the URL, it says that about.json is invalid or doesn’t exist, asking me if it is a theme.
About.json:

Is there something wrong?

Missing comma after license URL.

4 „Gefällt mir“

:roll_eyes:
@merefield Would version be in ""?

1 „Gefällt mir“

Probably that too. Just look at examples.

1 „Gefällt mir“

Thanks! One last one, I can’t seem to get the variable to display.

Was it because I didn’t initialise it properly? I tried following the guide…

  1. don’t use “header.html”, use a proper component (preferably a .gjs file, but .hbs might suffice).
  2. use html-safe helper whenever outputting html from settings or variables.
2 „Gefällt mir“

Would I have to use

import Component from "@glimmer/component";

export default class PracticeComponent extends Component {
  get bannerLinks() {
    return JSON.parse(settings.banner_links);
  }
}

then?

1 „Gefällt mir“

Look at the billions of examples :stuck_out_tongue_winking_eye:

1 „Gefällt mir“

You only need to use a gjs file if you need to process stuff with javascript, otherwise an hbs template file might suffice. Experiment.

1 „Gefällt mir“

I’m not sure if I’m going in the right direction.
I made javascripts/persistent-banner.hbs with this:

But nothing shows up. Tried putting it in different places, still won’t work.

Tried looking at example, but many don’t seem to help.
Any advice?

1 „Gefällt mir“

In which plugin outlet do you want to put your banner?
Take a look at Using Plugin Outlet Connectors from a Theme or Plugin

You could use Add a featured topic list to your Discourse homepage as an example

You can use the Plugin outlet locations theme component to find the names and locations of the plugin outlets. “above-main-container” for example is the top one above the topic list, but not above the sidebar.

Looking at the code of a Theme component which adds something similar is also a great way to learn.

2 „Gefällt mir“

You do not need and should not put script tags in hbs files. They should be limited to the content of the template.

Don’t stab in the dark, read the guides:

3 „Gefällt mir“

So… I managed to get it working without using a hbs file, but instead using the <script> tag with handlebars, and it now works.
I use it like this for now, but I’ll continue to try using a hbs file instead.

1 „Gefällt mir“

created a quick pull request for you so you can see the way to split up the files properly. feel free to merge or just have a look at the branch.

6 „Gefällt mir“

Thanks so much! It works now!

1 „Gefällt mir“

No worries Nate. Keep up the experimenting, reading and looking at other examples. In no time you’ll be much better than I am at this dev stuff :smiley: :raised_hands:

2 „Gefällt mir“

Thanks for the encouragement!

1 „Gefällt mir“

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