2019-07-07 11:18:12 +05:30
|
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
|
|
module Gitlab
|
|
|
|
|
module QuickActions
|
|
|
|
|
module IssuableActions
|
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
include Gitlab::QuickActions::Dsl
|
|
|
|
|
|
|
|
|
|
SHRUG = '¯\\_(ツ)_/¯'.freeze
|
|
|
|
|
TABLEFLIP = '(╯°□°)╯︵ ┻━┻'.freeze
|
|
|
|
|
|
|
|
|
|
included do
|
|
|
|
|
# Issue, MergeRequest, Epic: quick actions definitions
|
|
|
|
|
desc do
|
|
|
|
|
"Close this #{quick_action_target.to_ability_name.humanize(capitalize: false)}"
|
|
|
|
|
end
|
|
|
|
|
explanation do
|
|
|
|
|
"Closes this #{quick_action_target.to_ability_name.humanize(capitalize: false)}."
|
|
|
|
|
end
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
quick_action_target.open? &&
|
|
|
|
|
current_user.can?(:"update_#{quick_action_target.to_ability_name}", quick_action_target)
|
|
|
|
|
end
|
|
|
|
|
command :close do
|
|
|
|
|
@updates[:state_event] = 'close'
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
desc do
|
|
|
|
|
"Reopen this #{quick_action_target.to_ability_name.humanize(capitalize: false)}"
|
|
|
|
|
end
|
|
|
|
|
explanation do
|
|
|
|
|
"Reopens this #{quick_action_target.to_ability_name.humanize(capitalize: false)}."
|
|
|
|
|
end
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
quick_action_target.closed? &&
|
|
|
|
|
current_user.can?(:"update_#{quick_action_target.to_ability_name}", quick_action_target)
|
|
|
|
|
end
|
|
|
|
|
command :reopen do
|
|
|
|
|
@updates[:state_event] = 'reopen'
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Change title')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
explanation do |title_param|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
_("Changes the title to \"%{title_param}\".") % { title_param: title_param }
|
2019-07-07 11:18:12 +05:30
|
|
|
|
end
|
|
|
|
|
params '<New title>'
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
current_user.can?(:"update_#{quick_action_target.to_ability_name}", quick_action_target)
|
|
|
|
|
end
|
|
|
|
|
command :title do |title_param|
|
|
|
|
|
@updates[:title] = title_param
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Add label(s)')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
explanation do |labels_param|
|
|
|
|
|
labels = find_label_references(labels_param)
|
|
|
|
|
|
|
|
|
|
"Adds #{labels.join(' ')} #{'label'.pluralize(labels.count)}." if labels.any?
|
|
|
|
|
end
|
|
|
|
|
params '~label1 ~"label 2"'
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
parent &&
|
|
|
|
|
current_user.can?(:"admin_#{quick_action_target.to_ability_name}", parent) &&
|
|
|
|
|
find_labels.any?
|
|
|
|
|
end
|
|
|
|
|
command :label do |labels_param|
|
|
|
|
|
label_ids = find_label_ids(labels_param)
|
|
|
|
|
|
|
|
|
|
if label_ids.any?
|
|
|
|
|
@updates[:add_label_ids] ||= []
|
|
|
|
|
@updates[:add_label_ids] += label_ids
|
|
|
|
|
|
|
|
|
|
@updates[:add_label_ids].uniq!
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Remove all or specific label(s)')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
explanation do |labels_param = nil|
|
|
|
|
|
if labels_param.present?
|
|
|
|
|
labels = find_label_references(labels_param)
|
|
|
|
|
"Removes #{labels.join(' ')} #{'label'.pluralize(labels.count)}." if labels.any?
|
|
|
|
|
else
|
2019-07-31 22:56:46 +05:30
|
|
|
|
_('Removes all labels.')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
params '~label1 ~"label 2"'
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
quick_action_target.labels.any? &&
|
|
|
|
|
current_user.can?(:"admin_#{quick_action_target.to_ability_name}", parent)
|
|
|
|
|
end
|
|
|
|
|
command :unlabel do |labels_param = nil|
|
|
|
|
|
if labels_param.present?
|
|
|
|
|
label_ids = find_label_ids(labels_param)
|
|
|
|
|
|
|
|
|
|
if label_ids.any?
|
|
|
|
|
@updates[:remove_label_ids] ||= []
|
|
|
|
|
@updates[:remove_label_ids] += label_ids
|
|
|
|
|
|
|
|
|
|
@updates[:remove_label_ids].uniq!
|
|
|
|
|
end
|
|
|
|
|
else
|
|
|
|
|
@updates[:label_ids] = []
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Replace all label(s)')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
explanation do |labels_param|
|
|
|
|
|
labels = find_label_references(labels_param)
|
|
|
|
|
"Replaces all labels with #{labels.join(' ')} #{'label'.pluralize(labels.count)}." if labels.any?
|
|
|
|
|
end
|
|
|
|
|
params '~label1 ~"label 2"'
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
quick_action_target.labels.any? &&
|
|
|
|
|
current_user.can?(:"admin_#{quick_action_target.to_ability_name}", parent)
|
|
|
|
|
end
|
|
|
|
|
command :relabel do |labels_param|
|
|
|
|
|
label_ids = find_label_ids(labels_param)
|
|
|
|
|
|
|
|
|
|
if label_ids.any?
|
|
|
|
|
@updates[:label_ids] ||= []
|
|
|
|
|
@updates[:label_ids] += label_ids
|
|
|
|
|
|
|
|
|
|
@updates[:label_ids].uniq!
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Add a todo')
|
|
|
|
|
explanation _('Adds a todo.')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
!TodoService.new.todo_exist?(quick_action_target, current_user)
|
|
|
|
|
end
|
|
|
|
|
command :todo do
|
|
|
|
|
@updates[:todo_event] = 'add'
|
|
|
|
|
end
|
|
|
|
|
|
2019-09-30 21:07:59 +05:30
|
|
|
|
desc _('Mark to do as done')
|
|
|
|
|
explanation _('Marks to do as done.')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
TodoService.new.todo_exist?(quick_action_target, current_user)
|
|
|
|
|
end
|
|
|
|
|
command :done do
|
|
|
|
|
@updates[:todo_event] = 'done'
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Subscribe')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
explanation do
|
|
|
|
|
"Subscribes to this #{quick_action_target.to_ability_name.humanize(capitalize: false)}."
|
|
|
|
|
end
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
!quick_action_target.subscribed?(current_user, project)
|
|
|
|
|
end
|
|
|
|
|
command :subscribe do
|
|
|
|
|
@updates[:subscription_event] = 'subscribe'
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Unsubscribe')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
explanation do
|
|
|
|
|
"Unsubscribes from this #{quick_action_target.to_ability_name.humanize(capitalize: false)}."
|
|
|
|
|
end
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted? &&
|
|
|
|
|
quick_action_target.subscribed?(current_user, project)
|
|
|
|
|
end
|
|
|
|
|
command :unsubscribe do
|
|
|
|
|
@updates[:subscription_event] = 'unsubscribe'
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _('Toggle emoji award')
|
2019-07-07 11:18:12 +05:30
|
|
|
|
explanation do |name|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
_("Toggles :%{name}: emoji award.") % { name: name } if name
|
2019-07-07 11:18:12 +05:30
|
|
|
|
end
|
|
|
|
|
params ':emoji:'
|
|
|
|
|
types Issuable
|
|
|
|
|
condition do
|
|
|
|
|
quick_action_target.persisted?
|
|
|
|
|
end
|
|
|
|
|
parse_params do |emoji_param|
|
|
|
|
|
match = emoji_param.match(Banzai::Filter::EmojiFilter.emoji_pattern)
|
|
|
|
|
match[1] if match
|
|
|
|
|
end
|
|
|
|
|
command :award do |name|
|
|
|
|
|
if name && quick_action_target.user_can_award?(current_user)
|
|
|
|
|
@updates[:emoji_award] = name
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _("Append the comment with %{shrug}") % { shrug: SHRUG }
|
2019-07-07 11:18:12 +05:30
|
|
|
|
params '<Comment>'
|
|
|
|
|
types Issuable
|
|
|
|
|
substitution :shrug do |comment|
|
|
|
|
|
"#{comment} #{SHRUG}"
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
|
desc _("Append the comment with %{TABLEFLIP}") % { tableflip: TABLEFLIP }
|
2019-07-07 11:18:12 +05:30
|
|
|
|
params '<Comment>'
|
|
|
|
|
types Issuable
|
|
|
|
|
substitution :tableflip do |comment|
|
|
|
|
|
"#{comment} #{TABLEFLIP}"
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|