diff --git a/app/assets/stylesheets/application.scss b/app/assets/stylesheets/application.scss index bed67f59a..ced92a576 100644 --- a/app/assets/stylesheets/application.scss +++ b/app/assets/stylesheets/application.scss @@ -754,7 +754,7 @@ body { } } - table, .card-islet { + .card-islet { a:not(.btn):not(.dropdown-item) { text-decoration: none; @@ -825,7 +825,7 @@ body { } .ts-dropdown { - z-index: 9999; + z-index: 8888; } /* Tom-Select fix for bootstrap floating label */ diff --git a/app/assets/stylesheets/components/table_component.scss b/app/assets/stylesheets/components/table_component.scss new file mode 100644 index 000000000..ff2d302df --- /dev/null +++ b/app/assets/stylesheets/components/table_component.scss @@ -0,0 +1,62 @@ +.table-component { + table { + --bs-table-hover-bg: rgb(var(--bs-tertiary-bg-rgb)); + --bs-table-hover-color: var(--bs-link-color); + + th { + a { + font-size: .9rem; + color: var(--bs-tertiary-color); + + &:hover { + color: rgb(var(--bs-link-color-rgb)); + } + + i.bi-caret-down.active::before { + content: "\f229"; + } + + i.bi-caret-up.active::before { + content: "\f235"; + } + } + } + + tr { + td { + padding: 1rem .5rem; + + a:not(.btn):not(.dropdown-item) { + color: inherit; + text-decoration: underline dashed; + text-decoration-color: rgba(var(--bs-body-color-rgb), 0.5); + text-underline-offset: 0.4em; + + &:hover { + text-decoration: underline; + } + } + + /* &:nth-child(even) { + td { + background-color: var(--bs-table-color-state); + } + } */ + + &:hover { + a:not(.btn):not(.dropdown-item) { + &:hover { + text-decoration-color: rgba(var(--bs-link-color-rgb), 0.5); + } + } + } + } + + &:last-child { + td { + border: none !important; + } + } + } + } +} diff --git a/app/components/list/data_table_component.rb b/app/components/list/data_table_component.rb index 301111f53..72fcec225 100644 --- a/app/components/list/data_table_component.rb +++ b/app/components/list/data_table_component.rb @@ -42,10 +42,10 @@ def call def render_head_cell(col) render(List::TableComponent::TableHeadCell.new) do + concat col.title + if (sort_by = col.sort_by) - link_to_sort col.title, sort_by - else - col.title + links_to_sort sort_by end end end @@ -62,28 +62,29 @@ def render_col(col, row) col.call(row) end - def link_to_sort(label, attribute) + def links_to_sort(attribute) current_attribute = params[:sort_by]&.to_sym - current_direction = current_attribute == attribute ? params[:sort].to_sym : nil + is_current_attribute = current_attribute == attribute + current_direction = is_current_attribute ? params[:sort].to_sym : nil + + concat(link_to_sort(attribute, is_current_attribute, :asc, current_direction)) + concat(link_to_sort(attribute, is_current_attribute, :desc, current_direction)) + end - parameters = case current_direction - when nil then { sort_by: attribute, sort: :asc } - when :asc then { sort_by: attribute, sort: :desc } - else { sort_by: nil, sort: nil } - end + def link_to_sort(attribute, is_current_attribute, direction, current_direction) + caret = direction == :asc ? "caret-up" : "caret-down" + is_current_direction = current_direction == direction + parameters = is_current_direction ? { sort_by: nil, sort: nil } : { sort_by: attribute, sort: direction } url = url_for(controller.request.query_parameters.merge(parameters)) link_to(url) do - concat label - concat " #{sort_caret(current_direction)}" if current_attribute == attribute + concat tag.i class: class_names("bi bi-#{caret}", + "ms-2": direction == :asc, + active: is_current_direction && is_current_attribute) end end - def sort_caret(direction) - sanitize(direction == :desc ? "↓" : "↑") - end - class DatatableColumn < ApplicationComponent attr_reader :title, :sort_by, :html_options diff --git a/app/components/list/table_component.rb b/app/components/list/table_component.rb index 9cafae6e5..6bbf607ec 100644 --- a/app/components/list/table_component.rb +++ b/app/components/list/table_component.rb @@ -3,7 +3,7 @@ module List class TableComponent < ApplicationComponent erb_template <<~ERB -