angus
(Angus McLeod)
24 Septiembre, 2020 23:13
2
La forma en que he abordado esto en el pasado ha sido empaquetando los botones en un helper de HTML, que renderiza el HTML sin procesar en las plantillas sin procesar, y que luego puedes insertar mediante un outlet de plugin sin procesar. Aquí tienes un ejemplo:
https://github.com/paviliondev/discourse-topic-previews/blob/master/assets/javascripts/discourse/helpers/preview-helpers.js.es6#L8
El clic en el botón se maneja en el componente topic-list-item, por ejemplo:
https://github.com/paviliondev/discourse-topic-previews/blob/master/assets/javascripts/discourse/initializers/preview-edits.js.es6#L332
@merefield también podría tener algunas ideas
Además, probablemente querrás usar la estructura de carpetas de JavaScript del tema en lugar de agregar scripts al header.html. Consulta:
Complex theme javascript can be split into multiple files, to keep things nicely organised.
To use this functionality, simply add files to the /javascripts folder in your theme directory. These files can not be edited from the Discourse UI, so you must use the Theme CLI or source the theme from git .
Javascript files are treated exactly the same as they are in core/plugins, so you should follow the same file/folder structure. Theme files are loaded after core/plugins, so if the filenames match,…