From 051aeb468c602c5bbd82f3b6d10dffc17c08ec3b Mon Sep 17 00:00:00 2001 From: Kimo Knowles Date: Fri, 19 Jan 2024 02:44:25 +0100 Subject: [PATCH] Align simple-v-table column headers correctly Now, a column's :vertical-align only affects the cells, not the headers. Now, a column's :align affects headers as well as cells. For https://github.com/day8/rf8.day8.com.au/issues/74 --- CHANGELOG.md | 6 +++ src/re_com/simple_v_table.cljs | 75 ++++++++++++++++------------------ 2 files changed, 41 insertions(+), 40 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b9be3e1e..fbdf52c7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,12 @@ > Committed but unreleased changes are put here, at the top. Older releases are detailed chronologically below. +## 2.16.3 (2024-01-19) + +#### Fixed + +- `simple-v-table` column headers now :align correctly. Also, :vertical-align now only affects cells, not headers. + ## 2.16.2 (2024-01-16) #### Fixed diff --git a/src/re_com/simple_v_table.cljs b/src/re_com/simple_v_table.cljs index 06b6346f..513ede9d 100644 --- a/src/re_com/simple_v_table.cljs +++ b/src/re_com/simple_v_table.cljs @@ -52,51 +52,46 @@ [:path {:fill fill :d "M7 14l5-5 5 5H7z"}]]) -(def vertical-align->align - {:top :start - :middle :center - :bottom :end - :sub :end - :text-top :center}) +(def align->justify + {:left :start + :right :end + :center :center}) (defn column-header-item - [{:keys [id row-label-fn width height align vertical-align header-label sort-by] :as column} parts sort-by-column] + [{:keys [id row-label-fn width height align header-label sort-by]} parts sort-by-column] (let [{:keys [key-fn comp] :or {key-fn row-label-fn comp compare}} sort-by {current-key-fn :key-fn order :order} @sort-by-column] (let [on-click #(swap! sort-by-column swap!-sort-by-column key-fn comp) - align (get vertical-align->align (keyword vertical-align) vertical-align)] - (cond-> - [h-box - :class (str "rc-simple-v-table-column-header-item " (get-in parts [:simple-column-header-item :class])) - :width (px width) - :style (merge - {:padding "0px 12px" - :min-height "24px" - :height (px height) - :font-weight "bold" - :text-align align - :white-space "nowrap" - :overflow "hidden" - :text-overflow "ellipsis"} - (when sort-by - {:cursor "pointer"}) - (get-in parts [:simple-column-header-item :style])) - :attr (merge - {} - (when sort-by - {:on-click on-click}) - (get-in parts [:simple-column-header-item :attr])) - :children [header-label - (when sort-by - [:<> - [gap :size "16px"] - (if (not= current-key-fn key-fn) - [sort-icon] - (if (= order :desc) - [arrow-down-icon] - [arrow-up-icon]))])]] - (when align) - (into [:align align]))))) + justify (get align->justify (keyword align) :start)] + [h-box + :class (str "rc-simple-v-table-column-header-item " (get-in parts [:simple-column-header-item :class])) + :width (px width) + :justify justify + :style (merge + {:padding "0px 12px" + :min-height "24px" + :height (px height) + :font-weight "bold" + :white-space "nowrap" + :overflow "hidden" + :text-overflow "ellipsis"} + (when sort-by + {:cursor "pointer"}) + (get-in parts [:simple-column-header-item :style])) + :attr (merge + {} + (when sort-by + {:on-click on-click}) + (get-in parts [:simple-column-header-item :attr])) + :children [header-label + (when sort-by + [:<> + [gap :size "16px"] + (if (not= current-key-fn key-fn) + [sort-icon] + (if (= order :desc) + [arrow-down-icon] + [arrow-up-icon]))])]]))) (defn column-header-renderer ":column-header-renderer AND :top-left-renderer - Render the table header"