Compare commits

..

5 Commits

35 changed files with 2452 additions and 4874 deletions

View File

@@ -1,5 +1,2 @@
< 3.5.0.beta1-dev: 83e2797ceb40d9832a40ee8c4bc32c7127e9dcda
< 3.4.0.beta4-dev: a5ff3374335f17b46654c4ae1e5be7b539c2da1a
< 3.4.0.beta1-dev: 93551f55d6e9f8d688f1f9dc0b6a2f14eb08b603
< 3.3.0.beta1-dev: 85dc24d6b58d1b16e6d225ae710633dc20c34d08
3.1.999: 1e5882a1541b932f9512f6a7d667b333c1708f53

8
.eslintrc Normal file
View File

@@ -0,0 +1,8 @@
{
"extends": "eslint-config-discourse",
"ignorePatterns": ["javascripts/vendor/*"],
"globals": {
"settings": "readonly",
"themePrefix": "readonly"
}
}

48
.github/workflows/component-linting.yml vendored Normal file
View File

@@ -0,0 +1,48 @@
name: Linting
on:
push:
branches:
- main
pull_request:
concurrency:
group: plugin-linting-${{ format('{0}-{1}', github.head_ref || github.run_number, github.job) }}
cancel-in-progress: true
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set up Node.js
uses: actions/setup-node@v3
with:
node-version: 16
cache: yarn
- name: Yarn install
run: yarn install
- name: ESLint
if: ${{ always() }}
run: yarn eslint --ext .js,.js.es6 --no-error-on-unmatched-pattern {test,javascripts}
- name: Prettier
if: ${{ always() }}
shell: bash
run: |
yarn prettier -v
files=$(find javascripts desktop mobile common scss -type f \( -name "*.scss" -or -name "*.js" -or -name "*.es6" \) 2> /dev/null) || true
if [ -n "$files" ]; then
yarn prettier --list-different $files
fi
if [ 0 -lt $(find test -type f \( -name "*.js" -or -name "*.es6" \) 2> /dev/null | wc -l) ]; then
yarn prettier --list-different "test/**/*.{js,es6}"
fi
- name: Ember template lint
if: ${{ always() }}
run: yarn ember-template-lint --no-error-on-unmatched-pattern javascripts

147
.github/workflows/component-tests.yml vendored Normal file
View File

@@ -0,0 +1,147 @@
name: Tests
on:
push:
branches:
- main
pull_request:
concurrency:
group: plugin-tests-${{ format('{0}-{1}', github.head_ref || github.run_number, github.job) }}
cancel-in-progress: true
jobs:
check:
runs-on: ubuntu-latest
outputs:
tests_exist: ${{ steps.check_tests.outputs.tests_exist }}
steps:
- name: Install component
uses: actions/checkout@v3
with:
path: tmp/component
fetch-depth: 1
- name: Check QUnit existence
id: check_tests
shell: bash
run: |
if [ 0 -lt $(find tmp/component/test -type f \( -name "*.js" -or -name "*.es6" \) 2> /dev/null | wc -l) ]; then
echo "::set-output name=tests_exist::true"
fi
test:
needs: check
if: ${{ needs.check.outputs.tests_exist }}
runs-on: ubuntu-latest
container: discourse/discourse_test:slim-browsers
timeout-minutes: 15
env:
DISCOURSE_HOSTNAME: www.example.com
RUBY_GLOBAL_METHOD_CACHE_SIZE: 131072
RAILS_ENV: development
PGUSER: discourse
PGPASSWORD: discourse
steps:
- uses: actions/checkout@v3
with:
repository: discourse/discourse
fetch-depth: 1
- name: Install component
uses: actions/checkout@v3
with:
path: tmp/component
fetch-depth: 1
- name: Setup Git
run: |
git config --global user.email "ci@ci.invalid"
git config --global user.name "Discourse CI"
- name: Start redis
run: |
redis-server /etc/redis/redis.conf &
- name: Start Postgres
run: |
chown -R postgres /var/run/postgresql
sudo -E -u postgres script/start_test_db.rb
sudo -u postgres psql -c "CREATE ROLE $PGUSER LOGIN SUPERUSER PASSWORD '$PGPASSWORD';"
- name: Bundler cache
uses: actions/cache@v3
with:
path: vendor/bundle
key: ${{ runner.os }}-gem-${{ hashFiles('**/Gemfile.lock') }}
restore-keys: |
${{ runner.os }}-gem-
- name: Setup gems
run: |
gem install bundler --conservative -v $(awk '/BUNDLED WITH/ { getline; gsub(/ /,""); print $0 }' Gemfile.lock)
bundle config --local path vendor/bundle
bundle config --local deployment true
bundle config --local without development
bundle install --jobs 4
bundle clean
- name: Lint English locale
run: bundle exec ruby script/i18n_lint.rb "tmp/component/locales/en.yml"
- name: Get yarn cache directory
id: yarn-cache-dir
run: echo "::set-output name=dir::$(yarn cache dir)"
- name: Yarn cache
uses: actions/cache@v3
id: yarn-cache
with:
path: ${{ steps.yarn-cache-dir.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
- name: Yarn install
run: yarn install
- name: Fetch app state cache
uses: actions/cache@v3
id: app-cache
with:
path: tmp/app-cache
key: >-
${{ hashFiles('.github/workflows/tests.yml') }}-
${{ hashFiles('db/**/*', 'plugins/**/db/**/*') }}-
- name: Restore database from cache
if: steps.app-cache.outputs.cache-hit == 'true'
run: psql -f tmp/app-cache/cache.sql postgres
- name: Restore uploads from cache
if: steps.app-cache.outputs.cache-hit == 'true'
run: rm -rf public/uploads && cp -r tmp/app-cache/uploads public/uploads
- name: Create and migrate database
if: steps.app-cache.outputs.cache-hit != 'true'
run: |
bin/rake db:create
bin/rake db:migrate
- name: Dump database for cache
if: steps.app-cache.outputs.cache-hit != 'true'
run: mkdir -p tmp/app-cache && pg_dumpall > tmp/app-cache/cache.sql
- name: Dump uploads for cache
if: steps.app-cache.outputs.cache-hit != 'true'
run: rm -rf tmp/app-cache/uploads && cp -r public/uploads tmp/app-cache/uploads
- name: Component QUnit
run: |
THEME_NAME=$(ruby -e 'require "json"; puts JSON.parse(File.read("tmp/component/about.json"))["name"]')
bundle exec rake themes:install -- "--{\"$THEME_NAME\": \"tmp/component\"}"
UNICORN_TIMEOUT=120 bundle exec rake "themes:qunit[name,$THEME_NAME]"
timeout-minutes: 10

View File

@@ -1,11 +0,0 @@
name: Discourse Theme
on:
push:
branches:
- main
pull_request:
jobs:
ci:
uses: discourse/.github/.github/workflows/discourse-theme.yml@v1

2
.npmrc
View File

@@ -1,2 +0,0 @@
engine-strict = true
auto-install-peers = false

1
.prettierrc Normal file
View File

@@ -0,0 +1 @@
{}

View File

@@ -1 +0,0 @@
module.exports = require("@discourse/lint-configs/prettier");

View File

@@ -1,2 +0,0 @@
inherit_gem:
rubocop-discourse: stree-compat.yml

View File

@@ -1,2 +0,0 @@
--print-width=100
--plugins=plugin/trailing_comma,plugin/disable_auto_ternary

View File

@@ -1 +0,0 @@
module.exports = require("@discourse/lint-configs/template-lint");

4
.template-lintrc.js Normal file
View File

@@ -0,0 +1,4 @@
module.exports = {
plugins: ["ember-template-lint-plugin-discourse"],
extends: "discourse:recommended",
};

View File

@@ -1,8 +0,0 @@
# frozen_string_literal: true
source "https://rubygems.org"
group :development do
gem "rubocop-discourse"
gem "syntax_tree"
end

View File

@@ -1,101 +0,0 @@
GEM
remote: https://rubygems.org/
specs:
activesupport (8.0.2)
base64
benchmark (>= 0.3)
bigdecimal
concurrent-ruby (~> 1.0, >= 1.3.1)
connection_pool (>= 2.2.5)
drb
i18n (>= 1.6, < 2)
logger (>= 1.4.2)
minitest (>= 5.1)
securerandom (>= 0.3)
tzinfo (~> 2.0, >= 2.0.5)
uri (>= 0.13.1)
ast (2.4.2)
base64 (0.2.0)
benchmark (0.4.0)
bigdecimal (3.1.9)
concurrent-ruby (1.3.5)
connection_pool (2.5.0)
drb (2.2.1)
i18n (1.14.7)
concurrent-ruby (~> 1.0)
json (2.10.2)
language_server-protocol (3.17.0.4)
lint_roller (1.1.0)
logger (1.6.6)
minitest (5.25.5)
parallel (1.26.3)
parser (3.3.7.1)
ast (~> 2.4.1)
racc
prettier_print (1.2.1)
racc (1.8.1)
rack (3.1.12)
rainbow (3.1.1)
regexp_parser (2.10.0)
rubocop (1.74.0)
json (~> 2.3)
language_server-protocol (~> 3.17.0.2)
lint_roller (~> 1.1.0)
parallel (~> 1.10)
parser (>= 3.3.0.2)
rainbow (>= 2.2.2, < 4.0)
regexp_parser (>= 2.9.3, < 3.0)
rubocop-ast (>= 1.38.0, < 2.0)
ruby-progressbar (~> 1.7)
unicode-display_width (>= 2.4.0, < 4.0)
rubocop-ast (1.39.0)
parser (>= 3.3.1.0)
rubocop-capybara (2.22.1)
lint_roller (~> 1.1)
rubocop (~> 1.72, >= 1.72.1)
rubocop-discourse (3.12.1)
activesupport (>= 6.1)
lint_roller (>= 1.1.0)
rubocop (>= 1.73.2)
rubocop-capybara (>= 2.22.0)
rubocop-factory_bot (>= 2.27.0)
rubocop-rails (>= 2.30.3)
rubocop-rspec (>= 3.0.1)
rubocop-rspec_rails (>= 2.31.0)
rubocop-factory_bot (2.27.1)
lint_roller (~> 1.1)
rubocop (~> 1.72, >= 1.72.1)
rubocop-rails (2.30.3)
activesupport (>= 4.2.0)
lint_roller (~> 1.1)
rack (>= 1.1)
rubocop (>= 1.72.1, < 2.0)
rubocop-ast (>= 1.38.0, < 2.0)
rubocop-rspec (3.5.0)
lint_roller (~> 1.1)
rubocop (~> 1.72, >= 1.72.1)
rubocop-rspec_rails (2.31.0)
lint_roller (~> 1.1)
rubocop (~> 1.72, >= 1.72.1)
rubocop-rspec (~> 3.5)
ruby-progressbar (1.13.0)
securerandom (0.4.1)
syntax_tree (6.2.0)
prettier_print (>= 1.2.0)
tzinfo (2.0.6)
concurrent-ruby (~> 1.0)
unicode-display_width (3.1.4)
unicode-emoji (~> 4.0, >= 4.0.4)
unicode-emoji (4.0.4)
uri (1.0.3)
PLATFORMS
arm64-darwin-23
ruby
DEPENDENCIES
rubocop-discourse
syntax_tree
BUNDLED WITH
2.6.6

View File

@@ -1,25 +1,18 @@
{
"name": "OrcasHub Theme",
"about_url": "https://meta.discourse.org/t/discourse-air-theme/197703",
"license_url": "https://github.com/discourse/discourse-air/blob/main/LICENSE",
"about_url": null,
"license_url": null,
"components": [
"https://github.com/jordanvidrine/discourse-category-group-boxes.git",
"https://github.com/discourse/discourse-clickable-topic.git",
"https://github.com/discourse/discourse-custom-header-links.git",
"https://git.grosinger.net/tgrosinger/discourse-user-card-directory.git",
"https://github.com/discourse/DiscoTOC.git",
"https://github.com/paviliondev/discourse-tc-topic-list-previews.git"
"https://github.com/discourse/discourse-clickable-topic.git"
],
"assets": {
"OrcasHub-Top-Logo": "assets/OrcasHub-Top-Logo.png"
},
"modifiers": {
"serialize_topic_excerpts": true
},
"color_schemes": {
"OrcasHub": {
"primary": "1c1c1c",
"secondary": "ffffff",
"secondary": "f9fcff",
"tertiary": "3877e5",
"quaternary": "7e8b93",
"header_background": "374151",
@@ -27,10 +20,7 @@
"highlight": "e6cb37",
"danger": "d05454",
"success": "71bd9f",
"love": "c16ad7",
"selected": "2f0177",
"hover": "535353"
"love": "c16ad7"
}
}
},
"screenshots": ["screenshots/light.png", "screenshots/dark.png"]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 13 KiB

View File

@@ -1,9 +0,0 @@
<div id="login-message">
<h2>
There are a lot more discussions going on if you log in!
</h2>
<a href="/login" class="widget-button btn btn-primary btn-small sign-up-button btn-text">
<span class="d-button-label">Log in or Sign Up</span>
</a>
</div>

View File

@@ -1,107 +1,44 @@
// Login CTA
#login-message {
display: none;
}
html.anon {
body:not(.category-resources) {
// Display this message on all pages except in Community Resources
#login-message {
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
margin: 16px 0;
a:hover {
color: var(--secondary-very-high);
}
}
}
}
// Login form
.login-right-side {
display: none;
}
// Header image above nav bar
.outer {
padding-top: 1.5rem;
padding-bottom: 1.5rem;
display: flex;
justify-content: center;
background-color: var(--header_background);
}
.top-header-image {
background-image: url($OrcasHub-Top-Logo);
}
// Hide the default logo in the header bar
#site-logo,
.home-logo-wrapper-outlet {
display: none;
}
// custom search banner customizations
.custom-search-banner-wrap {
margin: 0 auto !important;
max-width: unset;
color: var(--secondary);
h1 {
line-height: var(--line-height-small);
@include breakpoint("large", min-width) {
font-size: 4em;
}
}
p {
margin-top: 0.5em;
margin-bottom: 2em;
@include breakpoint("large", min-width) {
font-size: var(--font-up-1);
font-size: 1.25em !important;
font-weight: bold;
margin-bottom: 1em;
}
}
.btn {
height: 100%;
}
.search-menu input[type="text"] {
border: 1px solid transparent;
border-radius: 0.25em;
min-height: 40px;
&:focus {
outline: 3px solid rgba(var(--primary-rgb), 0.35);
}
}
.widget-link.show-help {
color: rgba(var(--primary-rgb), 0.75);
border-radius: 0.5em;
padding: 0.5em;
background-color: rgba(var(--secondary-rgb), 0.25);
&:hover {
color: var(--primary);
}
}
.search-menu .search-input {
border-color: var(--tertiary-hover);
outline: 1px solid var(--tertiary-hover);
}
.results {
top: 43px;
border-radius: 0.25em;
}
.search-context {
top: 3.25em;
right: 1em;
@@ -124,15 +61,12 @@ html.anon {
.custom-search-banner-wrap {
padding: 1em 0 2em;
color: var(--tertiary);
.mobile-view & {
color: var(--secondary);
}
h1 {
margin-bottom: 0;
}
.search-widget {
margin-top: 2em;
}
@@ -163,14 +97,12 @@ html.anon {
.badge-category-bg {
border-radius: 0.125em;
}
.badge-category-parent-bg {
border-top-left-radius: 0.125em;
border-bottom-left-radius: 0.125em;
+ .badge-category-bg {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
border-top-left-radius: 0px;
border-bottom-left-radius: 0px;
border-top-right-radius: 0.125em;
border-bottom-right-radius: 0.125em;
}
@@ -187,7 +119,6 @@ html.anon {
padding: 0.15em 0.25em 0.15em 0.35em;
background-color: var(--primary-low);
color: var(--primary) !important;
&:hover {
background-color: var(--primary-low-mid);
color: var(--primary);
@@ -201,26 +132,11 @@ html.anon {
margin-left: unset;
}
.topic-list .link-bottom-line .discourse-tag.simple::after,
.topic-list .link-bottom-line .discourse-tag.simple:after,
.topic-list .link-bottom-line .discourse-tag.box {
margin-right: 0;
margin-right: 0px;
}
.custom-category-boxes {
.category-box {
box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px,
rgba(0, 0, 0, 0) 0px 0px 0px 0px,
rgba(0, 0, 0, 0.1) 0px 1px 3px 0px,
rgba(0, 0, 0, 0.1) 0px 1px 2px -1px !important;
}
.category-logo {
height: 100px !important;
width: 100px !important;
}
}
#site-text-logo {
color: var(--primary);
}
@@ -229,16 +145,11 @@ html.anon {
.cm-header-links {
display: none;
}
.list-controls .nav-pills .drop li:first-of-type {
display: none;
}
}
.not-found-container {
background-color: var(--secondary);
}
input[type="text"],
input[type="password"],
input[type="datetime"],
@@ -258,7 +169,6 @@ input[type="color"],
div.ac-wrap {
border-radius: 4px;
}
.d-header {
box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.06);
}
@@ -271,7 +181,6 @@ div.ac-wrap {
border-radius: 0.25em;
margin-left: 0.3em;
border: 1px solid transparent;
svg {
font-size: 1.25em;
}
@@ -289,7 +198,6 @@ div.ac-wrap {
.drop-down-mode .d-header-icons .active .icon {
border: 1px solid transparent;
.d-icon {
color: var(--tertiary);
}
@@ -306,7 +214,7 @@ div.ac-wrap {
background-color: rgba(var(--tertiary-rgb), 0.5);
}
.btn:not(.themes-tab, .components-tab),
.btn:not(.themes-tab):not(.components-tab),
.select-kit.dropdown-select-box .dropdown-select-box-header {
border-radius: .375rem;
border: 1px solid transparent;
@@ -314,7 +222,7 @@ div.ac-wrap {
.post-admin-menu.popup-menu {
.btn.widget-button {
border-radius: 0;
border-radius: 0px;
}
}
@@ -330,9 +238,22 @@ div.ac-wrap {
border-left-color: var(--tertiary);
}
// graceful ish style
@mixin box-shadow($value: 0px) {
box-shadow: 0 24px 40px rgba(0, 0, 0, 0.07),
0 10.8529px 24.1177px rgba(0, 0, 0, 0.0456112),
0 4.50776px 10.0172px rgba(0, 0, 0, 0.035),
0 1.63037px 3.62304px rgba(0, 0, 0, 0.0243888);
}
html {
body {
background-color: var(--secondary);
background: linear-gradient(
0deg,
rgba(var(--primary-rgb), 0.075) 0%,
rgba(var(--primary-rgb), 0.075) 100%
),
linear-gradient(0deg, var(--secondary) 100%, var(--secondary) 100%);
}
}
@@ -343,29 +264,21 @@ html body #main-outlet {
border-radius: .5rem;
padding: 3em 3em 5%;
max-width: 1150px;
padding-bottom: 5% !important; // overriding inline style
box-shadow:
0 24px 40px rgba(0, 0, 0, 0.07),
0 10.8529px 24.1177px rgba(0, 0, 0, 0.0456112),
0 4.50776px 10.0172px rgba(0, 0, 0, 0.035),
0 1.63037px 3.62304px rgba(0, 0, 0, 0.0243888);
.archetype-regular & {
min-height: 500px;
}
@media screen and (max-width: 700px) {
padding: 1.5em;
margin-top: 0;
}
padding-bottom: 5% !important; //overriding inline style
@include box-shadow;
@media screen and (max-width: 1120px) {
width: 80%;
}
@media screen and (max-width: 1075px) {
width: 85%;
}
.archetype-regular & {
min-height: 500px;
}
}
.nav-pills:not(.user-nav) > li a.active,
@@ -373,66 +286,12 @@ html body #main-outlet {
border-radius: 0.5em;
}
.category-calendar {
&.before-topic-list-body-outlet {
display: block;
}
background: var(--secondary);
padding: 1em;
border-radius: 8px;
margin-bottom: 1em;
}
.discourse-post-event-upcoming-events {
background: var(--secondary);
border-radius: 8px;
padding: 1em;
margin-bottom: 1em;
}
// User directory (people)
.users-directory {
.directory-controls {
justify-content: right !important;
}
.period-controls {
display: none;
}
}
// User Card (profile)
.user-card {
.badge-section,
.metadata-row {
display: none;
}
}
// Category List
.custom-category-boxes-container {
.custom-category-boxes {
.category-box {
border-radius: .5rem !important;
}
}
}
// Hide the "about this category" heading
.category-heading {
display: none;
}
// Topic List
@keyframes background-fade-highlight {
0% {
background-color: var(--highlight-low);
}
100% {
background-color: var(--secondary);
}
@@ -442,45 +301,37 @@ html body #main-outlet {
border-collapse: separate;
border-spacing: 0 0.25em;
display: contents;
.topic-list-header {
tr {
display: flex;
border-bottom: none;
}
display: contents;
.topic-list-data.default {
width: 63%;
}
.topic-list-data.posters {
width: 7%;
}
.topic-list-data.posts {
width: 15%;
}
.topic-list-data.activity {
width: 15%;
}
}
.topic-list-body {
display: contents;
.topic-list-item-separator {
width: 100%;
margin: 0.75em 0;
display: flex;
.topic-list-data {
width: 100%;
}
}
.topic-list-item {
width: 100%;
display: flex;
margin-bottom: 0.5em;
background-color: var(--secondary);
@@ -488,41 +339,33 @@ html body #main-outlet {
border-radius: .5rem;
position: relative;
transition: box-shadow 100ms ease-in-out;
box-shadow: 0 0 8px rgba(0, 0, 0, 0.05);
box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.05);
overflow: hidden;
&.visited {
border: 1px solid rgba(var(--primary-rgb), 0.1);
.discourse-tag {
opacity: 0.75;
}
&:hover {
border: 1px solid rgba(var(--primary-rgb), 0.25);
.discourse-tag {
opacity: 1;
}
}
}
&:hover {
background-color: var(--secondary);
box-shadow: 0 0 12px rgba(0, 0, 0, 0.1);
box-shadow: 0px 0px 12px rgba(0, 0, 0, 0.1);
border: 1px solid rgba(var(--primary-rgb), 0.3);
a.title:not(.badge-notification),
a.topic-excerpt {
color: var(--primary) !important;
}
}
.topic-list-data.main-link {
width: 63%;
order: 2;
}
.topic-list-data.posters {
width: 7%;
order: 1;
@@ -530,12 +373,10 @@ html body #main-outlet {
display: flex;
justify-content: center;
align-items: center;
a:not(.latest) {
display: none;
}
}
.topic-list-data.posts {
width: 15%;
order: 3;
@@ -543,7 +384,6 @@ html body #main-outlet {
justify-content: center;
align-items: center;
}
.topic-list-data.age {
width: 15%;
order: 4;
@@ -551,101 +391,6 @@ html body #main-outlet {
justify-content: center;
align-items: center;
}
&.selected {
td:nth-of-type(1) {
box-shadow: none;
}
&:focus-visible td:nth-of-type(2) {
box-shadow: inset 3px 0 0 var(--tertiary);
border-radius: calc(1em - 3px);
}
}
}
.main-link {
min-height: 100%;
.link-top-line {
display: block;
margin-bottom: 0.25em;
}
.title {
font-weight: bold;
}
.link-area {
display: flex;
.link-title-area {
margin-right: 1em;
font-size: $font-up-1;
}
.link-meta-area {
font-size: $font-down-3;
display: flex;
align-items: center;
}
}
}
.posters {
.avatar {
width: 40px;
height: 40px;
border-radius: .375rem;
}
a.latest {
margin-right: 4px;
width: 100%;
height: 100%;
display: flex;
justify-content: center;
align-content: center;
align-items: center;
.avatar {
margin-right: 0;
}
}
a:not(.latest) {
margin-left: -22px;
.avatar {
border: 3px solid var(--secondary);
}
}
}
.posts-map,
.num.age.activity {
a {
padding: 0;
}
}
.posts-map {
position: relative;
.number {
margin-right: 0.25em;
}
}
.post-activity {
.d-icon-reply {
color: var(--primary-medium);
margin-right: 0.25em;
}
.relative-date {
color: var(--primary-medium);
}
}
}
}
@@ -654,86 +399,104 @@ html body #main-outlet {
display: none;
}
.d-icon-lock {
display: none;
.full-width .contents .topic-list .topic-list-item .posters a.latest {
margin-right: 4px;
width: 100%;
height: 100%;
display: flex;
justify-content: center;
align-content: center;
align-items: center;
.avatar {
margin-right: 0;
}
}
// Community Resources Category
.category-resources {
// Topic List
.topic-list-header {
display: none !important;
.full-width .contents .topic-list {
.topic-list-item {
.main-link {
min-height: 100%;
min-height: 100%;
.link-top-line {
display: block;
margin-bottom: 0.25em;
}
.topic-list-body {
.topic-list-data {
// Center content in the topic list
.title {
font-weight: bold;
}
.link-area {
display: flex;
.link-title-area {
margin-right: 1em;
font-size: $font-up-1;
}
.link-meta-area {
font-size: $font-down-3;
display: flex;
align-items: center;
}
.num.views,
.num.posts,
.num.activity,
.posters,
.topic-statuses {
display: none !important;
}
}
.posters {
.avatar {
width: 40px;
height: 40px;
border-radius: .375rem;
}
a.latest {
.avatar {
margin-right: 0;
}
}
a:not(.latest) {
margin-left: -22px;
.avatar {
border: 3px solid var(--secondary);
}
}
}
.posts-map,
.num.age.activity {
a {
padding: 0;
}
}
.posts-map {
position: relative;
.number {
margin-right: 0.25em;
}
}
.post-activity {
.d-icon-reply {
color: var(--primary-medium);
margin-right: 0.25em;
}
.relative-date {
color: var(--primary-medium);
}
}
}
}
// Topic Posts
.topic-map,
.topic-avatar,
.more-topics__container,
.names.trigger-user-card { // Hide the lock icon in the topic header of the post
display: none !important;
}
.topic-meta-data {
display: flex;
justify-content: right;
}
.navigation-container {
margin-top: 2em;
}
// published page additions
.published-page-header {
background-color: unset;
box-shadow: unset;
top: unset;
position: unset;
margin-top: 30px;
.published-page-header-wrapper {
justify-content: center;
background: var(--secondary);
max-width: 1000px;
border-radius: 1em 1em 0 0;
padding-top: 3em;
a {
display: none;
}
.published-page-title {
color: var(--primary);
}
}
}
.published-page-content-wrapper {
max-width: 1000px;
margin-top: 0;
margin-top: 30px;
margin-bottom: 50px;
background: var(--secondary);
border-radius: 0 0 1em 1em;
border-radius: 1em;
padding: 3em 3em 5%;
ul,
ol {
margin-left: 1.25em;
}
box-shadow: 0 24px 40px rgba(0, 0, 0, 0.07),
0 10.8529px 24.1177px rgba(0, 0, 0, 0.0456112),
0 4.50776px 10.0172px rgba(0, 0, 0, 0.035),
0 1.63037px 3.62304px rgba(0, 0, 0, 0.0243888);
z-index: 1;
position: relative;
}
.published-page {
@@ -754,9 +517,24 @@ html body #main-outlet {
}
.quote-button {
background-color: var(--primary-low-mid);
border-radius: 0.5em;
}
.topic-list tr.selected td:nth-child(2),
.topic-list-item.selected td:nth-child(2),
.latest-topic-list-item.selected,
.search-results .fps-result.selected {
box-shadow: inset 3px 0 0 var(--danger);
}
.topic-list tr.selected td:first-child,
.topic-list-item.selected td:first-child,
.latest-topic-list-item.selected,
.search-results .fps-result.selected {
box-shadow: none;
}
.topic-list .main-link.focused + .posters {
box-shadow: inset 3px 0 0 var(--tertiary);
}
@@ -764,83 +542,3 @@ html body #main-outlet {
.topic-list .main-link.focused {
box-shadow: none;
}
.title-voting {
padding-left: 14px;
}
// Footer
.orcashub-footer {
background-color: rgb(31 41 55);
.outer-container {
max-width: 80rem;
margin-left: auto;
margin-right: auto;
padding: 3rem 1.5rem;
}
.inner-container {
padding-bottom: 2rem;
@media (min-width: 1280) {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 2rem;
}
}
.grid {
display: grid;
gap: 2rem;
grid-template-columns: repeat(2, minmax(0, 1fr));
@media (min-width: 1280) {
grid-column: span 4/span 4;
}
}
.grid-row {
@media (min-width: 768px) {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 2rem;
}
}
.second-group {
margin-top: 3rem;
@media (min-width: 768px) {
margin-top: 0;
}
}
h3 {
color: white;
font-size: 16px;
font-weight: 500;
line-height: 1.5rem;
}
ul {
margin: 0;
list-style: none;
}
li {
a {
color: rgb(209 213 219);
font-size: 16px;
line-height: 1.5rem;
}
a:hover {
color: white;
}
a:visited {
color: rgb(209 213 219) !important;
}
}
}

View File

@@ -1,46 +0,0 @@
<footer class="orcashub-footer">
<div class="outer-container">
<div class="inner-container">
<div class="grid">
<div class="grid-row">
<div>
<h3>Classifieds</h3>
<ul>
<li><a href="https://orcashub.org/classified/for-sale">For Sale</a></li>
<li><a href="https://orcashub.org/classified/for-free">For Free</a></li>
<li><a href="https://orcashub.org/classified/want-to-buy">Looking For</a></li>
<li><a href="https://orcashub.org/classified/want-to-borrow">Want to Borrow</a></li>
<li><a href="https://orcashub.org/classified/new">New Post</a> </li>
</ul>
</div>
<div class="second-group">
<h3>Housing</h3>
<ul>
<li><a href="https://orcashub.org/housing?filters=basic_for-rent">For Rent</a></li>
<li><a href="https://orcashub.org/housing?filters=basic_request">Requests</a> </li>
<li><a href="https://orcashub.org/housing/new">New Post</a> </li>
</ul>
</div>
</div>
<div class="grid-row">
<div>
<h3>Other Services</h3>
<ul>
<li><a href="/" target="_blank">Groups</a> </li>
<li><a href="https://orcashub.org/events">Events</a> </li>
<li><a href="https://wiki.orcashub.org/" target="_blank">Resources</a></li>
</ul>
</div>
<div class="second-group">
<h3>About</h3>
<ul>
<li><a href="https://orcashub.org/terms-of-service">Terms of Service</a></li>
<li><a href="https://orcashub.org/privacy-policy">Privacy Policy</a></li>
<li><a href="https://orcashub.org/donate" target="_blank">Donate</a></li>
</ul>
</div>
</div>
</div>
</div>
</div>
</footer>

View File

@@ -1,5 +0,0 @@
<div class="outer">
<a href="https://orcas.community/">
<div class="top-header-image"></div>
</a>
</div>

View File

@@ -1,47 +1,3 @@
@import "showcased-categories";
@import "chat-desktop";
@import "sidebar-desktop";
.top-header-image {
height: 128px;
width: 246px;
}
// Header links
.custom-header-links {
.headerLink a {
padding: .5rem .75rem;
margin: 0 .1rem;
color: var(--header_primary);
font-weight: 500;
font-size: .9rem;
line-height: 1.25rem;
&:hover {
color: white;
}
}
li:nth-last-child(2) {
a {
color: white;
background-color: #111827;
border-radius: .375rem;
}
}
}
// Sidebar
.sidebar-section[data-section-name="orcashub"] {
// Hide OrcasHub section in the sidebar on desktop since it's show in the header.
display: none !important;
}
// Footer
.custom-footer {
.list {
margin: 2rem 5em 4rem;
}
}

View File

@@ -1,3 +0,0 @@
import DiscourseRecommendedTheme from "@discourse/lint-configs/eslint-theme";
export default [...DiscourseRecommendedTheme];

View File

@@ -1,5 +1,5 @@
import { cancel } from "@ember/runloop";
import { withPluginApi } from "discourse/lib/plugin-api";
import { cancel } from "@ember/runloop";
export default {
name: "customize-edit-category-general",

View File

@@ -1,13 +1,8 @@
import { apiInitializer } from "discourse/lib/api";
import { withSilencedDeprecations } from "discourse/lib/deprecated";
export default apiInitializer("0.8", (api) => {
api.registerValueTransformer("topic-list-item-expand-pinned", () => true);
withSilencedDeprecations("discourse.hbr-topic-list-overrides", () => {
api.modifyClass("component:topic-list-item", {
pluginId: "orcashub-discourse-theme",
expandPinned: true,
});
});
});

View File

@@ -1,3 +1,3 @@
en:
theme_metadata:
description: "A clean and modern theme for Discourse"
description: "Discourse Air Theme"

View File

@@ -1,16 +1,9 @@
@import "chat-mobile";
.top-header-image {
height: 80px;
width: 154px;
background-size: 154px 80px;
}
.custom-search-banner-wrap {
h1 {
font-size: 2.5em !important;
}
p {
font-weight: normal;
font-size: $font-up-1;
@@ -18,45 +11,15 @@
}
html
body:not(
.static-tos,
.static-faq,
.static-privacy,
.about-page,
.static-faq,
.badges-page,
.tags-page,
.archetype-banner,
.archetype-regular,
.archetype-private_message,
.admin-interface,
.edit-category,
.user-summary-page,
.user-activity-page,
.user-invites-page,
.user-preferences-page,
.user-messages-page,
.user-notifications-page,
.user-badges-page
)
body:not(.static-tos):not(.static-faq):not(.static-privacy):not(.about-page):not(.static-faq):not(.badges-page):not(.tags-page):not(.archetype-banner):not(.archetype-regular):not(.archetype-private_message):not(.admin-interface):not(.edit-category):not(.user-summary-page):not(.user-activity-page):not(.user-invites-page):not(.user-preferences-page)
#main-outlet {
width: calc(100% - 1em);
padding: 0 0.5em 1em 0.5em;
padding: 0em 0.5em 1em 0.5em;
box-shadow: none;
background-color: transparent;
}
#main-outlet {
margin-inline: auto;
}
html body #main-outlet .docs {
padding: 1em;
background-color: var(--secondary);
}
html body.static-tos #main-outlet,
html body.no-ember #main-outlet,
html body.static-privacy #main-outlet,
html body.about-page #main-outlet,
html body.static-faq #main-outlet,
@@ -70,18 +33,11 @@ html body.user-summary-page #main-outlet,
html body.user-activity-page #main-outlet,
html body.user-invites-page #main-outlet,
html body.user-preferences-page #main-outlet,
html body.user-messages-page #main-outlet,
html body.user-notifications-page #main-outlet,
html body.user-badges-page #main-outlet,
html body.staff:not(.navigation-topics) #main-outlet {
border-radius: 0;
border-radius: 0px;
width: calc(100% - 3em);
background-color: var(--secondary);
margin-bottom: 0;
}
html body.navigation-category #main-outlet {
width: calc(100% - 1em) !important;
margin-bottom: 0px;
}
.container.posts > .row {
@@ -90,7 +46,7 @@ html body.navigation-category #main-outlet {
.navigation-categories .navigation-container,
.categories-list .navigation-container {
border-bottom: 0 !important;
border-bottom: 0px !important;
}
body.category .category-breadcrumb .select-kit-header,
@@ -119,18 +75,16 @@ ol.category-breadcrumb {
border-radius: 8px;
border: none;
background-color: var(--secondary);
a:hover,
a:focus {
color: var(--primary);
background-color: var(--secondary);
}
}
.drop {
top: calc(100% + 0.5em);
border-radius: 8px;
box-shadow: 0 0 12px rgba(0, 0, 0, 0.25);
box-shadow: 0px 0px 12px rgba(0, 0, 0, 0.25);
}
}
@@ -139,10 +93,6 @@ ol.category-breadcrumb {
max-width: unset;
}
.topic-list .topic-list-data .main-link {
width: 90%;
}
.custom-search-banner-wrap .search-context {
top: 3em !important;
}
@@ -177,7 +127,7 @@ ol.category-breadcrumb {
background: var(--secondary);
padding: 1em;
border-radius: 8px;
box-shadow: 0 0 8px rgba(0, 0, 0, 0.05);
box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.05);
border: 1px solid rgba(var(--primary-rgb), 0.1);
margin-bottom: 0.5em;
}
@@ -194,29 +144,26 @@ ol.category-breadcrumb {
border-bottom-right-radius: 8px;
}
.full-width .contents .topic-list .topic-list-header {
display: none;
.full-width .contents .topic-list .topic-list-header tr {
background-color: var(--secondary);
border-radius: 8px;
box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.05);
border: 1px solid rgba(var(--primary-rgb), 0.1);
margin-bottom: 1em;
}
.topic-list .topic-item-stats {
flex-wrap: wrap;
}
.topic-list-item {
> .topic-list-data {
width: 100%;
}
.discourse-tags {
.topic-list-item .discourse-tags {
order: 3;
width: 100%;
margin-top: 0.5em;
}
}
.full-width .contents .topic-list .topic-list-item .posts-map {
padding: 0;
.number {
margin: 0;
}
@@ -231,64 +178,25 @@ ol.category-breadcrumb {
width: unset;
}
.topic-list .topic-list-header .topic-list-data,
.topic-list .topic-list-item .topic-list-data {
padding: 15px;
}
// default category list styles when the modern category boxes theme component isn't used
.category-list-item.category {
background: var(--secondary);
border-radius: 1em;
tbody {
display: flex;
flex-direction: column;
width: 100%;
}
td {
width: 100%;
}
.num.posts {
padding-right: 0.25em;
}
}
.list-controls .nav-pills .list-control-toggle-link-trigger {
color: var(--secondary);
}
// Hide the "4/7" topic navigation when on mobile since it's always stuck to the bottom anyway.
.topic-navigation {
display: none !important;
}
// Footer
.custom-footer {
.list {
margin: 2rem 0;
}
}
// Community Resources Category
.category-resources {
// Topic List
.topic-list-data {
.right {
margin-left: 0 !important;
display: flex;
align-items: center;
}
}
// Topic Post
.topic-avatar,
.topic-meta-data {
display: none !important;
}
}

View File

@@ -1,17 +1,10 @@
{
"private": true,
"name": "orcashub-discourse-theme",
"version": "1.0.0",
"repository": "https://git.grosinger.net/tgrosinger/orcashub-discourse-theme",
"author": "Jordan Vidrine",
"license": "GPL-2.0-or-later",
"devDependencies": {
"@discourse/lint-configs": "2.11.1",
"ember-template-lint": "7.0.1",
"eslint": "9.22.0",
"prettier": "3.5.3",
"stylelint": "16.16.0"
},
"engines": {
"node": ">= 22",
"npm": "please-use-pnpm",
"yarn": "please-use-pnpm",
"pnpm": "9.x"
},
"packageManager": "pnpm@9.15.5"
"eslint-config-discourse": "^3.2.0"
}
}

4022
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

Binary file not shown.

Before

Width:  |  Height:  |  Size: 507 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 598 KiB

View File

@@ -2,7 +2,6 @@ html body.has-sidebar-page.has-full-page-chat {
#main-outlet-wrapper {
gap: 2em;
}
#main-outlet {
padding-bottom: 0 !important;
}
@@ -13,7 +12,7 @@ html body.has-sidebar-page.has-full-page-chat {
}
.chat-channel {
height: calc(100vh - (var(--header-offset) + 7.85em));
height: calc(100vh - (var(--header-offset) + 10em));
}
.c-navbar-container {
@@ -30,8 +29,7 @@ html body.has-sidebar-page.has-full-page-chat {
.has-full-page-chat #main-outlet.wrap {
margin-bottom: 30px;
padding-bottom: 0 !important;
padding-bottom: 0px !important;
.full-page-chat {
grid-template-rows: calc(var(--full-page-chat-height) - 50px);
}
@@ -48,7 +46,6 @@ html body.has-sidebar-page.has-full-page-chat {
border-radius: 0;
margin: 0;
padding: 0;
.full-page-chat {
grid-template-rows: var(--full-page-chat-height);
}

View File

@@ -1,5 +1,27 @@
.showcased-categories-sidebar .two-topic-list-sidebar {
.topic-excerpt {
display: none;
}
.btn-link.posts-map.badge-posts {
display: block;
}
.two-topic-list-sidebar .topic-list .topic-list-item {
height: unset;
}
}
.showcased-categories-sidebar {
.full-width .contents .topic-list {
display: unset;
}
.two-topic-list-sidebar {
.topic-excerpt {
display: none;
}
.btn-link.posts-map.badge-posts {
display: block;
}
@@ -7,13 +29,5 @@
.topic-list .topic-list-item {
height: unset;
}
.topic-excerpt {
display: none;
}
}
.full-width .contents .topic-list {
display: unset;
}
}

View File

@@ -1,4 +1,12 @@
// sidebar
@mixin box-shadow($value: 0px) {
box-shadow: 0 24px 40px rgba(0, 0, 0, 0.07),
0 10.8529px 24.1177px rgba(0, 0, 0, 0.0456112),
0 4.50776px 10.0172px rgba(0, 0, 0, 0.035),
0 1.63037px 3.62304px rgba(0, 0, 0, 0.0243888);
}
#main-outlet-wrapper {
.sidebar-wrapper {
margin: 30px 0 50px;
@@ -6,13 +14,8 @@
border-radius: .5rem;
top: calc(var(--header-offset) + 30px);
height: calc(100vh - (var(--header-offset) + 80px));
box-shadow:
0 24px 40px rgba(0, 0, 0, 0.07),
0 10.8529px 24.1177px rgba(0, 0, 0, 0.0456112),
0 4.50776px 10.0172px rgba(0, 0, 0, 0.035),
0 1.63037px 3.62304px rgba(0, 0, 0, 0.0243888);
@include box-shadow;
}
.sidebar-footer-wrapper {
background: var(--secondary);
}
@@ -22,7 +25,6 @@ body.has-sidebar-page {
#main-outlet-wrapper {
padding-left: 8px;
}
#main-outlet {
max-width: unset;
}

View File

@@ -1,3 +0,0 @@
export default {
extends: ["@discourse/lint-configs/stylelint"],
};

2036
yarn.lock Normal file

File diff suppressed because it is too large Load Diff