Commit 1a9657f9 authored by Mayra Cabrera's avatar Mayra Cabrera

Merge branch '212566-foss-design-management-finders-helpers' into 'master'

Move Design Management helpers and finders to FOSS

See merge request gitlab-org/gitlab!31561
parents d26dd793 fdb0d7e6
...@@ -23,7 +23,7 @@ class TodosFinder ...@@ -23,7 +23,7 @@ class TodosFinder
NONE = '0' NONE = '0'
TODO_TYPES = Set.new(%w(Issue MergeRequest)).freeze TODO_TYPES = Set.new(%w(Issue MergeRequest DesignManagement::Design)).freeze
attr_accessor :current_user, :params attr_accessor :current_user, :params
......
...@@ -167,6 +167,8 @@ module EventsHelper ...@@ -167,6 +167,8 @@ module EventsHelper
project_issue_url(event.project, id: event.note_target, anchor: dom_id(event.target)) project_issue_url(event.project, id: event.note_target, anchor: dom_id(event.target))
elsif event.merge_request_note? elsif event.merge_request_note?
project_merge_request_url(event.project, id: event.note_target, anchor: dom_id(event.target)) project_merge_request_url(event.project, id: event.note_target, anchor: dom_id(event.target))
elsif event.design_note?
design_url(event.note_target, anchor: dom_id(event.note))
else else
polymorphic_url([event.project.namespace.becomes(Namespace), polymorphic_url([event.project.namespace.becomes(Namespace),
event.project, event.note_target], event.project, event.note_target],
...@@ -237,6 +239,16 @@ module EventsHelper ...@@ -237,6 +239,16 @@ module EventsHelper
concat content_tag(:span, event.author.to_reference, class: "username") concat content_tag(:span, event.author.to_reference, class: "username")
end end
end end
private
def design_url(design, opts)
designs_project_issue_url(
design.project,
design.issue,
opts.merge(vueroute: design.filename)
)
end
end end
EventsHelper.prepend_if_ee('EE::EventsHelper') EventsHelper.prepend_if_ee('EE::EventsHelper')
...@@ -9,7 +9,8 @@ module ExportHelper ...@@ -9,7 +9,8 @@ module ExportHelper
_('Project configuration, including services'), _('Project configuration, including services'),
_('Issues with comments, merge requests with diffs and comments, labels, milestones, snippets, and other project entities'), _('Issues with comments, merge requests with diffs and comments, labels, milestones, snippets, and other project entities'),
_('LFS objects'), _('LFS objects'),
_('Issue Boards') _('Issue Boards'),
_('Design Management files and data')
] ]
end end
......
...@@ -54,7 +54,8 @@ module NavHelper ...@@ -54,7 +54,8 @@ module NavHelper
current_path?('merge_requests#show') || current_path?('merge_requests#show') ||
current_path?('projects/merge_requests/conflicts#show') || current_path?('projects/merge_requests/conflicts#show') ||
current_path?('issues#show') || current_path?('issues#show') ||
current_path?('milestones#show') current_path?('milestones#show') ||
current_path?('issues#designs')
end end
def admin_monitoring_nav_links def admin_monitoring_nav_links
......
...@@ -27,7 +27,11 @@ module SystemNoteHelper ...@@ -27,7 +27,11 @@ module SystemNoteHelper
'locked' => 'lock', 'locked' => 'lock',
'unlocked' => 'lock-open', 'unlocked' => 'lock-open',
'due_date' => 'calendar', 'due_date' => 'calendar',
'health_status' => 'status-health' 'health_status' => 'status-health',
'designs_added' => 'doc-image',
'designs_modified' => 'doc-image',
'designs_removed' => 'doc-image',
'designs_discussion_added' => 'doc-image'
}.freeze }.freeze
def system_note_icon_name(note) def system_note_icon_name(note)
......
...@@ -53,6 +53,8 @@ module TodosHelper ...@@ -53,6 +53,8 @@ module TodosHelper
end end
def todo_target_type_name(todo) def todo_target_type_name(todo)
return _('design') if todo.for_design?
todo.target_type.titleize.downcase todo.target_type.titleize.downcase
end end
...@@ -63,6 +65,8 @@ module TodosHelper ...@@ -63,6 +65,8 @@ module TodosHelper
if todo.for_commit? if todo.for_commit?
project_commit_path(todo.project, todo.target, path_options) project_commit_path(todo.project, todo.target, path_options)
elsif todo.for_design?
todos_design_path(todo, path_options)
else else
path = [todo.resource_parent, todo.target] path = [todo.resource_parent, todo.target]
...@@ -151,7 +155,8 @@ module TodosHelper ...@@ -151,7 +155,8 @@ module TodosHelper
[ [
{ id: '', text: 'Any Type' }, { id: '', text: 'Any Type' },
{ id: 'Issue', text: 'Issue' }, { id: 'Issue', text: 'Issue' },
{ id: 'MergeRequest', text: 'Merge Request' } { id: 'MergeRequest', text: 'Merge Request' },
{ id: 'DesignManagement::Design', text: 'Design' }
] ]
end end
...@@ -188,6 +193,18 @@ module TodosHelper ...@@ -188,6 +193,18 @@ module TodosHelper
private private
def todos_design_path(todo, path_options)
design = todo.target
designs_project_issue_path(
todo.resource_parent,
design.issue,
path_options.merge(
vueroute: design.filename
)
)
end
def todo_action_subject(todo) def todo_action_subject(todo)
todo.self_added? ? 'yourself' : 'you' todo.self_added? ? 'yourself' : 'you'
end end
......
# frozen_string_literal: true # frozen_string_literal: true
require_dependency 'design_management'
module DesignManagement module DesignManagement
class Action < ApplicationRecord class Action < ApplicationRecord
include WithUploads include WithUploads
......
...@@ -4,7 +4,7 @@ module EE ...@@ -4,7 +4,7 @@ module EE
module TodosFinder module TodosFinder
extend ActiveSupport::Concern extend ActiveSupport::Concern
EE_TODO_TYPES = (::TodosFinder::TODO_TYPES + %w[Epic DesignManagement::Design]).freeze EE_TODO_TYPES = (::TodosFinder::TODO_TYPES + %w[Epic]).freeze
class_methods do class_methods do
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
......
...@@ -6,23 +6,9 @@ module EE ...@@ -6,23 +6,9 @@ module EE
override :event_note_target_url override :event_note_target_url
def event_note_target_url(event) def event_note_target_url(event)
if event.epic_note? return group_epic_url(event.group, event.note_target, anchor: dom_id(event.target)) if event.epic_note?
group_epic_url(event.group, event.note_target, anchor: dom_id(event.target))
elsif event.design_note?
design_url(event.note_target, anchor: dom_id(event.note))
else
super
end
end
private
def design_url(design, opts) super
designs_project_issue_url(
design.project,
design.issue,
opts.merge(vueroute: design.filename)
)
end end
end end
end end
...@@ -4,11 +4,6 @@ module EE ...@@ -4,11 +4,6 @@ module EE
module ExportHelper module ExportHelper
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
override :project_export_descriptions
def project_export_descriptions
super + [_('Design Management files and data')]
end
override :group_export_descriptions override :group_export_descriptions
def group_export_descriptions def group_export_descriptions
super + [_('Epics'), _('Events')] super + [_('Epics'), _('Events')]
......
...@@ -11,9 +11,7 @@ module EE ...@@ -11,9 +11,7 @@ module EE
override :page_has_markdown? override :page_has_markdown?
def page_has_markdown? def page_has_markdown?
super || super || current_path?('epics#show')
current_path?('epics#show') ||
current_path?('issues#designs')
end end
override :admin_monitoring_nav_links override :admin_monitoring_nav_links
......
...@@ -19,10 +19,6 @@ module EE ...@@ -19,10 +19,6 @@ module EE
'weight' => 'weight', 'weight' => 'weight',
'relate_epic' => 'epic', 'relate_epic' => 'epic',
'unrelate_epic' => 'epic', 'unrelate_epic' => 'epic',
'designs_added' => 'doc-image',
'designs_modified' => 'doc-image',
'designs_removed' => 'doc-image',
'designs_discussion_added' => 'doc-image',
'vulnerability_confirmed' => 'shield', 'vulnerability_confirmed' => 'shield',
'vulnerability_dismissed' => 'cancel', 'vulnerability_dismissed' => 'cancel',
'vulnerability_resolved' => 'status_closed', 'vulnerability_resolved' => 'status_closed',
......
...@@ -4,45 +4,9 @@ module EE ...@@ -4,45 +4,9 @@ module EE
module TodosHelper module TodosHelper
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
override :todo_target_path
def todo_target_path(todo)
return todos_design_path(todo) if todo.for_design?
super
end
override :todo_target_type_name
def todo_target_type_name(todo)
return _('design') if todo.for_design?
super
end
override :todo_types_options override :todo_types_options
def todo_types_options def todo_types_options
super + ee_todo_types_options super + [{ id: 'Epic', text: 'Epic' }]
end
private
def todos_design_path(todo)
design = todo.target
path_options = todo_target_path_options(todo).merge(
vueroute: design.filename
)
designs_project_issue_path(
todo.resource_parent,
design.issue,
path_options
)
end
def ee_todo_types_options
[
{ id: 'Epic', text: 'Epic' },
{ id: 'DesignManagement::Design', text: 'Design' }
]
end end
end end
end end
...@@ -148,7 +148,7 @@ module EE ...@@ -148,7 +148,7 @@ module EE
scope :aimed_for_deletion, -> (date) { where('marked_for_deletion_at <= ?', date).without_deleted } scope :aimed_for_deletion, -> (date) { where('marked_for_deletion_at <= ?', date).without_deleted }
scope :with_repos_templates, -> { where(namespace_id: ::Gitlab::CurrentSettings.current_application_settings.custom_project_templates_group_id) } scope :with_repos_templates, -> { where(namespace_id: ::Gitlab::CurrentSettings.current_application_settings.custom_project_templates_group_id) }
scope :with_groups_level_repos_templates, -> { joins("INNER JOIN namespaces ON projects.namespace_id = namespaces.custom_project_templates_group_id") } scope :with_groups_level_repos_templates, -> { joins("INNER JOIN namespaces ON projects.namespace_id = namespaces.custom_project_templates_group_id") }
scope :with_designs, -> { where(id: DesignManagement::Design.select(:project_id)) } scope :with_designs, -> { where(id: ::DesignManagement::Design.select(:project_id)) }
scope :with_deleting_user, -> { includes(:deleting_user) } scope :with_deleting_user, -> { includes(:deleting_user) }
scope :with_compliance_framework_settings, -> { preload(:compliance_framework_setting) } scope :with_compliance_framework_settings, -> { preload(:compliance_framework_setting) }
scope :has_vulnerabilities, -> { joins(:vulnerabilities).group(:id) } scope :has_vulnerabilities, -> { joins(:vulnerabilities).group(:id) }
......
...@@ -9,15 +9,5 @@ FactoryBot.modify do ...@@ -9,15 +9,5 @@ FactoryBot.modify do
action { Event::CREATED } action { Event::CREATED }
project { nil } project { nil }
end end
trait :for_design do
transient do
design { create(:design, issue: create(:issue, project: project)) }
note { create(:note, author: author, project: project, noteable: design) }
end
action { Event::COMMENTED }
target { note }
end
end end
end end
...@@ -4,20 +4,16 @@ require 'spec_helper' ...@@ -4,20 +4,16 @@ require 'spec_helper'
describe EventsHelper do describe EventsHelper do
describe '#event_note_target_url' do describe '#event_note_target_url' do
let(:project) { event.project }
let(:project_base_url) { project_url(project) }
subject { helper.event_note_target_url(event) } subject { helper.event_note_target_url(event) }
context 'for design note events' do context 'for epic note events' do
let(:event) { create(:event, :for_design) } let_it_be(:group) { create(:group, :public) }
let_it_be(:event) { create(:event, group: group) }
it 'returns an appropriate URL' do it 'returns an epic url' do
iid = event.note_target.issue.iid event.target = create(:note_on_epic, note: 'foo')
filename = event.note_target.filename
note_id = event.target.id
expect(subject).to eq("#{project_base_url}/-/issues/#{iid}/designs/#{filename}#note_#{note_id}") expect(subject).to match("#{group.to_param}/-/epics/#{event.note_target.iid}#note_#{event.target.id}")
end end
end end
end end
......
...@@ -3,59 +3,11 @@ ...@@ -3,59 +3,11 @@
require 'spec_helper' require 'spec_helper'
describe ::TodosHelper do describe ::TodosHelper do
let_it_be(:user) { create(:user) }
let_it_be(:author) { create(:user) }
let_it_be(:issue) { create(:issue) }
let_it_be(:design) { create(:design, issue: issue) }
let_it_be(:note) do
create(:note,
project: issue.project,
note: "I am note, hear me roar")
end
let_it_be(:design_todo) do
create(:todo, :mentioned,
user: user,
project: issue.project,
target: design,
author: author,
note: note)
end
let(:project) { issue.project }
describe '#todo_target_link' do
context 'when given a design' do
let(:todo) { design_todo }
it 'produces a good link' do
path = helper.todo_target_path(todo)
link = helper.todo_target_link(todo)
expected = "<a href=\"#{path}\">design #{design.to_reference}</a>"
expect(link).to eq(expected)
end
end
end
describe '#todo_target_path' do
context 'when given a design' do
let(:todo) { design_todo }
it 'responds with an appropriate path' do
path = helper.todo_target_path(todo)
issue_path = Gitlab::Routing.url_helpers
.project_issue_path(project, issue)
expect(path).to eq("#{issue_path}/designs/#{design.filename}##{dom_id(design_todo.note)}")
end
end
end
describe '#todo_types_options' do describe '#todo_types_options' do
it 'includes a match for a design todo' do it 'includes options for an epic todo' do
options = helper.todo_types_options expect(helper.todo_types_options).to include(
design_option = options.find { |o| o[:id] == design_todo.target_type } { id: 'Epic', text: 'Epic' }
)
expect(design_option).to include(text: 'Design')
end end
end end
end end
...@@ -81,7 +81,7 @@ describe EE::SystemNotes::DesignManagementService do ...@@ -81,7 +81,7 @@ describe EE::SystemNotes::DesignManagementService do
end end
it 'has a valid action' do it 'has a valid action' do
expect(EE::SystemNoteHelper::EE_ICON_NAMES_BY_ACTION) expect(::SystemNoteHelper::ICON_NAMES_BY_ACTION)
.to include(metadata.action) .to include(metadata.action)
end end
end end
......
...@@ -32,6 +32,16 @@ FactoryBot.define do ...@@ -32,6 +32,16 @@ FactoryBot.define do
wiki_page { create(:wiki_page, container: project) } wiki_page { create(:wiki_page, container: project) }
end end
end end
trait :for_design do
transient do
design { create(:design, issue: create(:issue, project: project)) }
note { create(:note, author: author, project: project, noteable: design) }
end
action { Event::COMMENTED }
target { note }
end
end end
factory :push_event, class: 'PushEvent' do factory :push_event, class: 'PushEvent' do
......
...@@ -260,9 +260,9 @@ describe TodosFinder do ...@@ -260,9 +260,9 @@ describe TodosFinder do
it 'returns the expected types' do it 'returns the expected types' do
expected_result = expected_result =
if Gitlab.ee? if Gitlab.ee?
%w[DesignManagement::Design Epic Issue MergeRequest] %w[Epic Issue MergeRequest DesignManagement::Design]
else else
%w[Issue MergeRequest] %w[Issue MergeRequest DesignManagement::Design]
end end
expect(described_class.todo_types).to contain_exactly(*expected_result) expect(described_class.todo_types).to contain_exactly(*expected_result)
......
...@@ -199,5 +199,17 @@ describe EventsHelper do ...@@ -199,5 +199,17 @@ describe EventsHelper do
expect(subject).to eq("#{project_base_url}/-/merge_requests/#{event.note_target.iid}#note_#{event.target.id}") expect(subject).to eq("#{project_base_url}/-/merge_requests/#{event.note_target.iid}#note_#{event.target.id}")
end end
context 'for design note events' do
let(:event) { create(:event, :for_design, project: project) }
it 'returns an appropriate URL' do
iid = event.note_target.issue.iid
filename = event.note_target.filename
note_id = event.target.id
expect(subject).to eq("#{project_base_url}/-/issues/#{iid}/designs/#{filename}#note_#{note_id}")
end
end
end end
end end
...@@ -117,4 +117,27 @@ describe NavHelper, :do_not_mock_admin_mode do ...@@ -117,4 +117,27 @@ describe NavHelper, :do_not_mock_admin_mode do
it { is_expected.to all(be_a(String)) } it { is_expected.to all(be_a(String)) }
end end
describe '#page_has_markdown?' do
using RSpec::Parameterized::TableSyntax
where path: %w(
merge_requests#show
projects/merge_requests/conflicts#show
issues#show
milestones#show
issues#designs
)
with_them do
before do
allow(helper).to receive(:current_path?).and_call_original
allow(helper).to receive(:current_path?).with(path).and_return(true)
end
subject { helper.page_has_markdown? }
it { is_expected.to eq(true) }
end
end
end end
# frozen_string_literal: true # frozen_string_literal: true
require "spec_helper" require 'spec_helper'
describe TodosHelper do describe TodosHelper do
let_it_be(:user) { create(:user) }
let_it_be(:author) { create(:user) }
let_it_be(:issue) { create(:issue) }
let_it_be(:design) { create(:design, issue: issue) }
let_it_be(:note) do
create(:note,
project: issue.project,
note: 'I am note, hear me roar')
end
let_it_be(:design_todo) do
create(:todo, :mentioned,
user: user,
project: issue.project,
target: design,
author: author,
note: note)
end
describe '#todos_count_format' do describe '#todos_count_format' do
it 'shows fuzzy count for 100 or more items' do it 'shows fuzzy count for 100 or more items' do
expect(helper.todos_count_format(100)).to eq '99+' expect(helper.todos_count_format(100)).to eq '99+'
...@@ -35,4 +53,53 @@ describe TodosHelper do ...@@ -35,4 +53,53 @@ describe TodosHelper do
expect(Gitlab::Json.parse(helper.todo_projects_options)).to match_array(expected_results) expect(Gitlab::Json.parse(helper.todo_projects_options)).to match_array(expected_results)
end end
end end
describe '#todo_target_link' do
context 'when given a design' do
let(:todo) { design_todo }
it 'produces a good link' do
path = helper.todo_target_path(todo)
link = helper.todo_target_link(todo)
expected = "<a href=\"#{path}\">design #{design.to_reference}</a>"
expect(link).to eq(expected)
end
end
end
describe '#todo_target_path' do
context 'when given a design' do
let(:todo) { design_todo }
it 'responds with an appropriate path' do
path = helper.todo_target_path(todo)
issue_path = Gitlab::Routing.url_helpers
.project_issue_path(issue.project, issue)
expect(path).to eq("#{issue_path}/designs/#{design.filename}##{dom_id(design_todo.note)}")
end
end
end
describe '#todo_target_type_name' do
context 'when given a design todo' do
let(:todo) { design_todo }
it 'responds with an appropriate target type name' do
name = helper.todo_target_type_name(todo)
expect(name).to eq('design')
end
end
end
describe '#todo_types_options' do
it 'includes a match for a design todo' do
options = helper.todo_types_options
design_option = options.find { |o| o[:id] == design_todo.target_type }
expect(design_option).to include(text: 'Design')
end
end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment