/ / Cómo obtener el "contenido" en bruto de todas las páginas - ruby, sitemap, piñones, intermediario

Cómo obtener el "contenido" en bruto de todas las páginas: ruby, sitemap, piñones, intermediario

Intento crear un archivo de índice para mi sitio de Middleman, y me gustaría incluir en ese archivo el "contenido" en bruto de mis páginas.

/source/mypage.md:

---
title: My Page
---
# This is my page
With *my markdown*

y

/source/myotherpage.md:

---
title: My Other Page
---
# Here is my other page

Me gustaría tener una tercera página que está en /source/site_index.json.erb que cuando la salida se ve algo así como:

 [
{"title": "My Page", "body": "#This is my pagenWith *my markdownn"},
{"title": "My Other Page", "body": "#Here is my other pagen"}
]

Puedo obtener el título, etc. utilizando algo como esto, pero no sé cómo obtener el cuerpo sin procesar:

[
<% sitemap.resources.select{|resource| resource.content_type == "text/html; charset=utf-8" unless resource.data.ignore }.each do |resource| %>
{
"title": <%= resource.data.title.to_json %>,
"body": <%= nil %>
} ,
<% end %>
]

Respuestas

1 para la respuesta № 1

Nunca antes habías usado a Middleman pero has intentado resource.render?

De acuerdo con la documentación en http://rubydoc.info/gems/middleman-core/Middleman/Sitemap/Resource#render-instance_method parece que debería funcionar

Otra posible ventaja es la siguiente referencia a raw_body_content a https://github.com/middleman/middleman-sitemap-api/blob/master/lib/middleman-sitemap-api/extension.rb#L122

Espero que esto ayude


1 para la respuesta № 2

los resource objeto tiene un puntero al archivo de origen (source_file) y puedes leer el contenido del archivo:

[
<%
pages = sitemap.resources.select{|resource| resource.content_type == "text/html; charset=utf-8" unless resource.data.ignore }
pages.each_with_index do |resource, index|
file = File.open(resource.source_file, "r")
content = file.read
%>
{
"title": <%= resource.data.title.to_json %>,
"body": <%= content.to_json %>
} <%="," unless( index == pages.length-1) %>
<% end %>
]

Esto funcionó para mí, probado con Middleman 3.3.3.