Compare commits
14 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| efebb531c0 | |||
| a54dbdc59b | |||
| 0715bdc33a | |||
| 34dfba0677 | |||
| 701b69e0df | |||
| 0fbe345c0c | |||
| 7d48d0f936 | |||
| 8b6c056720 | |||
| 94c31086f9 | |||
| 1459099b8d | |||
| 2983bac4a0 | |||
| cb72e6e091 | |||
| 49f708db2c | |||
| 6364aa74e6 |
@@ -1,2 +0,0 @@
|
|||||||
< 3.5.0.beta5-dev: 31249c4f27d93e83c6b83d42d93974522a9a612e
|
|
||||||
|
|
||||||
|
|||||||
+44
-60
@@ -1,9 +1,8 @@
|
|||||||
GEM
|
GEM
|
||||||
remote: https://rubygems.org/
|
remote: https://rubygems.org/
|
||||||
specs:
|
specs:
|
||||||
activesupport (8.0.2)
|
activesupport (7.2.1.1)
|
||||||
base64
|
base64
|
||||||
benchmark (>= 0.3)
|
|
||||||
bigdecimal
|
bigdecimal
|
||||||
concurrent-ruby (~> 1.0, >= 1.3.1)
|
concurrent-ruby (~> 1.0, >= 1.3.1)
|
||||||
connection_pool (>= 2.2.5)
|
connection_pool (>= 2.2.5)
|
||||||
@@ -13,83 +12,68 @@ GEM
|
|||||||
minitest (>= 5.1)
|
minitest (>= 5.1)
|
||||||
securerandom (>= 0.3)
|
securerandom (>= 0.3)
|
||||||
tzinfo (~> 2.0, >= 2.0.5)
|
tzinfo (~> 2.0, >= 2.0.5)
|
||||||
uri (>= 0.13.1)
|
ast (2.4.2)
|
||||||
ast (2.4.3)
|
base64 (0.2.0)
|
||||||
base64 (0.3.0)
|
bigdecimal (3.1.8)
|
||||||
benchmark (0.4.1)
|
concurrent-ruby (1.3.4)
|
||||||
bigdecimal (3.2.2)
|
connection_pool (2.4.1)
|
||||||
concurrent-ruby (1.3.5)
|
drb (2.2.1)
|
||||||
connection_pool (2.5.3)
|
i18n (1.14.6)
|
||||||
drb (2.2.3)
|
|
||||||
i18n (1.14.7)
|
|
||||||
concurrent-ruby (~> 1.0)
|
concurrent-ruby (~> 1.0)
|
||||||
json (2.12.2)
|
json (2.7.2)
|
||||||
language_server-protocol (3.17.0.5)
|
language_server-protocol (3.17.0.3)
|
||||||
lint_roller (1.1.0)
|
logger (1.6.1)
|
||||||
logger (1.7.0)
|
minitest (5.25.1)
|
||||||
minitest (5.25.5)
|
parallel (1.26.3)
|
||||||
parallel (1.27.0)
|
parser (3.3.5.0)
|
||||||
parser (3.3.8.0)
|
|
||||||
ast (~> 2.4.1)
|
ast (~> 2.4.1)
|
||||||
racc
|
racc
|
||||||
prettier_print (1.2.1)
|
prettier_print (1.2.1)
|
||||||
prism (1.4.0)
|
|
||||||
racc (1.8.1)
|
racc (1.8.1)
|
||||||
rack (3.1.15)
|
rack (3.1.10)
|
||||||
rainbow (3.1.1)
|
rainbow (3.1.1)
|
||||||
regexp_parser (2.10.0)
|
regexp_parser (2.9.2)
|
||||||
rubocop (1.76.0)
|
rubocop (1.67.0)
|
||||||
json (~> 2.3)
|
json (~> 2.3)
|
||||||
language_server-protocol (~> 3.17.0.2)
|
language_server-protocol (>= 3.17.0)
|
||||||
lint_roller (~> 1.1.0)
|
|
||||||
parallel (~> 1.10)
|
parallel (~> 1.10)
|
||||||
parser (>= 3.3.0.2)
|
parser (>= 3.3.0.2)
|
||||||
rainbow (>= 2.2.2, < 4.0)
|
rainbow (>= 2.2.2, < 4.0)
|
||||||
regexp_parser (>= 2.9.3, < 3.0)
|
regexp_parser (>= 2.4, < 3.0)
|
||||||
rubocop-ast (>= 1.45.0, < 2.0)
|
rubocop-ast (>= 1.32.2, < 2.0)
|
||||||
ruby-progressbar (~> 1.7)
|
ruby-progressbar (~> 1.7)
|
||||||
unicode-display_width (>= 2.4.0, < 4.0)
|
unicode-display_width (>= 2.4.0, < 3.0)
|
||||||
rubocop-ast (1.45.0)
|
rubocop-ast (1.32.3)
|
||||||
parser (>= 3.3.7.2)
|
parser (>= 3.3.1.0)
|
||||||
prism (~> 1.4)
|
rubocop-capybara (2.21.0)
|
||||||
rubocop-capybara (2.22.1)
|
rubocop (~> 1.41)
|
||||||
lint_roller (~> 1.1)
|
rubocop-discourse (3.8.2)
|
||||||
rubocop (~> 1.72, >= 1.72.1)
|
|
||||||
rubocop-discourse (3.12.1)
|
|
||||||
activesupport (>= 6.1)
|
activesupport (>= 6.1)
|
||||||
lint_roller (>= 1.1.0)
|
rubocop (>= 1.59.0)
|
||||||
rubocop (>= 1.73.2)
|
rubocop-capybara (>= 2.0.0)
|
||||||
rubocop-capybara (>= 2.22.0)
|
rubocop-factory_bot (>= 2.0.0)
|
||||||
rubocop-factory_bot (>= 2.27.0)
|
rubocop-rails (>= 2.25.0)
|
||||||
rubocop-rails (>= 2.30.3)
|
|
||||||
rubocop-rspec (>= 3.0.1)
|
rubocop-rspec (>= 3.0.1)
|
||||||
rubocop-rspec_rails (>= 2.31.0)
|
rubocop-rspec_rails (>= 2.30.0)
|
||||||
rubocop-factory_bot (2.27.1)
|
rubocop-factory_bot (2.26.1)
|
||||||
lint_roller (~> 1.1)
|
rubocop (~> 1.61)
|
||||||
rubocop (~> 1.72, >= 1.72.1)
|
rubocop-rails (2.26.2)
|
||||||
rubocop-rails (2.32.0)
|
|
||||||
activesupport (>= 4.2.0)
|
activesupport (>= 4.2.0)
|
||||||
lint_roller (~> 1.1)
|
|
||||||
rack (>= 1.1)
|
rack (>= 1.1)
|
||||||
rubocop (>= 1.75.0, < 2.0)
|
rubocop (>= 1.52.0, < 2.0)
|
||||||
rubocop-ast (>= 1.44.0, < 2.0)
|
rubocop-ast (>= 1.31.1, < 2.0)
|
||||||
rubocop-rspec (3.6.0)
|
rubocop-rspec (3.1.0)
|
||||||
lint_roller (~> 1.1)
|
rubocop (~> 1.61)
|
||||||
rubocop (~> 1.72, >= 1.72.1)
|
rubocop-rspec_rails (2.30.0)
|
||||||
rubocop-rspec_rails (2.31.0)
|
rubocop (~> 1.61)
|
||||||
lint_roller (~> 1.1)
|
rubocop-rspec (~> 3, >= 3.0.1)
|
||||||
rubocop (~> 1.72, >= 1.72.1)
|
|
||||||
rubocop-rspec (~> 3.5)
|
|
||||||
ruby-progressbar (1.13.0)
|
ruby-progressbar (1.13.0)
|
||||||
securerandom (0.4.1)
|
securerandom (0.3.1)
|
||||||
syntax_tree (6.2.0)
|
syntax_tree (6.2.0)
|
||||||
prettier_print (>= 1.2.0)
|
prettier_print (>= 1.2.0)
|
||||||
tzinfo (2.0.6)
|
tzinfo (2.0.6)
|
||||||
concurrent-ruby (~> 1.0)
|
concurrent-ruby (~> 1.0)
|
||||||
unicode-display_width (3.1.4)
|
unicode-display_width (2.6.0)
|
||||||
unicode-emoji (~> 4.0, >= 4.0.4)
|
|
||||||
unicode-emoji (4.0.4)
|
|
||||||
uri (1.0.3)
|
|
||||||
|
|
||||||
PLATFORMS
|
PLATFORMS
|
||||||
ruby
|
ruby
|
||||||
@@ -99,4 +83,4 @@ DEPENDENCIES
|
|||||||
syntax_tree
|
syntax_tree
|
||||||
|
|
||||||
BUNDLED WITH
|
BUNDLED WITH
|
||||||
2.6.9
|
2.5.21
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
Horizon is a simple, beautiful theme that improves the out-of-the-box experience for Discourse sites.
|
# next-gen
|
||||||
|
|
||||||
https://meta.discourse.org/t/horizon-theme/360486
|
**Theme Summary**
|
||||||
|
|
||||||
|
For more information, please see: **url to meta topic**
|
||||||
|
|||||||
+25
-79
@@ -1,135 +1,81 @@
|
|||||||
{
|
{
|
||||||
"name": "Horizon",
|
"name": "Horizon Theme",
|
||||||
"authors": "Design Team",
|
"authors": "Design Team",
|
||||||
"about_url": "https://meta.discourse.org/t/horizon-theme/360486",
|
"about_url": "TODO: Put your theme's public repo or Meta topic URL here",
|
||||||
"license_url": "https://github.com/discourse/horizon/blob/main/LICENSE",
|
"license_url": "TODO: Put your theme's LICENSE URL here",
|
||||||
"learn_more": "https://meta.discourse.org/t/installing-a-theme-or-theme-component/63682",
|
"learn_more": "TODO",
|
||||||
"theme_version": "0.0.1",
|
"theme_version": "0.0.1",
|
||||||
|
"minimum_discourse_version": null,
|
||||||
|
"maximum_discourse_version": null,
|
||||||
|
"assets": {},
|
||||||
"modifiers": {
|
"modifiers": {
|
||||||
"svg_icons": ["fire"],
|
"svg_icons": ["fire"],
|
||||||
"serialize_topic_is_hot": true
|
"serialize_topic_is_hot": true
|
||||||
},
|
},
|
||||||
|
"components": [
|
||||||
|
"https://github.com/discourse/discourse-sidebar-new-topic-button.git",
|
||||||
|
"https://github.com/discourse/discourse-full-width-component.git"
|
||||||
|
],
|
||||||
"color_schemes": {
|
"color_schemes": {
|
||||||
"Horizon": {
|
"Horizon": {
|
||||||
"primary": "1A1A1A",
|
"primary": "1A1A1A",
|
||||||
"secondary": "ffffff",
|
"secondary": "ffffff",
|
||||||
"tertiary": "595bca",
|
"tertiary": "595bca"
|
||||||
"tertiary-med-or-tertiary": "595bca",
|
|
||||||
"selected": "d7dfff",
|
|
||||||
"header_background": "ffffff",
|
|
||||||
"header_primary": "1A1A1A",
|
|
||||||
"hover": "E1E8FF"
|
|
||||||
},
|
},
|
||||||
"Horizon Dark": {
|
"Horizon Dark": {
|
||||||
"primary": "ffffff",
|
"primary": "ffffff",
|
||||||
"secondary": "1A1A1A",
|
"secondary": "1A1A1A",
|
||||||
"tertiary": "595bca",
|
"tertiary": "595bca"
|
||||||
"tertiary-med-or-tertiary": "595bca",
|
|
||||||
"selected": "3b3e56",
|
|
||||||
"header_background": "1A1A1A",
|
|
||||||
"header_primary": "ffffff",
|
|
||||||
"hover": "333548"
|
|
||||||
},
|
},
|
||||||
"Royal": {
|
"Royal": {
|
||||||
"primary": "1A1A1A",
|
"primary": "1A1A1A",
|
||||||
"secondary": "ffffff",
|
"secondary": "ffffff",
|
||||||
"tertiary": "1F7BC1",
|
"tertiary": "4169e1"
|
||||||
"tertiary-med-or-tertiary": "1F7BC1",
|
|
||||||
"selected": "c7e3ff",
|
|
||||||
"header_background": "ffffff",
|
|
||||||
"header_primary": "1A1A1A",
|
|
||||||
"hover": "D6EBFF"
|
|
||||||
},
|
},
|
||||||
"Royal Dark": {
|
"Royal Dark": {
|
||||||
"primary": "ffffff",
|
"primary": "ffffff",
|
||||||
"secondary": "1A1A1A",
|
"secondary": "1A1A1A",
|
||||||
"tertiary": "1F7BC1",
|
"tertiary": "4169e1"
|
||||||
"tertiary-med-or-tertiary": "1F7BC1",
|
|
||||||
"selected": "3a455f",
|
|
||||||
"header_background": "1A1A1A",
|
|
||||||
"header_primary": "ffffff",
|
|
||||||
"hover": "323B4E"
|
|
||||||
},
|
},
|
||||||
"Clover": {
|
"Clover": {
|
||||||
"primary": "1A1A1A",
|
"primary": "1A1A1A",
|
||||||
"secondary": "ffffff",
|
"secondary": "ffffff",
|
||||||
"tertiary": "39845B",
|
"tertiary": "45a06e"
|
||||||
"tertiary-med-or-tertiary": "39845B",
|
|
||||||
"selected": "c6f1d5",
|
|
||||||
"header_background": "ffffff",
|
|
||||||
"header_primary": "1A1A1A",
|
|
||||||
"hover": "D5F5E0"
|
|
||||||
},
|
},
|
||||||
"Clover Dark": {
|
"Clover Dark": {
|
||||||
"primary": "ffffff",
|
"primary": "ffffff",
|
||||||
"secondary": "1A1A1A",
|
"secondary": "1A1A1A",
|
||||||
"tertiary": "39845B",
|
"tertiary": "45a06e"
|
||||||
"tertiary-med-or-tertiary": "39845B",
|
|
||||||
"selected": "47594e",
|
|
||||||
"header_background": "1A1A1A",
|
|
||||||
"header_primary": "ffffff",
|
|
||||||
"hover": "3C4A40"
|
|
||||||
},
|
},
|
||||||
"Lily": {
|
"Lily": {
|
||||||
"primary": "1A1A1A",
|
"primary": "1A1A1A",
|
||||||
"secondary": "ffffff",
|
"secondary": "ffffff",
|
||||||
"tertiary": "cc338c",
|
"tertiary": "cc338c"
|
||||||
"tertiary-med-or-tertiary": "cc338c",
|
|
||||||
"selected": "ffc8ee",
|
|
||||||
"header_background": "ffffff",
|
|
||||||
"header_primary": "1A1A1A",
|
|
||||||
"hover": "FFD7F3"
|
|
||||||
},
|
},
|
||||||
"Lily Dark": {
|
"Lily Dark": {
|
||||||
"primary": "ffffff",
|
"primary": "ffffff",
|
||||||
"secondary": "1A1A1A",
|
"secondary": "1A1A1A",
|
||||||
"tertiary": "cc338c",
|
"tertiary": "cc338c"
|
||||||
"tertiary-med-or-tertiary": "cc338c",
|
|
||||||
"selected": "5f3e4e",
|
|
||||||
"header_background": "1A1A1A",
|
|
||||||
"header_primary": "ffffff",
|
|
||||||
"hover": "4E3640"
|
|
||||||
},
|
},
|
||||||
"Violet": {
|
"Violet": {
|
||||||
"primary": "1A1A1A",
|
"primary": "1A1A1A",
|
||||||
"secondary": "ffffff",
|
"secondary": "ffffff",
|
||||||
"tertiary": "9b15de",
|
"tertiary": "9b15de"
|
||||||
"tertiary-med-or-tertiary": "9b15de",
|
|
||||||
"selected": "feccff",
|
|
||||||
"header_background": "ffffff",
|
|
||||||
"header_primary": "1A1A1A",
|
|
||||||
"hover": "FFD9FF"
|
|
||||||
},
|
},
|
||||||
"Violet Dark": {
|
"Violet Dark": {
|
||||||
"primary": "ffffff",
|
"primary": "ffffff",
|
||||||
"secondary": "1A1A1A",
|
"secondary": "1A1A1A",
|
||||||
"tertiary": "9b15de",
|
"tertiary": "9b15de"
|
||||||
"tertiary-med-or-tertiary": "9b15de",
|
|
||||||
"selected": "4c385c",
|
|
||||||
"header_background": "1A1A1A",
|
|
||||||
"header_primary": "ffffff",
|
|
||||||
"hover": "40314C"
|
|
||||||
},
|
},
|
||||||
"Marigold": {
|
"Marigold": {
|
||||||
"primary": "1A1A1A",
|
"primary": "1A1A1A",
|
||||||
"secondary": "ffffff",
|
"secondary": "ffffff",
|
||||||
"tertiary": "d3881f",
|
"tertiary": "d3881f"
|
||||||
"tertiary-med-or-tertiary": "d3881f",
|
|
||||||
"selected": "ffdcb2",
|
|
||||||
"header_background": "ffffff",
|
|
||||||
"header_primary": "1A1A1A",
|
|
||||||
"hover": "FFE6C6"
|
|
||||||
},
|
},
|
||||||
"Marigold Dark": {
|
"Marigold Dark": {
|
||||||
"primary": "ffffff",
|
"primary": "ffffff",
|
||||||
"secondary": "1A1A1A",
|
"secondary": "1A1A1A",
|
||||||
"tertiary": "d3881f",
|
"tertiary": "d3881f"
|
||||||
"tertiary-med-or-tertiary": "d3881f",
|
|
||||||
"selected": "6c5b49",
|
|
||||||
"header_background": "1A1A1A",
|
|
||||||
"header_primary": "ffffff",
|
|
||||||
"hover": "584B3E"
|
|
||||||
}
|
}
|
||||||
},
|
}
|
||||||
"screenshots": ["screenshots/light.png", "screenshots/dark.png"]
|
}
|
||||||
}
|
|
||||||
@@ -1,105 +0,0 @@
|
|||||||
html {
|
|
||||||
--accent-color: #{$tertiary} !important;
|
|
||||||
--accent-text-color: #fff;
|
|
||||||
|
|
||||||
// Background Colors
|
|
||||||
--background-color: light-dark(
|
|
||||||
oklch(from #{$tertiary} 96% calc(c * 0.125) h),
|
|
||||||
oklch(from #{$tertiary} 10% 0.025 h)
|
|
||||||
) !important;
|
|
||||||
--d-content-background: light-dark(
|
|
||||||
oklch(from #{$secondary} calc(2 * l) c h),
|
|
||||||
oklch(from #{$secondary} l c h)
|
|
||||||
) !important;
|
|
||||||
|
|
||||||
// HeaderColors
|
|
||||||
--header_primary-low-mid: light-dark(
|
|
||||||
oklch(from #{$tertiary} 73.5% calc(c * 0.5) h),
|
|
||||||
oklch(from #{$tertiary} l calc(c * 0.25) h)
|
|
||||||
) !important;
|
|
||||||
--header_primary-medium: light-dark(
|
|
||||||
oklch(from #{$tertiary} 54% calc(c * 0.5) h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.35) calc(c * 0.25) h)
|
|
||||||
) !important;
|
|
||||||
|
|
||||||
// Sidebar Colors
|
|
||||||
--d-sidebar-border-color: light-dark(
|
|
||||||
oklch(from #{$tertiary} 88% calc(c * 0.25) h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 0.7) calc(c * 0.25) h)
|
|
||||||
) !important;
|
|
||||||
--d-sidebar-link-color: light-dark(
|
|
||||||
oklch(from #{$tertiary} calc(l * 0.8) calc(c * 0.25) h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.5) calc(c * 0.25) h)
|
|
||||||
) !important;
|
|
||||||
--d-sidebar-active-color: #{$primary} !important;
|
|
||||||
--d-sidebar-suffix-color: light-dark(
|
|
||||||
oklch(from #{$tertiary} l calc(c * 0.9) h),
|
|
||||||
oklch(from #{$tertiary} l calc(c * 0.9) h)
|
|
||||||
) !important;
|
|
||||||
|
|
||||||
// Other Colors
|
|
||||||
--d-selected: light-dark(
|
|
||||||
oklch(from #{$tertiary} 92% calc(c * 0.5) h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 0.7) calc(c * 0.25) h)
|
|
||||||
) !important;
|
|
||||||
--d-nav-color--active: light-dark(
|
|
||||||
oklch(from #{$tertiary} l c h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.2) c h)
|
|
||||||
) !important;
|
|
||||||
--d-nav-color--hover: light-dark(
|
|
||||||
oklch(from #{$tertiary} l c h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.2) c h)
|
|
||||||
) !important;
|
|
||||||
--link-color: light-dark(
|
|
||||||
oklch(from #{$tertiary} l c h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 0.95) c h)
|
|
||||||
) !important;
|
|
||||||
--link-color-hover: light-dark(
|
|
||||||
oklch(from #{$tertiary} l c h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.5) calc(c * 2.25) h)
|
|
||||||
) !important;
|
|
||||||
--tertiary-hover: #{$tertiary} !important;
|
|
||||||
|
|
||||||
// Search Colors
|
|
||||||
--search-color: light-dark(
|
|
||||||
oklch(from #{$tertiary} l c h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.5) calc(c * 0.25) h)
|
|
||||||
) !important;
|
|
||||||
|
|
||||||
// Topic Card Colors
|
|
||||||
--topic-card-shadow: light-dark(
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.85) calc(c * 0.5) h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 0.2) calc(c * 0.01) h / 0.25)
|
|
||||||
) !important;
|
|
||||||
|
|
||||||
// Button Colors
|
|
||||||
--button-box-shadow: light-dark(
|
|
||||||
oklch(from #{$tertiary} calc(l * 1.5) calc(c * 0.35) h),
|
|
||||||
oklch(from #{$tertiary} calc(l * 0.75) calc(c * 0.5) h)
|
|
||||||
) !important;
|
|
||||||
--d-sidebar-highlight-hover-icon: var(--d-sidebar-link-color) !important;
|
|
||||||
--d-sidebar-highlight-hover-background: var(--d-selected) !important;
|
|
||||||
--d-sidebar-link-icon-color: var(--d-sidebar-link-color) !important;
|
|
||||||
--d-sidebar-header-color: var(--d-sidebar-link-color) !important;
|
|
||||||
--d-sidebar-header-icon-color: var(--d-sidebar-link-color) !important;
|
|
||||||
--d-sidebar-active-suffix-color: var(--d-sidebar-suffix-color) !important;
|
|
||||||
--d-sidebar-background: var(--background-color) !important;
|
|
||||||
--d-sidebar-footer-fade: var(--background-color) !important;
|
|
||||||
--d-sidebar-prefix-background: var(--d-selected) !important;
|
|
||||||
--d-sidebar-active-prefix-background: light-dark(
|
|
||||||
oklch(from var(--d-selected) calc(l * 0.85) c h),
|
|
||||||
oklch(from var(--d-selected) calc(l * 0.7) c h)
|
|
||||||
) !important;
|
|
||||||
--d-sidebar-highlight-prefix-background: light-dark(
|
|
||||||
oklch(from var(--d-selected) calc(l * 0.85) c h),
|
|
||||||
oklch(from var(--d-selected) calc(l * 0.7) c h)
|
|
||||||
) !important;
|
|
||||||
--d-sidebar-highlight-suffix-color: var(
|
|
||||||
--d-sidebar-active-suffix-color
|
|
||||||
) !important;
|
|
||||||
--d-sidebar-highlight-color: var(--primary) !important;
|
|
||||||
--d-sidebar-highlight-background: var(--d-selected) !important;
|
|
||||||
--d-sidebar-section-link-icon-size: 1em !important;
|
|
||||||
--d-hover: oklch(from var(--d-selected) l c h / 0.75) !important;
|
|
||||||
--d-input-bg-color: var(--d-content-background) !important;
|
|
||||||
}
|
|
||||||
+2
-5
@@ -1,20 +1,17 @@
|
|||||||
@import "box-view";
|
@import "box-view";
|
||||||
@import "buttons";
|
@import "buttons";
|
||||||
@import "chat";
|
@import "chat";
|
||||||
@import "categories-view";
|
|
||||||
@import "color-choice";
|
@import "color-choice";
|
||||||
|
@import "color-exploration";
|
||||||
@import "composer";
|
@import "composer";
|
||||||
@import "composer-peek-mode";
|
|
||||||
@import "header";
|
@import "header";
|
||||||
@import "hiddenstuff";
|
@import "hiddenstuff";
|
||||||
@import "login";
|
|
||||||
@import "main";
|
@import "main";
|
||||||
@import "misc";
|
@import "misc";
|
||||||
@import "mobile-stuff";
|
@import "mobile-stuff";
|
||||||
@import "nav-pills";
|
@import "nav-pills";
|
||||||
@import "welcome-banner";
|
@import "search-banner";
|
||||||
@import "sidebar";
|
@import "sidebar";
|
||||||
@import "sidebar-new-topic-button";
|
|
||||||
@import "topic";
|
@import "topic";
|
||||||
@import "topic-cards";
|
@import "topic-cards";
|
||||||
@import "variables";
|
@import "variables";
|
||||||
|
|||||||
@@ -1,7 +0,0 @@
|
|||||||
<script>
|
|
||||||
if (!CSS.supports("(color: hsl(from white h s l))")) {
|
|
||||||
window.unsupportedBrowser = true;
|
|
||||||
window.I18n.translations[I18n.locale].js.browser_update =
|
|
||||||
'The Horizon theme does not support your browser. Please update your browser, or <a href="?safe_mode=no_themes">switch to safe mode</a>.';
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
+63
-2
@@ -1,2 +1,63 @@
|
|||||||
@import "desktop-horizon-fixes";
|
.bulk-select-enabled {
|
||||||
@import "desktop-full-width";
|
.topic-list-header .topic-list-data.default {
|
||||||
|
position: sticky;
|
||||||
|
top: 10em;
|
||||||
|
}
|
||||||
|
.topic-author-avatar-data {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bulk-select.topic-list-data {
|
||||||
|
grid-area: bulk-select;
|
||||||
|
margin-left: -0.5em;
|
||||||
|
|
||||||
|
@media screen and (max-width: 576px) {
|
||||||
|
margin-top: 0;
|
||||||
|
label {
|
||||||
|
padding-block: 0.345em;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
input {
|
||||||
|
transform: scale(1.5);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.topic-list-header {
|
||||||
|
tr {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.topic-list-data {
|
||||||
|
padding: 0;
|
||||||
|
|
||||||
|
&:not(.default) {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.default {
|
||||||
|
position: absolute;
|
||||||
|
right: 0;
|
||||||
|
.bulk-select,
|
||||||
|
span:not(.bulk-select-topics, .d-button-label) {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.bulk-select-topics {
|
||||||
|
position: absolute;
|
||||||
|
right: -1em;
|
||||||
|
@media screen and (max-width: 1048px) {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
background: var(--secondary);
|
||||||
|
border-radius: 0 0 0 var(--d-border-radius);
|
||||||
|
padding: 1em;
|
||||||
|
button {
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
import { apiInitializer } from "discourse/lib/api";
|
|
||||||
import ComposerPeekModeToggle from "../components/composer-peek-mode-toggle";
|
|
||||||
|
|
||||||
export default apiInitializer("1.8.0", (api) => {
|
|
||||||
api.renderInOutlet("before-composer-toggles", ComposerPeekModeToggle);
|
|
||||||
});
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
import { apiInitializer } from "discourse/lib/api";
|
|
||||||
|
|
||||||
export default apiInitializer("0.8", (api) => {
|
|
||||||
document.body.classList.add("full-width-enabled");
|
|
||||||
|
|
||||||
// When the sidebar is visible, force the HomeLogo to be in an 'un-minimized' state.
|
|
||||||
api.registerValueTransformer?.(
|
|
||||||
"home-logo-minimized",
|
|
||||||
({ value, context }) => {
|
|
||||||
if (value && context.showSidebar) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
import { apiInitializer } from "discourse/lib/api";
|
|
||||||
|
|
||||||
export default apiInitializer("0.8", (api) => {
|
|
||||||
api.registerValueTransformer(
|
|
||||||
"hamburger-dropdown-click-outside-exceptions",
|
|
||||||
({ value }) => {
|
|
||||||
return [...value, ".topic-drafts-menu-content"];
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
@@ -1,10 +1,12 @@
|
|||||||
import { apiInitializer } from "discourse/lib/api";
|
import { apiInitializer } from "discourse/lib/api";
|
||||||
|
import CustomColorHtmlClass from "../components/custom-color-html-class";
|
||||||
|
import CustomUserPalette from "../components/custom-user-palette";
|
||||||
import ExperimentalScreen from "../components/experimental-screen";
|
import ExperimentalScreen from "../components/experimental-screen";
|
||||||
import UserColorPaletteSelector from "../components/user-color-palette-selector";
|
|
||||||
|
|
||||||
export default apiInitializer("1.8.0", (api) => {
|
export default apiInitializer("1.8.0", (api) => {
|
||||||
api.renderInOutlet("above-main-container", ExperimentalScreen);
|
api.renderInOutlet("above-main-container", ExperimentalScreen);
|
||||||
api.renderInOutlet("sidebar-footer-actions", UserColorPaletteSelector);
|
api.renderInOutlet("above-main-container", CustomColorHtmlClass);
|
||||||
|
api.renderInOutlet("sidebar-footer-actions", CustomUserPalette);
|
||||||
|
|
||||||
api.registerValueTransformer("site-setting-enable-welcome-banner", () => {
|
api.registerValueTransformer("site-setting-enable-welcome-banner", () => {
|
||||||
return settings.enable_welcome_banner;
|
return settings.enable_welcome_banner;
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
import { apiInitializer } from "discourse/lib/api";
|
|
||||||
import SidebarNewTopicButton from "../components/sidebar-new-topic-button";
|
|
||||||
|
|
||||||
export default apiInitializer("1.8.0", (api) => {
|
|
||||||
api.renderInOutlet("before-sidebar-sections", SidebarNewTopicButton);
|
|
||||||
});
|
|
||||||
@@ -1,48 +1,49 @@
|
|||||||
import Component from "@glimmer/component";
|
import Component from "@glimmer/component";
|
||||||
import concatClass from "discourse/helpers/concat-class";
|
import avatar from "discourse/helpers/avatar";
|
||||||
import formatDate from "discourse/helpers/format-date";
|
import formatDate from "discourse/helpers/format-date";
|
||||||
|
import { i18n } from "discourse-i18n";
|
||||||
|
import gt from "truth-helpers/helpers/gt";
|
||||||
|
|
||||||
export default class TopicActivityColumn extends Component {
|
export default class TopicActivityColumn extends Component {
|
||||||
get topicUser() {
|
get activityText() {
|
||||||
|
// this should handle any case where a topic was no bumped due to a reply/post
|
||||||
if (
|
if (
|
||||||
moment(this.args.topic.bumped_at).isAfter(this.args.topic.last_posted_at)
|
moment(this.args.topic.bumped_at).isAfter(this.args.topic.last_posted_at)
|
||||||
) {
|
) {
|
||||||
return {
|
return "user_updated";
|
||||||
user: undefined,
|
|
||||||
username: undefined,
|
|
||||||
activityText: "user_updated",
|
|
||||||
class: "--updated",
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.args.topic.posts_count > 1) {
|
if (this.args.topic.posts_count > 1) {
|
||||||
return {
|
return "user_replied";
|
||||||
user: this.args.topic.lastPosterUser,
|
|
||||||
username: this.args.topic.last_poster_username,
|
|
||||||
activityText: "user_replied",
|
|
||||||
class: "--replied",
|
|
||||||
};
|
|
||||||
} else if (this.args.topic.posts_count === 1) {
|
} else if (this.args.topic.posts_count === 1) {
|
||||||
return {
|
return "user_posted";
|
||||||
user: this.args.topic.firstPosterUser,
|
|
||||||
username: this.args.topic.last_poster_username,
|
|
||||||
class: "--created",
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<span class={{concatClass "topic-activity" this.topicUser.class}}>
|
<span class="topic-activity">
|
||||||
{{#if this.topicUser.username}}
|
<div class="topic-activity__user">
|
||||||
<span
|
{{#if (gt @topic.replyCount 1)}}
|
||||||
class="topic-activity__username"
|
{{avatar @topic.lastPosterUser imageSize="small"}}
|
||||||
>{{this.topicUser.username}}</span>
|
<span
|
||||||
<span class="dot-separator"></span>
|
class="topic-activity__username"
|
||||||
{{/if}}
|
>@{{@topic.last_poster_username}}</span>
|
||||||
|
{{else}}
|
||||||
|
{{avatar @topic.creator imageSize="small"}}
|
||||||
|
<span
|
||||||
|
class="topic-activity__username"
|
||||||
|
>@{{@topic.creator.username}}</span>
|
||||||
|
{{/if}}
|
||||||
|
</div>
|
||||||
|
<div class="topic-activity__reason">
|
||||||
|
{{i18n (themePrefix this.activityText)}}
|
||||||
|
</div>
|
||||||
<div class="topic-activity__time">
|
<div class="topic-activity__time">
|
||||||
{{formatDate @topic.bumpedAt leaveAgo="true" format="tiny"}}
|
{{formatDate
|
||||||
|
@topic.bumpedAt
|
||||||
|
leaveAgo="true"
|
||||||
|
format="medium-with-ago-and-on"
|
||||||
|
}}
|
||||||
</div>
|
</div>
|
||||||
</span>
|
</span>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
@@ -0,0 +1,9 @@
|
|||||||
|
import avatar from "discourse/helpers/avatar";
|
||||||
|
|
||||||
|
const TopicAuthorAvatarColumn = <template>
|
||||||
|
<span class="topic-author-avatar">
|
||||||
|
{{avatar @topic.creator imageSize="large"}}
|
||||||
|
</span>
|
||||||
|
</template>;
|
||||||
|
|
||||||
|
export default TopicAuthorAvatarColumn;
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
const TopicAuthorColumn = <template>
|
||||||
|
<span class="topic-author">@{{@topic.creator.username}}</span>
|
||||||
|
</template>;
|
||||||
|
|
||||||
|
export default TopicAuthorColumn;
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
import Component from "@glimmer/component";
|
|
||||||
import avatar from "discourse/helpers/avatar";
|
|
||||||
|
|
||||||
export default class TopicCreatorColumn extends Component {
|
|
||||||
get topicCreator() {
|
|
||||||
return {
|
|
||||||
user: this.args.topic.creator,
|
|
||||||
class: "--topic-creator",
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<div class={{this.topicCreator.class}}>
|
|
||||||
{{avatar this.topicCreator.user}}
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
}
|
|
||||||
@@ -1,12 +1,9 @@
|
|||||||
import { gt } from "truth-helpers";
|
|
||||||
import icon from "discourse/helpers/d-icon";
|
import icon from "discourse/helpers/d-icon";
|
||||||
import number from "discourse/helpers/number";
|
import gt from "truth-helpers/helpers/gt";
|
||||||
|
|
||||||
const TopicRepliesColumn = <template>
|
const TopicRepliesColumn = <template>
|
||||||
{{#if (gt @topic.replyCount 1)}}
|
{{#if (gt @topic.replyCount 1)}}
|
||||||
<span class="topic-replies">{{icon "reply"}}{{number
|
<span class="topic-replies">{{icon "reply"}}{{@topic.replyCount}}</span>
|
||||||
@topic.posts_count
|
|
||||||
}}</span>
|
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</template>;
|
</template>;
|
||||||
|
|
||||||
|
|||||||
@@ -30,9 +30,7 @@ export default class TopicStatusColumn extends Component {
|
|||||||
{{#if this.badge}}
|
{{#if this.badge}}
|
||||||
<span class="topic-status-card {{this.badge.className}}">{{icon
|
<span class="topic-status-card {{this.badge.className}}">{{icon
|
||||||
this.badge.icon
|
this.badge.icon
|
||||||
}}<p class="topic-status-card__name">{{i18n
|
}}{{i18n (themePrefix this.badge.text)}}</span>
|
||||||
(themePrefix this.badge.text)
|
|
||||||
}}</p></span>
|
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</template>
|
</template>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,37 +0,0 @@
|
|||||||
import Component from "@glimmer/component";
|
|
||||||
import { tracked } from "@glimmer/tracking";
|
|
||||||
import { action } from "@ember/object";
|
|
||||||
import { service } from "@ember/service";
|
|
||||||
import DButton from "discourse/components/d-button";
|
|
||||||
import bodyClass from "discourse/helpers/body-class";
|
|
||||||
|
|
||||||
export default class ComposerPeekModeToggle extends Component {
|
|
||||||
@service composer;
|
|
||||||
@service keyValueStore;
|
|
||||||
|
|
||||||
@tracked
|
|
||||||
peekModeActive = this.keyValueStore.getItem("peekModeActive") === "true";
|
|
||||||
|
|
||||||
get bodyCssClass() {
|
|
||||||
return this.peekModeActive ? "peek-mode-active" : "";
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
togglePeekMode() {
|
|
||||||
this.peekModeActive = !this.peekModeActive;
|
|
||||||
this.keyValueStore.setItem("peekModeActive", this.peekModeActive);
|
|
||||||
if (this.composer.showPreview) {
|
|
||||||
this.composer.togglePreview();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
<template>
|
|
||||||
{{bodyClass this.bodyCssClass}}
|
|
||||||
<DButton
|
|
||||||
@action={{this.togglePeekMode}}
|
|
||||||
@preventFocus={{true}}
|
|
||||||
@icon="discourse-sidebar"
|
|
||||||
class="btn-mini-toggle no-text peek-mode-toggle btn-transparent"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,12 @@
|
|||||||
|
import Component from "@glimmer/component";
|
||||||
|
import { concat } from "@ember/helper";
|
||||||
|
import { service } from "@ember/service";
|
||||||
|
import htmlClass from "discourse/helpers/html-class";
|
||||||
|
|
||||||
|
export default class CustomColorHtmlClass extends Component {
|
||||||
|
@service customColor;
|
||||||
|
|
||||||
|
<template>
|
||||||
|
{{htmlClass (concat "custom-color-" this.customColor.color)}}
|
||||||
|
</template>
|
||||||
|
}
|
||||||
@@ -0,0 +1,60 @@
|
|||||||
|
import icon from "discourse/helpers/d-icon";
|
||||||
|
import DMenu from "float-kit/components/d-menu";
|
||||||
|
import SitePaletteMenuItem from "./site-palette-menu-item";
|
||||||
|
|
||||||
|
const PALETTES = [
|
||||||
|
{
|
||||||
|
label: "Marigold",
|
||||||
|
name: "marigold",
|
||||||
|
color: "#d3881f",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: "Violet",
|
||||||
|
name: "violet",
|
||||||
|
color: "#9b15de",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: "Lily",
|
||||||
|
name: "lily",
|
||||||
|
color: "#CC336F",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: "Clover",
|
||||||
|
name: "clover",
|
||||||
|
color: "#45a06e",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: "Royal",
|
||||||
|
name: "royal",
|
||||||
|
color: "#4169e1",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: "Horizon",
|
||||||
|
name: "horizon",
|
||||||
|
color: "#595bca",
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
export const DEFAULT_PALETTE_NAME = "horizon";
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<DMenu
|
||||||
|
@identifier="user-color-palette"
|
||||||
|
@placementStrategy="fixed"
|
||||||
|
class="btn-flat user-color-palette sidebar-footer-actions-button"
|
||||||
|
@inline={{true}}
|
||||||
|
>
|
||||||
|
<:trigger>
|
||||||
|
{{icon "paintbrush"}}
|
||||||
|
</:trigger>
|
||||||
|
<:content>
|
||||||
|
<div class="color-palette-menu">
|
||||||
|
<div class="color-palette-menu__content">
|
||||||
|
{{#each PALETTES as |colorPalette|}}
|
||||||
|
<SitePaletteMenuItem @colorPalette={{colorPalette}} />
|
||||||
|
{{/each}}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</:content>
|
||||||
|
</DMenu>
|
||||||
|
</template>
|
||||||
@@ -2,15 +2,10 @@ import Component from "@glimmer/component";
|
|||||||
import { tracked } from "@glimmer/tracking";
|
import { tracked } from "@glimmer/tracking";
|
||||||
import { action } from "@ember/object";
|
import { action } from "@ember/object";
|
||||||
import didInsert from "@ember/render-modifiers/modifiers/did-insert";
|
import didInsert from "@ember/render-modifiers/modifiers/did-insert";
|
||||||
import { service } from "@ember/service";
|
|
||||||
import { htmlSafe } from "@ember/template";
|
import { htmlSafe } from "@ember/template";
|
||||||
import { bind } from "discourse/lib/decorators";
|
import { bind } from "discourse/lib/decorators";
|
||||||
|
|
||||||
const DO_NOT_RENDER_LIST = ["login"];
|
|
||||||
|
|
||||||
export default class ExperimentalScreen extends Component {
|
export default class ExperimentalScreen extends Component {
|
||||||
@service router;
|
|
||||||
|
|
||||||
@tracked left = 0;
|
@tracked left = 0;
|
||||||
@tracked right = 0;
|
@tracked right = 0;
|
||||||
resizeObserver;
|
resizeObserver;
|
||||||
@@ -33,10 +28,6 @@ export default class ExperimentalScreen extends Component {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
get shouldRender() {
|
|
||||||
return !DO_NOT_RENDER_LIST.includes(this.router.currentRouteName);
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
@action
|
||||||
onInsert(element) {
|
onInsert(element) {
|
||||||
this.calculateDistance(element);
|
this.calculateDistance(element);
|
||||||
@@ -51,18 +42,16 @@ export default class ExperimentalScreen extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
{{#if this.shouldRender}}
|
<ul
|
||||||
<ul
|
class="experimental-screen"
|
||||||
class="experimental-screen"
|
{{didInsert this.onInsert}}
|
||||||
{{didInsert this.onInsert}}
|
style={{this.distanceStyles}}
|
||||||
style={{this.distanceStyles}}
|
>
|
||||||
>
|
<li class="experimental-screen__top-left"></li>
|
||||||
<li class="experimental-screen__top-left"></li>
|
<li class="experimental-screen__top-right"></li>
|
||||||
<li class="experimental-screen__top-right"></li>
|
<li class="experimental-screen__bottom-left"></li>
|
||||||
<li class="experimental-screen__bottom-left"></li>
|
<li class="experimental-screen__bottom-right"></li>
|
||||||
<li class="experimental-screen__bottom-right"></li>
|
<li class="experimental-screen__bottom-bar"></li>
|
||||||
<li class="experimental-screen__bottom-bar"></li>
|
</ul>
|
||||||
</ul>
|
|
||||||
{{/if}}
|
|
||||||
</template>
|
</template>
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,116 +0,0 @@
|
|||||||
import Component from "@glimmer/component";
|
|
||||||
import { tracked } from "@glimmer/tracking";
|
|
||||||
import { action } from "@ember/object";
|
|
||||||
import didInsert from "@ember/render-modifiers/modifiers/did-insert";
|
|
||||||
import didUpdate from "@ember/render-modifiers/modifiers/did-update";
|
|
||||||
import willDestroy from "@ember/render-modifiers/modifiers/will-destroy";
|
|
||||||
import { service } from "@ember/service";
|
|
||||||
import { gt, not } from "truth-helpers";
|
|
||||||
import CreateTopicButton from "discourse/components/create-topic-button";
|
|
||||||
|
|
||||||
export default class SidebarNewTopicButton extends Component {
|
|
||||||
@service composer;
|
|
||||||
@service currentUser;
|
|
||||||
@service siteSettings;
|
|
||||||
@service router;
|
|
||||||
@service header;
|
|
||||||
@service appEvents;
|
|
||||||
|
|
||||||
@tracked category;
|
|
||||||
@tracked tag;
|
|
||||||
|
|
||||||
get shouldRender() {
|
|
||||||
return this.currentUser && !this.router.currentRouteName.includes("admin");
|
|
||||||
}
|
|
||||||
|
|
||||||
get canCreateTopic() {
|
|
||||||
return this.currentUser?.can_create_topic;
|
|
||||||
}
|
|
||||||
|
|
||||||
get draftCount() {
|
|
||||||
return this.currentUser?.get("draft_count");
|
|
||||||
}
|
|
||||||
|
|
||||||
get createTopicTargetCategory() {
|
|
||||||
if (this.category?.canCreateTopic) {
|
|
||||||
return this.category;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this.siteSettings.default_subcategory_on_read_only_category) {
|
|
||||||
return this.category?.subcategoryWithCreateTopicPermission;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
get tagRestricted() {
|
|
||||||
return this.tag?.staff;
|
|
||||||
}
|
|
||||||
|
|
||||||
get createTopicDisabled() {
|
|
||||||
return (
|
|
||||||
(this.category && !this.createTopicTargetCategory) ||
|
|
||||||
(this.tagRestricted && !this.currentUser.staff)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
get categoryReadOnlyBanner() {
|
|
||||||
if (this.category && this.currentUser && this.createTopicDisabled) {
|
|
||||||
return this.category.read_only_banner;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
get createTopicClass() {
|
|
||||||
const baseClasses = "btn-default sidebar-new-topic-button";
|
|
||||||
return this.categoryReadOnlyBanner
|
|
||||||
? `${baseClasses} disabled`
|
|
||||||
: baseClasses;
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
createNewTopic() {
|
|
||||||
this.composer.openNewTopic({ category: this.category, tags: this.tag?.id });
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
getCategoryandTag() {
|
|
||||||
this.category = this.router.currentRoute.attributes?.category || null;
|
|
||||||
this.tag = this.router.currentRoute.attributes?.tag || null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
watchForComposer() {
|
|
||||||
// this covers opening drafts from the hamburger menu
|
|
||||||
this.appEvents.on("composer:will-open", this, this.closeHamburger);
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
stopWatchingForComposer() {
|
|
||||||
this.appEvents.off("composer:will-open", this, this.closeHamburger);
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
closeHamburger() {
|
|
||||||
this.header.hamburgerVisible = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
<template>
|
|
||||||
{{#if this.shouldRender}}
|
|
||||||
<div
|
|
||||||
class="sidebar-new-topic-button__wrapper"
|
|
||||||
{{didInsert this.getCategoryandTag}}
|
|
||||||
{{didUpdate this.getCategoryandTag this.router.currentRoute}}
|
|
||||||
{{didInsert this.watchForComposer}}
|
|
||||||
{{willDestroy this.stopWatchingForComposer}}
|
|
||||||
>
|
|
||||||
<CreateTopicButton
|
|
||||||
@canCreateTopic={{this.canCreateTopic}}
|
|
||||||
@action={{this.createNewTopic}}
|
|
||||||
@disabled={{this.createTopicDisabled}}
|
|
||||||
@label="topic.create"
|
|
||||||
@btnClass={{this.createTopicClass}}
|
|
||||||
@canCreateTopicOnTag={{not this.tagRestricted}}
|
|
||||||
@showDrafts={{gt this.draftCount 0}}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
{{/if}}
|
|
||||||
</template>
|
|
||||||
}
|
|
||||||
+11
-14
@@ -1,43 +1,40 @@
|
|||||||
import Component from "@glimmer/component";
|
import Component from "@glimmer/component";
|
||||||
|
import { fn } from "@ember/helper";
|
||||||
import { action } from "@ember/object";
|
import { action } from "@ember/object";
|
||||||
import { service } from "@ember/service";
|
import { service } from "@ember/service";
|
||||||
import { htmlSafe } from "@ember/template";
|
import { htmlSafe } from "@ember/template";
|
||||||
import DButton from "discourse/components/d-button";
|
import DButton from "discourse/components/d-button";
|
||||||
import concatClass from "discourse/helpers/concat-class";
|
import concatClass from "discourse/helpers/concat-class";
|
||||||
|
|
||||||
export default class UserColorPaletteMenuItem extends Component {
|
export default class SitePaletteMenuItem extends Component {
|
||||||
@service site;
|
@service customColor;
|
||||||
@service session;
|
|
||||||
|
|
||||||
get siteStyle() {
|
get siteStyle() {
|
||||||
return `--icon-color: ${this.args.colorPalette.accent}`;
|
return `--icon-color: ${this.args.colorPalette.color}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
get activeClass() {
|
get activeClass() {
|
||||||
if (this.args.selectedColorPaletteId === this.args.colorPalette.id) {
|
if (this.customColor.color === this.args.colorPalette.name) {
|
||||||
return "active";
|
return "active";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@action
|
@action
|
||||||
paletteSelected() {
|
handleInput(colorPalette) {
|
||||||
this.args.paletteSelected(this.args.colorPalette);
|
this.customColor.setColor(colorPalette.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div
|
<div class="color-palette-menu__item" data-color={{@colorPalette.name}}>
|
||||||
class="user-color-palette-menu__item"
|
|
||||||
data-color-palette={{@colorPalette.name}}
|
|
||||||
>
|
|
||||||
<DButton
|
<DButton
|
||||||
class={{concatClass
|
class={{concatClass
|
||||||
"btn-flat user-color-palette-menu__item-choice"
|
"btn-flat color-palette-menu__item-choice"
|
||||||
this.activeClass
|
this.activeClass
|
||||||
}}
|
}}
|
||||||
style={{htmlSafe this.siteStyle}}
|
style={{htmlSafe this.siteStyle}}
|
||||||
@icon="circle"
|
@icon="circle"
|
||||||
@translatedLabel={{@colorPalette.name}}
|
@translatedLabel={{@colorPalette.label}}
|
||||||
@action={{this.paletteSelected}}
|
@action={{fn this.handleInput @colorPalette}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@@ -1,210 +0,0 @@
|
|||||||
import Component from "@glimmer/component";
|
|
||||||
import { tracked } from "@glimmer/tracking";
|
|
||||||
import { action } from "@ember/object";
|
|
||||||
import { service } from "@ember/service";
|
|
||||||
import { isEmpty } from "@ember/utils";
|
|
||||||
import { Promise } from "rsvp";
|
|
||||||
import concatClass from "discourse/helpers/concat-class";
|
|
||||||
import icon from "discourse/helpers/d-icon";
|
|
||||||
import { reload } from "discourse/helpers/page-reloader";
|
|
||||||
import { ajax } from "discourse/lib/ajax";
|
|
||||||
import {
|
|
||||||
listColorSchemes,
|
|
||||||
updateColorSchemeCookie,
|
|
||||||
} from "discourse/lib/color-scheme-picker";
|
|
||||||
import cookie from "discourse/lib/cookie";
|
|
||||||
import DMenu from "float-kit/components/d-menu";
|
|
||||||
import UserColorPaletteMenuItem from "./user-color-palette-menu-item";
|
|
||||||
|
|
||||||
const HORIZON_PALETTES = [
|
|
||||||
"Horizon",
|
|
||||||
"Marigold",
|
|
||||||
"Violet",
|
|
||||||
"Lily",
|
|
||||||
"Clover",
|
|
||||||
"Royal",
|
|
||||||
];
|
|
||||||
|
|
||||||
export default class UserColorPaletteSelector extends Component {
|
|
||||||
@service currentUser;
|
|
||||||
@service keyValueStore;
|
|
||||||
@service site;
|
|
||||||
@service session;
|
|
||||||
@service interfaceColor;
|
|
||||||
|
|
||||||
@tracked anonColorPaletteId = this.#loadAnonColorPalette();
|
|
||||||
@tracked userColorPaletteId = this.session.userColorSchemeId;
|
|
||||||
@tracked cssLoaded = true;
|
|
||||||
|
|
||||||
get userColorPalettes() {
|
|
||||||
const availablePalettes = listColorSchemes(this.site)
|
|
||||||
?.map((userPalette) => {
|
|
||||||
return {
|
|
||||||
...userPalette,
|
|
||||||
accent: `#${
|
|
||||||
userPalette.colors.find((color) => color.name === "tertiary").hex
|
|
||||||
}`,
|
|
||||||
};
|
|
||||||
})
|
|
||||||
.filter((userPalette) => {
|
|
||||||
return HORIZON_PALETTES.some((palette) => {
|
|
||||||
return userPalette.name.toLowerCase().includes(palette.toLowerCase());
|
|
||||||
});
|
|
||||||
})
|
|
||||||
.sort();
|
|
||||||
|
|
||||||
// Match the light scheme with the corresponding dark id based in the name
|
|
||||||
return (
|
|
||||||
availablePalettes
|
|
||||||
?.map((palette) => {
|
|
||||||
if (palette.is_dark) {
|
|
||||||
return palette;
|
|
||||||
}
|
|
||||||
|
|
||||||
const normalizedLightName = palette.name.toLowerCase();
|
|
||||||
|
|
||||||
const correspondingDarkModeId = availablePalettes.find(
|
|
||||||
(item) =>
|
|
||||||
item.is_dark &&
|
|
||||||
normalizedLightName ===
|
|
||||||
item.name.toLowerCase().replace(/\s+dark$/, "")
|
|
||||||
)?.id;
|
|
||||||
|
|
||||||
return {
|
|
||||||
...palette,
|
|
||||||
correspondingDarkModeId,
|
|
||||||
};
|
|
||||||
})
|
|
||||||
// Only want to show palettes that have corresponding light/dark modes
|
|
||||||
.filter((palette) => !palette.is_dark)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
get selectedColorPaletteId() {
|
|
||||||
if (this.currentUser) {
|
|
||||||
return this.userColorPaletteId;
|
|
||||||
}
|
|
||||||
|
|
||||||
return this.anonColorPaletteId;
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
onRegisterMenu(api) {
|
|
||||||
this.dMenu = api;
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
|
||||||
paletteSelected(selectedPalette) {
|
|
||||||
if (selectedPalette.id === this.selectedColorPaletteId) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.#updatePreference(selectedPalette);
|
|
||||||
this.#changeSiteColorPalette(selectedPalette);
|
|
||||||
this.dMenu.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
#updatePreference(selectedPalette) {
|
|
||||||
updateColorSchemeCookie(selectedPalette.id);
|
|
||||||
updateColorSchemeCookie(selectedPalette.correspondingDarkModeId, {
|
|
||||||
dark: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!this.currentUser) {
|
|
||||||
this.anonColorPaletteId = selectedPalette.id;
|
|
||||||
} else {
|
|
||||||
this.userColorPaletteId = selectedPalette.id;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#loadAnonColorPalette() {
|
|
||||||
const storedAnonPaletteId = cookie("color_scheme_id");
|
|
||||||
if (storedAnonPaletteId) {
|
|
||||||
return parseInt(storedAnonPaletteId, 10);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async #changeSiteColorPalette(colorPalette) {
|
|
||||||
this.cssLoaded = false;
|
|
||||||
|
|
||||||
const lightPaletteId = colorPalette.id;
|
|
||||||
const darkPaletteId = colorPalette.correspondingDarkModeId;
|
|
||||||
const darkTag = document.querySelector("link.dark-scheme");
|
|
||||||
|
|
||||||
// TODO(osama) once we have built-in light/dark modes for each palette, we
|
|
||||||
// can stop making the 2nd ajax call for the dark palette and replace it
|
|
||||||
// with a include_dark_scheme param on the ajax call for the light
|
|
||||||
// palette which will include the href for the dark palette in the response
|
|
||||||
if (!darkTag) {
|
|
||||||
reload();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const lightPaletteInfo = await ajax(
|
|
||||||
`/color-scheme-stylesheet/${lightPaletteId}/${colorPalette.theme_id}.json`
|
|
||||||
);
|
|
||||||
const darkPaletteInfo = await ajax(
|
|
||||||
`/color-scheme-stylesheet/${darkPaletteId}/${colorPalette.theme_id}.json`
|
|
||||||
);
|
|
||||||
|
|
||||||
Promise.all([
|
|
||||||
this.#preloadAndSwapCSS(lightPaletteInfo.new_href, "light-scheme"),
|
|
||||||
this.#preloadAndSwapCSS(darkPaletteInfo.new_href, "dark-scheme"),
|
|
||||||
]).then(() => {
|
|
||||||
this.cssLoaded = true;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#preloadAndSwapCSS(newHref, existingLinkClass) {
|
|
||||||
return new Promise((resolve) => {
|
|
||||||
const existingLink = document.querySelector(
|
|
||||||
`link[rel='stylesheet'].${existingLinkClass}`
|
|
||||||
);
|
|
||||||
const newTag = document.createElement("link");
|
|
||||||
|
|
||||||
newTag.rel = "preload";
|
|
||||||
newTag.href = newHref;
|
|
||||||
newTag.as = "style";
|
|
||||||
newTag.onload = () => {
|
|
||||||
existingLink.href = newHref;
|
|
||||||
newTag.remove();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
|
|
||||||
document.head.appendChild(newTag);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
<template>
|
|
||||||
{{#unless (isEmpty this.userColorPalettes)}}
|
|
||||||
<DMenu
|
|
||||||
@identifier="user-color-palette-selector"
|
|
||||||
@placementStrategy="fixed"
|
|
||||||
@onRegisterApi={{this.onRegisterMenu}}
|
|
||||||
class={{concatClass
|
|
||||||
"btn-flat user-color-palette-selector sidebar-footer-actions-button"
|
|
||||||
(if this.cssLoaded "user-color-palette-css-loaded")
|
|
||||||
}}
|
|
||||||
data-selected-color-palette-id={{this.selectedColorPaletteId}}
|
|
||||||
@inline={{true}}
|
|
||||||
>
|
|
||||||
<:trigger>
|
|
||||||
{{icon "paintbrush"}}
|
|
||||||
</:trigger>
|
|
||||||
<:content>
|
|
||||||
<div class="user-color-palette-menu">
|
|
||||||
<div class="user-color-palette-menu__content">
|
|
||||||
{{#each this.userColorPalettes as |colorPalette|}}
|
|
||||||
<UserColorPaletteMenuItem
|
|
||||||
@selectedColorPaletteId={{this.selectedColorPaletteId}}
|
|
||||||
@colorPalette={{colorPalette}}
|
|
||||||
@paletteSelected={{this.paletteSelected}}
|
|
||||||
/>
|
|
||||||
{{/each}}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</:content>
|
|
||||||
</DMenu>
|
|
||||||
{{/unless}}
|
|
||||||
</template>
|
|
||||||
}
|
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
import { withPluginApi } from "discourse/lib/plugin-api";
|
import { withPluginApi } from "discourse/lib/plugin-api";
|
||||||
import TopicActivityColumn from "../components/card/topic-activity-column";
|
import TopicActivityColumn from "../components/card/topic-activity-column";
|
||||||
import TopicCategoryColumn from "../components/card/topic-category-column";
|
import TopicCategoryColumn from "../components/card/topic-category-column";
|
||||||
import TopicCreatorColumn from "../components/card/topic-creator-column";
|
import TopicLikesColumn from "../components/card/topic-likes-column";
|
||||||
import TopicRepliesColumn from "../components/card/topic-replies-column";
|
import TopicRepliesColumn from "../components/card/topic-replies-column";
|
||||||
import TopicStatusColumn from "../components/card/topic-status-column";
|
import TopicStatusColumn from "../components/card/topic-status-column";
|
||||||
|
|
||||||
@@ -23,27 +23,25 @@ const TopicCategory = <template>
|
|||||||
</td>
|
</td>
|
||||||
</template>;
|
</template>;
|
||||||
|
|
||||||
const TopicReplies = <template>
|
const TopicLikesReplies = <template>
|
||||||
<td class="topic-likes-replies-data">
|
<td class="topic-likes-replies-data">
|
||||||
|
<TopicLikesColumn @topic={{@topic}} />
|
||||||
<TopicRepliesColumn @topic={{@topic}} />
|
<TopicRepliesColumn @topic={{@topic}} />
|
||||||
</td>
|
</td>
|
||||||
</template>;
|
</template>;
|
||||||
|
|
||||||
const TopicCreator = <template>
|
|
||||||
<td class="topic-creator-data">
|
|
||||||
<TopicCreatorColumn @topic={{@topic}} />
|
|
||||||
</td>
|
|
||||||
</template>;
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "topic-list-customizations",
|
name: "topic-list-customizations",
|
||||||
|
|
||||||
initialize(container) {
|
initialize() {
|
||||||
const router = container.lookup("service:router");
|
|
||||||
withPluginApi("1.39.0", (api) => {
|
withPluginApi("1.39.0", (api) => {
|
||||||
api.registerValueTransformer(
|
api.registerValueTransformer(
|
||||||
"topic-list-columns",
|
"topic-list-columns",
|
||||||
({ value: columns }) => {
|
({ value: columns }) => {
|
||||||
|
columns.add("topic-activity", {
|
||||||
|
item: TopicActivity,
|
||||||
|
after: "title",
|
||||||
|
});
|
||||||
columns.add("topic-status", {
|
columns.add("topic-status", {
|
||||||
item: TopicStatus,
|
item: TopicStatus,
|
||||||
after: "topic-author",
|
after: "topic-author",
|
||||||
@@ -52,25 +50,14 @@ export default {
|
|||||||
item: TopicCategory,
|
item: TopicCategory,
|
||||||
after: "topic-status",
|
after: "topic-status",
|
||||||
});
|
});
|
||||||
|
|
||||||
columns.add("topic-likes-replies", {
|
columns.add("topic-likes-replies", {
|
||||||
item: TopicReplies,
|
item: TopicLikesReplies,
|
||||||
after: "topic-author-avatar",
|
|
||||||
});
|
|
||||||
columns.add("topic-creator", {
|
|
||||||
item: TopicCreator,
|
|
||||||
after: "topic-author-avatar",
|
after: "topic-author-avatar",
|
||||||
});
|
});
|
||||||
|
columns.delete("posters");
|
||||||
columns.delete("views");
|
columns.delete("views");
|
||||||
columns.delete("replies");
|
columns.delete("replies");
|
||||||
if (!router.currentRouteName.includes("userPrivateMessages")) {
|
columns.delete("activity");
|
||||||
columns.add("topic-activity", {
|
|
||||||
item: TopicActivity,
|
|
||||||
after: "title",
|
|
||||||
});
|
|
||||||
columns.delete("posters");
|
|
||||||
columns.delete("activity");
|
|
||||||
}
|
|
||||||
return columns;
|
return columns;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
@@ -85,9 +72,6 @@ export default {
|
|||||||
) {
|
) {
|
||||||
classes.push("--has-status-card");
|
classes.push("--has-status-card");
|
||||||
}
|
}
|
||||||
if (context.topic.replyCount > 1) {
|
|
||||||
classes.push("has-replies");
|
|
||||||
}
|
|
||||||
return classes;
|
return classes;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
@@ -95,34 +79,6 @@ export default {
|
|||||||
api.registerValueTransformer("topic-list-item-mobile-layout", () => {
|
api.registerValueTransformer("topic-list-item-mobile-layout", () => {
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
|
||||||
api.registerBehaviorTransformer(
|
|
||||||
"topic-list-item-click",
|
|
||||||
({ context: { event }, next }) => {
|
|
||||||
if (event.target.closest("a, button, input")) {
|
|
||||||
return next();
|
|
||||||
}
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
const topicLink = event.target
|
|
||||||
.closest("tr")
|
|
||||||
.querySelector("a.raw-topic-link");
|
|
||||||
|
|
||||||
// Redespatch the click on the topic link, so that all key-handing is sorted
|
|
||||||
topicLink.dispatchEvent(
|
|
||||||
new MouseEvent("click", {
|
|
||||||
ctrlKey: event.ctrlKey,
|
|
||||||
metaKey: event.metaKey,
|
|
||||||
shiftKey: event.shiftKey,
|
|
||||||
button: event.button,
|
|
||||||
bubbles: true,
|
|
||||||
cancelable: true,
|
|
||||||
})
|
|
||||||
);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -0,0 +1,18 @@
|
|||||||
|
import { tracked } from "@glimmer/tracking";
|
||||||
|
import { action } from "@ember/object";
|
||||||
|
import Service, { service } from "@ember/service";
|
||||||
|
import { DEFAULT_PALETTE_NAME } from "../components/custom-user-palette";
|
||||||
|
|
||||||
|
const CUSTOM_COLOR_KEY = "d-custom-color-preference";
|
||||||
|
|
||||||
|
export default class CustomColor extends Service {
|
||||||
|
@service keyValueStore;
|
||||||
|
@tracked
|
||||||
|
color = this.keyValueStore.getItem(CUSTOM_COLOR_KEY) || DEFAULT_PALETTE_NAME;
|
||||||
|
|
||||||
|
@action
|
||||||
|
setColor(color) {
|
||||||
|
this.color = color;
|
||||||
|
this.keyValueStore.setItem(CUSTOM_COLOR_KEY, color);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -6,3 +6,4 @@ en:
|
|||||||
user_replied: "replied"
|
user_replied: "replied"
|
||||||
user_posted: "posted"
|
user_posted: "posted"
|
||||||
user_updated: "updated"
|
user_updated: "updated"
|
||||||
|
|
||||||
|
|||||||
+5
-6
@@ -1,14 +1,13 @@
|
|||||||
{
|
{
|
||||||
"private": true,
|
"private": true,
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@discourse/lint-configs": "2.25.0",
|
"@discourse/lint-configs": "2.4.0",
|
||||||
"ember-template-lint": "7.8.1",
|
"ember-template-lint": "6.1.0",
|
||||||
"eslint": "9.28.0",
|
"eslint": "9.19.0",
|
||||||
"prettier": "3.5.3",
|
"prettier": "2.8.8"
|
||||||
"stylelint": "16.20.0"
|
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">= 22",
|
"node": ">= 18",
|
||||||
"npm": "please-use-pnpm",
|
"npm": "please-use-pnpm",
|
||||||
"yarn": "please-use-pnpm",
|
"yarn": "please-use-pnpm",
|
||||||
"pnpm": "9.x"
|
"pnpm": "9.x"
|
||||||
|
|||||||
Generated
+1766
-1085
File diff suppressed because it is too large
Load Diff
Binary file not shown.
|
Before Width: | Height: | Size: 127 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 129 KiB |
+22
-72
@@ -1,6 +1,4 @@
|
|||||||
@use "lib/viewport";
|
@media screen and (min-width: 1300px) {
|
||||||
|
|
||||||
@media screen and (width >= 1300px) {
|
|
||||||
#main-outlet {
|
#main-outlet {
|
||||||
border-top-right-radius: var(--d-border-radius-large);
|
border-top-right-radius: var(--d-border-radius-large);
|
||||||
border-top-left-radius: var(--d-border-radius-large);
|
border-top-left-radius: var(--d-border-radius-large);
|
||||||
@@ -20,47 +18,38 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.has-full-page-chat .chat-replying-indicator-container {
|
.has-full-page-chat .chat-replying-indicator-container {
|
||||||
margin-bottom: var(--main-grid-gap);
|
margin-bottom: var(--d-border-radius-large);
|
||||||
|
@include breakpoint(medium) {
|
||||||
@include viewport.until(lg) {
|
|
||||||
margin-bottom: 0;
|
margin-bottom: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.has-full-page-chat .chat-selection-management {
|
.has-full-page-chat .chat-selection-management {
|
||||||
margin-bottom: var(--main-grid-gap);
|
margin-bottom: var(--d-border-radius-large);
|
||||||
|
@include breakpoint(medium) {
|
||||||
@include viewport.until(lg) {
|
|
||||||
margin-bottom: 0;
|
margin-bottom: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.experimental-screen {
|
.experimental-screen {
|
||||||
|
@include breakpoint(medium) {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
max-width: unset !important;
|
max-width: unset !important;
|
||||||
|
@media screen and (max-width: 488px) {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
width: 100%;
|
width: 100%;
|
||||||
display: block;
|
display: block;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
position: relative;
|
position: relative;
|
||||||
|
container: content-width / inline-size;
|
||||||
@include viewport.until(lg) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width <= 488px) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(md) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
li {
|
li {
|
||||||
list-style: none;
|
list-style: none;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
&__top-left,
|
&__top-left,
|
||||||
&__top-right,
|
&__top-right,
|
||||||
&__bottom-left,
|
&__bottom-left,
|
||||||
@@ -70,45 +59,38 @@
|
|||||||
height: var(--d-border-radius-large);
|
height: var(--d-border-radius-large);
|
||||||
background-color: var(--background-color);
|
background-color: var(--background-color);
|
||||||
z-index: 399;
|
z-index: 399;
|
||||||
mask: radial-gradient(
|
-webkit-mask: radial-gradient(
|
||||||
circle at var(--d-border-radius-large) var(--d-border-radius-large),
|
circle at var(--d-border-radius-large) var(--d-border-radius-large),
|
||||||
transparent var(--d-border-radius-large),
|
transparent var(--d-border-radius-large),
|
||||||
transparent var(--d-border-radius-large),
|
transparent var(--d-border-radius-large),
|
||||||
black var(--d-border-radius-large)
|
black var(--d-border-radius-large)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
&__top-left {
|
&__top-left {
|
||||||
top: var(--header-offset);
|
top: var(--header-offset);
|
||||||
left: var(--left-distance);
|
left: var(--left-distance);
|
||||||
}
|
}
|
||||||
|
|
||||||
&__top-right {
|
&__top-right {
|
||||||
top: var(--header-offset);
|
top: var(--header-offset);
|
||||||
transform: rotate(90deg);
|
transform: rotate(90deg);
|
||||||
left: calc(var(--right-distance) - var(--d-border-radius-large));
|
left: calc(var(--right-distance) - var(--d-border-radius-large));
|
||||||
}
|
}
|
||||||
|
|
||||||
&__bottom-left {
|
&__bottom-left {
|
||||||
transform: rotate(-90deg);
|
transform: rotate(-90deg);
|
||||||
bottom: var(--main-grid-gap);
|
bottom: var(--d-border-radius-large);
|
||||||
left: var(--left-distance);
|
left: var(--left-distance);
|
||||||
|
@media screen and (max-width: 768px) {
|
||||||
@media screen and (width <= 768px) {
|
|
||||||
bottom: calc(var(--d-border-radius-large) * 2);
|
bottom: calc(var(--d-border-radius-large) * 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&__bottom-right {
|
&__bottom-right {
|
||||||
transform: rotate(180deg);
|
transform: rotate(180deg);
|
||||||
bottom: var(--main-grid-gap);
|
bottom: var(--d-border-radius-large);
|
||||||
left: calc(var(--right-distance) - var(--d-border-radius-large));
|
left: calc(var(--right-distance) - var(--d-border-radius-large));
|
||||||
|
@media screen and (max-width: 768px) {
|
||||||
@media screen and (width <= 768px) {
|
|
||||||
bottom: calc(var(--d-border-radius-large) * 2);
|
bottom: calc(var(--d-border-radius-large) * 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&__bottom-bar {
|
&__bottom-bar {
|
||||||
position: fixed;
|
position: fixed;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
@@ -116,49 +98,17 @@
|
|||||||
background-color: var(--background-color);
|
background-color: var(--background-color);
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: var(--left-distance);
|
left: var(--left-distance);
|
||||||
height: var(--main-grid-gap);
|
height: var(--d-border-radius-large);
|
||||||
|
@media screen and (max-width: 768px) {
|
||||||
@media screen and (width <= 768px) {
|
|
||||||
height: calc(var(--d-border-radius-large) * 2);
|
height: calc(var(--d-border-radius-large) * 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@container content-width (width > 1px) {
|
@container content-width (width > 1px) {
|
||||||
width: 100cqw;
|
width: 100cqw;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.rtl .experimental-screen {
|
@media screen and (min-width: 768px) {
|
||||||
&__top-left {
|
|
||||||
right: var(--left-distance);
|
|
||||||
left: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__top-right {
|
|
||||||
transform: rotate(-90deg) !important;
|
|
||||||
right: calc(var(--right-distance) - var(--d-border-radius-large));
|
|
||||||
left: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__bottom-left {
|
|
||||||
transform: rotate(90deg);
|
|
||||||
right: var(--left-distance);
|
|
||||||
left: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__bottom-right {
|
|
||||||
transform: rotate(180deg);
|
|
||||||
left: unset;
|
|
||||||
right: calc(var(--right-distance) - var(--d-border-radius-large));
|
|
||||||
}
|
|
||||||
|
|
||||||
&__bottom-bar {
|
|
||||||
right: var(--left-distance);
|
|
||||||
left: unset;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width >= 768px) {
|
|
||||||
.with-topic-progress {
|
.with-topic-progress {
|
||||||
bottom: calc(
|
bottom: calc(
|
||||||
env(safe-area-inset-bottom) + var(--composer-height, 0px) +
|
env(safe-area-inset-bottom) + var(--composer-height, 0px) +
|
||||||
@@ -167,7 +117,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@media screen and (width <= 768px) {
|
@media screen and (max-width: 768px) {
|
||||||
.with-topic-progress {
|
.with-topic-progress {
|
||||||
bottom: calc(
|
bottom: calc(
|
||||||
env(safe-area-inset-bottom) + var(--composer-height, 0px) +
|
env(safe-area-inset-bottom) + var(--composer-height, 0px) +
|
||||||
@@ -176,7 +126,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@media screen and (width <= 400px) {
|
@media screen and (max-width: 400px) {
|
||||||
.with-topic-progress {
|
.with-topic-progress {
|
||||||
bottom: calc(env(safe-area-inset-bottom) + var(--composer-height, 0px));
|
bottom: calc(env(safe-area-inset-bottom) + var(--composer-height, 0px));
|
||||||
}
|
}
|
||||||
|
|||||||
+8
-31
@@ -8,13 +8,11 @@
|
|||||||
|
|
||||||
.sidebar-new-topic-button__wrapper .topic-drafts-menu-trigger.btn.no-text {
|
.sidebar-new-topic-button__wrapper .topic-drafts-menu-trigger.btn.no-text {
|
||||||
background: var(--accent-color);
|
background: var(--accent-color);
|
||||||
|
|
||||||
&:hover,
|
&:hover,
|
||||||
&:focus-visible {
|
&:focus-visible {
|
||||||
background: oklch(from var(--accent-color) 40% c h) !important;
|
background: oklch(from var(--accent-color) 40% c h) !important;
|
||||||
box-shadow: none;
|
box-shadow: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-text-color);
|
color: var(--accent-text-color);
|
||||||
}
|
}
|
||||||
@@ -28,37 +26,31 @@
|
|||||||
.discourse-no-touch .btn-default,
|
.discourse-no-touch .btn-default,
|
||||||
.discourse-no-touch .select-kit .select-kit-header.btn-default {
|
.discourse-no-touch .select-kit .select-kit-header.btn-default {
|
||||||
background: var(--primary-100);
|
background: var(--primary-100);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
border-color: transparent;
|
border-color: transparent;
|
||||||
box-shadow: 0 0 8px 1px var(--button-box-shadow);
|
box-shadow: 0px 0px 8px 1px var(--button-box-shadow);
|
||||||
background: var(--d-content-background);
|
background: var(--d-content-background);
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&:focus-visible {
|
&:focus-visible {
|
||||||
background: var(--d-content-background);
|
background: var(--d-content-background);
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
box-shadow: 0 0 0 3px var(--button-box-shadow);
|
box-shadow: 0px 0px 0px 3px var(--button-box-shadow);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&:active:not(:hover, :focus) {
|
&:active:not(:hover, :focus) {
|
||||||
color: var(--primary);
|
color: var(--primary);
|
||||||
background: var(--tertiary-300);
|
background: var(--tertiary-300);
|
||||||
background-image: none;
|
background-image: none;
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--tertiary-high);
|
color: var(--tertiary-high);
|
||||||
}
|
}
|
||||||
@@ -66,45 +58,30 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.btn-primary,
|
.btn-primary,
|
||||||
#create-topic.btn,
|
#create-topic.btn {
|
||||||
.discourse-no-touch .btn-default.ai-new-question-button {
|
|
||||||
background-color: var(--accent-color);
|
background-color: var(--accent-color);
|
||||||
color: var(--accent-text-color);
|
color: var(--accent-text-color);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-text-color);
|
color: var(--accent-text-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
.discourse-no-touch & {
|
.discourse-no-touch & {
|
||||||
background: light-dark(
|
background: oklch(from var(--accent-color) 40% c h) !important;
|
||||||
oklch(from var(--accent-color) 40% c h),
|
box-shadow: 0px 0px 6px 1px var(--button-box-shadow);
|
||||||
oklch(from var(--accent-color) 50% c h)
|
|
||||||
);
|
|
||||||
box-shadow: 0 0 6px 1px var(--button-box-shadow);
|
|
||||||
color: var(--accent-text-color);
|
color: var(--accent-text-color);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-text-color);
|
color: var(--accent-text-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&:focus-visible {
|
&:focus-visible {
|
||||||
.discourse-no-touch & {
|
.discourse-no-touch & {
|
||||||
background: light-dark(
|
background: oklch(from var(--accent-color) 40% c h) !important;
|
||||||
oklch(from var(--accent-color) 40% c h),
|
box-shadow: 0px 0px 0px 4px var(--button-box-shadow);
|
||||||
oklch(from var(--accent-color) 50% c h)
|
|
||||||
);
|
|
||||||
box-shadow: 0 0 0 4px var(--button-box-shadow);
|
|
||||||
color: var(--accent-text-color);
|
color: var(--accent-text-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&:active {
|
&:active {
|
||||||
background: light-dark(
|
background: oklch(from var(--accent-color) 30% c h) !important;
|
||||||
oklch(from var(--accent-color) 40% c h),
|
|
||||||
oklch(from var(--accent-color) 50% c h)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,357 +0,0 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
.categories-and-latest {
|
|
||||||
.category-list {
|
|
||||||
border-collapse: separate;
|
|
||||||
|
|
||||||
th.topics {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
thead tr th {
|
|
||||||
font-size: var(--font-up-1-rem);
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
gap: 1em;
|
|
||||||
padding-top: 1em;
|
|
||||||
border: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody tr {
|
|
||||||
display: grid;
|
|
||||||
grid-template-areas:
|
|
||||||
"title topics"
|
|
||||||
"category category"
|
|
||||||
"subcategory subcategory";
|
|
||||||
row-gap: 1em;
|
|
||||||
border: 1px solid var(--primary-300);
|
|
||||||
border-radius: var(--d-border-radius-large);
|
|
||||||
box-shadow: 0 0 12px 1px var(--topic-card-shadow);
|
|
||||||
}
|
|
||||||
|
|
||||||
td.category {
|
|
||||||
display: contents;
|
|
||||||
border-top-left-radius: var(--d-border-radius-large);
|
|
||||||
border-bottom-left-radius: var(--d-border-radius-large);
|
|
||||||
border-width: 2px;
|
|
||||||
padding: 1em 1.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody h3 {
|
|
||||||
grid-area: title;
|
|
||||||
padding: 1em 0 0 1.5rem;
|
|
||||||
font-size: var(--font-up-1-rem);
|
|
||||||
|
|
||||||
.category-name {
|
|
||||||
display: flex;
|
|
||||||
align-self: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-category {
|
|
||||||
gap: 0.25em;
|
|
||||||
align-items: center;
|
|
||||||
font-size: var(--font-up-1-rem);
|
|
||||||
|
|
||||||
.d-icon:first-of-type:not(.d-icon-lock),
|
|
||||||
&.--style-square::before,
|
|
||||||
&.--style-emoji .emoji {
|
|
||||||
width: 1.25em;
|
|
||||||
height: 1.25em;
|
|
||||||
margin-right: 0.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.--style-square::before {
|
|
||||||
border-radius: 6px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-icon.d-icon-lock {
|
|
||||||
order: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.topics {
|
|
||||||
width: auto;
|
|
||||||
padding: 1em 1.5rem 0 0;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: end;
|
|
||||||
}
|
|
||||||
|
|
||||||
.category-description {
|
|
||||||
grid-area: category;
|
|
||||||
padding: 0 1.5rem;
|
|
||||||
margin: 0;
|
|
||||||
font-size: var(--font-down-1-rem);
|
|
||||||
}
|
|
||||||
|
|
||||||
.subcategories {
|
|
||||||
grid-area: subcategory;
|
|
||||||
gap: 0.25em 0.5em;
|
|
||||||
padding: 0 1.5rem 1em;
|
|
||||||
margin: 0;
|
|
||||||
|
|
||||||
.badge-category__wrapper {
|
|
||||||
background-color: light-dark(
|
|
||||||
oklch(from var(--category-badge-color) 98% calc(c * 0.2) h),
|
|
||||||
oklch(from var(--category-badge-color) 45% calc(c * 0.5) h)
|
|
||||||
);
|
|
||||||
padding: 0.25em 0.5rem;
|
|
||||||
border-radius: var(--d-border-radius);
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-category__name {
|
|
||||||
color: light-dark(
|
|
||||||
oklch(from var(--category-badge-color) 20% calc(c * 1) h),
|
|
||||||
oklch(from var(--category-badge-color) 100% calc(c * 0.9) h)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-category.--style-square::before {
|
|
||||||
border-radius: 3px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.latest-topic-list {
|
|
||||||
.table-heading {
|
|
||||||
border: 0;
|
|
||||||
font-size: var(--font-up-1-rem);
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
&-item {
|
|
||||||
display: grid;
|
|
||||||
grid-template-columns: min-content min-content auto min-content;
|
|
||||||
grid-template-areas:
|
|
||||||
"creator title title status"
|
|
||||||
". category activity activity";
|
|
||||||
grid-column-gap: 0.75rem;
|
|
||||||
grid-row-gap: 0.5rem;
|
|
||||||
background: var(--d-content-background);
|
|
||||||
box-shadow: 0 0 12px 1px var(--topic-card-shadow);
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
padding: 0.75em 1rem;
|
|
||||||
border: 1px solid var(--primary-300);
|
|
||||||
border-radius: var(--d-border-radius-large);
|
|
||||||
margin-top: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.main-link,
|
|
||||||
.topic-stats {
|
|
||||||
display: contents;
|
|
||||||
}
|
|
||||||
|
|
||||||
.top-row {
|
|
||||||
grid-area: title;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bottom-row {
|
|
||||||
grid-area: category;
|
|
||||||
|
|
||||||
.discourse-tags {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-category__wrapper {
|
|
||||||
border-radius: var(--d-border-radius);
|
|
||||||
padding: 0.25em 0.5rem;
|
|
||||||
background-color: light-dark(
|
|
||||||
oklch(from var(--category-badge-color) 97% calc(c * 0.3) h),
|
|
||||||
oklch(from var(--category-badge-color) 45% calc(c * 0.5) h)
|
|
||||||
);
|
|
||||||
|
|
||||||
@include viewport.until(md) {
|
|
||||||
padding: 0.25em 0.5rem;
|
|
||||||
font-size: var(--font-down-2);
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-category__name {
|
|
||||||
color: light-dark(
|
|
||||||
oklch(from var(--category-badge-color) 20% calc(c * 1) h),
|
|
||||||
oklch(from var(--category-badge-color) 100% calc(c * 0.9) h)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-list-data {
|
|
||||||
grid-area: likes-replies;
|
|
||||||
}
|
|
||||||
|
|
||||||
.num.posts-map {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-last-activity {
|
|
||||||
grid-area: activity;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
text-align: left;
|
|
||||||
font-size: var(--font-down-1-rem);
|
|
||||||
|
|
||||||
&::before {
|
|
||||||
content: "";
|
|
||||||
display: inline-block;
|
|
||||||
width: 0.25em;
|
|
||||||
height: 0.25em;
|
|
||||||
background-color: var(--primary-500);
|
|
||||||
border-radius: 100%;
|
|
||||||
margin-right: 0.5em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-poster {
|
|
||||||
grid-area: creator;
|
|
||||||
width: auto;
|
|
||||||
align-self: flex-start;
|
|
||||||
|
|
||||||
.avatar {
|
|
||||||
height: 24px;
|
|
||||||
width: 24px;
|
|
||||||
border-radius: var(--d-border-radius-small);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
.category-list.with-topics {
|
|
||||||
margin-inline: 1rem;
|
|
||||||
|
|
||||||
.num.posts,
|
|
||||||
.category-topics-count {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.category-list {
|
|
||||||
&-item {
|
|
||||||
padding-top: 0;
|
|
||||||
padding-bottom: 0;
|
|
||||||
border-top: 0 !important;
|
|
||||||
border-bottom: 0 !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
|
|
||||||
tr:first-of-type {
|
|
||||||
order: -2;
|
|
||||||
}
|
|
||||||
|
|
||||||
tr.subcategories-list {
|
|
||||||
order: -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
tr:nth-last-of-type(2) {
|
|
||||||
border-bottom: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
th.main-link {
|
|
||||||
padding-top: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.category-boxes.with-subcategories {
|
|
||||||
@include viewport.from(sm) {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(md) {
|
|
||||||
padding-inline: 1rem;
|
|
||||||
box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
.category {
|
|
||||||
border: 0;
|
|
||||||
|
|
||||||
&-box-inner {
|
|
||||||
border-radius: var(--d-border-radius-large);
|
|
||||||
border: 1px solid var(--primary-300);
|
|
||||||
background: var(--d-content-background);
|
|
||||||
box-shadow: 0 0 12px 1px var(--topic-card-shadow);
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
.discourse-no-touch & {
|
|
||||||
border-color: var(--accent-color);
|
|
||||||
background: var(--d-content-background);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&.selected {
|
|
||||||
box-shadow:
|
|
||||||
0 0 0 2px var(--accent-color),
|
|
||||||
0 0 12px 1px var(--topic-card-shadow);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&-details {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
gap: 1rem;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
&-box-heading {
|
|
||||||
h3 {
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-category {
|
|
||||||
display: flex;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
align-items: flex-start;
|
|
||||||
gap: 1em;
|
|
||||||
justify-content: space-between;
|
|
||||||
width: 100%;
|
|
||||||
|
|
||||||
&__wrapper {
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.--style-square::before {
|
|
||||||
aspect-ratio: 1 / 1;
|
|
||||||
height: auto;
|
|
||||||
width: 13%;
|
|
||||||
border-radius: var(--d-border-radius);
|
|
||||||
}
|
|
||||||
|
|
||||||
&__name {
|
|
||||||
flex-basis: 100%;
|
|
||||||
font-size: var(--font-up-1-rem);
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-icon:not(.d-icon-lock),
|
|
||||||
img.emoji {
|
|
||||||
aspect-ratio: 1 / 1;
|
|
||||||
height: auto;
|
|
||||||
width: 13%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.description {
|
|
||||||
text-align: left;
|
|
||||||
margin: 0;
|
|
||||||
font-size: var(--font-down-1-rem);
|
|
||||||
}
|
|
||||||
|
|
||||||
.subcategories {
|
|
||||||
margin-top: auto;
|
|
||||||
row-gap: 0.5em;
|
|
||||||
|
|
||||||
.subcategory {
|
|
||||||
margin-bottom: 0;
|
|
||||||
font-size: var(--font-down-1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+4
-35
@@ -1,13 +1,9 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
.full-page-chat.full-page-chat-sidebar-enabled {
|
.full-page-chat.full-page-chat-sidebar-enabled {
|
||||||
border: none;
|
border: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.c-navbar-container {
|
.c-navbar-container {
|
||||||
.full-page-chat & {
|
padding: 0 1.5em;
|
||||||
padding: 0 1.5em;
|
|
||||||
}
|
|
||||||
background-color: var(--d-content-background);
|
background-color: var(--d-content-background);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -17,43 +13,22 @@ body.has-full-page-chat {
|
|||||||
|
|
||||||
.chat-drawer-container {
|
.chat-drawer-container {
|
||||||
.is-expanded & {
|
.is-expanded & {
|
||||||
box-shadow: 0 0 0 2px var(--tertiary-medium);
|
box-shadow: 0px 0px 0px 2px var(--d-chat-border);
|
||||||
}
|
}
|
||||||
|
|
||||||
.chat-drawer.is-expanded & {
|
.chat-drawer.is-expanded & {
|
||||||
border: none;
|
border: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.c-navbar__title {
|
|
||||||
padding-left: 0.33em; // visual alignment for chat index, which does not havea a backarrow
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.chat-drawer-outlet-container {
|
.chat-drawer-outlet-container {
|
||||||
z-index: z("composer", "content");
|
z-index: z("composer", "content");
|
||||||
|
|
||||||
.peek-mode-active & {
|
|
||||||
padding-bottom: 0;
|
|
||||||
left: unset;
|
|
||||||
right: var(--main-grid-gap);
|
|
||||||
|
|
||||||
&:has(.is-expanded) {
|
|
||||||
z-index: calc(z("composer", "dropdown") + 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.chat-drawer {
|
|
||||||
.peek-mode-active & {
|
|
||||||
max-width: 90vw;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.chat-drawer .channels-list-container .chat-channel-row {
|
.chat-drawer .channels-list-container .chat-channel-row {
|
||||||
margin-bottom: var(--spacing-block-xs);
|
margin-bottom: var(--spacing-block-xs);
|
||||||
font-size: var(--font-up-1);
|
font-size: var(--font-up-1);
|
||||||
|
border-radius: var(--d-border-radius);
|
||||||
border-bottom: none;
|
border-bottom: none;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: var(--d-sidebar-active-background);
|
background-color: var(--d-sidebar-active-background);
|
||||||
}
|
}
|
||||||
@@ -78,11 +53,5 @@ body.has-full-page-chat {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.chat-drawer-active.chat-drawer-expanded .chat-composer-dropdown__menu-content {
|
.chat-drawer-active.chat-drawer-expanded .chat-composer-dropdown__menu-content {
|
||||||
z-index: z("modal", "dialog");
|
z-index: z("composer", "content") + 1;
|
||||||
}
|
|
||||||
|
|
||||||
.chat-replying-indicator-container {
|
|
||||||
@include viewport.from(sm) {
|
|
||||||
margin-left: calc(0.65em + 0.2rem);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
+25
-5
@@ -1,24 +1,20 @@
|
|||||||
.user-color-palette-menu {
|
.color-palette-menu {
|
||||||
&__item .btn-icon-text.btn-flat {
|
&__item .btn-icon-text.btn-flat {
|
||||||
background-color: var(--d-content-background);
|
background-color: var(--d-content-background);
|
||||||
width: 100%;
|
width: 100%;
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
}
|
}
|
||||||
|
|
||||||
&__item .btn-icon-text.btn-flat:hover {
|
&__item .btn-icon-text.btn-flat:hover {
|
||||||
background-color: var(--d-selected);
|
background-color: var(--d-selected);
|
||||||
box-shadow: none;
|
box-shadow: none;
|
||||||
color: var(--primary);
|
color: var(--primary);
|
||||||
}
|
}
|
||||||
|
|
||||||
&__item .btn-icon-text.btn-flat:hover svg {
|
&__item .btn-icon-text.btn-flat:hover svg {
|
||||||
color: var(--icon-color);
|
color: var(--icon-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
&__item .btn-icon-text.btn-flat svg {
|
&__item .btn-icon-text.btn-flat svg {
|
||||||
color: var(--icon-color);
|
color: var(--icon-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
&__item-choice.active.btn-icon-text.btn-flat {
|
&__item-choice.active.btn-icon-text.btn-flat {
|
||||||
background-color: var(--d-selected);
|
background-color: var(--d-selected);
|
||||||
}
|
}
|
||||||
@@ -27,3 +23,27 @@
|
|||||||
.user-color-palette-content .fk-d-menu__inner-content {
|
.user-color-palette-content .fk-d-menu__inner-content {
|
||||||
border: none;
|
border: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
html.custom-color-horizon {
|
||||||
|
--accent-base-color: #595bca;
|
||||||
|
}
|
||||||
|
|
||||||
|
html.custom-color-marigold {
|
||||||
|
--accent-base-color: #d3881f;
|
||||||
|
}
|
||||||
|
|
||||||
|
html.custom-color-violet {
|
||||||
|
--accent-base-color: #9b15de;
|
||||||
|
}
|
||||||
|
|
||||||
|
html.custom-color-lily {
|
||||||
|
--accent-base-color: #cc338c;
|
||||||
|
}
|
||||||
|
|
||||||
|
html.custom-color-clover {
|
||||||
|
--accent-base-color: #45a06e;
|
||||||
|
}
|
||||||
|
|
||||||
|
html.custom-color-royal {
|
||||||
|
--accent-base-color: #4169e1;
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,12 +1,108 @@
|
|||||||
:root {
|
:root {
|
||||||
|
--accent-base-color: #595bca;
|
||||||
|
--accent-color: light-dark(
|
||||||
|
var(--accent-base-color),
|
||||||
|
oklch(from var(--accent-base-color) calc(l * 0.95) c h)
|
||||||
|
);
|
||||||
|
// --background-color: light-dark(#f5f8ff, #101112);
|
||||||
|
--background-color: light-dark(
|
||||||
|
oklch(from var(--accent-color) 98% calc(c * 0.25) h),
|
||||||
|
oklch(from var(--accent-color) 10% 0.025 h)
|
||||||
|
);
|
||||||
|
--header_primary-low-mid: light-dark(
|
||||||
|
oklch(from var(--background-color) calc(l * 0.75) calc(c * 2) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 1) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
|
--header_primary-medium: light-dark(
|
||||||
|
oklch(from var(--background-color) calc(l * 0.55) calc(c * 2) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.35) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
|
--d-content-background: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 2) 0 h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.375) 0 h)
|
||||||
|
);
|
||||||
|
--primary-100: light-dark(#f2f2f2, #333333);
|
||||||
|
--primary-300: light-dark(#d1d1d1, #838383);
|
||||||
|
--primary-low: light-dark(#e9e9e9, #313131);
|
||||||
|
--primary-high: light-dark(#646464, #a6a6a6);
|
||||||
|
--primary-very-high: light-dark(#434343, #c7c7c7);
|
||||||
|
--d-hover: oklch(from var(--d-selected) l c h / 0.75);
|
||||||
|
--tertiary: var(--accent-color);
|
||||||
|
--tertiary-medium: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.25) calc(c * 0.25) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.75) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
|
--tertiary-very-low: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.75) calc(c * 0.25) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.5) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
|
--tertiary-med-or-tertiary: var(--accent-color);
|
||||||
|
--tertiary-low: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.6) calc(c * 0.25) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.6) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
|
--tertiary-300: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.5) calc(c * 2) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.65) calc(c * 0.65) h)
|
||||||
|
);
|
||||||
|
--tertiary-high: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1) c h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 1) c h)
|
||||||
|
);
|
||||||
--d-sidebar-highlight-hover-icon: var(--d-sidebar-link-color);
|
--d-sidebar-highlight-hover-icon: var(--d-sidebar-link-color);
|
||||||
|
--search-color: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.65) calc(c * 0.65) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.5) calc(c * 2) h)
|
||||||
|
);
|
||||||
|
--search-banner-text-color: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.65) calc(c * 0.65) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.85) calc(c * 2) h)
|
||||||
|
);
|
||||||
|
--topic-card-shadow: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.85) calc(c * 0.5) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.2) calc(c * 0.01) h / 0.25)
|
||||||
|
);
|
||||||
|
--button-box-shadow: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.5) calc(c * 0.35) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.75) calc(c * 0.5) h)
|
||||||
|
);
|
||||||
|
--d-selected: light-dark(
|
||||||
|
oklch(from var(--background-color) calc(l * 0.9375) calc(c * 2) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.7) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
--d-sidebar-highlight-hover-background: var(--d-selected);
|
--d-sidebar-highlight-hover-background: var(--d-selected);
|
||||||
|
--d-sidebar-border-color: light-dark(
|
||||||
|
oklch(from var(--background-color) calc(l * 0.9) calc(c * 1) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.7) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
|
--d-chat-border: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.25) calc(c * 0.25) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.25) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
|
--accent-text-color: light-dark(#ffffff, #212121);
|
||||||
|
--d-nav-color--active: var(--accent-color);
|
||||||
|
--d-sidebar-background: var(--background-color);
|
||||||
|
--d-sidebar-footer-fade: rgba(var(--tertiary-50-rgb), 1);
|
||||||
|
--d-sidebar-link-color: light-dark(
|
||||||
|
oklch(from var(--accent-color) calc(l * 0.8) calc(c * 0.25) h),
|
||||||
|
oklch(from var(--accent-color) calc(l * 1.5) calc(c * 0.25) h)
|
||||||
|
);
|
||||||
--d-sidebar-link-icon-color: var(--d-sidebar-link-color);
|
--d-sidebar-link-icon-color: var(--d-sidebar-link-color);
|
||||||
--d-sidebar-header-color: var(--d-sidebar-link-color);
|
--d-sidebar-header-color: var(--d-sidebar-link-color);
|
||||||
--d-sidebar-header-icon-color: var(--d-sidebar-link-color);
|
--d-sidebar-header-icon-color: var(--d-sidebar-link-color);
|
||||||
|
--d-sidebar-suffix-color: light-dark(
|
||||||
|
oklch(from var(--accent-base-color) calc(l * 1) calc(c * 0.9) h),
|
||||||
|
oklch(from var(--accent-base-color) calc(l * 1) calc(c * 0.9) h)
|
||||||
|
);
|
||||||
--d-sidebar-active-suffix-color: var(--d-sidebar-suffix-color);
|
--d-sidebar-active-suffix-color: var(--d-sidebar-suffix-color);
|
||||||
--d-sidebar-background: var(--background-color);
|
--link-color: light-dark(
|
||||||
--d-sidebar-footer-fade: rgb(var(--tertiary-50-rgb), 1);
|
var(--accent-base-color),
|
||||||
|
oklch(from var(--accent-base-color) calc(l * 0.95) c h)
|
||||||
|
);
|
||||||
|
--link-color-hover: light-dark(
|
||||||
|
var(--accent-base-color),
|
||||||
|
oklch(from var(--accent-base-color) calc(l * 1.5) calc(c * 2.25) h)
|
||||||
|
);
|
||||||
--d-sidebar-prefix-background: var(--d-selected);
|
--d-sidebar-prefix-background: var(--d-selected);
|
||||||
--d-sidebar-active-prefix-background: light-dark(
|
--d-sidebar-active-prefix-background: light-dark(
|
||||||
oklch(from var(--d-selected) calc(l * 0.85) c h),
|
oklch(from var(--d-selected) calc(l * 0.85) c h),
|
||||||
@@ -20,7 +116,6 @@
|
|||||||
--d-sidebar-highlight-color: var(--primary);
|
--d-sidebar-highlight-color: var(--primary);
|
||||||
--d-sidebar-highlight-background: var(--d-selected);
|
--d-sidebar-highlight-background: var(--d-selected);
|
||||||
--d-sidebar-section-link-icon-size: 1em;
|
--d-sidebar-section-link-icon-size: 1em;
|
||||||
--d-hover: oklch(from var(--d-selected) l c h / 0.75);
|
|
||||||
--d-input-bg-color: var(--d-content-background);
|
--d-input-bg-color: var(--d-content-background);
|
||||||
--d-sidebar-active-color: var(--primary) !important;
|
--tertiary-hover: var(--accent-color);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,65 +0,0 @@
|
|||||||
.peek-mode-toggle {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width >= 1300px) {
|
|
||||||
html:not(.fullscreen-composer) {
|
|
||||||
.peek-mode-toggle svg {
|
|
||||||
transform: scaleX(-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.composer-open {
|
|
||||||
.full-width-enabled .peek-mode-toggle {
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
|
|
||||||
.full-width-enabled.peek-mode-active {
|
|
||||||
#reply-control.hide-preview {
|
|
||||||
transition: none;
|
|
||||||
box-shadow: none;
|
|
||||||
border-radius: var(--d-border-radius-large);
|
|
||||||
|
|
||||||
.grippie {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.reply-area {
|
|
||||||
padding-inline: 0.67em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#reply-control:not(.fullscreen).hide-preview {
|
|
||||||
width: 100%;
|
|
||||||
right: var(--main-grid-gap);
|
|
||||||
top: var(--header-offset);
|
|
||||||
bottom: var(--main-grid-gap);
|
|
||||||
left: unset;
|
|
||||||
height: unset;
|
|
||||||
max-width: 36.5vw;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.has-sidebar-page {
|
|
||||||
#main-outlet-wrapper {
|
|
||||||
grid-template-columns:
|
|
||||||
var(--d-sidebar-width) calc(100vw - 38vw - var(--d-sidebar-width))
|
|
||||||
1fr;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&:not(.has-sidebar-page) {
|
|
||||||
#main-outlet-wrapper {
|
|
||||||
grid-template-columns: 0 calc(100vw - 52vw) 1fr;
|
|
||||||
}
|
|
||||||
|
|
||||||
#reply-control:not(.fullscreen).hide-preview {
|
|
||||||
max-width: 46vw;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-wrapper .sidebar-container {
|
|
||||||
height: unset;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+3
-175
@@ -1,11 +1,8 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
#reply-control
|
#reply-control
|
||||||
.select-kit.dropdown-select-box.composer-actions
|
.select-kit.dropdown-select-box.composer-actions
|
||||||
.select-kit-header {
|
.select-kit-header {
|
||||||
border: 1px solid var(--tertiary-700);
|
border: 1px solid var(--tertiary-700);
|
||||||
background: var(--secondary);
|
background: var(--secondary);
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
@@ -13,23 +10,17 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#reply-control {
|
|
||||||
background-color: var(--background-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
#reply-control.hide-preview:not(.draft) {
|
#reply-control.hide-preview:not(.draft) {
|
||||||
@include viewport.from(sm) {
|
@include breakpoint("mobile-extra-large", $rule: min-width) {
|
||||||
background: var(--d-content-background);
|
background: var(--d-content-background);
|
||||||
|
|
||||||
border-top-right-radius: var(--d-border-radius);
|
border-top-right-radius: var(--d-border-radius);
|
||||||
border-top-left-radius: var(--d-border-radius);
|
border-top-left-radius: var(--d-border-radius);
|
||||||
|
|
||||||
.grippie {
|
.grippie {
|
||||||
background: var(--tertiary-low);
|
background: var(--tertiary-low);
|
||||||
border-top-right-radius: var(--d-border-radius);
|
|
||||||
border-top-left-radius: var(--d-border-radius);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.user-selector,
|
|
||||||
.title-and-category {
|
.title-and-category {
|
||||||
padding: 0 var(--spacing-inline-m);
|
padding: 0 var(--spacing-inline-m);
|
||||||
width: calc(100% - var(--spacing-inline-m) * 2);
|
width: calc(100% - var(--spacing-inline-m) * 2);
|
||||||
@@ -51,7 +42,6 @@
|
|||||||
.reply-area {
|
.reply-area {
|
||||||
padding-inline: 0;
|
padding-inline: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.reply-to,
|
.reply-to,
|
||||||
.submit-panel {
|
.submit-panel {
|
||||||
padding-inline: var(--spacing-inline-sm);
|
padding-inline: var(--spacing-inline-sm);
|
||||||
@@ -68,7 +58,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.d-editor-button-bar {
|
.d-editor-button-bar {
|
||||||
.btn:hover,
|
.btn:hover,
|
||||||
.toolbar-popup-menu-options.is-expanded {
|
.toolbar-popup-menu-options.is-expanded {
|
||||||
@@ -80,12 +69,11 @@
|
|||||||
color: inherit;
|
color: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
// to have parity with regular select-kit styling used elsewhere
|
//to have parity with regular select-kit styling used elsewhere
|
||||||
.select-kit-row {
|
.select-kit-row {
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--primary-high);
|
color: var(--primary-high);
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--primary);
|
color: var(--primary);
|
||||||
@@ -99,163 +87,3 @@
|
|||||||
border-radius: var(--d-border-radius);
|
border-radius: var(--d-border-radius);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.discourse-no-touch .translation-selector-dropdown {
|
|
||||||
.select-kit-header.btn-default {
|
|
||||||
background: var(--background-color);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#reply-control.composer-action-add_translation {
|
|
||||||
.d-editor-preview .d-editor-translation-preview-wrapper {
|
|
||||||
border-color: var(--d-sidebar-border-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-editor-preview .d-editor-translation-preview-wrapper__header {
|
|
||||||
top: 6.5rem;
|
|
||||||
padding: 0.25rem 0.75rem;
|
|
||||||
background: var(--background-color);
|
|
||||||
color: var(--accent-color);
|
|
||||||
border-radius: var(--d-border-radius-large);
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-title-translator input {
|
|
||||||
width: 47.25vw;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@keyframes fade {
|
|
||||||
from {
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
to {
|
|
||||||
opacity: 0.6;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
.composer-open {
|
|
||||||
body::after {
|
|
||||||
height: 100vh;
|
|
||||||
content: "";
|
|
||||||
top: 0;
|
|
||||||
bottom: 0;
|
|
||||||
position: fixed;
|
|
||||||
width: 100vw;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
background: black;
|
|
||||||
z-index: calc(z("mobile-composer") - 1);
|
|
||||||
user-select: none;
|
|
||||||
animation: fade 0.3s forwards;
|
|
||||||
|
|
||||||
@media (prefers-reduced-motion) {
|
|
||||||
animation-duration: 0s;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.toggle-toolbar {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#reply-control {
|
|
||||||
background: var(--secondary);
|
|
||||||
|
|
||||||
&.open {
|
|
||||||
top: 0;
|
|
||||||
transform: none;
|
|
||||||
height: 100dvh;
|
|
||||||
max-height: unset;
|
|
||||||
}
|
|
||||||
|
|
||||||
.title-input {
|
|
||||||
order: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#reply-title {
|
|
||||||
border: 0;
|
|
||||||
padding: var(--space-3) 0;
|
|
||||||
border-radius: 0;
|
|
||||||
background: var(--secondary);
|
|
||||||
font-size: var(--font-up-1);
|
|
||||||
margin: 0;
|
|
||||||
|
|
||||||
&:focus {
|
|
||||||
outline: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.reply-area {
|
|
||||||
padding-inline: var(--space-4);
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-editor {
|
|
||||||
&-textarea-wrapper {
|
|
||||||
border: 0;
|
|
||||||
|
|
||||||
&.in-focus {
|
|
||||||
outline: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&-input {
|
|
||||||
padding-inline: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
p[data-placeholder] {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
&-button-bar {
|
|
||||||
width: 100%;
|
|
||||||
justify-content: space-around;
|
|
||||||
flex-wrap: nowrap;
|
|
||||||
overflow-x: scroll;
|
|
||||||
position: absolute;
|
|
||||||
bottom: 0;
|
|
||||||
border: 1px solid var(--primary-low);
|
|
||||||
border-radius: var(--d-border-radius);
|
|
||||||
background: var(--secondary-very-high);
|
|
||||||
scrollbar-width: none;
|
|
||||||
-ms-overflow-style: none;
|
|
||||||
margin-block: var(--space-3);
|
|
||||||
|
|
||||||
&::-webkit-scrollbar {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn {
|
|
||||||
font-size: var(--font-up-1);
|
|
||||||
color: var(--primary-high);
|
|
||||||
|
|
||||||
&:not(a) {
|
|
||||||
flex-shrink: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.composer-toggle-switch__slider {
|
|
||||||
background: var(--secondary);
|
|
||||||
}
|
|
||||||
|
|
||||||
.submit-panel {
|
|
||||||
.cancel {
|
|
||||||
position: absolute;
|
|
||||||
top: 0.5rem;
|
|
||||||
right: 3rem;
|
|
||||||
|
|
||||||
.d-icon {
|
|
||||||
font-size: var(--font-0);
|
|
||||||
padding: 0.4em 0.467em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.mobile-preview {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -1,276 +0,0 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
// Full width layout. Ported from the Discourse Full Width theme component here
|
|
||||||
// https://meta.discourse.org/t/discourse-full-width-component/292496, which we
|
|
||||||
// intend to move into core over time.
|
|
||||||
//
|
|
||||||
// We are copying this here so we can continue to iterate on Horizon with full
|
|
||||||
// width without having to include the theme component as a dependency, we
|
|
||||||
// need to remove this once full width is in core.
|
|
||||||
|
|
||||||
$sidebar-width: 17em;
|
|
||||||
|
|
||||||
.wrap {
|
|
||||||
max-width: unset; // undoing core default
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header #site-logo {
|
|
||||||
// this prevents the logo from shifting header content
|
|
||||||
// when the sidebar is opened
|
|
||||||
max-height: 100%;
|
|
||||||
max-width: 100%;
|
|
||||||
object-fit: contain; // contains logo without squishing/stretching
|
|
||||||
|
|
||||||
// allows some flexibility for wide logos
|
|
||||||
body:not(.has-sidebar-page) & {
|
|
||||||
max-width: unset;
|
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
max-width: 25vw;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header #site-text-logo {
|
|
||||||
font-size: clamp(var(--font-0), 2.5vw, var(--font-up-2));
|
|
||||||
|
|
||||||
.has-sidebar-page & {
|
|
||||||
white-space: wrap;
|
|
||||||
line-height: var(--line-height-medium);
|
|
||||||
|
|
||||||
@include line-clamp(2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-outlet-wrapper {
|
|
||||||
padding: 0;
|
|
||||||
|
|
||||||
body.has-sidebar-page & {
|
|
||||||
.sidebar-wrapper {
|
|
||||||
width: var(--d-sidebar-width);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
body.has-full-page-chat & {
|
|
||||||
gap: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-wrapper {
|
|
||||||
width: 100%; // safari has issues without this
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-outlet {
|
|
||||||
margin: 0 auto;
|
|
||||||
max-width: var(--d-max-width);
|
|
||||||
width: 100%;
|
|
||||||
|
|
||||||
body.has-full-page-chat & {
|
|
||||||
max-width: unset;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.has-full-page-chat:not(.discourse-sidebar) .full-page-chat {
|
|
||||||
border: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-outlet > .regular {
|
|
||||||
max-width: var(--d-max-width);
|
|
||||||
margin: 0 auto;
|
|
||||||
|
|
||||||
body.has-sidebar-page & {
|
|
||||||
margin: 0 auto;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header .title:not(.title--minimized) {
|
|
||||||
// allowing overflow here isn't always ideal
|
|
||||||
// but works well enough most of the time
|
|
||||||
overflow: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header {
|
|
||||||
> .wrap {
|
|
||||||
.contents {
|
|
||||||
display: grid;
|
|
||||||
grid-template-areas: "logo lspace extra-info rspace panel";
|
|
||||||
grid-template-columns:
|
|
||||||
minmax(auto, 1fr)
|
|
||||||
auto
|
|
||||||
minmax(0, calc(var(--d-max-width)))
|
|
||||||
auto
|
|
||||||
minmax(auto, 1fr);
|
|
||||||
|
|
||||||
.d-header-mode {
|
|
||||||
grid-area: extra-info;
|
|
||||||
white-space: nowrap;
|
|
||||||
|
|
||||||
@include viewport.until(md) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header .title {
|
|
||||||
min-width: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.has-sidebar-page & {
|
|
||||||
// at wide widths, when 1fr > 0
|
|
||||||
// we want the panel to be the same width as the sidebar
|
|
||||||
// this way we can get more accurate centering
|
|
||||||
grid-template-columns:
|
|
||||||
calc(var(--d-sidebar-width) - 11px) // 11px is wrap padding
|
|
||||||
1fr
|
|
||||||
minmax(0, calc(var(--d-max-width)))
|
|
||||||
1fr
|
|
||||||
minmax(0, calc(var(--d-sidebar-width) - 11px));
|
|
||||||
gap: 1em;
|
|
||||||
|
|
||||||
// at narrower widths, when 1fr = 0
|
|
||||||
// we can center without matching the sidebar's width
|
|
||||||
// which allows the title to take up the remaining width
|
|
||||||
@media screen and (width <= 1400px) {
|
|
||||||
grid-template-columns:
|
|
||||||
calc(var(--d-sidebar-width) - 11px)
|
|
||||||
1fr
|
|
||||||
minmax(0, calc(var(--d-max-width)))
|
|
||||||
1fr
|
|
||||||
auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width <= 1000px) {
|
|
||||||
gap: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header-mode {
|
|
||||||
grid-area: extra-info;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.header-sidebar-toggle {
|
|
||||||
grid-area: logo;
|
|
||||||
}
|
|
||||||
|
|
||||||
.before-header-panel-outlet {
|
|
||||||
grid-area: extra-info;
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header-mode {
|
|
||||||
.bootstrap-mode {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.home-logo-wrapper-outlet {
|
|
||||||
grid-area: logo;
|
|
||||||
margin-left: 3.7em; // 2.7em hamburger width + 1em for margin
|
|
||||||
margin-right: 0.725em;
|
|
||||||
display: flex;
|
|
||||||
overflow: visible;
|
|
||||||
|
|
||||||
.title {
|
|
||||||
flex: 1 1 auto;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.panel {
|
|
||||||
grid-area: panel;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.extra-info-wrapper {
|
|
||||||
grid-area: extra-info;
|
|
||||||
max-width: var(--d-max-width);
|
|
||||||
width: 100%;
|
|
||||||
box-sizing: border-box;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.header-search--enabled .floating-search-input-wrapper {
|
|
||||||
grid-area: extra-info;
|
|
||||||
|
|
||||||
@include viewport.until(md) {
|
|
||||||
grid-area: rspace;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
body.has-sidebar-page {
|
|
||||||
.wrap {
|
|
||||||
max-width: unset; // undoing core default
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header-mode,
|
|
||||||
.extra-info-wrapper {
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width >= calc($reply-area-max-width + ($sidebar-width * 2))) {
|
|
||||||
#reply-control.show-preview {
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-container {
|
|
||||||
height: auto;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width <= calc($reply-area-max-width + ($sidebar-width * 2))) and (width >= calc($reply-area-max-width + calc($sidebar-width / 2))) {
|
|
||||||
#reply-control.show-preview:not(.fullscreen) {
|
|
||||||
margin-left: $sidebar-width;
|
|
||||||
width: auto;
|
|
||||||
|
|
||||||
// overruling new core composer changes
|
|
||||||
max-width: $reply-area-max-width;
|
|
||||||
transform: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-container {
|
|
||||||
height: auto;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// overruling new core composer changes
|
|
||||||
@media screen and (min-width: $reply-area-max-width) {
|
|
||||||
#reply-control.show-preview:not(.fullscreen) {
|
|
||||||
max-width: $reply-area-max-width;
|
|
||||||
transform: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
body.sidebar-animate {
|
|
||||||
#main-outlet-wrapper {
|
|
||||||
transition: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header-wrap .wrap {
|
|
||||||
transition: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header-icons {
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
|
|
||||||
.rtl {
|
|
||||||
.d-header .title {
|
|
||||||
margin-right: 3.7em; // 2.7em hamburger width + 1em for margin
|
|
||||||
margin-left: 0.725em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// provides some extra space for login buttons
|
|
||||||
@media screen and (width >= 1400px) {
|
|
||||||
.anon {
|
|
||||||
.d-header .panel {
|
|
||||||
grid-column-start: -4;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,65 +0,0 @@
|
|||||||
// Fixing bulk select (only needed for desktop)
|
|
||||||
.bulk-select-enabled {
|
|
||||||
.topic-list-header {
|
|
||||||
position: relative;
|
|
||||||
top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-author-avatar-data {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bulk-select.topic-list-data {
|
|
||||||
grid-area: bulk-select;
|
|
||||||
margin-left: -0.5em;
|
|
||||||
|
|
||||||
@media screen and (width <= 576px) {
|
|
||||||
margin-top: 0;
|
|
||||||
|
|
||||||
label {
|
|
||||||
padding-block: 0.345em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
input {
|
|
||||||
transform: scale(1.5);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-list-header {
|
|
||||||
tr {
|
|
||||||
border: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-list-data {
|
|
||||||
padding: 0;
|
|
||||||
|
|
||||||
&:not(.default) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.default {
|
|
||||||
.bulk-select,
|
|
||||||
span:not(.bulk-select-topics, .d-button-label) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// bulk select
|
|
||||||
.bulk-select-topics {
|
|
||||||
position: absolute;
|
|
||||||
right: 0;
|
|
||||||
background: var(--secondary);
|
|
||||||
border-radius: 0 0 0 var(--d-border-radius);
|
|
||||||
display: flex;
|
|
||||||
gap: 0.5rem;
|
|
||||||
margin: 0.5rem;
|
|
||||||
|
|
||||||
button {
|
|
||||||
white-space: nowrap;
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+19
-17
@@ -1,14 +1,15 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
.d-header {
|
.d-header {
|
||||||
box-shadow: none;
|
box-shadow: none;
|
||||||
background: var(--background-color);
|
background: var(--background-color);
|
||||||
|
@include breakpoint(extra-large, $rule: min-width) {
|
||||||
@include viewport.from(xl) {
|
padding-bottom: 1em;
|
||||||
padding-bottom: var(--main-grid-gap);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.has-full-page-chat .d-header {
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
.user-menu .quick-access-panel,
|
.user-menu .quick-access-panel,
|
||||||
.user-notifications-list {
|
.user-notifications-list {
|
||||||
li {
|
li {
|
||||||
@@ -43,18 +44,15 @@
|
|||||||
.d-header-icons
|
.d-header-icons
|
||||||
.header-color-scheme-toggle
|
.header-color-scheme-toggle
|
||||||
.-expanded
|
.-expanded
|
||||||
> .d-icon,
|
> .d-icon {
|
||||||
.discourse-no-touch .header-sidebar-toggle button:hover .d-icon {
|
|
||||||
color: var(--header_primary-medium);
|
color: var(--header_primary-medium);
|
||||||
}
|
}
|
||||||
|
|
||||||
.discourse-no-touch .interface-color-selector-content {
|
.discourse-no-touch .interface-color-selector-content {
|
||||||
border: none;
|
border: none;
|
||||||
border-radius: var(--d-border-radius);
|
border-radius: var(--d-border-radius);
|
||||||
|
|
||||||
.btn {
|
.btn {
|
||||||
border: none;
|
border: none;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
box-shadow: none;
|
box-shadow: none;
|
||||||
}
|
}
|
||||||
@@ -64,6 +62,10 @@
|
|||||||
.drop-down-mode .d-header-icons .active .icon,
|
.drop-down-mode .d-header-icons .active .icon,
|
||||||
.drop-down-mode .d-header-icons .header-color-scheme-toggle .-expanded {
|
.drop-down-mode .d-header-icons .header-color-scheme-toggle .-expanded {
|
||||||
border-color: transparent;
|
border-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.drop-down-mode .d-header-icons .active .icon,
|
||||||
|
.drop-down-mode .d-header-icons .header-color-scheme-toggle .-expanded {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -71,6 +73,14 @@
|
|||||||
color: var(--accent-text-color);
|
color: var(--accent-text-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.user-menu .quick-access-panel li,
|
||||||
|
.user-notifications-list li,
|
||||||
|
.user-menu .quick-access-panel li.do-not-disturb,
|
||||||
|
.menu-panel .panel-body-bottom .btn,
|
||||||
|
.menu-panel .panel-body-bottom .btn:hover {
|
||||||
|
// background-color: var(--d-content-background);
|
||||||
|
}
|
||||||
|
|
||||||
body.login-page,
|
body.login-page,
|
||||||
body.signup-page,
|
body.signup-page,
|
||||||
body.invite-page,
|
body.invite-page,
|
||||||
@@ -80,11 +90,3 @@ body.activate-account-page {
|
|||||||
background: var(--background-color);
|
background: var(--background-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.header-dropdown-toggle.chat-header-icon .icon .chat-channel-unread-indicator {
|
|
||||||
border-color: var(--background-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-header-icons .badge-notification {
|
|
||||||
border-color: var(--background-color);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -2,6 +2,8 @@
|
|||||||
.list-controls #create-topic,
|
.list-controls #create-topic,
|
||||||
.notifications-button-footer .reason .text,
|
.notifications-button-footer .reason .text,
|
||||||
.pinned-button .reason .text,
|
.pinned-button .reason .text,
|
||||||
.more-topics__browse-more {
|
.more-topics__browse-more,
|
||||||
|
//footer-message might cause issues, not sure what possible stuff can be in there, but the general idea is to hide it bcs having an ugly H3 (what?) CTA at the bottom is just… ugly imo
|
||||||
|
.footer-message {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,15 +0,0 @@
|
|||||||
body.static-login {
|
|
||||||
#main-outlet-wrapper {
|
|
||||||
grid-template-areas:
|
|
||||||
"sidebar blank"
|
|
||||||
"sidebar content"
|
|
||||||
"sidebar below-content";
|
|
||||||
grid-template-rows: auto 1fr auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.login-welcome {
|
|
||||||
border-radius: none;
|
|
||||||
border: none;
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+37
-54
@@ -1,112 +1,105 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
:root {
|
:root {
|
||||||
--main-grid-gap: 0.5em;
|
--main-grid-gap: 2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
html:not(:has(.has-full-page-chat)) {
|
html:not(:has(.has-full-page-chat)) {
|
||||||
background-color: var(--background-color);
|
background-color: var(--background-color);
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
@include breakpoint("mobile-extra-large") {
|
||||||
background-color: var(--d-content-background);
|
background-color: var(--d-content-background);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
-webkit-font-smoothing: antialiased;
|
-webkit-font-smoothing: antialiased;
|
||||||
|
@include breakpoint("mobile-extra-large") {
|
||||||
@include viewport.until(sm) {
|
|
||||||
background-color: var(--d-content-background);
|
background-color: var(--d-content-background);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#main-outlet-wrapper {
|
#main-outlet-wrapper {
|
||||||
gap: var(--main-grid-gap);
|
gap: var(--main-grid-gap);
|
||||||
}
|
}
|
||||||
|
|
||||||
body.has-sidebar-page.has-full-page-chat #main-outlet-wrapper {
|
body.has-sidebar-page.has-full-page-chat #main-outlet-wrapper {
|
||||||
grid-column-gap: var(--main-grid-gap);
|
grid-column-gap: var(--main-grid-gap);
|
||||||
background-color: var(--background-color);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
body.has-full-page-chat:not(.has-sidebar-page) {
|
body.has-full-page-chat:not(.has-sidebar-page) {
|
||||||
.d-header {
|
.d-header {
|
||||||
background-color: var(--background-color);
|
background-color: var(--background-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
#main-outlet-wrapper {
|
#main-outlet-wrapper {
|
||||||
gap: var(--main-grid-gap);
|
gap: var(--main-grid-gap);
|
||||||
|
@include breakpoint(medium) {
|
||||||
@include viewport.until(lg) {
|
|
||||||
gap: 0;
|
gap: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
body.has-sidebar-page #main-outlet-wrapper {
|
body.has-sidebar-page #main-outlet-wrapper {
|
||||||
grid-template-columns: var(--d-sidebar-width) minmax(0, 1fr) 0;
|
grid-template-columns: var(--d-sidebar-width) minmax(0, 1fr) 0px;
|
||||||
|
|
||||||
#main-outlet {
|
#main-outlet {
|
||||||
max-width: unset;
|
max-width: unset;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
body:not(.has-sidebar-page) #main-outlet-wrapper {
|
body:not(.has-sidebar-page) #main-outlet-wrapper {
|
||||||
@include viewport.from(lg) {
|
@include breakpoint(medium, $rule: min-width) {
|
||||||
grid-template-columns: 0 minmax(0, 1fr) 0;
|
grid-template-columns: 0px minmax(0, 1fr) 0px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
body:not(.has-full-page-chat, .wizard) {
|
body:not(.has-full-page-chat) {
|
||||||
@include viewport.from(xl) {
|
@include breakpoint(extra-large, $rule: min-width) {
|
||||||
background-color: var(--background-color);
|
background-color: var(--background-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
#main-outlet-wrapper {
|
#main-outlet-wrapper {
|
||||||
@include viewport.until(lg) {
|
@include breakpoint(medium) {
|
||||||
--main-grid-gap: 0;
|
--main-grid-gap: 0;
|
||||||
}
|
}
|
||||||
|
@include breakpoint(tablet, $rule: min-width) {
|
||||||
@media screen and (width >= 768px) {
|
|
||||||
gap: var(--main-grid-gap);
|
gap: var(--main-grid-gap);
|
||||||
}
|
}
|
||||||
|
|
||||||
#main-outlet {
|
#main-outlet {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
max-width: unset;
|
|
||||||
padding-bottom: var(--spacing-block-l);
|
padding-bottom: var(--spacing-block-l);
|
||||||
border-radius: var(--d-border-radius-large);
|
max-width: unset;
|
||||||
background-color: var(--d-content-background);
|
//thanks to random container elements on the page, I can't do a direct child selector here because it targets all the randomness, so I see no other option than MANUALLY adding every possible element that can appear in the main outlet YAY
|
||||||
|
.list-controls,
|
||||||
@include viewport.until(lg) {
|
.list-container,
|
||||||
border-radius: 0;
|
#topic-title,
|
||||||
}
|
.container.posts,
|
||||||
|
#topic-footer-buttons,
|
||||||
html.composer-open & {
|
.more-topics__container,
|
||||||
padding-bottom: var(--composer-height);
|
.welcome-banner,
|
||||||
}
|
.container .user-main,
|
||||||
|
.reviewable,
|
||||||
> *:not(.experimental-screen, .activate-account) {
|
.admin-content,
|
||||||
@include viewport.from(lg) {
|
.discourse-post-event-upcoming-events,
|
||||||
box-sizing: border-box;
|
.container.groups-index,
|
||||||
|
.body-page,
|
||||||
|
.container.badges,
|
||||||
|
.topic-above-footer-buttons-outlet .presence-users,
|
||||||
|
.global-notice,
|
||||||
|
.container.tags-index {
|
||||||
|
@include breakpoint(medium, $rule: min-width) {
|
||||||
max-width: 1000px;
|
max-width: 1000px;
|
||||||
margin-inline: auto;
|
margin-inline: auto;
|
||||||
padding-inline: var(--spacing-inline-l);
|
padding-inline: var(--spacing-inline-l);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
border-radius: var(--d-border-radius-large);
|
||||||
|
@include breakpoint(medium) {
|
||||||
|
border-radius: 0px;
|
||||||
|
}
|
||||||
|
background-color: var(--d-content-background);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
.welcome-banner {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#list-area {
|
#list-area {
|
||||||
.show-more.has-topics {
|
.show-more.has-topics {
|
||||||
@include viewport.from(lg) {
|
@include breakpoint(medium, $rule: min-width) {
|
||||||
width: auto;
|
width: auto;
|
||||||
right: 50%;
|
right: 50%;
|
||||||
transform: translateX(50%);
|
transform: translateX(50%);
|
||||||
@@ -118,7 +111,6 @@ body:not(.has-full-page-chat, .wizard) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.topic-list-body {
|
.topic-list-body {
|
||||||
padding-top: var(--spacing-block-m);
|
padding-top: var(--spacing-block-m);
|
||||||
}
|
}
|
||||||
@@ -133,12 +125,3 @@ aside.onebox {
|
|||||||
padding: 1em;
|
padding: 1em;
|
||||||
background-color: var(--d-content-background);
|
background-color: var(--d-content-background);
|
||||||
}
|
}
|
||||||
|
|
||||||
.no-ember {
|
|
||||||
#main-outlet {
|
|
||||||
border-radius: var(--d-border-radius-large);
|
|
||||||
margin: 0 var(--main-grid-gap) var(--main-grid-gap) var(--main-grid-gap);
|
|
||||||
padding: 2em;
|
|
||||||
max-height: calc(100vh - 50px - 1em - var(--main-grid-gap));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
+8
-49
@@ -1,5 +1,3 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
.user-main .about.collapsed-info .details {
|
.user-main .about.collapsed-info .details {
|
||||||
background: var(--d-content-background);
|
background: var(--d-content-background);
|
||||||
}
|
}
|
||||||
@@ -10,7 +8,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.powered-by-discourse {
|
.powered-by-discourse {
|
||||||
z-index: 400;
|
z-index: 9999;
|
||||||
}
|
}
|
||||||
|
|
||||||
.boxed.white {
|
.boxed.white {
|
||||||
@@ -67,11 +65,12 @@ input[type="color"]:focus,
|
|||||||
outline: 2px solid var(--accent-color);
|
outline: 2px solid var(--accent-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
#reply-control {
|
||||||
// pinned topic excerpts are hidden on small screens too
|
background-color: var(--background-color);
|
||||||
.fk-d-menu__trigger.topic-list-layout-trigger {
|
}
|
||||||
display: none;
|
|
||||||
}
|
.fk-d-menu__trigger.topic-list-layout-trigger {
|
||||||
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.search-container .search-header,
|
.search-container .search-header,
|
||||||
@@ -83,7 +82,7 @@ input[type="color"]:focus,
|
|||||||
|
|
||||||
.user-main .about .details {
|
.user-main .about .details {
|
||||||
padding: 1em 1em 0;
|
padding: 1em 1em 0;
|
||||||
border-bottom: 0;
|
border-bottom: 0px;
|
||||||
border-radius: var(--d-border-radius);
|
border-radius: var(--d-border-radius);
|
||||||
background-color: var(--primary-50);
|
background-color: var(--primary-50);
|
||||||
}
|
}
|
||||||
@@ -95,43 +94,3 @@ input[type="color"]:focus,
|
|||||||
.discourse-reactions-list .reactions {
|
.discourse-reactions-list .reactions {
|
||||||
gap: 0.15em;
|
gap: 0.15em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.group-details-container {
|
|
||||||
border-radius: var(--d-border-radius);
|
|
||||||
}
|
|
||||||
|
|
||||||
.period-chooser-header {
|
|
||||||
border-radius: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// compatibility with the top contributors sidebar theme component
|
|
||||||
// https://meta.discourse.org/t/top-contributors-sidebar/215110
|
|
||||||
.list-container
|
|
||||||
#list-area
|
|
||||||
> .contents
|
|
||||||
> .topic-list:has(.discourse-top-contributors) {
|
|
||||||
grid-template-areas: "head head" "body sidebar";
|
|
||||||
grid-template-rows: auto 1fr;
|
|
||||||
|
|
||||||
@include viewport.until(lg) {
|
|
||||||
grid-template-areas: "head head" "body body";
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody {
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
|
|
||||||
.discourse-top-contributors {
|
|
||||||
width: auto;
|
|
||||||
box-sizing: border-box;
|
|
||||||
|
|
||||||
@include viewport.until(lg) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.top-contributors-heading {
|
|
||||||
font-size: var(--font-up-2);
|
|
||||||
padding-bottom: 0.5em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
+25
-65
@@ -1,93 +1,73 @@
|
|||||||
@use "lib/viewport";
|
//temp sepeate file to avoid merge hell… to be distributed later
|
||||||
|
@include breakpoint(medium) {
|
||||||
// temp separate file to avoid merge hell… to be distributed later
|
|
||||||
@include viewport.until(lg) {
|
|
||||||
html,
|
html,
|
||||||
.d-header {
|
.d-header {
|
||||||
background-color: var(--d-content-background);
|
background-color: var(--d-content-background);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#main-outlet-wrapper {
|
#main-outlet-wrapper {
|
||||||
*[class*="navigation-"] & {
|
*[class*="navigation-"] & {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#main-outlet {
|
#main-outlet {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
padding-top: var(--spacing-block-sm);
|
padding-top: var(--spacing-block-sm);
|
||||||
}
|
}
|
||||||
|
|
||||||
.list-controls {
|
.list-controls {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
padding-inline: var(
|
padding-inline: var(
|
||||||
--spacing-inline-m
|
--spacing-inline-m
|
||||||
) !important; // override will be fixed when the whole chat page shenanigans is resolved
|
) !important; //override will be fixed when the whole chat page shenanigans is resolved
|
||||||
padding-block: var(--spacing-block-s);
|
padding-block: var(--spacing-block-s);
|
||||||
border-bottom: 1px solid var(--primary-200);
|
border-bottom: 1px solid var(--primary-200);
|
||||||
}
|
}
|
||||||
|
|
||||||
.navigation-container {
|
.navigation-container {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
gap: var(--spacing-inline-s);
|
gap: var(--spacing-inline-s);
|
||||||
|
//dont know why we even hide this crucial navigation on mobile
|
||||||
.category-breadcrumb.hidden,
|
.category-breadcrumb.hidden,
|
||||||
.category-breadcrumb {
|
.category-breadcrumb {
|
||||||
display: flex !important;
|
display: flex !important;
|
||||||
column-gap: var(--spacing-inline-m);
|
column-gap: var(--spacing-inline-s);
|
||||||
row-gap: var(--spacing-block-xs);
|
row-gap: var(--spacing-block-xs);
|
||||||
flex-basis: 100%;
|
flex-basis: 100%;
|
||||||
|
|
||||||
li {
|
|
||||||
margin-right: 0;
|
|
||||||
margin-left: calc(
|
|
||||||
(var(--spacing-block-s) - 2px) * -1
|
|
||||||
); // 2px is width of the outline
|
|
||||||
}
|
|
||||||
|
|
||||||
.select-kit-header-wrapper {
|
|
||||||
gap: 0.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.select-kit-header {
|
.select-kit-header {
|
||||||
background: var(--d-content-background);
|
background: var(--d-content-background);
|
||||||
|
padding-block: var(--spacing-block-s);
|
||||||
|
padding-inline: 0;
|
||||||
|
border: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn-default {
|
.btn-default {
|
||||||
border: 0;
|
border: 0;
|
||||||
margin-right: 0;
|
margin-right: 0;
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
font-size: var(--font-up-1);
|
font-size: var(--font-up-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.fk-d-button-tooltip {
|
.fk-d-button-tooltip {
|
||||||
margin-right: 0;
|
margin-right: 0;
|
||||||
margin-left: var(
|
margin-left: var(
|
||||||
--spacing-inline-xs
|
--spacing-inline-xs
|
||||||
); // pure visual correction for horizontal alignment
|
); //pure visual correction for horitzontal alignment
|
||||||
|
|
||||||
&:has(#create-topic) {
|
&:has(#create-topic) {
|
||||||
order: 1;
|
order: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#navigation-bar,
|
#navigation-bar,
|
||||||
.navigation-controls,
|
.navigation-controls,
|
||||||
.category-breadcrumb {
|
.category-breadcrumb {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
margin-bottom: 0;
|
margin-bottom: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.navigation-controls {
|
.navigation-controls {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
gap: var(--spacing-inline-s);
|
gap: var(--spacing-inline-s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -95,12 +75,12 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.list-container {
|
.list-container {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
padding-inline: 0 !important;
|
padding-inline: 0 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.topic-list-body {
|
.topic-list-body {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
border-top: 0;
|
border-top: 0;
|
||||||
padding-top: 0;
|
padding-top: 0;
|
||||||
}
|
}
|
||||||
@@ -108,18 +88,16 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
#topic-title {
|
#topic-title {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
padding-inline: var(--spacing-inline-s) !important;
|
padding-inline: var(--spacing-inline-s) !important;
|
||||||
|
|
||||||
.title-wrapper {
|
.title-wrapper {
|
||||||
gap: var(--spacing-block-s);
|
gap: var(--spacing-block-s);
|
||||||
}
|
}
|
||||||
|
|
||||||
.topic-category {
|
.topic-category {
|
||||||
order: -1;
|
order: -1;
|
||||||
}
|
}
|
||||||
|
//make mixin of this
|
||||||
// make mixin of this
|
|
||||||
.badge-category__wrapper {
|
.badge-category__wrapper {
|
||||||
font-size: var(--font-down-2-rem);
|
font-size: var(--font-down-2-rem);
|
||||||
border-radius: var(--d-border-radius);
|
border-radius: var(--d-border-radius);
|
||||||
@@ -141,15 +119,12 @@
|
|||||||
oklch(from var(--category-badge-color) 100% calc(c * 0.9) h)
|
oklch(from var(--category-badge-color) 100% calc(c * 0.9) h)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
.discourse-tags {
|
.discourse-tags {
|
||||||
gap: var(--spacing-inline-xs);
|
gap: var(--spacing-inline-xs);
|
||||||
|
|
||||||
&__tag-separator {
|
&__tag-separator {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.discourse-tag {
|
.discourse-tag {
|
||||||
font-size: var(--font-down-2-rem);
|
font-size: var(--font-down-2-rem);
|
||||||
padding: var(--spacing-inline-xs) var(--spacing-inline-s);
|
padding: var(--spacing-inline-xs) var(--spacing-inline-s);
|
||||||
@@ -160,14 +135,14 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.container.posts {
|
.container.posts {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
padding-inline: var(--spacing-inline-xs) !important;
|
padding-inline: var(--spacing-inline-xs) !important;
|
||||||
|
|
||||||
.main-avatar .avatar {
|
.main-avatar .avatar {
|
||||||
width: 40px;
|
width: 40px;
|
||||||
height: 40px;
|
height: 40px;
|
||||||
|
border-radius: var(--d-border-radius);
|
||||||
}
|
}
|
||||||
|
|
||||||
.topic-body {
|
.topic-body {
|
||||||
@@ -176,22 +151,18 @@
|
|||||||
font-size: var(--font-0-rem);
|
font-size: var(--font-0-rem);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.contents {
|
.contents {
|
||||||
padding-top: var(--spacing-block-m);
|
padding-top: var(--spacing-block-m);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.small-action {
|
.small-action {
|
||||||
&-desc {
|
&-desc {
|
||||||
padding: var(--spacing-block-xs) 0;
|
padding: var(--spacing-block-xs) 0;
|
||||||
}
|
}
|
||||||
|
//for core eventually, better way imo
|
||||||
// for core eventually, better way imo
|
|
||||||
.topic-avatar {
|
.topic-avatar {
|
||||||
padding-top: 0;
|
padding-top: 0;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
font-size: var(--font-up-1);
|
font-size: var(--font-up-1);
|
||||||
}
|
}
|
||||||
@@ -201,43 +172,32 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
#topic-footer-buttons {
|
#topic-footer-buttons {
|
||||||
@include viewport.until(sm) {
|
@include breakpoint(mobile-extra-large) {
|
||||||
padding-inline: var(--spacing-inline-xs) !important;
|
padding-inline: var(--spacing-inline-xs) !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// should be changed in core, should not be a primary btn
|
//should be changed in core, should not be a primary btn
|
||||||
// changing this into straight buttons to match the progress one, which doesn't work well with rounded corners
|
//changing this into straight buttons to match the progress one, which doesnt work well with rounded corners
|
||||||
#topic-progress-wrapper {
|
#topic-progress-wrapper {
|
||||||
.progress-back-container {
|
.progress-back-container {
|
||||||
margin-right: 0;
|
margin-right: 0;
|
||||||
margin-bottom: var(--spacing-block-xs);
|
margin-bottom: var(--spacing-block-xs);
|
||||||
|
|
||||||
.btn-primary.progress-back {
|
.btn-primary.progress-back {
|
||||||
border-radius: 0;
|
border-radius: 0;
|
||||||
background: var(--secondary);
|
background: var(--secondary);
|
||||||
border: 1px solid var(--tertiary-low);
|
border: 1px solid var(--tertiary-low);
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
padding: var(--spacing-inline-s) var(--spacing-inline-m);
|
padding: var(--spacing-inline-s) var(--spacing-inline-m);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.topic-admin-menu-trigger {
|
.topic-admin-menu-trigger {
|
||||||
border-radius: 0;
|
border-radius: 0;
|
||||||
background: var(--secondary);
|
background: var(--secondary);
|
||||||
border: 1px solid var(--tertiary-low);
|
border: 1px solid var(--tertiary-low);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.mobile-device #reply-control.show-preview .submit-panel {
|
|
||||||
background-color: var(--background-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-editor-preview-wrapper {
|
|
||||||
outline: 2px solid var(--background-color);
|
|
||||||
}
|
|
||||||
|
|||||||
+6
-12
@@ -8,35 +8,30 @@
|
|||||||
|
|
||||||
.navigation-container {
|
.navigation-container {
|
||||||
gap: 1rem;
|
gap: 1rem;
|
||||||
|
|
||||||
.category-breadcrumb {
|
.category-breadcrumb {
|
||||||
order: 1;
|
order: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.combo-box .combo-box-header {
|
.combo-box .combo-box-header {
|
||||||
// needs more specificity than just in the button file
|
// needs more specificy than just in the button file
|
||||||
background-color: var(--secondary);
|
background-color: var(--secondary);
|
||||||
border-radius: var(--d-border-radius);
|
border-radius: var(--d-border-radius-large);
|
||||||
border: 1px solid var(--primary-300);
|
border: 1px solid var(--primary-300);
|
||||||
|
// font-size: var(--font-up-1-rem);
|
||||||
&:hover {
|
&:hover {
|
||||||
border: 1px solid var(--accent-color);
|
border: 1px solid var(--accent-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
&:focus-visible {
|
&:focus-visible {
|
||||||
.discourse-no-touch & {
|
.discourse-no-touch & {
|
||||||
background: var(--secondary);
|
background: var(--secondary);
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
box-shadow: 0 0 0 3px var(--button-box-shadow);
|
box-shadow: 0px 0px 0px 3px var(--button-box-shadow);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.select-kit.combo-box.category-drop.has-selection
|
.select-kit.combo-box.category-drop.has-selection
|
||||||
.category-drop-header:hover {
|
.category-drop-header:hover {
|
||||||
border-color: transparent;
|
border-color: transparent;
|
||||||
@@ -52,8 +47,7 @@
|
|||||||
.nav-pills > li button:hover {
|
.nav-pills > li button:hover {
|
||||||
.discourse-no-touch & {
|
.discourse-no-touch & {
|
||||||
background: transparent;
|
background: transparent;
|
||||||
color: var(--d-nav-color--hover);
|
color: var(--accent-color);
|
||||||
|
|
||||||
&::after {
|
&::after {
|
||||||
content: "";
|
content: "";
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@@ -61,7 +55,7 @@
|
|||||||
bottom: 0;
|
bottom: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
height: var(--d-nav-underline-height);
|
height: var(--d-nav-underline-height);
|
||||||
background: var(--d-nav-color--hover);
|
background: var(--accent-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,86 @@
|
|||||||
|
.welcome-banner {
|
||||||
|
z-index: calc(z("base") + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.custom-search-banner-wrap {
|
||||||
|
display: grid;
|
||||||
|
grid-template-rows: 0.33fr 0.33fr 0.33fr;
|
||||||
|
grid-template-columns: 1fr 1fr;
|
||||||
|
grid-column-gap: 1em;
|
||||||
|
grid-row-gap: 0.5em;
|
||||||
|
border-bottom: 1px solid var(--primary-300);
|
||||||
|
padding: 1.5em 0 2.5em;
|
||||||
|
margin-bottom: 0;
|
||||||
|
@media screen and (max-width: 768px) {
|
||||||
|
padding: 1em;
|
||||||
|
}
|
||||||
|
h1 {
|
||||||
|
grid-column: 1/2;
|
||||||
|
grid-row: 1/-1;
|
||||||
|
text-align: left;
|
||||||
|
align-self: center;
|
||||||
|
margin: 0;
|
||||||
|
font-weight: 400;
|
||||||
|
color: var(--search-banner-text-color);
|
||||||
|
@media screen and (max-width: 1028px) {
|
||||||
|
font-size: var(--font-up-4);
|
||||||
|
grid-column: 1/-1;
|
||||||
|
grid-row: 1;
|
||||||
|
text-align: center;
|
||||||
|
margin-bottom: 0.5em;
|
||||||
|
}
|
||||||
|
@media screen and (max-width: 768px) {
|
||||||
|
text-align: left;
|
||||||
|
grid-column: 1/2;
|
||||||
|
grid-row: 1/-1;
|
||||||
|
font-size: var(--font-up-3);
|
||||||
|
}
|
||||||
|
@media screen and (max-width: 600px) {
|
||||||
|
grid-column: 1/-1;
|
||||||
|
grid-row: 1;
|
||||||
|
text-align: center;
|
||||||
|
margin-bottom: 0.5em;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.search-menu {
|
||||||
|
grid-column: 2/3;
|
||||||
|
grid-row: 1/-1;
|
||||||
|
width: 100%;
|
||||||
|
align-self: center;
|
||||||
|
@media screen and (max-width: 1028px) {
|
||||||
|
grid-row: 2/-1;
|
||||||
|
grid-column: 1/-1;
|
||||||
|
}
|
||||||
|
@media screen and (max-width: 768px) {
|
||||||
|
grid-column: 2/-1;
|
||||||
|
grid-row: 1/-1;
|
||||||
|
}
|
||||||
|
@media screen and (max-width: 600px) {
|
||||||
|
grid-row: 2/-1;
|
||||||
|
grid-column: 1/-1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.search-input {
|
||||||
|
background: var(--d-content-background);
|
||||||
|
border: 1px solid var(--search-color);
|
||||||
|
box-shadow: 0 4px 10px rgba(52, 6, 121, 15%);
|
||||||
|
}
|
||||||
|
.search-menu .search-input:focus-within,
|
||||||
|
.search-menu-container .search-input:focus-within {
|
||||||
|
border: 1px solid var(--search-color);
|
||||||
|
outline: 2px solid var(--search-color);
|
||||||
|
}
|
||||||
|
.search-menu .d-icon,
|
||||||
|
.search-menu .searching .d-icon {
|
||||||
|
color: var(--search-color);
|
||||||
|
}
|
||||||
|
.panel-body {
|
||||||
|
z-index: z("dropdown");
|
||||||
|
}
|
||||||
|
.results {
|
||||||
|
background: var(--d-content-background);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,71 +0,0 @@
|
|||||||
.navigation-controls {
|
|
||||||
.topic-drafts-menu-trigger,
|
|
||||||
.fk-d-button-tooltip {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.has-ai-conversations-sidebar {
|
|
||||||
.sidebar-new-topic-button__wrapper {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.sidebar-new-topic-button {
|
|
||||||
flex: 1 1 auto;
|
|
||||||
|
|
||||||
&__wrapper {
|
|
||||||
box-sizing: border-box;
|
|
||||||
display: flex;
|
|
||||||
|
|
||||||
.mobile-view & {
|
|
||||||
margin: 0 0 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:has(.topic-drafts-menu-trigger) {
|
|
||||||
.sidebar-new-topic-button {
|
|
||||||
border-radius: var(--d-button-border-radius) 0 0
|
|
||||||
var(--d-button-border-radius);
|
|
||||||
border-right: 1px solid var(--primary-300);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.fk-d-button-tooltip {
|
|
||||||
flex: 1 1 auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.topic-drafts-menu-trigger {
|
|
||||||
flex: 0 1 auto;
|
|
||||||
margin: 0;
|
|
||||||
border-radius: 0 var(--d-button-border-radius)
|
|
||||||
var(--d-button-border-radius) 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fk-d-button-tooltip:has(button[disabled]) {
|
|
||||||
+ .topic-drafts-menu-trigger {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fk-d-tooltip__trigger {
|
|
||||||
background: var(--accent-color);
|
|
||||||
border-radius: 0 var(--d-button-border-radius)
|
|
||||||
var(--d-button-border-radius) 0;
|
|
||||||
padding-right: 0.65em;
|
|
||||||
|
|
||||||
.d-icon {
|
|
||||||
color: var(--secondary);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
li.sidebar-section-link-wrapper[data-list-item-name="New Topic"] {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.has-full-page-chat {
|
|
||||||
.sidebar-new-topic-button__wrapper {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+7
-27
@@ -1,24 +1,18 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
.sidebar-wrapper,
|
.sidebar-wrapper,
|
||||||
.sidebar-hamburger-dropdown {
|
.sidebar-hamburger-dropdown {
|
||||||
@include viewport.until(lg) {
|
@include breakpoint(medium) {
|
||||||
background: var(--secondary);
|
background: var(--secondary);
|
||||||
|
|
||||||
.sidebar-footer-wrapper {
|
.sidebar-footer-wrapper {
|
||||||
background: var(--secondary);
|
background: var(--secondary);
|
||||||
|
|
||||||
.sidebar-footer-container::before {
|
.sidebar-footer-container::before {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.has-full-page-chat &,
|
.has-full-page-chat &,
|
||||||
.has-full-page-chat & .sidebar-footer-wrapper {
|
.has-full-page-chat & .sidebar-footer-wrapper {
|
||||||
background: transparent;
|
background: transparent;
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidebar-container {
|
.sidebar-container {
|
||||||
border-right: none;
|
border-right: none;
|
||||||
}
|
}
|
||||||
@@ -26,38 +20,31 @@
|
|||||||
.sidebar-sections {
|
.sidebar-sections {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidebar-section-link {
|
.sidebar-section-link {
|
||||||
transition: none;
|
transition: none;
|
||||||
border-radius: var(--d-border-radius);
|
border-radius: var(--d-border-radius);
|
||||||
}
|
}
|
||||||
|
|
||||||
.dropdown-menu__item .sidebar-section-link {
|
.dropdown-menu__item .sidebar-section-link {
|
||||||
border-radius: 0;
|
border-radius: 0px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidebar-section-wrapper {
|
.sidebar-section-wrapper {
|
||||||
@include viewport.from(xl) {
|
@include breakpoint(extra-large, $rule: min-width) {
|
||||||
padding-block: 0.45em;
|
padding-block: 0.45em;
|
||||||
}
|
}
|
||||||
|
@include breakpoint(mobile-extra-large) {
|
||||||
@include viewport.until(sm) {
|
|
||||||
.hamburger-panel .revamped & {
|
.hamburger-panel .revamped & {
|
||||||
margin-bottom: var(--spacing-block-m);
|
margin-bottom: var(--spacing-block-m);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidebar-section-header {
|
.sidebar-section-header {
|
||||||
font-size: var(--font-down-2);
|
font-size: var(--font-down-2);
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidebar-section-content {
|
.sidebar-section-content {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
|
@include breakpoint(extra-large, $rule: min-width) {
|
||||||
@include viewport.from(xl) {
|
|
||||||
gap: var(--spacing-block-xs);
|
gap: var(--spacing-block-xs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -65,7 +52,6 @@
|
|||||||
|
|
||||||
.sidebar-wrapper .sidebar-sections {
|
.sidebar-wrapper .sidebar-sections {
|
||||||
--scrollbarThumbBg: var(--d-selected);
|
--scrollbarThumbBg: var(--d-selected);
|
||||||
padding: 0 1rem;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.sidebar-section-link-wrapper .sidebar-section-link:focus,
|
.sidebar-section-link-wrapper .sidebar-section-link:focus,
|
||||||
@@ -77,17 +63,11 @@
|
|||||||
|
|
||||||
.sidebar-new-topic-button__wrapper {
|
.sidebar-new-topic-button__wrapper {
|
||||||
margin: 0 var(--spacing-inline-m) var(--spacing-block-l);
|
margin: 0 var(--spacing-inline-m) var(--spacing-block-l);
|
||||||
|
|
||||||
.sidebar-new-topic-button .d-icon {
|
.sidebar-new-topic-button .d-icon {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// put the draft menu above the slide-out hamburger on small desktop screens
|
.sidebar-wrapper .sidebar-sections {
|
||||||
@include viewport.until(md) {
|
padding: 0 1rem;
|
||||||
html:not(.mobile-view) {
|
|
||||||
.topic-drafts-menu-content {
|
|
||||||
z-index: z("modal", "overlay");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
+372
-587
File diff suppressed because it is too large
Load Diff
+32
-26
@@ -1,5 +1,3 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
.post-stream {
|
.post-stream {
|
||||||
.contents {
|
.contents {
|
||||||
font-size: var(--font-up-1);
|
font-size: var(--font-up-1);
|
||||||
@@ -8,40 +6,56 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.container.posts .topic-navigation {
|
||||||
|
// super fragile because new sticky topic title doesnt have a calculated value (= 53px with this font and size but…)
|
||||||
|
top: calc(
|
||||||
|
var(--header-offset, 60px) + 53px + calc(var(--spacing-block-l) * 2)
|
||||||
|
);
|
||||||
|
z-index: 300;
|
||||||
|
}
|
||||||
|
|
||||||
.timeline-container .topic-timeline {
|
.timeline-container .topic-timeline {
|
||||||
min-width: unset; // why we have this?
|
min-width: unset; // why we have this?
|
||||||
|
|
||||||
.timeline-scrollarea {
|
.timeline-scrollarea {
|
||||||
border-left: 1px solid var(--accent-color);
|
border-left: 1px solid var(--accent-color);
|
||||||
|
|
||||||
.timeline-scroller {
|
.timeline-scroller {
|
||||||
@include viewport.from(lg) {
|
@include breakpoint("medium", $rule: min-width) {
|
||||||
margin-left: -4.5px;
|
padding: 0.25em;
|
||||||
|
border: 1px solid var(--accent-color);
|
||||||
|
border-radius: 0.75em;
|
||||||
|
padding-left: 0.5em;
|
||||||
|
margin-left: calc(-0.5em - 2.5px);
|
||||||
background: var(--d-content-background);
|
background: var(--d-content-background);
|
||||||
height: 40px !important; // height is coming from element style have no other choice
|
height: 40px !important; // height is coming from element style have no other choice
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.timeline-scroller-content {
|
||||||
|
// display: flex;
|
||||||
|
// flex-direction: column;
|
||||||
|
// gap: 0.25em;
|
||||||
|
}
|
||||||
.timeline-replies,
|
.timeline-replies,
|
||||||
.timeline-ago {
|
.timeline-ago {
|
||||||
line-height: 1;
|
line-height: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.timeline-handle {
|
.timeline-handle {
|
||||||
background-color: var(--accent-color);
|
background-color: var(--accent-color);
|
||||||
|
@include breakpoint("medium", $rule: min-width) {
|
||||||
@include viewport.from(lg) {
|
width: 3px;
|
||||||
width: 8px;
|
border-radius: 2px;
|
||||||
border-radius: 10px;
|
|
||||||
height: calc(100% - 6px);
|
height: calc(100% - 6px);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// should probably get rid of this extra specificity class in core?
|
//should probably get rid of this extra specificity class in core?
|
||||||
.timeline-container.timeline-fullscreen {
|
.timeline-container.timeline-fullscreen {
|
||||||
@include viewport.until(lg) {
|
@include breakpoint("medium", $rule: max-width) {
|
||||||
|
.topic-timeline .timeline-scrollarea-wrapper {
|
||||||
|
}
|
||||||
.topic-timeline
|
.topic-timeline
|
||||||
.timeline-scrollarea
|
.timeline-scrollarea
|
||||||
.timeline-scroller
|
.timeline-scroller
|
||||||
@@ -50,24 +64,16 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
.container.posts,
|
||||||
|
#topic-footer-buttons {
|
||||||
|
padding: 0 24px;
|
||||||
|
}
|
||||||
|
|
||||||
.container.posts {
|
.container.posts {
|
||||||
grid-template-columns: auto 8em;
|
grid-template-columns: auto 150px;
|
||||||
|
@media screen and (max-width: 924px) {
|
||||||
@media screen and (width <= 924px) {
|
|
||||||
grid-template-columns: auto auto;
|
grid-template-columns: auto auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-notice {
|
|
||||||
padding: var(--spacing-block-sm);
|
|
||||||
border-radius: var(--d-border-radius);
|
|
||||||
font-size: var(--font-down-1-rem);
|
|
||||||
|
|
||||||
.d-icon {
|
|
||||||
font-size: var(--font-up-1);
|
|
||||||
width: 1em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.timeline-container .topic-timeline .timeline-ago {
|
.timeline-container .topic-timeline .timeline-ago {
|
||||||
|
|||||||
+2
-2
@@ -3,8 +3,8 @@
|
|||||||
--d-border-radius-large: 20px;
|
--d-border-radius-large: 20px;
|
||||||
--d-border-radius: 8px;
|
--d-border-radius: 8px;
|
||||||
--d-input-border-radius: 6px;
|
--d-input-border-radius: 6px;
|
||||||
|
// --d-sidebar-row-height: 2.8em;
|
||||||
// the idea is: block spacing can grow with font-size, but inline spacing should not to maintain horizontal (text) alignment
|
//the idea is: block spacing can grow with font-size, but inline spacing should not to maintain horizontal (text) alignment
|
||||||
--spacing-block-xs: 0.25em;
|
--spacing-block-xs: 0.25em;
|
||||||
--spacing-block-s: 0.5em;
|
--spacing-block-s: 0.5em;
|
||||||
--spacing-block-sm: 0.75em;
|
--spacing-block-sm: 0.75em;
|
||||||
|
|||||||
@@ -1,117 +0,0 @@
|
|||||||
@use "lib/viewport";
|
|
||||||
|
|
||||||
.welcome-banner {
|
|
||||||
&__wrap {
|
|
||||||
display: grid;
|
|
||||||
grid-template-rows: 0.33fr 0.33fr 0.33fr;
|
|
||||||
grid-template-columns: 1fr 1fr;
|
|
||||||
grid-column-gap: 1em;
|
|
||||||
grid-row-gap: 0.5em;
|
|
||||||
border-bottom: 1px solid var(--primary-300);
|
|
||||||
padding: 1.5em 0 2.5em;
|
|
||||||
margin-bottom: 0;
|
|
||||||
|
|
||||||
@media screen and (width <= 768px) {
|
|
||||||
padding: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
display: block;
|
|
||||||
padding: 0.5em;
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-menu {
|
|
||||||
grid-column: 2/3;
|
|
||||||
grid-row: 1/-1;
|
|
||||||
width: 100%;
|
|
||||||
align-self: center;
|
|
||||||
|
|
||||||
@media screen and (width <= 1028px) {
|
|
||||||
grid-row: 2/-1;
|
|
||||||
grid-column: 1/-1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width <= 768px) {
|
|
||||||
grid-column: 2/-1;
|
|
||||||
grid-row: 1/-1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width <= 600px) {
|
|
||||||
grid-row: 2/-1;
|
|
||||||
grid-column: 1/-1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
p {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-menu .search-input,
|
|
||||||
.search-menu-container .search-input {
|
|
||||||
background: var(--d-content-background);
|
|
||||||
border: 1px solid var(--search-color);
|
|
||||||
box-shadow: 0 4px 10px rgb(52, 6, 121, 15%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-menu .search-input:focus-within,
|
|
||||||
.search-menu-container .search-input:focus-within {
|
|
||||||
border: 1px solid var(--search-color);
|
|
||||||
outline: 2px solid var(--search-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-menu .d-icon,
|
|
||||||
.search-menu .searching .d-icon,
|
|
||||||
.search-menu .searching .show-advanced-search .d-icon {
|
|
||||||
color: var(--search-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.panel-body {
|
|
||||||
z-index: z("dropdown");
|
|
||||||
}
|
|
||||||
|
|
||||||
.results {
|
|
||||||
background: var(--d-content-background);
|
|
||||||
}
|
|
||||||
|
|
||||||
&__title {
|
|
||||||
grid-column: 1/2;
|
|
||||||
grid-row: 1/-1;
|
|
||||||
text-align: left;
|
|
||||||
align-self: center;
|
|
||||||
margin: 0;
|
|
||||||
font-weight: 400;
|
|
||||||
color: var(--search-color);
|
|
||||||
|
|
||||||
@media screen and (width <= 1028px) {
|
|
||||||
font-size: var(--font-up-4);
|
|
||||||
grid-column: 1/-1;
|
|
||||||
grid-row: 1;
|
|
||||||
text-align: center;
|
|
||||||
margin-bottom: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width <= 768px) {
|
|
||||||
text-align: left;
|
|
||||||
grid-column: 1/2;
|
|
||||||
grid-row: 1/-1;
|
|
||||||
font-size: var(--font-up-3);
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (width <= 600px) {
|
|
||||||
grid-column: 1/-1;
|
|
||||||
grid-row: 1;
|
|
||||||
text-align: center;
|
|
||||||
margin-bottom: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include viewport.until(sm) {
|
|
||||||
font-size: var(--font-up-2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
describe "Composer peek", type: :system do
|
|
||||||
fab!(:current_user) { Fabricate(:user, refresh_auto_groups: true) }
|
|
||||||
fab!(:topic) { Fabricate(:topic_with_op) }
|
|
||||||
|
|
||||||
let(:topic_page) { PageObjects::Pages::Topic.new }
|
|
||||||
let(:composer) { PageObjects::Components::Composer.new }
|
|
||||||
|
|
||||||
before do
|
|
||||||
upload_theme
|
|
||||||
sign_in(current_user)
|
|
||||||
end
|
|
||||||
|
|
||||||
it "does not show composer peek for small windows" do
|
|
||||||
topic_page.visit_topic(topic)
|
|
||||||
topic_page.click_footer_reply
|
|
||||||
expect(composer).to be_opened
|
|
||||||
|
|
||||||
resize_window(width: 600) { expect(page).to have_no_css(".peek-mode-toggle") }
|
|
||||||
end
|
|
||||||
|
|
||||||
it "turns on composer peek and remembers this preference on page load" do
|
|
||||||
topic_page.visit_topic(topic)
|
|
||||||
topic_page.click_footer_reply
|
|
||||||
expect(composer).to be_opened
|
|
||||||
|
|
||||||
resize_window(width: 1380) do
|
|
||||||
find(".peek-mode-toggle").click
|
|
||||||
expect(page).to have_css("body.peek-mode-active")
|
|
||||||
|
|
||||||
topic_page.visit_topic(topic)
|
|
||||||
topic_page.click_footer_reply
|
|
||||||
expect(composer).to be_opened
|
|
||||||
expect(page).to have_css("body.peek-mode-active")
|
|
||||||
|
|
||||||
find(".peek-mode-toggle").click
|
|
||||||
expect(page).to have_no_css("body.peek-mode-active")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
it "hides the composer preview when toggling" do
|
|
||||||
topic_page.visit_topic(topic)
|
|
||||||
topic_page.click_footer_reply
|
|
||||||
expect(composer).to be_opened
|
|
||||||
expect(composer).to have_composer_preview
|
|
||||||
|
|
||||||
resize_window(width: 1380) do
|
|
||||||
find(".peek-mode-toggle").click
|
|
||||||
expect(page).to have_css("body.peek-mode-active")
|
|
||||||
expect(composer).to have_no_composer_preview
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
RSpec.describe "Core features", type: :system do
|
|
||||||
fab!(:current_user) { Fabricate(:user, refresh_auto_groups: true) }
|
|
||||||
let(:composer) { PageObjects::Components::Composer.new }
|
|
||||||
|
|
||||||
before { upload_theme_or_component }
|
|
||||||
|
|
||||||
it_behaves_like "having working core features",
|
|
||||||
skip_examples: %i[search:quick_search topics:create]
|
|
||||||
|
|
||||||
it "creates a new topic" do
|
|
||||||
sign_in(current_user)
|
|
||||||
visit("/new-topic")
|
|
||||||
composer.fill_title("This is a new topic")
|
|
||||||
composer.fill_content("This is a long enough sentence.")
|
|
||||||
expect(page).to have_css(".d-editor-preview p", visible: true)
|
|
||||||
within(".save-or-cancel") { click_button("Create Topic") }
|
|
||||||
expect(page).to have_content("This is a new topic")
|
|
||||||
expect(page).to have_content("This is a long enough sentence.")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
@@ -1,16 +1,7 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
require_relative "./page_objects/components/user_color_palette_selector"
|
|
||||||
|
|
||||||
describe "Horizon theme | High level", type: :system do
|
describe "Horizon theme | High level", type: :system do
|
||||||
let!(:theme) do
|
let!(:theme) { upload_theme }
|
||||||
horizon_theme = upload_theme
|
|
||||||
ColorScheme
|
|
||||||
.where(theme_id: horizon_theme.id)
|
|
||||||
.where.not("name LIKE '%Dark%'")
|
|
||||||
.update_all(user_selectable: true)
|
|
||||||
horizon_theme
|
|
||||||
end
|
|
||||||
fab!(:current_user) { Fabricate(:user) }
|
fab!(:current_user) { Fabricate(:user) }
|
||||||
fab!(:tag_1) { Fabricate(:tag, name: "wow-cool") }
|
fab!(:tag_1) { Fabricate(:tag, name: "wow-cool") }
|
||||||
fab!(:tag_2) { Fabricate(:tag, name: "another-tag") }
|
fab!(:tag_2) { Fabricate(:tag, name: "another-tag") }
|
||||||
@@ -19,7 +10,6 @@ describe "Horizon theme | High level", type: :system do
|
|||||||
let(:topic_list) { PageObjects::Components::TopicList.new }
|
let(:topic_list) { PageObjects::Components::TopicList.new }
|
||||||
let(:topic_page) { PageObjects::Pages::Topic.new }
|
let(:topic_page) { PageObjects::Pages::Topic.new }
|
||||||
let(:sidebar) { PageObjects::Components::NavigationMenu::Sidebar.new }
|
let(:sidebar) { PageObjects::Components::NavigationMenu::Sidebar.new }
|
||||||
let(:palette_selector) { PageObjects::Components::UserColorPaletteSelector.new }
|
|
||||||
|
|
||||||
def run_all_high_level_tests
|
def run_all_high_level_tests
|
||||||
expect(page).to have_css(".experimental-screen")
|
expect(page).to have_css(".experimental-screen")
|
||||||
@@ -36,26 +26,25 @@ describe "Horizon theme | High level", type: :system do
|
|||||||
expect(topic_item.all("td").map { |el| el["class"] }).to eq(
|
expect(topic_item.all("td").map { |el| el["class"] }).to eq(
|
||||||
[
|
[
|
||||||
"main-link topic-list-data",
|
"main-link topic-list-data",
|
||||||
"topic-category-data",
|
|
||||||
"topic-creator-data",
|
|
||||||
"topic-activity-data",
|
"topic-activity-data",
|
||||||
|
"topic-status-data",
|
||||||
|
"topic-category-data",
|
||||||
|
"topic-likes-replies-data",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
# Can see a topic in the list and navigate to it successfully.
|
# Can see a topic in the list and navigate to it successfully
|
||||||
topic_list.visit_topic(topic_1)
|
topic_list.visit_topic(topic_1)
|
||||||
expect(topic_page).to have_topic_title(topic_1.title)
|
expect(topic_page).to have_topic_title(topic_1.title)
|
||||||
|
|
||||||
# Can change site colors from the sidebar palette, which are remembered
|
# Can change site colors from the sidebar palette, which are remembered across page reloads
|
||||||
# across page reloads.
|
palette_menu =
|
||||||
marigold_palette = theme.color_schemes.find_by(name: "Marigold")
|
PageObjects::Components::DMenu.new(find(".sidebar-footer-actions .user-color-palette"))
|
||||||
palette_selector.open_palette_menu
|
palette_menu.expand
|
||||||
palette_selector.click_palette_menu_item(marigold_palette.name)
|
find(".color-palette-menu__content .color-palette-menu__item[data-color='marigold']").click
|
||||||
expect(palette_selector).to have_no_palette_menu
|
expect(page).to have_css(".custom-color-marigold")
|
||||||
|
|
||||||
page.refresh
|
page.refresh
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
expect(page).to have_css(".custom-color-marigold")
|
||||||
expect(palette_selector).to have_tertiary_color(marigold_palette)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
it "works for anon" do
|
it "works for anon" do
|
||||||
|
|||||||
@@ -1,55 +0,0 @@
|
|||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
module PageObjects
|
|
||||||
module Components
|
|
||||||
class UserColorPaletteSelector < PageObjects::Components::Base
|
|
||||||
def sidebar_footer_button_css
|
|
||||||
".sidebar-footer-actions .user-color-palette-selector"
|
|
||||||
end
|
|
||||||
|
|
||||||
def palette_menu
|
|
||||||
PageObjects::Components::DMenu.new(find(sidebar_footer_button_css))
|
|
||||||
end
|
|
||||||
|
|
||||||
def open_palette_menu
|
|
||||||
palette_menu.expand
|
|
||||||
end
|
|
||||||
|
|
||||||
def has_no_palette_menu?
|
|
||||||
has_no_css?(".user-color-palette-selector-content")
|
|
||||||
end
|
|
||||||
|
|
||||||
def click_palette_menu_item(palette_name)
|
|
||||||
find(
|
|
||||||
".user-color-palette-menu__content .user-color-palette-menu__item[data-color-palette='#{palette_name}']",
|
|
||||||
).click
|
|
||||||
end
|
|
||||||
|
|
||||||
def has_selected_palette?(palette)
|
|
||||||
has_css?(
|
|
||||||
".user-color-palette-selector-trigger[data-selected-color-palette-id=\"#{palette.id}\"]",
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
def has_loaded_css?
|
|
||||||
has_css?(".user-color-palette-selector.user-color-palette-css-loaded")
|
|
||||||
end
|
|
||||||
|
|
||||||
def has_tertiary_color?(palette)
|
|
||||||
computed_color_hex =
|
|
||||||
page.evaluate_script(
|
|
||||||
"getComputedStyle(document.documentElement).getPropertyValue('--tertiary')",
|
|
||||||
)
|
|
||||||
computed_color_hex == "#" + palette.colors.find { |color| color.name == "tertiary" }.hex
|
|
||||||
end
|
|
||||||
|
|
||||||
def has_computed_color?(color)
|
|
||||||
computed_background_color =
|
|
||||||
page.evaluate_script(
|
|
||||||
"getComputedStyle(document.querySelector(\"li.sidebar-section-link-wrapper[data-list-item-name='everything'] .active\")).backgroundColor",
|
|
||||||
)
|
|
||||||
computed_background_color == color
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
@@ -1,55 +0,0 @@
|
|||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
RSpec.describe "Sidebar New Topic Button", system: true do
|
|
||||||
before { upload_theme }
|
|
||||||
fab!(:group)
|
|
||||||
fab!(:user) { Fabricate(:user, trust_level: 3, groups: [group]) }
|
|
||||||
fab!(:category)
|
|
||||||
fab!(:private_category) do
|
|
||||||
c = Fabricate(:category_with_definition)
|
|
||||||
c.set_permissions(group => :readonly)
|
|
||||||
c.save
|
|
||||||
c
|
|
||||||
end
|
|
||||||
|
|
||||||
context "for signed in users" do
|
|
||||||
before { sign_in(user) }
|
|
||||||
|
|
||||||
it "renders the new topic button in the sidebar" do
|
|
||||||
visit("/latest")
|
|
||||||
expect(page).to have_css(".sidebar-new-topic-button__wrapper")
|
|
||||||
expect(page).to have_css(".sidebar-new-topic-button:not(.disabled)")
|
|
||||||
end
|
|
||||||
|
|
||||||
it "opens the composer when clicked" do
|
|
||||||
visit("/")
|
|
||||||
find(".sidebar-new-topic-button").click
|
|
||||||
expect(page).to have_css("#reply-title")
|
|
||||||
end
|
|
||||||
|
|
||||||
it "shows draft menu when drafts exist" do
|
|
||||||
Draft.create!(user: user, draft_key: "topic_1", data: {})
|
|
||||||
|
|
||||||
visit("/")
|
|
||||||
expect(page).to have_css(".sidebar-new-topic-button__wrapper .topic-drafts-menu-trigger")
|
|
||||||
end
|
|
||||||
|
|
||||||
it "disables button when visiting read-only category" do
|
|
||||||
visit("/c/#{private_category.slug}/#{private_category.id}")
|
|
||||||
|
|
||||||
expect(page).to have_css(".sidebar-new-topic-button[disabled]")
|
|
||||||
|
|
||||||
visit("/c/#{category.slug}/#{category.id}")
|
|
||||||
|
|
||||||
expect(page).not_to have_css(".sidebar-new-topic-button[disabled]")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context "for anon" do
|
|
||||||
it "does not render the sidebar button for anons" do
|
|
||||||
visit("/latest")
|
|
||||||
expect(page).not_to have_css(".sidebar-new-topic-button__wrapper")
|
|
||||||
expect(page).not_to have_css(".sidebar-new-topic-button:not(.disabled)")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
@@ -1,119 +0,0 @@
|
|||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require_relative "./page_objects/components/user_color_palette_selector"
|
|
||||||
|
|
||||||
describe "Horizon theme | User color palette selector", type: :system do
|
|
||||||
let(:set_theme_as_default) { true }
|
|
||||||
let!(:theme) do
|
|
||||||
horizon_theme = upload_theme(set_theme_as_default: set_theme_as_default)
|
|
||||||
horizon_theme.color_schemes.update_all(user_selectable: true)
|
|
||||||
horizon_theme
|
|
||||||
end
|
|
||||||
fab!(:current_user) { Fabricate(:user) }
|
|
||||||
let(:sidebar) { PageObjects::Components::NavigationMenu::Sidebar.new }
|
|
||||||
let(:palette_selector) { PageObjects::Components::UserColorPaletteSelector.new }
|
|
||||||
let(:interface_color_mode) { PageObjects::Components::InterfaceColorMode.new }
|
|
||||||
let(:interface_color_selector) do
|
|
||||||
PageObjects::Components::InterfaceColorSelector.new(".sidebar-footer-actions")
|
|
||||||
end
|
|
||||||
let(:marigold_palette) { theme.color_schemes.find_by(name: "Marigold") }
|
|
||||||
let(:marigold_palette_dark) { theme.color_schemes.find_by(name: "Marigold Dark") }
|
|
||||||
|
|
||||||
before { SiteSetting.interface_color_selector = "sidebar_footer" }
|
|
||||||
|
|
||||||
it "does not show the sidebar button if there are no user-selectable color palettes" do
|
|
||||||
ColorScheme.update_all(user_selectable: false)
|
|
||||||
visit "/"
|
|
||||||
expect(page).to have_no_css(palette_selector.sidebar_footer_button_css)
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "for logged in user" do
|
|
||||||
before { sign_in(current_user) }
|
|
||||||
|
|
||||||
it "can open the user color palette menu and select a palette, which is preseved on reload" do
|
|
||||||
visit "/"
|
|
||||||
palette_selector.open_palette_menu
|
|
||||||
palette_selector.click_palette_menu_item(marigold_palette.name)
|
|
||||||
|
|
||||||
expect(palette_selector).to have_no_palette_menu
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_loaded_css
|
|
||||||
expect(palette_selector).to have_tertiary_color(marigold_palette)
|
|
||||||
|
|
||||||
page.refresh
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
end
|
|
||||||
|
|
||||||
it "uses the dark version of the palette if the user selects dark mode" do
|
|
||||||
visit "/"
|
|
||||||
palette_selector.open_palette_menu
|
|
||||||
palette_selector.click_palette_menu_item(marigold_palette.name)
|
|
||||||
|
|
||||||
expect(palette_selector).to have_no_palette_menu
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_loaded_css
|
|
||||||
expect(palette_selector).to have_computed_color("oklch(0.92 0.0708528 68.5036)")
|
|
||||||
|
|
||||||
interface_color_selector.expand
|
|
||||||
interface_color_selector.dark_option.click
|
|
||||||
expect(interface_color_mode).to have_dark_mode_forced
|
|
||||||
expect(palette_selector).to have_computed_color("oklch(0.481966 0.0354264 68.5036)")
|
|
||||||
|
|
||||||
page.refresh
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_computed_color("oklch(0.481966 0.0354264 68.5036)")
|
|
||||||
end
|
|
||||||
|
|
||||||
context "when the theme is not default but is selected by a user" do
|
|
||||||
let(:set_theme_as_default) { false }
|
|
||||||
|
|
||||||
it "can open the user color palette menu and select a palette, which is preseved on reload" do
|
|
||||||
theme.update!(user_selectable: true)
|
|
||||||
current_user.user_option.update!(theme_ids: [theme.id])
|
|
||||||
visit "/"
|
|
||||||
palette_selector.open_palette_menu
|
|
||||||
palette_selector.click_palette_menu_item(marigold_palette.name)
|
|
||||||
|
|
||||||
expect(palette_selector).to have_no_palette_menu
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_loaded_css
|
|
||||||
expect(palette_selector).to have_tertiary_color(marigold_palette)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "for anon" do
|
|
||||||
it "can open the user color palette menu and select a palette, which is preseved on reload" do
|
|
||||||
visit "/"
|
|
||||||
palette_selector.open_palette_menu
|
|
||||||
palette_selector.click_palette_menu_item(marigold_palette.name)
|
|
||||||
|
|
||||||
expect(palette_selector).to have_no_palette_menu
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_loaded_css
|
|
||||||
expect(palette_selector).to have_tertiary_color(marigold_palette)
|
|
||||||
end
|
|
||||||
|
|
||||||
it "uses the dark version of the palette if the user selects dark mode, which is preserved on reload" do
|
|
||||||
visit "/"
|
|
||||||
palette_selector.open_palette_menu
|
|
||||||
palette_selector.click_palette_menu_item(marigold_palette.name)
|
|
||||||
|
|
||||||
expect(palette_selector).to have_no_palette_menu
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_loaded_css
|
|
||||||
expect(palette_selector).to have_computed_color("oklch(0.92 0.0708528 68.5036)")
|
|
||||||
|
|
||||||
interface_color_selector.expand
|
|
||||||
interface_color_selector.dark_option.click
|
|
||||||
expect(interface_color_mode).to have_dark_mode_forced
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_loaded_css
|
|
||||||
expect(palette_selector).to have_computed_color("oklch(0.481966 0.0354264 68.5036)")
|
|
||||||
|
|
||||||
page.refresh
|
|
||||||
expect(palette_selector).to have_selected_palette(marigold_palette)
|
|
||||||
expect(palette_selector).to have_computed_color("oklch(0.481966 0.0354264 68.5036)")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
export default {
|
|
||||||
extends: ["@discourse/lint-configs/stylelint"],
|
|
||||||
};
|
|
||||||
Reference in New Issue
Block a user