L’API JavaScript di Discourse consente a temi e plugin di apportare ampie personalizzazioni all’esperienza utente. Il modo più semplice per utilizzarla è creare un nuovo tema dal pannello di amministrazione, fare clic su “Modifica codice” e quindi accedere alla scheda JS.
Per i temi basati su file, l’API può essere utilizzata creando un file nella directory api-initializers. Per i temi è {theme}/javascripts/api-initializers/init-theme.gjs, e per i plugin è {plugin}/assets/javascripts/discourse/api-initializers/init-plugin.js. Il contenuto dovrebbe essere:
import { apiInitializer } from "discourse/lib/api";
export default apiInitializer((api) => {
// Il tuo codice qui
});
Tutte le API disponibili sono elencate nel codice sorgente di plugin-api.gjs nel core di Discourse, insieme a una breve descrizione ed esempi.
Per un tutorial completo, inclusi esempi di utilizzo dell’API JS, consulta:
Questo documento è controllato tramite versione - suggerisci modifiche su github.
What’s the best way to “import” as a Site Customisation? - is it just to use require?
Whilst this works:
<script type="text/discourse-plugin" version="0.1">
var HamburgerMenuComponent = require('discourse/components/hamburger-menu').default;
</script>
This does not:
<script type="text/discourse-plugin" version="0.1">
import {default as HamburgerMenuComponent2 } from 'discourse/components/hamburger-menu';
</script>
Where I get this error:
<script type="text/discourse-js-error">unknown: 'import' and 'export' may only appear at the top level (3:0)
1 | Discourse._registerPluginCode('0.1', api => {
2 |
> 3 | import {default as HamburgerMenuComponent2 } from 'discourse/components/hamburger-menu';
| ^
4 |
5 |
6 | }); at <eval>:8695:14</script>
Is there a way to get access to the h helper from virtual-dom in a site customization? I’m trying to add a simple dropdown widget to use in our header, and I can’t get that darned h, even though I can get createWidget
I wouldn’t recommend doing it that way as it would likely break future compatibility. You can use this for now but I’ll try to introduce a workaround shortly that will be safer long term.
Makes sense, it’s kinda circumventing the whole Plugin API thing and relying on implementation details of the ES6 compilation output, both things that are Dangerous™
Anyways, I’ll definitely keep an eye out for a better solution
Actually thinking about it, the decorateWidget helper gets called with an object that has the h method. How are you inserting your widget if not via a decorator?