Compare commits
	
		
			16 Commits
		
	
	
		
			main
			...
			5108eb856f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5108eb856f | |||
| f18c70d867 | |||
| b2cc4a2ae9 | |||
| 50b9a0ca14 | |||
| 1c17f3b507 | |||
| f75fbd72e5 | |||
| c8fd61c67b | |||
| 0b9ae900e3 | |||
| d39e74ca58 | |||
| e347ce42e4 | |||
| 47b081d2a9 | |||
| f715c54b8b | |||
| 910f435080 | |||
| ce2e975d10 | |||
| a8bb351e2f | |||
| 98be4851e7 | 
| @@ -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
									
								
							
							
						
						
									
										8
									
								
								.eslintrc
									
									
									
									
									
										Normal 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
									
								
							
							
						
						
									
										48
									
								
								.github/workflows/component-linting.yml
									
									
									
									
										vendored
									
									
										Normal 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
									
								
							
							
						
						
									
										147
									
								
								.github/workflows/component-tests.yml
									
									
									
									
										vendored
									
									
										Normal 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 | ||||
							
								
								
									
										11
									
								
								.github/workflows/discourse-theme.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.github/workflows/discourse-theme.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,11 +0,0 @@ | ||||
| name: Discourse Theme | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|   pull_request: | ||||
|  | ||||
| jobs: | ||||
|   ci: | ||||
|     uses: discourse/.github/.github/workflows/discourse-theme.yml@v1 | ||||
							
								
								
									
										1
									
								
								.prettierrc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.prettierrc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| {} | ||||
| @@ -1 +0,0 @@ | ||||
| module.exports = require("@discourse/lint-configs/prettier"); | ||||
| @@ -1,2 +0,0 @@ | ||||
| inherit_gem: | ||||
|   rubocop-discourse: stree-compat.yml | ||||
							
								
								
									
										2
									
								
								.streerc
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								.streerc
									
									
									
									
									
								
							| @@ -1,2 +0,0 @@ | ||||
| --print-width=100 | ||||
| --plugins=plugin/trailing_comma,plugin/disable_auto_ternary | ||||
| @@ -1 +0,0 @@ | ||||
| module.exports = require("@discourse/lint-configs/template-lint"); | ||||
							
								
								
									
										4
									
								
								.template-lintrc.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.template-lintrc.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| module.exports = { | ||||
|   plugins: ["ember-template-lint-plugin-discourse"], | ||||
|   extends: "discourse:recommended", | ||||
| }; | ||||
							
								
								
									
										8
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								Gemfile
									
									
									
									
									
								
							| @@ -1,8 +0,0 @@ | ||||
| # frozen_string_literal: true | ||||
|  | ||||
| source "https://rubygems.org" | ||||
|  | ||||
| group :development do | ||||
|   gem "rubocop-discourse" | ||||
|   gem "syntax_tree" | ||||
| end | ||||
							
								
								
									
										101
									
								
								Gemfile.lock
									
									
									
									
									
								
							
							
						
						
									
										101
									
								
								Gemfile.lock
									
									
									
									
									
								
							| @@ -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 | ||||
							
								
								
									
										18
									
								
								about.json
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								about.json
									
									
									
									
									
								
							| @@ -1,14 +1,13 @@ | ||||
| { | ||||
|   "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-user-card-directory.git", | ||||
|     "https://github.com/discourse/Discourse-easy-footer.git" | ||||
|   ], | ||||
|   "assets": { | ||||
|     "OrcasHub-Top-Logo": "assets/OrcasHub-Top-Logo.png" | ||||
| @@ -19,7 +18,7 @@ | ||||
|   "color_schemes": { | ||||
|     "OrcasHub": { | ||||
|       "primary": "1c1c1c", | ||||
|       "secondary": "ffffff", | ||||
|       "secondary": "f9fcff", | ||||
|       "tertiary": "3877e5", | ||||
|       "quaternary": "7e8b93", | ||||
|       "header_background": "374151", | ||||
| @@ -27,10 +26,7 @@ | ||||
|       "highlight": "e6cb37", | ||||
|       "danger": "d05454", | ||||
|       "success": "71bd9f", | ||||
|       "love": "c16ad7", | ||||
|       "selected": "2f0177", | ||||
|       "hover": "535353" | ||||
|       "love": "c16ad7" | ||||
|     } | ||||
|   } | ||||
|   }, | ||||
|   "screenshots": ["screenshots/light.png", "screenshots/dark.png"] | ||||
| } | ||||
|   | ||||
| @@ -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> | ||||
| @@ -1,25 +1,3 @@ | ||||
| // 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; | ||||
| @@ -39,7 +17,6 @@ html.anon { | ||||
| } | ||||
|  | ||||
| // Hide the default logo in the header bar | ||||
| #site-logo, | ||||
| .home-logo-wrapper-outlet { | ||||
|     display: none; | ||||
| } | ||||
| @@ -49,59 +26,42 @@ html.anon { | ||||
|   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 +84,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 +120,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 +142,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,19 +155,12 @@ 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; | ||||
| @@ -229,16 +176,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 +200,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 +212,6 @@ div.ac-wrap { | ||||
|   border-radius: 0.25em; | ||||
|   margin-left: 0.3em; | ||||
|   border: 1px solid transparent; | ||||
|  | ||||
|   svg { | ||||
|     font-size: 1.25em; | ||||
|   } | ||||
| @@ -289,7 +229,6 @@ div.ac-wrap { | ||||
|  | ||||
| .drop-down-mode .d-header-icons .active .icon { | ||||
|   border: 1px solid transparent; | ||||
|  | ||||
|   .d-icon { | ||||
|     color: var(--tertiary); | ||||
|   } | ||||
| @@ -306,7 +245,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 +253,7 @@ div.ac-wrap { | ||||
|  | ||||
| .post-admin-menu.popup-menu { | ||||
|   .btn.widget-button { | ||||
|     border-radius: 0; | ||||
|     border-radius: 0px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| @@ -330,9 +269,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 +295,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,42 +317,10 @@ 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 { | ||||
| .user-card .badge-section { | ||||
| 	display: none; | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Category List | ||||
| @@ -432,7 +344,6 @@ html body #main-outlet { | ||||
|   0% { | ||||
|     background-color: var(--highlight-low); | ||||
|   } | ||||
|  | ||||
|   100% { | ||||
|     background-color: var(--secondary); | ||||
|   } | ||||
| @@ -442,45 +353,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 +391,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 +425,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 +436,6 @@ html body #main-outlet { | ||||
|         justify-content: center; | ||||
|         align-items: center; | ||||
|       } | ||||
|  | ||||
|       .topic-list-data.age { | ||||
|         width: 15%; | ||||
|         order: 4; | ||||
| @@ -551,101 +443,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,8 +451,88 @@ 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; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .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; | ||||
|       } | ||||
|       .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 { | ||||
|         .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); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .navigation-container { | ||||
|   margin-top: 2em; | ||||
| } | ||||
|  | ||||
| // Community Resources Category | ||||
| @@ -685,55 +562,25 @@ html body #main-outlet { | ||||
|     // 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; | ||||
|     .topic-status { // Hide the lock icon in the topic header of the post | ||||
|         display: none; | ||||
|     } | ||||
| } | ||||
|  | ||||
| // 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 +601,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); | ||||
| } | ||||
| @@ -765,82 +627,27 @@ html body #main-outlet { | ||||
|   box-shadow: none; | ||||
| } | ||||
|  | ||||
| .title-voting { | ||||
|   padding-left: 14px; | ||||
| } | ||||
|  | ||||
| // Footer | ||||
| .orcashub-footer { | ||||
|     background-color: rgb(31 41 55); | ||||
| .custom-footer { | ||||
|     background-color: #1f2937; | ||||
|  | ||||
|     .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; | ||||
|     .list { | ||||
|         span { | ||||
| 	        font-weight: 500; | ||||
|         line-height: 1.5rem; | ||||
| 	    } | ||||
|     } | ||||
|  | ||||
|     ul { | ||||
|     .second-box .links li { | ||||
|     	margin: 0; | ||||
|         list-style: none; | ||||
|     } | ||||
|  | ||||
|     li { | ||||
|         a { | ||||
|             color: rgb(209 213 219); | ||||
|             font-size: 16px; | ||||
|     .footer-section-link-wrapper a { | ||||
|         color: var(--header_primary); | ||||
|         font-size: 1rem; | ||||
|     	line-height: 1.5rem; | ||||
|         } | ||||
|  | ||||
|         a:hover { | ||||
|         &:hover { | ||||
|           color: white; | ||||
|         } | ||||
|  | ||||
|         a:visited { | ||||
|             color: rgb(209 213 219) !important; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -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> | ||||
| @@ -22,7 +22,7 @@ | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     li:nth-last-child(2) { | ||||
|     li:last-child { | ||||
|         a { | ||||
|             color: white; | ||||
|             background-color: #111827; | ||||
| @@ -31,17 +31,10 @@ | ||||
|     } | ||||
| } | ||||
|  | ||||
| // 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; | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,3 +0,0 @@ | ||||
| import DiscourseRecommendedTheme from "@discourse/lint-configs/eslint-theme"; | ||||
|  | ||||
| export default [...DiscourseRecommendedTheme]; | ||||
| @@ -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", | ||||
|   | ||||
| @@ -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, | ||||
|   }); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| en: | ||||
|   theme_metadata: | ||||
|     description: "A clean and modern theme for Discourse" | ||||
|     description: "Discourse Air Theme" | ||||
|   | ||||
| @@ -10,7 +10,6 @@ | ||||
|   h1 { | ||||
|     font-size: 2.5em !important; | ||||
|   } | ||||
|  | ||||
|   p { | ||||
|     font-weight: normal; | ||||
|     font-size: $font-up-1; | ||||
| @@ -18,45 +17,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 +39,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 +52,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 +81,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 +99,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 +133,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 +150,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,39 +184,29 @@ 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 { | ||||
|   | ||||
							
								
								
									
										21
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								package.json
									
									
									
									
									
								
							| @@ -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
									
									
									
								
							
							
						
						
									
										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 | 
| @@ -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); | ||||
|     } | ||||
|   | ||||
| @@ -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; | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -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; | ||||
|   } | ||||
|   | ||||
| @@ -1,3 +0,0 @@ | ||||
| export default { | ||||
|   extends: ["@discourse/lint-configs/stylelint"], | ||||
| }; | ||||
		Reference in New Issue
	
	Block a user