diff --git a/schemas/source-data.schema.ts b/schemas/source-data.schema.ts index 50c28a1f8..5fe9ba03c 100644 --- a/schemas/source-data.schema.ts +++ b/schemas/source-data.schema.ts @@ -2,7 +2,7 @@ export default function getSourceDataSchema (schema) { // const copy = merge(schema, {}) - Object.values(schema.properties).forEach((schema: any) => { + Object.values(schema.properties ?? {}).forEach((schema: any) => { if (schema.properties.gain) schema.properties.gain.step = null // Do not show steps }) diff --git a/src/renderer/assets/css/guided.css b/src/renderer/assets/css/guided.css index 5ad2a7326..952871706 100644 --- a/src/renderer/assets/css/guided.css +++ b/src/renderer/assets/css/guided.css @@ -812,7 +812,8 @@ h1.guided--text-sub-step { display: flex; justify-content: center; flex-wrap: wrap; - padding: 10px; + padding: 20px 10px; + margin: 5px; border: 1px dashed #ccc; border-radius: 5px; } diff --git a/src/renderer/assets/css/main.css b/src/renderer/assets/css/main.css index b1eb0db0a..6097644ee 100644 --- a/src/renderer/assets/css/main.css +++ b/src/renderer/assets/css/main.css @@ -1471,12 +1471,11 @@ details[open] > summary::before { box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); } -.standalone-section { +.getting-started { width: 100%; display: flex; flex-direction: column; align-items: center; - margin-bottom: 20px; } .overview-card-layout { @@ -1695,7 +1694,6 @@ details[open] > summary::before { line-height: 2.25rem; padding-bottom: 0.25rem; margin: 0; - padding-top: 1.25rem; } .docu_divide { diff --git a/src/renderer/assets/css/section.css b/src/renderer/assets/css/section.css index ce05dcc80..a9f7c63f4 100755 --- a/src/renderer/assets/css/section.css +++ b/src/renderer/assets/css/section.css @@ -4,7 +4,8 @@ height: 100%; width: 100%; margin-right: 0; - padding: 0px 50px 50px 50px; + padding: 15px 50px; + display: flex; flex-direction: column; box-sizing: border-box; @@ -12,62 +13,31 @@ overflow-y: auto; color: var(--color-accent); background-color: var(--color-section); - /* pointer-events: none; - visibility: hidden; - opacity: 0; */ - /* transform: translateX(-20px); */ transition: visibility 0s 0.12s linear, opacity 0.12s ease-in, transform 0.12s ease-in-out; } -.section.is-shown { - pointer-events: auto; - visibility: visible; - opacity: 1; - z-index: 1000; - /* transform: translateX(20px); */ - transition: - visibility 0s 0s linear, - opacity 0.36s ease-out, - transform 0.36s ease-out; + +.section.nested { + padding-top: 15px; + padding-bottom: 15px; } -.section.fullShown { - left: 210px; - max-width: 100%; - transition: all 0.25s linear; +.section > * { + height: 100%; } -.section h3, -.section p { +nwb-main h3, +nwb-main p { color: var(--color); } -.section h1 { + +nwb-main h1 { font-size: 20px; } -.section h3 { +nwb-main h3 { padding-bottom: 30px; font-size: 16px; } - -.section-wrapper { - position: relative; - max-width: 100%; - margin: 0 auto; - padding: 0px 20px 0px 25px; - border-bottom: 1px solid var(--color-border); -} -/* @media (min-width: 940px) { - .section-wrapper { - padding-top: 4rem; - } -} */ - -.section-icon { - width: 32px; - height: 32px; - vertical-align: sub; - margin-right: 0.5em; -} diff --git a/src/renderer/src/stories/JSONSchemaForm.js b/src/renderer/src/stories/JSONSchemaForm.js index 4bbc76abf..c73e04526 100644 --- a/src/renderer/src/stories/JSONSchemaForm.js +++ b/src/renderer/src/stories/JSONSchemaForm.js @@ -25,6 +25,16 @@ const componentCSS = ` width:100%; } + #empty { + display: flex; + align-items: center; + justify-content: center; + height: 100%; + width: 100%; + color: gray; + } + + p { margin: 0 0 1em; line-height: 1.4285em; @@ -195,6 +205,8 @@ export class JSONSchemaForm extends LitElement { this.dialogType = props.dialogType; this.deferLoading = props.deferLoading ?? false; + this.emptyMessage = props.emptyMessage ?? "No properties to render"; + this.requirementMode = props.requirementMode ?? "default"; this.onlyRequired = props.onlyRequired ?? false; this.showLevelOverride = props.showLevelOverride ?? false; @@ -705,7 +717,7 @@ export class JSONSchemaForm extends LitElement { // // Filter non-required properties (if specified) and render the sub-schema // const renderable = path.length ? this.#getRenderable(schema, required) : Object.entries(schema.properties ?? {}) - if (renderable.length === 0) return html`

No properties to render

`; + if (renderable.length === 0) return html`
${this.emptyMessage}
`; let renderableWithLinks = renderable.reduce((acc, [name, info]) => { const externalPath = [...this.base, ...path, name]; @@ -910,13 +922,11 @@ export class JSONSchemaForm extends LitElement { this.#registerRequirements(this.schema, this.required); return html` -
- ${schema.description - ? html`

Description

-

${unsafeHTML(schema.description)}

` - : ""} - ${this.#render(schema, this.resolved, this.#requirements)} -
+ ${schema.description + ? html`

Description

+

${unsafeHTML(schema.description)}

` + : ""} + ${this.#render(schema, this.resolved, this.#requirements)} `; } } diff --git a/src/renderer/src/stories/Main.js b/src/renderer/src/stories/Main.js index 7ad3d4968..ad813f477 100644 --- a/src/renderer/src/stories/Main.js +++ b/src/renderer/src/stories/Main.js @@ -70,6 +70,10 @@ export class Main extends LitElement { this.style.overflow = "hidden"; this.content.style.height = "100%"; + + // Reset scroll position on page change + const section = this.content.children[0]; + section.scrollTop = 0; } render() { @@ -101,6 +105,7 @@ export class Main extends LitElement { // Default Capsules Behavior const section = sections[info.section]; + console.log("Sections", section, sections); if (section) { if (capsules === true || !("capsules" in page)) { let pages = Object.values(section.pages); @@ -142,28 +147,24 @@ export class Main extends LitElement { ${headerEl} ${capsules ? html`
${capsules}
` - : html`
`} -
-
- ${title - ? html`
-
-
-

${title}

- ${unsafeHTML(subtitle)} -
-
${controls}
-
-
-
` - : ""} - -
${page}
-
+ : html`
`} + ${title + ? html`
+
+
+

${title}

+ ${unsafeHTML(subtitle)} +
+
${controls}
+
+
+
` + : ""} + +
+
${page}
${footerEl} `; diff --git a/src/renderer/src/stories/pages/Page.js b/src/renderer/src/stories/pages/Page.js index 50f962a65..2deb6e1c4 100644 --- a/src/renderer/src/stories/pages/Page.js +++ b/src/renderer/src/stories/pages/Page.js @@ -22,9 +22,6 @@ export class Page extends LitElement { constructor(info = {}) { super(); Object.assign(this.info, info); - - this.style.height = "100%"; - this.style.color = "black"; } createRenderRoot() { diff --git a/src/renderer/src/stories/pages/contact-us/Contact.js b/src/renderer/src/stories/pages/contact-us/Contact.js index ea57e16bf..169ebe89e 100644 --- a/src/renderer/src/stories/pages/contact-us/Contact.js +++ b/src/renderer/src/stories/pages/contact-us/Contact.js @@ -5,6 +5,11 @@ import { Page } from "../Page.js"; import { startLottie } from "../../../dependencies/globals.js"; export class ContactPage extends Page { + header = { + title: "Contact Us", + subtitle: "Let us know your issues and feature requests.", + }; + constructor(...args) { super(...args); } @@ -20,8 +25,6 @@ export class ContactPage extends Page {
-

Contact Us

-
diff --git a/src/renderer/src/stories/pages/documentation/Documentation.js b/src/renderer/src/stories/pages/documentation/Documentation.js index b952afaf7..9b009c7c3 100644 --- a/src/renderer/src/stories/pages/documentation/Documentation.js +++ b/src/renderer/src/stories/pages/documentation/Documentation.js @@ -5,6 +5,11 @@ import { Page } from "../Page.js"; import { startLottie } from "../../../dependencies/globals.js"; export class DocumentationPage extends Page { + header = { + title: "Documentation", + subtitle: "Learn more about the GUIDE.", + }; + constructor(...args) { super(...args); } @@ -21,8 +26,6 @@ export class DocumentationPage extends Page {
-

Documentation

-
diff --git a/src/renderer/src/stories/pages/getting-started/GettingStarted.js b/src/renderer/src/stories/pages/getting-started/GettingStarted.js index 701f9dc00..e9f2fef09 100644 --- a/src/renderer/src/stories/pages/getting-started/GettingStarted.js +++ b/src/renderer/src/stories/pages/getting-started/GettingStarted.js @@ -22,7 +22,7 @@ export class GettingStartedPage extends Page { render() { return html` -
+

Your one-stop tool for converting and uploading NWB datasets to the DANDI Archive!

@@ -80,12 +80,6 @@ export class GettingStartedPage extends Page {
-
-
-
`; } diff --git a/src/renderer/src/stories/pages/guided-mode/GuidedHome.js b/src/renderer/src/stories/pages/guided-mode/GuidedHome.js index 02ec44cb0..058d25f16 100644 --- a/src/renderer/src/stories/pages/guided-mode/GuidedHome.js +++ b/src/renderer/src/stories/pages/guided-mode/GuidedHome.js @@ -7,6 +7,11 @@ import * as progress from "../../../progress/index.js"; import { newDataset } from "../../../../assets/lotties/index.js"; export class GuidedHomePage extends Page { + header = { + title: "Your Conversions", + subtitle: "Start new conversions and resume existing ones.", + }; + constructor(...args) { super(...args); } @@ -178,31 +183,17 @@ export class GuidedHomePage extends Page { render() { return html` -
-
-
-

Your Conversions

-
-
-
- -

+

+

The NWB GUIDE walks users step-by-step through all the requirements for converting their data to the NWB format and uploading datasets to the DANDI Archive. Each stage is designed to conveniently guide users through the conversion process and include all necessary information such that no prior knowledge of the NWB data standard is required.

-
-
-
-

Create a new conversion pipeline

-
+
+
+

Create a new conversion pipeline

diff --git a/src/renderer/src/stories/pages/guided-mode/GuidedStart.js b/src/renderer/src/stories/pages/guided-mode/GuidedStart.js index 70bb960ab..42129a61f 100644 --- a/src/renderer/src/stories/pages/guided-mode/GuidedStart.js +++ b/src/renderer/src/stories/pages/guided-mode/GuidedStart.js @@ -55,7 +55,7 @@ export class GuidedStartPage extends Page {

- In the NWB GUIDE, the process of running a conversion pipeline is broken into four high-level sections. + In the GUIDE, the process of running a conversion pipeline is broken into four high-level sections.

1. Project Structure

diff --git a/src/renderer/src/stories/pages/guided-mode/data/GuidedSourceData.js b/src/renderer/src/stories/pages/guided-mode/data/GuidedSourceData.js index 40454e18d..d23d77956 100644 --- a/src/renderer/src/stories/pages/guided-mode/data/GuidedSourceData.js +++ b/src/renderer/src/stories/pages/guided-mode/data/GuidedSourceData.js @@ -116,6 +116,7 @@ export class GuidedSourceDataPage extends ManagedPage { mode: "accordion", schema: schemaResolved, results: info.source_data, + emptyMessage: "No source data required for this session.", ignore: [ "verbose", "es_key", @@ -130,6 +131,8 @@ export class GuidedSourceDataPage extends ManagedPage { onThrow, }); + form.style.height = "100%"; + return { subject, session, diff --git a/src/renderer/src/stories/pages/inspect/InspectPage.js b/src/renderer/src/stories/pages/inspect/InspectPage.js index dbdee36cc..f8dd22ca3 100644 --- a/src/renderer/src/stories/pages/inspect/InspectPage.js +++ b/src/renderer/src/stories/pages/inspect/InspectPage.js @@ -14,6 +14,11 @@ export class InspectPage extends Page { super(...args); } + header = { + title: "NWB Inspector Report", + subtitle: "This page allows you to inspect NWB files using the NWB Inspector.", + }; + showReport = async (value) => { if (!value) { const message = "Please provide filesystem entries to inspect."; @@ -72,17 +77,9 @@ export class InspectPage extends Page { } return html` -

-

NWB Inspector Report

-
-

This page allows you to inspect NWB files using the NWB Inspector.

-
- -
- ${this.input} -
- ${button} -
+ ${this.input} +
+ ${button} `; } } diff --git a/src/renderer/src/stories/pages/preview/PreviewPage.js b/src/renderer/src/stories/pages/preview/PreviewPage.js index 04d06a46b..80f30dfde 100644 --- a/src/renderer/src/stories/pages/preview/PreviewPage.js +++ b/src/renderer/src/stories/pages/preview/PreviewPage.js @@ -6,6 +6,11 @@ import { Neurosift } from "../../preview/Neurosift.js"; import { baseUrl } from "../../../globals.js"; export class PreviewPage extends Page { + header = { + title: "Neurosift File Visualization", + subtitle: "Explore your NWB file using Neurosift.", + }; + constructor(...args) { super(...args); } @@ -25,7 +30,7 @@ export class PreviewPage extends Page { type: "string", format: "file", description: - "Please provide a file path that you'd like to visualize using Neurosift. The NWB GUIDE will serve this file and access the appropriate URL automatically.", + "Please provide a file path that you'd like to visualize using Neurosift. The GUIDE will serve this file and access the appropriate URL automatically.", }, onUpdate: this.updatePath, onThrow, @@ -40,16 +45,7 @@ export class PreviewPage extends Page { } return html` -
-
-
-

Neurosift File Visualization

-
-

Explore your NWB file using Neurosift

-
-
+
${this.input} ${this.neurosift}
`; diff --git a/src/renderer/src/stories/pages/settings/SettingsPage.js b/src/renderer/src/stories/pages/settings/SettingsPage.js index d610f96ac..afa2cb408 100644 --- a/src/renderer/src/stories/pages/settings/SettingsPage.js +++ b/src/renderer/src/stories/pages/settings/SettingsPage.js @@ -29,6 +29,11 @@ const setUndefinedIfNotDeclared = (schema, resolved) => { }; export class SettingsPage extends Page { + header = { + title: "App Settings", + subtitle: "This page allows you to set global settings for the GUIDE.", + }; + constructor(...args) { super(...args); } @@ -80,17 +85,9 @@ export class SettingsPage extends Page { }); return html` -
-

NWB GUIDE Settings

-
-

This page allows you to set global settings for the NWB GUIDE.

+ ${this.form}
- -
- ${this.form} -
- ${button} -
+ ${button} `; } } diff --git a/src/renderer/src/stories/pages/tutorial/Tutorial.js b/src/renderer/src/stories/pages/tutorial/Tutorial.js index c4b3066c5..32c730084 100644 --- a/src/renderer/src/stories/pages/tutorial/Tutorial.js +++ b/src/renderer/src/stories/pages/tutorial/Tutorial.js @@ -19,6 +19,12 @@ const { shell } = electron; const tutorialPipelineName = "NWB GUIDE Tutorial Data"; export class TutorialPage extends Page { + header = { + title: "Tutorial Data Generation", + subtitle: + "This page allows you to generate a dataset with multiple subjects and sessions so you can practice using NWB GUIDE before converting your own datasets.", + }; + constructor(...args) { super(...args); } @@ -41,16 +47,6 @@ export class TutorialPage extends Page { const entry = entryExists ? get(tutorialPipelineName) : {}; return html` -
-

Tutorial Data Generation

-
-

- This page allows you to generate a dataset with multiple subjects and sessions so you can practice using - NWB GUIDE before converting your own datasets. -

- -
- ${hasEntry(tutorialPipelineName) ? html`

@@ -89,7 +85,7 @@ export class TutorialPage extends Page { })}

-

Let's get started with your first conversion on the NWB GUIDE!

+

Let's get started with your first conversion on the GUIDE!

-

DANDI Uploads

-
-

This page allows you to upload folders with NWB files to the DANDI Archive.

+ ${this.form}
- -
- ${this.form} -
- ${button} -
+ ${button} `; } }