5
0
Fork 0
mirror of https://0xacab.org/sutty/sutty synced 2025-02-24 20:21:50 +00:00

Merge branch 'recuperar-partials' into panel.sutty.nl

This commit is contained in:
f 2022-03-07 12:26:51 -03:00
commit 1a4a56983b
4 changed files with 66 additions and 39 deletions

View file

@ -29,7 +29,11 @@ class Post
# TODO: Reemplazar cuando leamos el contenido del Document # TODO: Reemplazar cuando leamos el contenido del Document
# a demanda? # a demanda?
def find_layout(path) def find_layout(path)
IO.foreach(path).lazy.grep(/^layout: /).take(1).first&.split(' ')&.last&.tr('\'', '')&.tr('"', '')&.to_sym IO.foreach(path).lazy.grep(/^layout: /).take(1).first&.split(' ')&.last&.tr('\'', '')&.tr('"', '')&.to_sym || :post
rescue Errno::ENOENT => e
ExceptionNotifier.notify(e)
:post
end end
end end
@ -113,7 +117,7 @@ class Post
# Devuelve una llave para poder guardar el post en una cache # Devuelve una llave para poder guardar el post en una cache
def cache_key def cache_key
'posts/' + uuid.value "posts/#{uuid.value}"
end end
def cache_version def cache_version
@ -123,7 +127,7 @@ class Post
# Agregar el timestamp para saber si cambió, siguiendo el módulo # Agregar el timestamp para saber si cambió, siguiendo el módulo
# ActiveRecord::Integration # ActiveRecord::Integration
def cache_key_with_version def cache_key_with_version
cache_key + '-' + cache_version "#{cache_key}-#{cache_version}"
end end
# TODO: Convertir a UUID? # TODO: Convertir a UUID?

View file

@ -92,40 +92,46 @@
-# -#
TODO: Solo les usuaries cachean porque tenemos que separar TODO: Solo les usuaries cachean porque tenemos que separar
les botones por permisos. les botones por permisos.
- cache_if @usuarie, [post, I18n.locale] do - begin
- checkbox_id = "checkbox-#{post.id}" - cache_if @usuarie, [post, I18n.locale] do
%tr{ id: post.id, data: { target: 'reorder.row' } } - checkbox_id = "checkbox-#{post.id}"
%td %tr{ id: post.id, data: { target: 'reorder.row' } }
.custom-control.custom-checkbox %td
%input.custom-control-input{ id: checkbox_id, type: 'checkbox', autocomplete: 'off', data: { action: 'reorder#select' } } .custom-control.custom-checkbox
%label.custom-control-label{ for: checkbox_id } %input.custom-control-input{ id: checkbox_id, type: 'checkbox', autocomplete: 'off', data: { action: 'reorder#select' } }
%span.sr-only= t('posts.reorder.select') %label.custom-control-label{ for: checkbox_id }
-# Orden más alto es mayor prioridad %span.sr-only= t('posts.reorder.select')
= hidden_field 'post[reorder]', post.id, -# Orden más alto es mayor prioridad
value: size - i, = hidden_field 'post[reorder]', post.id,
data: { reorder: true } value: size - i,
%td.w-100{ class: dir } data: { reorder: true }
= link_to site_post_path(@site, post.path) do %td.w-100{ class: dir }
%span{ lang: post.locale, dir: dir }= post.title = link_to site_post_path(@site, post.path) do
- if post.front_matter['draft'].present? %span{ lang: post.locale, dir: dir }= post.title
%span.badge.badge-primary= I18n.t('posts.attributes.draft.label') - if post.front_matter['draft'].present?
%br %span.badge.badge-primary= I18n.t('posts.attributes.draft.label')
%small %br
= link_to @site.layouts[post.layout].humanized_name, site_posts_path(@site, **@filter_params.merge(layout: post.layout)) %small
- post.front_matter['categories']&.each do |category| = link_to @site.layouts[post.layout].humanized_name, site_posts_path(@site, **@filter_params.merge(layout: post.layout))
= link_to site_posts_path(@site, **@filter_params.merge(category: category)) do - post.front_matter['categories']&.each do |category|
%span{ lang: post.locale, dir: dir }= category = link_to site_posts_path(@site, **@filter_params.merge(category: category)) do
= '/' unless post.front_matter['categories'].last == category %span{ lang: post.locale, dir: dir }= category
= '/' unless post.front_matter['categories'].last == category
%td.text-nowrap %td.text-nowrap
= post.created_at.strftime('%F') = post.created_at.strftime('%F')
%br/ %br/
= post.order = post.order
%td.text-nowrap %td.text-nowrap
- if @usuarie || policy(post).edit? - if @usuarie || policy(post).edit?
= link_to t('posts.edit'), edit_site_post_path(@site, post.path), class: 'btn btn-block' = link_to t('posts.edit'), edit_site_post_path(@site, post.path), class: 'btn btn-block'
- if @usuarie || policy(post).destroy? - if @usuarie || policy(post).destroy?
= link_to t('posts.destroy'), site_post_path(@site, post.path), class: 'btn btn-block', method: :delete, data: { confirm: t('posts.confirm_destroy') } = link_to t('posts.destroy'), site_post_path(@site, post.path), class: 'btn btn-block', method: :delete, data: { confirm: t('posts.confirm_destroy') }
-#
Rescatar cualquier error en un post, notificarlo e
ignorar su renderización.
- rescue ActionView::Template::Error => e
- ExceptionNotifier.notify_exception(e.cause, data: { site: @site.name, post: @post.path.absolute, usuarie: current_usuarie.id })
#footnotes{ hidden: true } #footnotes{ hidden: true }
- @filter_params.each do |param, value| - @filter_params.each do |param, value|

View file

@ -50,6 +50,15 @@ Rails.application.configure do
config.action_mailer.default_url_options = { host: 'localhost', config.action_mailer.default_url_options = { host: 'localhost',
port: 3000 } port: 3000 }
config.middleware.use ExceptionNotification::Rack,
error_grouping: true,
email: {
email_prefix: '',
sender_address: ENV['DEFAULT_FROM'],
exception_recipients: ENV['EXCEPTION_TO'],
normalize_subject: true
}
# Print deprecation notices to the stderr. # Print deprecation notices to the stderr.
config.active_support.deprecation = :stderr config.active_support.deprecation = :stderr

View file

@ -150,7 +150,7 @@ class PostsControllerTest < ActionDispatch::IntegrationTest
end end
posts = @site.posts(**lang) posts = @site.posts(**lang)
reorder = Hash[posts.map { |p| p.uuid.value }.shuffle.each_with_index.to_a] reorder = posts.map { |p| p.uuid.value }.shuffle.each_with_index.to_a.to_h
post site_posts_reorder_url(@site), post site_posts_reorder_url(@site),
headers: @authorization, headers: @authorization,
@ -159,10 +159,18 @@ class PostsControllerTest < ActionDispatch::IntegrationTest
@site = Site.find @site.id @site = Site.find @site.id
assert_equal reorder, assert_equal reorder,
Hash[@site.posts(**lang).map do |p| @site.posts(**lang).map do |p|
[p.uuid.value, p.order.value] [p.uuid.value, p.order.value]
end] end.to_h
assert_equal I18n.t('post_service.reorder'), assert_equal I18n.t('post_service.reorder'),
@site.repository.rugged.head.target.message @site.repository.rugged.head.target.message
end end
test 'si hay algún error se recupera' do
File.open(File.join(@site.path, '_es', "#{Date.today}-#{SecureRandom.hex}.markdown"), 'w') do |f|
f.write ''
end
get site_posts_url(@site), headers: @authorization
end
end end