Commit f5af4d6d authored by Alexis Reigel's avatar Alexis Reigel Committed by Winnie Hellmann

convert admin runners table to responsive table

(cherry picked from commit 72c5fc73df4be39a6aa6265aa3584147d922e63e)
parent e39f2c6f
%tr{ id: dom_id(runner) } .gl-responsive-table-row{ id: dom_id(runner) }
%td .table-section.section-10
- if runner.instance_type? .table-mobile-header{ role: "rowheader" } Type
%span.badge.badge-success shared .table-mobile-content
- elsif runner.group_type? - if runner.instance_type?
%span.badge.badge-success group %span.badge.badge-success shared
- else - elsif runner.group_type?
%span.badge.badge-info specific %span.badge.badge-success group
- if runner.locked?
%span.badge.badge-warning locked
- unless runner.active?
%span.badge.badge-danger paused
%td
= link_to admin_runner_path(runner) do
= runner.short_sha
%td
= runner.description
%td
= runner.version
%td
= runner.ip_address
%td
- if runner.instance_type? || runner.group_type?
n/a
- else
= runner.projects.count(:all)
%td
#{runner.builds.count(:all)}
%td
- runner.tag_list.sort.each do |tag|
%span.badge.badge-primary
= tag
%td
- if runner.contacted_at
= time_ago_with_tooltip runner.contacted_at
- else
Never
%td.admin-runner-btn-group-cell
.float-right.btn-group
= link_to admin_runner_path(runner), class: 'btn btn-sm btn-default has-tooltip', title: 'Edit', ref: 'tooltip', aria: { label: 'Edit' }, data: { placement: 'top', container: 'body'} do
= icon('pencil')
 
- if runner.active?
= link_to [:pause, :admin, runner], method: :get, class: 'btn btn-sm btn-default has-tooltip', title: 'Pause', ref: 'tooltip', aria: { label: 'Pause' }, data: { placement: 'top', container: 'body', confirm: "Are you sure?" } do
= icon('pause')
- else - else
= link_to [:resume, :admin, runner], method: :get, class: 'btn btn-default btn-sm has-tooltip', title: 'Resume', ref: 'tooltip', aria: { label: 'Resume' }, data: { placement: 'top', container: 'body'} do %span.badge.badge-info specific
= icon('play') - if runner.locked?
= link_to [:admin, runner], method: :delete, class: 'btn btn-danger btn-sm has-tooltip', title: 'Remove', ref: 'tooltip', aria: { label: 'Remove' }, data: { placement: 'top', container: 'body', confirm: "Are you sure?" } do %span.badge.badge-warning locked
= icon('remove') - unless runner.active?
%span.badge.badge-danger paused
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } Runner token
.table-mobile-content
= link_to runner.short_sha, admin_runner_path(runner)
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } Description
.table-mobile-content
= runner.description
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } Version
.table-mobile-content
= runner.version
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } IP Address
.table-mobile-content
= runner.ip_address
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } Projects
.table-mobile-content
- if runner.instance_type? || runner.group_type?
n/a
- else
= runner.projects.count(:all)
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } Jobs
.table-mobile-content
= runner.builds.count(:all)
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } Tags
.table-mobile-content
- runner.tag_list.sort.each do |tag|
%span.badge.badge-primary
= tag
.table-section.section-10
.table-mobile-header{ role: 'rowheader' } Last contact
.table-mobile-content
- if runner.contacted_at
= time_ago_with_tooltip runner.contacted_at
- else
Never
.table-section.table-button-footer.section-10
.btn-group.table-action-buttons
.btn-group
= link_to admin_runner_path(runner), class: 'btn btn-default has-tooltip', title: 'Edit', ref: 'tooltip', aria: { label: 'Edit' }, data: { placement: 'top', container: 'body'} do
= icon('pencil')
.btn-group
- if runner.active?
= link_to [:pause, :admin, runner], method: :get, class: 'btn btn-default has-tooltip', title: 'Pause', ref: 'tooltip', aria: { label: 'Pause' }, data: { placement: 'top', container: 'body', confirm: "Are you sure?" } do
= icon('pause')
- else
= link_to [:resume, :admin, runner], method: :get, class: 'btn btn-default has-tooltip', title: 'Resume', ref: 'tooltip', aria: { label: 'Resume' }, data: { placement: 'top', container: 'body'} do
= icon('play')
.btn-group
= link_to [:admin, runner], method: :delete, class: 'btn btn-danger has-tooltip', title: 'Remove', ref: 'tooltip', aria: { label: 'Remove' }, data: { placement: 'top', container: 'body', confirm: "Are you sure?" } do
= icon('remove')
...@@ -92,24 +92,21 @@ ...@@ -92,24 +92,21 @@
%br %br
- if @runners.any? - if @runners.any?
.runners-content .runners-content.content-list
.table-holder .table-holder
%table.table .gl-responsive-table-row.table-row-header{ role: 'row' }
%thead .table-section.section-10{ role: 'rowheader' } Type
%tr .table-section.section-10{ role: 'rowheader' } Runner token
%th Type .table-section.section-10{ role: 'rowheader' } Description
%th Runner token .table-section.section-10{ role: 'rowheader' } Version
%th Description .table-section.section-10{ role: 'rowheader' } IP Address
%th Version .table-section.section-10{ role: 'rowheader' } Projects
%th IP Address .table-section.section-10{ role: 'rowheader' } Jobs
%th Projects .table-section.section-10{ role: 'rowheader' } Tags
%th Jobs .table-section.section-10{ role: 'rowheader' } Last contact
%th Tags
%th Last contact
%th
- @runners.each do |runner| - @runners.each do |runner|
= render "admin/runners/runner", runner: runner = render "admin/runners/runner", runner: runner
= paginate @runners, theme: "gitlab" = paginate @runners, theme: "gitlab"
- else - else
.nothing-here-block No runners found .nothing-here-block No runners found
...@@ -99,26 +99,22 @@ describe "Admin Runners", :js do ...@@ -99,26 +99,22 @@ describe "Admin Runners", :js do
visit admin_runners_path visit admin_runners_path
within '.runners-content tbody' do within '.runners-content .gl-responsive-table-row:nth-child(2)' do
within('tr:nth-child(1)') do expect(page).to have_content 'runner-2'
expect(page).to have_content 'runner-2' end
end
within('tr:nth-child(2)') do within '.runners-content .gl-responsive-table-row:nth-child(3)' do
expect(page).to have_content 'runner-1' expect(page).to have_content 'runner-1'
end
end end
sorting_by 'Last Contact' sorting_by 'Last Contact'
within '.runners-content tbody' do within '.runners-content .gl-responsive-table-row:nth-child(2)' do
within('tr:nth-child(1)') do expect(page).to have_content 'runner-1'
expect(page).to have_content 'runner-1' end
end
within('tr:nth-child(2)') do within '.runners-content .gl-responsive-table-row:nth-child(3)' do
expect(page).to have_content 'runner-2' expect(page).to have_content 'runner-2'
end
end end
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