Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Timezone Control in the GUIDE #820

Merged
merged 61 commits into from
Jun 5, 2024
Merged
Changes from 1 commit
Commits
Show all changes
61 commits
Select commit Hold shift + click to select a range
9a8bc6e
Allow user to specify a timezone to use in the GUIDE
garrettmflynn Jun 3, 2024
5b826f5
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 3, 2024
4dc776f
Generate timezone list
garrettmflynn Jun 3, 2024
ad1cf97
Merge branch 'main' into timezone
CodyCBakerPhD Jun 3, 2024
303e275
Provide datetime values with a timezone offset specified. Render diff…
garrettmflynn Jun 3, 2024
ad1e9c9
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 3, 2024
31b5fec
More uniform time handling
garrettmflynn Jun 3, 2024
977950f
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 3, 2024
f521e57
Extract timezone offset using timezone awareness. Remove timezone awa…
garrettmflynn Jun 3, 2024
3681429
Merge branch 'timezone' of https://github.com/NeurodataWithoutBorders…
garrettmflynn Jun 3, 2024
4c69fab
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 3, 2024
a195173
Set timezone when converting data
garrettmflynn Jun 3, 2024
7af0222
Add timestamp awareness to forms and conversion process
garrettmflynn Jun 3, 2024
3e74935
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 3, 2024
fae3596
Ensure default values are carried in the preform
garrettmflynn Jun 3, 2024
864c2da
Merge branch 'timezone' of https://github.com/NeurodataWithoutBorders…
garrettmflynn Jun 3, 2024
9b7eb71
Merge branch 'main' into timezone
CodyCBakerPhD Jun 4, 2024
5beaafe
Merge branch 'main' into timezone
CodyCBakerPhD Jun 4, 2024
389c113
Use keywords, categories, and labels to improve the rendering of time…
garrettmflynn Jun 4, 2024
d026cd8
Merge branch 'timezone' of https://github.com/NeurodataWithoutBorders…
garrettmflynn Jun 4, 2024
74856c9
Require timezone and move workflow value resolution into the Dashboar…
garrettmflynn Jun 4, 2024
f868b1e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
ca3ea2d
Update Dashboard.js
garrettmflynn Jun 4, 2024
720fe30
Merge branch 'timezone' of https://github.com/NeurodataWithoutBorders…
garrettmflynn Jun 4, 2024
d0d49c1
Add non-category timezone information to the end
garrettmflynn Jun 4, 2024
ed416e1
Show long and short name
garrettmflynn Jun 4, 2024
7042094
Instead of always including UTC, add it if the timezone detector has …
garrettmflynn Jun 4, 2024
fa29aa4
Properly resolve promises
garrettmflynn Jun 4, 2024
b619ce3
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
f02a800
Bring dashboard changes directly from the backend configuration PR
garrettmflynn Jun 4, 2024
bf96a46
Update Dashboard.js
garrettmflynn Jun 4, 2024
28bc090
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
90fa005
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
aad5e9a
Merge branch 'main' into timezone
CodyCBakerPhD Jun 4, 2024
b82875d
Rely on Python for timezone information
garrettmflynn Jun 4, 2024
c9370ad
Update GuidedMetadata.js
garrettmflynn Jun 4, 2024
75e2f79
Merge branch 'main' into timezone
garrettmflynn Jun 4, 2024
c8a69fc
Update GuidedSourceData.js
garrettmflynn Jun 4, 2024
6476daf
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
b3fc871
cleanup modules
CodyCBakerPhD Jun 4, 2024
6d03f2e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
48d8e76
add call to management helpers
CodyCBakerPhD Jun 4, 2024
051bbd5
Merge remote-tracking branch 'origin/timezone' into timezone
CodyCBakerPhD Jun 4, 2024
b440644
remove placeholder
CodyCBakerPhD Jun 4, 2024
5f948c9
object does not mutate
CodyCBakerPhD Jun 4, 2024
eaf29a1
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
8e1b835
adjust fetch calls
CodyCBakerPhD Jun 4, 2024
987e1b2
fix namespace for docs
CodyCBakerPhD Jun 4, 2024
b75e55d
debug import
CodyCBakerPhD Jun 4, 2024
6bd7823
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
d3ba6d1
fix import and parse datetime object
CodyCBakerPhD Jun 4, 2024
d2bec56
Merge remote-tracking branch 'origin/timezone' into timezone
CodyCBakerPhD Jun 4, 2024
3180bc3
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 4, 2024
10aa18b
Sort by category
garrettmflynn Jun 4, 2024
0cc837c
Update timezone.schema.ts
garrettmflynn Jun 4, 2024
37d75d6
Add current timezone if filtered out (e.g. in Actions)
garrettmflynn Jun 5, 2024
1006ac0
Merge branch 'main' into timezone
CodyCBakerPhD Jun 5, 2024
518dd96
Fix workflow loading. Add localstorage data handling back on the web
garrettmflynn Jun 5, 2024
aaaeef7
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 5, 2024
4f3056f
Fix preform page. Add multi-session workflow to show other pages
garrettmflynn Jun 5, 2024
8473378
Merge branch 'timezone' of https://github.com/NeurodataWithoutBorders…
garrettmflynn Jun 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Bring dashboard changes directly from the backend configuration PR
garrettmflynn committed Jun 4, 2024
commit f02a80057bfb2715cfb53659700410847ee9bd99
52 changes: 40 additions & 12 deletions src/electron/frontend/core/components/Dashboard.js
Original file line number Diff line number Diff line change
@@ -261,7 +261,7 @@ export class Dashboard extends LitElement {
});

page.requestUpdate(); // Ensure the page is re-rendered with new workflow configurations

// Ensure that all states are synced to the proper state for this page (e.g. conversions have been run)
this.page
.checkSyncState()
.then(async () => {
@@ -271,23 +271,34 @@ export class Dashboard extends LitElement {
? `<h4 style="margin-bottom: 0px;">${projectName}</h4><small>Conversion Pipeline</small>`
: projectName;

this.updateSections({ sidebar: false, main: true });

const { skipped } = this.subSidebar.sections[info.section]?.pages?.[info.id] ?? {};

if (skipped) {
if (isStorybook) return; // Do not skip on storybook

// Run skip functions
Object.entries(page.workflow).forEach(([key, state]) => {
if (typeof state.skip === "function") state.skip();
});

// Skip right over the page if configured as such
if (previous && previous.info.previous === this.page) await this.page.onTransition(-1);
else await this.page.onTransition(1);
const backwards = previous && previous.info.previous === this.page;

return (
Promise.all(
Object.entries(page.workflow).map(async ([_, state]) => {
if (typeof state.skip === "function" && !backwards) return await state.skip(); // Run skip functions
})
)

// Skip right over the page if configured as such
.then(async () => {
if (backwards) await this.main.onTransition(-1);
else await this.main.onTransition(1);
})
);
}

page.requestUpdate(); // Re-render the page on each load

// Update main to render page
this.updateSections({ sidebar: false, main: true });
})

.catch((e) => {
const previousId = previous?.info?.id ?? -1;
this.main.onTransition(previousId); // Revert back to previous page
@@ -300,7 +311,7 @@ export class Dashboard extends LitElement {
);
})
.finally(() => {
if (this.#transitionPromise.value) this.#transitionPromise.trigger(page); // This ensures calls to page.to() can be properly awaited until the next page is ready
if (this.#transitionPromise.value) this.#transitionPromise.trigger(this.main.page); // This ensures calls to page.to() can be properly awaited until the next page is ready
});
}

@@ -370,6 +381,23 @@ export class Dashboard extends LitElement {
})
));


let resolved;
promise.then(res => {
resolved = true
console.log("Transitioned to", res.info.id);
})
.catch(e => {
console.error('SOMETHIG THAPPENED WOTH', res.info.id, e)
})

setTimeout(() => {
if (!resolved) {
console.warn("Transition Promise Timed Out", res.info.id)
// this.#transitionPromise.trigger(this.page)
}
}, 1000)

if (typeof transition === "number") {
const info = this.page.info;
const sign = Math.sign(transition);