From d34aea175a9772e184acc94452310ddb533ba7c2 Mon Sep 17 00:00:00 2001 From: Antoine Le Gonidec Date: Thu, 25 Jul 2024 13:15:55 +0200 Subject: [PATCH] Topics index - Make the "new topic" button more visible --- MessageIndex.template.php | 10 ++--- css/index.css | 7 +++- index.template.php | 83 +++++++++++++++++++++++---------------- 3 files changed, 60 insertions(+), 40 deletions(-) diff --git a/MessageIndex.template.php b/MessageIndex.template.php index 9b779d2..774bb5e 100644 --- a/MessageIndex.template.php +++ b/MessageIndex.template.php @@ -120,12 +120,12 @@ function template_main() { echo '
- ', template_button_strip($context['normal_buttons'], ), ' - ', $context['menu_separator'], ' + ', $context['menu_separator'], ' + ', template_button_strip($context['normal_buttons'], ), ' '; // Mobile action buttons (top) @@ -338,12 +338,12 @@ function template_main() echo '
- ', template_button_strip($context['normal_buttons'], ), ' - ', $context['menu_separator'], ' '; +
+ ', $context['menu_separator'], ' + ', template_button_strip($context['normal_buttons'], ); // Mobile action buttons (bottom) if (!empty($context['normal_buttons'])) diff --git a/css/index.css b/css/index.css index 014464f..450fa63 100644 --- a/css/index.css +++ b/css/index.css @@ -25,6 +25,8 @@ html { --menu-background-hover: #555555; --menu-background-active: black; --menu-font: white; + --font-regular: "Cabin", sans-serif; + --font-emphasis: "Oswald", sans-serif; } /* Index */ @@ -1133,13 +1135,16 @@ generic_menu .dropmenu .subsections ul li a { border: 1px solid; border-color: var(--bgcolor); border-radius: 3px; - box-shadow: 1px 1px 1px rgba(221, 221, 221, 0.57) inset; box-sizing: border-box; vertical-align: middle; background: var(--neutral-color); outline: none; padding: 0 0.4em; } +.button_strip_new_topic { + font-weight: 700; + font-family: var(--font-emphasis); +} a.button, a.button:hover, .button:focus { border-bottom: none; diff --git a/index.template.php b/index.template.php index 0ef5caa..f52282d 100644 --- a/index.template.php +++ b/index.template.php @@ -634,8 +634,6 @@ function template_menu() */ function template_button_strip($button_strip, $direction = '', $strip_options = array()) { - global $context, $txt; - if (!is_array($strip_options)) $strip_options = array(); @@ -643,40 +641,18 @@ function template_button_strip($button_strip, $direction = '', $strip_options = $buttons = array(); foreach ($button_strip as $key => $value) { - // As of 2.1, the 'test' for each button happens while the array is being generated. The extra 'test' check here is deprecated but kept for backward compatibility (update your mods, folks!) - if (!isset($value['test']) || !empty($context[$value['test']])) - { - if (!isset($value['id'])) - $value['id'] = $key; + // If a "new topic" button is provided, skip it in this first pass. + // It will be added at the end of the strip. + if ( $key == 'new_topic' ) continue; - $button = ' - '.(!empty($value['icon']) ? '' : '').'' . $txt[$value['text']] . ''; + $buttons = template_button_strip_single_button($key, $value, $buttons); + } + // If a "new topic" button is provided, add it at the end of the strip. + if ( array_key_exists('new_topic', $button_strip) ) { + $key = 'new_topic'; + $value = $button_strip[$key]; - if (!empty($value['sub_buttons'])) - { - $button .= ' -
-
-
'; - foreach ($value['sub_buttons'] as $element) - { - if (isset($element['test']) && empty($context[$element['test']])) - continue; - - $button .= ' - ' . $txt[$element['text']] . ''; - if (isset($txt[$element['text'] . '_desc'])) - $button .= '
' . $txt[$element['text'] . '_desc'] . ''; - $button .= '
'; - } - $button .= ' -
-
-
'; - } - - $buttons[] = $button; - } + $buttons = template_button_strip_single_button($key, $value, $buttons); } // No buttons? No button strip either. @@ -688,6 +664,45 @@ function template_button_strip($button_strip, $direction = '', $strip_options = ', implode('', $buttons), '
'; } +function template_button_strip_single_button($key, $value, $buttons) { + global $context, $txt; + + // As of 2.1, the 'test' for each button happens while the array is being generated. The extra 'test' check here is deprecated but kept for backward compatibility (update your mods, folks!) + if (!isset($value['test']) || !empty($context[$value['test']])) + { + if (!isset($value['id'])) + $value['id'] = $key; + + $button = ' + '.(!empty($value['icon']) ? '' : '').'' . $txt[$value['text']] . ''; + + if (!empty($value['sub_buttons'])) + { + $button .= ' +
+
+
'; + foreach ($value['sub_buttons'] as $element) + { + if (isset($element['test']) && empty($context[$element['test']])) + continue; + + $button .= ' + ' . $txt[$element['text']] . ''; + if (isset($txt[$element['text'] . '_desc'])) + $button .= '
' . $txt[$element['text'] . '_desc'] . ''; + $button .= '
'; + } + $button .= ' +
+
+
'; + } + + $buttons[] = $button; + } + return $buttons; +} /** * Generate a list of quickbuttons.