Skip to content

Commit

Permalink
Merge branch 'main' into portal
Browse files Browse the repository at this point in the history
  • Loading branch information
rahafjrw committed Nov 26, 2024
2 parents 9a8532a + 3832cab commit feeea95
Show file tree
Hide file tree
Showing 187 changed files with 9,758 additions and 5,231 deletions.
2 changes: 1 addition & 1 deletion .devcontainer/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM registry.gitlab.com/finestructure/spi-base:1.0.3
FROM registry.gitlab.com/finestructure/spi-base:1.1.0

# Install SPM build dependencies
RUN apt-get update && apt-get install -y curl git make unzip \
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ jobs:
name: Test
runs-on: ubuntu-latest
container:
image: registry.gitlab.com/finestructure/spi-base:1.0.3
image: registry.gitlab.com/finestructure/spi-base:1.1.0
options: --privileged
services:
postgres:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/query-performance.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ jobs:
runs-on: ubuntu-latest
continue-on-error: true
container:
image: registry.gitlab.com/finestructure/spi-base:1.0.3
image: registry.gitlab.com/finestructure/spi-base:1.1.0
steps:
- name: Checkout code
uses: actions/checkout@v4
Expand Down
4 changes: 2 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
# ================================
# Build image
# ================================
FROM registry.gitlab.com/finestructure/spi-base:1.0.3 as build
FROM registry.gitlab.com/finestructure/spi-base:1.1.0 as build

# Set up a build area
WORKDIR /build
Expand Down Expand Up @@ -61,7 +61,7 @@ RUN [ -d /build/Resources ] && { mv /build/Resources ./Resources && chmod -R a-w
# ================================
# Run image
# ================================
FROM registry.gitlab.com/finestructure/spi-base:1.0.3
FROM registry.gitlab.com/finestructure/spi-base:1.1.0

# NB sas 2022-09-23: We're not using a dedicated `vapor` user to run the executable, because it
# makes managing the data in the checkouts volume difficult. See
Expand Down
33 changes: 33 additions & 0 deletions FrontEnd/scripts/controllers/readme_controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,41 @@
// limitations under the License.

import { Controller } from '@hotwired/stimulus'
import mermaid from 'mermaid'

export class ReadmeController extends Controller {
frameLoaded() {
this.navigateToAnchorFromLocation()
this.renderMermaidDiagrams()
}

async renderMermaidDiagrams() {
// Replace all Mermaid chart sources with rendered diagrams.
const mermaidSectionElements = document.querySelectorAll('section[data-type="mermaid"]')
for (const [index, mermaidSectionElement] of Array.from(mermaidSectionElements).entries()) {
// No need to parse the JSON, the chart source is in a `data-plain` attribute.
const mermaidDataElement = mermaidSectionElement.querySelector('[data-plain]')
if (!mermaidDataElement) continue
const chartDefinition = mermaidDataElement.getAttribute('data-plain')
if (!chartDefinition) continue

// Make a container with *both* light and dark charts.
const chartContainer = document.createElement('div')
chartContainer.classList.add('mermaid-chart')
mermaidDataElement.appendChild(chartContainer)

// The documentation says not to call `initialize` more than once. That said, it's
// the only way to switch themes and therefore the only way to get this working.
mermaid.initialize({ theme: 'default', nodeSpacing: 50, rankSpacing: 50, curve: 'basis' })
const lightRenderResult = await mermaid.render(`mermaid-chart-light-${index}`, chartDefinition)
chartContainer.insertAdjacentHTML('beforeend', lightRenderResult.svg)

mermaid.initialize({ theme: 'dark', nodeSpacing: 50, rankSpacing: 50, curve: 'basis' })
const darkRenderResult = await mermaid.render(`mermaid-chart-dark-${index}`, chartDefinition)
chartContainer.insertAdjacentHTML('beforeend', darkRenderResult.svg)
}
}

navigateToAnchorFromLocation() {
// If the browser has an anchor in the URL that may be inside the README then
// we should attempt to scroll it into view once the README is loaded.
Expand Down
4 changes: 0 additions & 4 deletions FrontEnd/scripts/debug_panel.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,10 +26,6 @@ export class SPIDebugPanel extends HTMLElement {
}
}

disconnectedCallback() {
console.log('SPIDebugPanel disconnectedCallback')
}

reset() {
const buttonsContainer = this.querySelector('.buttons')
if (buttonsContainer) buttonsContainer.remove()
Expand Down
1 change: 1 addition & 0 deletions FrontEnd/styles/base.scss
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ pre {

code {
font-size: 14px;
overflow-wrap: break-word;
}

blockquote {
Expand Down
2 changes: 2 additions & 0 deletions FrontEnd/styles/images.scss
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
--image-download: url('');
--image-error: url('');
--image-executables: url('');
--image-fork: url('');
--image-ghcta-header: url('');
--image-github: url('');
--image-heart: url('');
Expand Down Expand Up @@ -73,6 +74,7 @@
--image-download: url('');
--image-error: url('');
--image-executables: url('');
--image-fork: url('');
--image-ghcta-header: url('');
--image-github: url('');
--image-heart: url('');
Expand Down
16 changes: 16 additions & 0 deletions FrontEnd/styles/package.scss
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,11 @@
background-image: var(--image-warning);
}

li.forked {
grid-column-start: span 2;
background-image: var(--image-fork);
}

li.authors {
grid-column-start: span 2;
background-image: var(--image-authors);
Expand Down Expand Up @@ -151,6 +156,17 @@
align-items: center;
}
}

li.custom-collections {
grid-column-start: span 2;
background-image: var(--image-tags);

a {
display: flex;
gap: 5px;
align-items: center;
}
}
}

section.sidebar-links {
Expand Down
25 changes: 25 additions & 0 deletions FrontEnd/styles/readme.scss
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,31 @@
.markdown-alert-caution {
color: var(--mid-red);
}

.mermaid-chart {
display: flex;
justify-content: center;
padding: 30px 0;
}

section[data-type='mermaid'] {
pre,
.js-render-enrichment-loader {
display: none;
}

@media (prefers-color-scheme: light) {
[id^='mermaid-chart-dark'] {
display: none;
}
}

@media (prefers-color-scheme: dark) {
[id^='mermaid-chart-light'] {
display: none;
}
}
}
}

g-emoji {
Expand Down
49 changes: 12 additions & 37 deletions FrontEnd/styles/supporters.scss
Original file line number Diff line number Diff line change
Expand Up @@ -23,25 +23,23 @@

section {
ul {
display: grid;
display: flex;
flex-wrap: wrap;
gap: 30px 70px;
justify-content: center;
margin: 60px 0;
padding: 0;

li {
display: flex;
list-style: none;

> a {
display: flex;
align-items: center;
}
}

@media screen and (max-width: $mobile-breakpoint) {
gap: 20px;

li {
justify-content: center;
@media screen and (max-width: $mobile-breakpoint) {
width: 100%;
}
}
}
Expand All @@ -57,32 +55,13 @@
}
}

&.corporate,
&.infrastructure {
ul {
grid-template-columns: 1fr 1fr;

li {
justify-content: center;
}

&.solo {
grid-template-columns: 1fr;
}
}

@media screen and (max-width: $mobile-breakpoint) {
ul {
grid-template-columns: 1fr;
}
}
}

&.community {
ul {
grid-template-columns: 1fr 1fr 1fr;
justify-content: flex-start;

> li {
width: calc(100% / 3 - 70px);

li {
a:not(:hover) {
color: var(--page-text);
}
Expand All @@ -100,6 +79,8 @@
}

@media screen and (max-width: $mobile-breakpoint) {
width: 50%;

img {
margin: 0;
}
Expand All @@ -117,12 +98,6 @@
}
}
}

@media screen and (max-width: $mobile-breakpoint) {
ul {
grid-template-columns: 1fr 1fr;
}
}
}
}

Expand Down
2 changes: 1 addition & 1 deletion LOCAL_DEVELOPMENT_SETUP.md
Original file line number Diff line number Diff line change
Expand Up @@ -216,7 +216,7 @@ The trickiest part of this is to ensure the test or app container can connect to
So, in order to run the tests in a Linux container run:

```
docker run --rm -v "$PWD":/host -w /host --add-host=host.docker.internal:host-gateway registry.gitlab.com/finestructure/spi-base:1.0.3 swift test
docker run --rm -v "$PWD":/host -w /host --add-host=host.docker.internal:host-gateway registry.gitlab.com/finestructure/spi-base:1.1.0 swift test
```

Make sure you use the most recent `spi-base` image. You can find the latest image name in the `test-docker` target, which also provides a convenient way to run all all tests in a docker container.
Expand Down
10 changes: 2 additions & 8 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -33,16 +33,10 @@ build:
run:
swift run

# sas 2024-09-07: temporarily disable TSAN, it's triggering on Linux again (not on macOS).
# Probably related to the Swift 6 nightly image we're currently using.
test: xcbeautify
set -o pipefail \
&& swift test --disable-automatic-resolution \
&& swift test --disable-automatic-resolution --sanitize=thread \
2>&1 | ./xcbeautify --renderer github-actions
#test: xcbeautify
# set -o pipefail \
# && swift test --disable-automatic-resolution --sanitize=thread \
# 2>&1 | ./xcbeautify --renderer github-actions

test-query-performance: xcbeautify
set -o pipefail \
Expand Down Expand Up @@ -74,7 +68,7 @@ test-docker:
@# run tests inside a docker container
docker run --rm -v "$(PWD)":/host -w /host \
--add-host=host.docker.internal:host-gateway \
registry.gitlab.com/finestructure/spi-base:1.0.3 \
registry.gitlab.com/finestructure/spi-base:1.1.0 \
make test

test-e2e: db-reset reconcile ingest analyze
Expand Down
Loading

0 comments on commit feeea95

Please sign in to comment.