Merge branch 'dashboard-labels' into 'master'
Dashboard labels Previously because there were no JSON endpoint for labels or milestones it was fetching HTML and parsing that. This is wrong. It now fetches from a JSON endpoint. This also fixes the dashboard/issues page not loading labels or milestones as the path used to be only for a single project. So instead I have created a endpoint for labels & milestones JSON on dashboard. See merge request !3253
This commit is contained in:
commit
7a33afb760
12 changed files with 113 additions and 94 deletions
|
@ -39,18 +39,9 @@ class @LabelsSelect
|
||||||
|
|
||||||
$dropdown.glDropdown(
|
$dropdown.glDropdown(
|
||||||
data: (term, callback) ->
|
data: (term, callback) ->
|
||||||
# We have to fetch the JS version of the labels list because there is no
|
|
||||||
# public facing JSON url for labels
|
|
||||||
$.ajax(
|
$.ajax(
|
||||||
url: labelUrl
|
url: labelUrl
|
||||||
).done (data) ->
|
).done (data) ->
|
||||||
html = $(data)
|
|
||||||
data = []
|
|
||||||
html.find('.label-row a').each ->
|
|
||||||
data.push(
|
|
||||||
title: $(@).text().trim()
|
|
||||||
)
|
|
||||||
|
|
||||||
if showNo
|
if showNo
|
||||||
data.unshift(
|
data.unshift(
|
||||||
id: 0
|
id: 0
|
||||||
|
|
|
@ -15,15 +15,6 @@ class @MilestoneSelect
|
||||||
$.ajax(
|
$.ajax(
|
||||||
url: milestonesUrl
|
url: milestonesUrl
|
||||||
).done (data) ->
|
).done (data) ->
|
||||||
html = $(data)
|
|
||||||
data = []
|
|
||||||
html.find('.milestone strong a').each ->
|
|
||||||
link = $(@).attr('href').split('/')
|
|
||||||
data.push(
|
|
||||||
id: link[link.length - 1]
|
|
||||||
title: $(@).text().trim()
|
|
||||||
)
|
|
||||||
|
|
||||||
if showNo
|
if showNo
|
||||||
data.unshift(
|
data.unshift(
|
||||||
id: '0'
|
id: '0'
|
||||||
|
|
|
@ -3,7 +3,7 @@ class DashboardController < Dashboard::ApplicationController
|
||||||
include MergeRequestsAction
|
include MergeRequestsAction
|
||||||
|
|
||||||
before_action :event_filter, only: :activity
|
before_action :event_filter, only: :activity
|
||||||
before_action :projects, only: [:issues, :merge_requests]
|
before_action :projects, only: [:issues, :merge_requests, :labels, :milestones]
|
||||||
|
|
||||||
respond_to :html
|
respond_to :html
|
||||||
|
|
||||||
|
@ -20,6 +20,22 @@ class DashboardController < Dashboard::ApplicationController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def labels
|
||||||
|
respond_to do |format|
|
||||||
|
format.json do
|
||||||
|
render json: view_context.projects_labels_options
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def milestones
|
||||||
|
respond_to do |format|
|
||||||
|
format.json do
|
||||||
|
render json: view_context.projects_milestones_options
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def load_events
|
def load_events
|
||||||
|
|
|
@ -12,6 +12,13 @@ class Projects::LabelsController < Projects::ApplicationController
|
||||||
|
|
||||||
def index
|
def index
|
||||||
@labels = @project.labels.page(params[:page]).per(PER_PAGE)
|
@labels = @project.labels.page(params[:page]).per(PER_PAGE)
|
||||||
|
|
||||||
|
respond_to do |format|
|
||||||
|
format.html
|
||||||
|
format.json do
|
||||||
|
render json: @project.labels
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def new
|
def new
|
||||||
|
|
|
@ -19,7 +19,15 @@ class Projects::MilestonesController < Projects::ApplicationController
|
||||||
end
|
end
|
||||||
|
|
||||||
@milestones = @milestones.includes(:project)
|
@milestones = @milestones.includes(:project)
|
||||||
@milestones = @milestones.page(params[:page]).per(PER_PAGE)
|
|
||||||
|
respond_to do |format|
|
||||||
|
format.html do
|
||||||
|
@milestones = @milestones.page(params[:page]).per(PER_PAGE)
|
||||||
|
end
|
||||||
|
format.json do
|
||||||
|
render json: @milestones
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def new
|
def new
|
||||||
|
|
|
@ -24,7 +24,7 @@ module DropdownsHelper
|
||||||
capture(&block) if block && !options.has_key?(:footer_content)
|
capture(&block) if block && !options.has_key?(:footer_content)
|
||||||
end
|
end
|
||||||
|
|
||||||
if block && options.has_key?(:footer_content)
|
if block && options[:footer_content]
|
||||||
output << content_tag(:div, class: "dropdown-footer") do
|
output << content_tag(:div, class: "dropdown-footer") do
|
||||||
capture(&block)
|
capture(&block)
|
||||||
end
|
end
|
||||||
|
|
|
@ -110,18 +110,19 @@ module LabelsHelper
|
||||||
end
|
end
|
||||||
|
|
||||||
def projects_labels_options
|
def projects_labels_options
|
||||||
labels =
|
if @project
|
||||||
if @project
|
@project.labels
|
||||||
@project.labels
|
else
|
||||||
else
|
Label.where(project_id: @projects)
|
||||||
Label.where(project_id: @projects)
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
grouped_labels = GlobalLabel.build_collection(labels)
|
def labels_filter_path
|
||||||
grouped_labels.unshift(Label::None)
|
if @project
|
||||||
grouped_labels.unshift(Label::Any)
|
namespace_project_labels_path(@project.namespace, @project, :json)
|
||||||
|
else
|
||||||
options_from_collection_for_select(grouped_labels, 'name', 'title', params[:label_name])
|
labels_dashboard_path(:json)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def label_subscription_status(label)
|
def label_subscription_status(label)
|
||||||
|
|
|
@ -56,12 +56,15 @@ module MilestonesHelper
|
||||||
|
|
||||||
epoch = DateTime.parse('1970-01-01')
|
epoch = DateTime.parse('1970-01-01')
|
||||||
grouped_milestones = GlobalMilestone.build_collection(milestones)
|
grouped_milestones = GlobalMilestone.build_collection(milestones)
|
||||||
grouped_milestones = grouped_milestones.sort_by { |x| x.due_date.nil? ? epoch : x.due_date }
|
grouped_milestones.sort_by { |x| x.due_date.nil? ? epoch : x.due_date }
|
||||||
grouped_milestones.unshift(Milestone::None)
|
end
|
||||||
grouped_milestones.unshift(Milestone::Any)
|
|
||||||
grouped_milestones.unshift(Milestone::Upcoming)
|
|
||||||
|
|
||||||
options_from_collection_for_select(grouped_milestones, 'name', 'title', params[:milestone_title])
|
def milestones_filter_dropdown_path
|
||||||
|
if @project
|
||||||
|
namespace_project_milestones_path(@project.namespace, @project, :json)
|
||||||
|
else
|
||||||
|
milestones_dashboard_path(:json)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def milestone_remaining_days(milestone)
|
def milestone_remaining_days(milestone)
|
||||||
|
|
|
@ -19,65 +19,10 @@
|
||||||
placeholder: "Search assignee", data: { any_user: "Any Assignee", first_user: (current_user.username if current_user), null_user: true, current_user: true, project_id: (@project.id if @project), selected: params[:assignee_id], field_name: "assignee_id" } })
|
placeholder: "Search assignee", data: { any_user: "Any Assignee", first_user: (current_user.username if current_user), null_user: true, current_user: true, project_id: (@project.id if @project), selected: params[:assignee_id], field_name: "assignee_id" } })
|
||||||
|
|
||||||
.filter-item.inline.milestone-filter
|
.filter-item.inline.milestone-filter
|
||||||
- if params[:milestone_title]
|
= render "shared/issuable/milestone_dropdown"
|
||||||
= hidden_field_tag(:milestone_title, params[:milestone_title])
|
|
||||||
= dropdown_tag(h(params[:milestone_name] || "Milestone"), options: { title: "Filter by milestone", toggle_class: 'js-milestone-select js-filter-submit', filter: true, dropdown_class: "dropdown-menu-selectable",
|
|
||||||
placeholder: "Search milestones", footer_content: true, data: { show_no: true, show_any: true, field_name: "milestone_title", selected: params[:milestone_title], project_id: (@project.id if @project), milestones: (namespace_project_milestones_path(@project.namespace, @project, :js) if @project) } }) do
|
|
||||||
- if @project
|
|
||||||
%ul.dropdown-footer-list
|
|
||||||
- if can? current_user, :admin_milestone, @project
|
|
||||||
%li
|
|
||||||
= link_to new_namespace_project_milestone_path(@project.namespace, @project), title: "New Milestone" do
|
|
||||||
Create new
|
|
||||||
%li
|
|
||||||
= link_to namespace_project_milestones_path(@project.namespace, @project) do
|
|
||||||
- if can? current_user, :admin_milestone, @project
|
|
||||||
Manage milestones
|
|
||||||
- else
|
|
||||||
View milestones
|
|
||||||
|
|
||||||
.filter-item.inline.labels-filter
|
.filter-item.inline.labels-filter
|
||||||
- if params[:label_name]
|
= render "shared/issuable/label_dropdown"
|
||||||
= hidden_field_tag(:label_name, params[:label_name])
|
|
||||||
.dropdown
|
|
||||||
%button.dropdown-menu-toggle.js-label-select.js-filter-submit{type: "button", data: {toggle: "dropdown", field_name: "label_name", show_no: "true", show_any: "true", selected: params[:label_name], project_id: (@project.id if @project), labels: (namespace_project_labels_path(@project.namespace, @project, :js) if @project)}}
|
|
||||||
%span.dropdown-toggle-text
|
|
||||||
= h(params[:label_name] || "Label")
|
|
||||||
= icon('chevron-down')
|
|
||||||
.dropdown-menu.dropdown-select.dropdown-menu-paging.dropdown-menu-labels.dropdown-menu-selectable
|
|
||||||
.dropdown-page-one
|
|
||||||
= dropdown_title("Filter by label")
|
|
||||||
= dropdown_filter("Search labels")
|
|
||||||
= dropdown_content
|
|
||||||
- if @project
|
|
||||||
= dropdown_footer do
|
|
||||||
%ul.dropdown-footer-list
|
|
||||||
- if can? current_user, :admin_label, @project
|
|
||||||
%li
|
|
||||||
%a.dropdown-toggle-page{href: "#"}
|
|
||||||
Create new
|
|
||||||
%li
|
|
||||||
= link_to namespace_project_labels_path(@project.namespace, @project) do
|
|
||||||
- if can? current_user, :admin_label, @project
|
|
||||||
Manage labels
|
|
||||||
- else
|
|
||||||
View labels
|
|
||||||
- if can? current_user, :admin_label, @project
|
|
||||||
.dropdown-page-two
|
|
||||||
= dropdown_title("Create new label", back: true)
|
|
||||||
= dropdown_content do
|
|
||||||
%input#new_label_color{type: "hidden"}
|
|
||||||
%input#new_label_name.dropdown-input-field{type: "text", placeholder: "Name new label"}
|
|
||||||
.dropdown-label-color-preview.js-dropdown-label-color-preview
|
|
||||||
.suggest-colors.suggest-colors-dropdown
|
|
||||||
- suggested_colors.each do |color|
|
|
||||||
= link_to '#', style: "background-color: #{color}", data: { color: color } do
|
|
||||||
 
|
|
||||||
%button.btn.btn-primary.js-new-label-btn{type: "button"}
|
|
||||||
Create
|
|
||||||
= dropdown_loading
|
|
||||||
.dropdown-loading
|
|
||||||
= icon('spinner spin')
|
|
||||||
|
|
||||||
.pull-right
|
.pull-right
|
||||||
= render 'shared/sort_dropdown'
|
= render 'shared/sort_dropdown'
|
||||||
|
|
39
app/views/shared/issuable/_label_dropdown.html.haml
Normal file
39
app/views/shared/issuable/_label_dropdown.html.haml
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
- if params[:label_name]
|
||||||
|
= hidden_field_tag(:label_name, params[:label_name])
|
||||||
|
.dropdown
|
||||||
|
%button.dropdown-menu-toggle.js-label-select.js-filter-submit{type: "button", data: {toggle: "dropdown", field_name: "label_name", show_no: "true", show_any: "true", selected: params[:label_name], project_id: @project.try(:id), labels: labels_filter_path}}
|
||||||
|
%span.dropdown-toggle-text
|
||||||
|
= h(params[:label_name] || "Label")
|
||||||
|
= icon('chevron-down')
|
||||||
|
.dropdown-menu.dropdown-select.dropdown-menu-paging.dropdown-menu-labels.dropdown-menu-selectable
|
||||||
|
.dropdown-page-one
|
||||||
|
= dropdown_title("Filter by label")
|
||||||
|
= dropdown_filter("Search labels")
|
||||||
|
= dropdown_content
|
||||||
|
- if @project
|
||||||
|
= dropdown_footer do
|
||||||
|
%ul.dropdown-footer-list
|
||||||
|
- if can? current_user, :admin_label, @project
|
||||||
|
%li
|
||||||
|
%a.dropdown-toggle-page{href: "#"}
|
||||||
|
Create new
|
||||||
|
%li
|
||||||
|
= link_to namespace_project_labels_path(@project.namespace, @project) do
|
||||||
|
- if can? current_user, :admin_label, @project
|
||||||
|
Manage labels
|
||||||
|
- else
|
||||||
|
View labels
|
||||||
|
- if can? current_user, :admin_label, @project and @project
|
||||||
|
.dropdown-page-two
|
||||||
|
= dropdown_title("Create new label", back: true)
|
||||||
|
= dropdown_content do
|
||||||
|
%input#new_label_color{type: "hidden"}
|
||||||
|
%input#new_label_name.dropdown-input-field{type: "text", placeholder: "Name new label"}
|
||||||
|
.dropdown-label-color-preview.js-dropdown-label-color-preview
|
||||||
|
.suggest-colors.suggest-colors-dropdown
|
||||||
|
- suggested_colors.each do |color|
|
||||||
|
= link_to '#', style: "background-color: #{color}", data: { color: color } do
|
||||||
|
 
|
||||||
|
%button.btn.btn-primary.js-new-label-btn{type: "button"}
|
||||||
|
Create
|
||||||
|
= dropdown_loading
|
16
app/views/shared/issuable/_milestone_dropdown.html.haml
Normal file
16
app/views/shared/issuable/_milestone_dropdown.html.haml
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
- if params[:milestone_title]
|
||||||
|
= hidden_field_tag(:milestone_title, params[:milestone_title])
|
||||||
|
= dropdown_tag(h(params[:milestone_name] || "Milestone"), options: { title: "Filter by milestone", toggle_class: 'js-milestone-select js-filter-submit', filter: true, dropdown_class: "dropdown-menu-selectable",
|
||||||
|
placeholder: "Search milestones", footer_content: @project.present?, data: { show_no: true, show_any: true, field_name: "milestone_title", selected: params[:milestone_title], project_id: @project.try(:id), milestones: milestones_filter_dropdown_path } }) do
|
||||||
|
- if @project
|
||||||
|
%ul.dropdown-footer-list
|
||||||
|
- if can? current_user, :admin_milestone, @project
|
||||||
|
%li
|
||||||
|
= link_to new_namespace_project_milestone_path(@project.namespace, @project), title: "New Milestone" do
|
||||||
|
Create new
|
||||||
|
%li
|
||||||
|
= link_to namespace_project_milestones_path(@project.namespace, @project) do
|
||||||
|
- if can? current_user, :admin_milestone, @project
|
||||||
|
Manage milestones
|
||||||
|
- else
|
||||||
|
View milestones
|
|
@ -351,6 +351,8 @@ Rails.application.routes.draw do
|
||||||
get :issues
|
get :issues
|
||||||
get :merge_requests
|
get :merge_requests
|
||||||
get :activity
|
get :activity
|
||||||
|
get :labels
|
||||||
|
get :milestones
|
||||||
|
|
||||||
scope module: :dashboard do
|
scope module: :dashboard do
|
||||||
resources :milestones, only: [:index, :show]
|
resources :milestones, only: [:index, :show]
|
||||||
|
|
Loading…
Reference in a new issue