mirror of
https://0xacab.org/sutty/sutty
synced 2024-11-22 19:16:23 +00:00
feat: hacer una acción con las seleccionadas
This commit is contained in:
parent
761d68604b
commit
9b2efaafac
8 changed files with 60 additions and 24 deletions
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
# Actualiza la relación entre un sitio y una instancia
|
# Actualiza la relación entre un sitio y una instancia
|
||||||
class InstanceModerationsController < ApplicationController
|
class InstanceModerationsController < ApplicationController
|
||||||
before_action :authorize_policy
|
before_action :authorize_policy, except: %i[action_on_several]
|
||||||
|
|
||||||
def pause
|
def pause
|
||||||
instance_moderation.pause!
|
instance_moderation.pause!
|
||||||
|
@ -22,6 +22,27 @@ class InstanceModerationsController < ApplicationController
|
||||||
redirect_to site_moderation_queue_path
|
redirect_to site_moderation_queue_path
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def action_on_several
|
||||||
|
instance_moderations = site.instance_moderations.where(id: params[:instance_moderation])
|
||||||
|
|
||||||
|
authorize instance_moderations
|
||||||
|
|
||||||
|
action = params[:instance_moderation_action].to_sym
|
||||||
|
method = :"#{action}!"
|
||||||
|
|
||||||
|
InstanceModeration.transaction do
|
||||||
|
instance_moderations.find_each do |instance_moderation|
|
||||||
|
events = instance_moderation.aasm.events.map(&:name)
|
||||||
|
|
||||||
|
next unless events.include? action
|
||||||
|
|
||||||
|
instance_moderation.public_send(method)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
redirect_to site_moderation_queue_path
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
# @return [InstanceModeration]
|
# @return [InstanceModeration]
|
||||||
|
|
|
@ -13,4 +13,10 @@ InstanceModerationPolicy = Struct.new(:usuarie, :instance_moderation) do
|
||||||
def block?
|
def block?
|
||||||
pause?
|
pause?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# En este paso tenemos varias instancias por moderar pero todas son
|
||||||
|
# del mismo sitio.
|
||||||
|
def action_on_several?
|
||||||
|
instance_moderation.first.site.usuarie? usuarie
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
-# Componente Checkbox
|
-# Componente Checkbox
|
||||||
|
- local_assigns[:name] ||= id
|
||||||
.custom-control.custom-checkbox
|
.custom-control.custom-checkbox
|
||||||
%input.custom-control-input{ type: 'checkbox', id: id, name: id, **local_assigns }
|
%input.custom-control-input{ type: 'checkbox', id: id, **local_assigns }
|
||||||
%label.custom-control-label{ for: id }= yield
|
%label.custom-control-label{ for: id }= yield
|
||||||
|
|
4
app/views/components/_dropdown_button.haml
Normal file
4
app/views/components/_dropdown_button.haml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
-#
|
||||||
|
@param name [String]
|
||||||
|
@param value [String]
|
||||||
|
%button.dropdown-item{type: 'submit', data: { target: 'dropdown.item' }, name: name, value: value }= text
|
|
@ -1,3 +1,3 @@
|
||||||
= render 'components/dropdown_item', text: t('.submenu_pause'), path: '/'
|
= render 'components/dropdown_button', text: t('.submenu_pause'), name: 'instance_moderation_action', value: 'pause'
|
||||||
= render 'components/dropdown_item', text: t('.submenu_allow'), path: '/'
|
= render 'components/dropdown_button', text: t('.submenu_allow'), name: 'instance_moderation_action', value: 'allow'
|
||||||
= render 'components/dropdown_item', text: t('.submenu_block'), path: '/'
|
= render 'components/dropdown_button', text: t('.submenu_block'), name: 'instance_moderation_action', value: 'block'
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
.row.no-gutters.pt-2
|
.row.no-gutters.pt-2
|
||||||
.col-1
|
.col-1
|
||||||
= render 'components/checkbox', id: instance.hostname, data: { target: 'select-all.input' }
|
= render 'components/checkbox', id: instance.hostname, name: 'instance_moderation[]', value: instance_moderation.id, data: { target: 'select-all.input' }
|
||||||
.col-11
|
.col-11
|
||||||
%h4
|
%h4
|
||||||
%a{ href: instance.uri }= instance.content['title']
|
%a{ href: instance.uri }= instance.content['title']
|
||||||
|
|
|
@ -1,24 +1,26 @@
|
||||||
.row.no-gutters.pt-2{ data: { controller: 'select-all' } }
|
%section
|
||||||
.col-1.d-flex.align-items-center
|
%form{ action: site_instance_moderations_action_on_several_path, method: :post }
|
||||||
= render 'components/select_all', id: 'instances'
|
.row.no-gutters.pt-2{ data: { controller: 'select-all' } }
|
||||||
.col-11
|
.col-1.d-flex.align-items-center
|
||||||
-# Filtros
|
= render 'components/select_all', id: 'instances'
|
||||||
= render 'components/instances_filters'
|
.col-11
|
||||||
|
-# Filtros
|
||||||
|
= render 'components/instances_filters'
|
||||||
|
|
||||||
.col-12
|
.col-12
|
||||||
- if instance_moderations.count.zero?
|
- if instance_moderations.count.zero?
|
||||||
%h3= t('moderation_queue.nothing')
|
%h3= t('moderation_queue.nothing')
|
||||||
|
|
||||||
|
- instance_moderations.each do |instance_moderation|
|
||||||
|
%hr
|
||||||
|
= render 'moderation_queue/instance', instance_moderation: instance_moderation, instance: instance_moderation.instance
|
||||||
|
|
||||||
|
-# Botones moderación
|
||||||
|
.d-flex.pb-4
|
||||||
|
= render 'components/instances_btn_box', site: site, instance_moderation: instance_moderation
|
||||||
|
|
||||||
- instance_moderations.each do |instance_moderation|
|
|
||||||
%hr
|
%hr
|
||||||
= render 'moderation_queue/instance', instance: instance_moderation.instance
|
%div
|
||||||
|
|
||||||
-# Botones moderación
|
|
||||||
.d-flex.pb-4
|
|
||||||
= render 'components/instances_btn_box', site: site, instance_moderation: instance_moderation
|
|
||||||
|
|
||||||
%hr
|
|
||||||
.col-12
|
|
||||||
%h3.mt-5= t('moderation_queue.instances.title')
|
%h3.mt-5= t('moderation_queue.instances.title')
|
||||||
%lead= t('moderation_queue.instances.description')
|
%lead= t('moderation_queue.instances.description')
|
||||||
= render 'components/block_lists', blocklists: @blocklists
|
= render 'components/block_lists', blocklists: @blocklists
|
||||||
|
|
|
@ -68,6 +68,8 @@ Rails.application.routes.draw do
|
||||||
patch :block, to: 'instance_moderations#block'
|
patch :block, to: 'instance_moderations#block'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
patch :instance_moderations_action_on_several, to: 'instance_moderations#action_on_several'
|
||||||
|
|
||||||
# Gestionar artículos según idioma
|
# Gestionar artículos según idioma
|
||||||
nested do
|
nested do
|
||||||
scope '/(:locale)', constraint: /[a-z]{2}(-[A-Z]{2})?/ do
|
scope '/(:locale)', constraint: /[a-z]{2}(-[A-Z]{2})?/ do
|
||||||
|
|
Loading…
Reference in a new issue