I have j/s in my theme (am I infamous yet? ;) which is modifying the DOM by adding elements via api.decorateCooked(…. It inserts a variety HTML head elements.
I also have the DiscoTOC Theme component installed.
However, adding the usual <div data-theme-toc="true"> </div> that DiscoTOC notices and expands, doesn’t generate a table-of-contents including my dynamically inserted elements.
I’m figuring this might be as simple as execution order… if DiscoTOC looks before my j/s adds more elements . . .
What determines the ordering of execution if multiple bits of theme j/s code are calling api.cooked(?
I’m inserting within the post, yes. That’s why I suspect execution order.
Some bit of code determines the execution order… that’s the leverage point for me to get my component before TOC. eg, if it’s alpha by component name (ie, as displayed in the Component list in Admin area) then I can try namin my component accordingly, etc
That said, you can set initializer order for advanced use cases. I can put DiscoTOC in a named initializer so you can run your code before DiscoTOC, but I need to know what you’re trying to do first to give you a clear answer.
Your modifications here are based on an HTTP/AJAX request, correct?
Yes AJAX, but using a synchronous call. (I’ve always loved the oxymoron of synchronous AJAX :^)
I’m feeling like my next step is create a proper component—atm, it’s just some j/s pasted into my Theme’s Header. Then I can try fiddling with a judiciously chosen ID. “_foo” or “0-foo” might be all I need.
Si no recuerdo mal, los componentes de tema se evalúan después de los complementos.
Y puedo estar equivocado, pero se cargan en orden alfabético, por lo que poner una x- delante del nombre me ha ayudado en el pasado a asegurar que un componente de tema específico se evalúe al final.
Las respuestas de otros sugieren que el nombre del componente no afecta el orden de ejecución. Acabo de renombrarlos a aa-mycomponent y x-last-DiscoTOC y no funciona. [DiscoTOC no incluye encabezados añadidos dinámicamente al DOM, sí, dentro del cuerpo de la publicación]
hmmmmmmm… tal vez lo que está mal es más que el pedido. Acabo de inspeccionar… y las cosas en el DOM que pensé que eran encabezados HTML… son en realidad etiquetas DIV con class=\"d-toc-ignore\"
Hora de que profundice más. ¿A dónde fueron mis encabezados?
Bueno, creo que podrías demostrarlo de cualquier manera probando un ejemplo muy básico.
Crea dos componentes simples, anulando o conectando lo mismo, quizás una plantilla simple con una ligera diferencia, llama a uno por un nombre que comience más tarde en el alfabeto, observa cuál termina anulando el tema.
Está muy claramente ordenado por nombre en el código aquí en el modelo:
El nombre no afecta el orden de ejecución. @merefield la línea que enlazaste afecta cómo se muestran en la interfaz de administración, pero no se usa para la ejecución real.
Esta es la línea relevante para el orden de ejecución:
Por lo tanto, se ejecutan en orden ascendente de ‘id’ en la base de datos.
La única garantía que es portable entre instancias de Discourse es que el código del tema siempre se ejecuta antes que el código del componente del tema.
Como mencionó @Johani anteriormente, si necesita ejecutar código después de que se haya cargado algún otro componente, la mejor opción probablemente sea usar un inicializador de Ember, que admite el orden. Desafortunadamente, eso no será posible de inmediato en este caso, ya que parece que DiscoTOC no está utilizando inicializadores de Ember. Actualizar DiscoTOC para usar javascript de múltiples archivos (y, por lo tanto, inicializadores de Ember) ciertamente sería pr-welcome