From 3266c3e047aca80ba8e55642235871eba5eeacaf Mon Sep 17 00:00:00 2001 From: Garrett Date: Tue, 17 Oct 2023 09:46:39 -0700 Subject: [PATCH 1/3] Add tooltips using Tippy.js --- package-lock.json | 18 +++++++++++++++ package.json | 1 + src/renderer/assets/css/demo.css | 7 ------ src/renderer/assets/css/global.css | 9 ++++++++ src/renderer/src/stories/Table.js | 35 +++++++++++++++++++++++------- 5 files changed, 55 insertions(+), 15 deletions(-) diff --git a/package-lock.json b/package-lock.json index 5d07fc752..5ee7d7459 100644 --- a/package-lock.json +++ b/package-lock.json @@ -24,6 +24,7 @@ "lottie-web": "^5.9.5", "notyf": "^3.9.0", "sweetalert2": "^11.6.13", + "tippy.js": "^6.3.7", "v8-compile-cache": "^2.3.0" }, "devDependencies": { @@ -3400,6 +3401,15 @@ "node": ">=14" } }, + "node_modules/@popperjs/core": { + "version": "2.11.8", + "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz", + "integrity": "sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/popperjs" + } + }, "node_modules/@radix-ui/number": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/@radix-ui/number/-/number-1.0.1.tgz", @@ -19446,6 +19456,14 @@ "node": ">=14.0.0" } }, + "node_modules/tippy.js": { + "version": "6.3.7", + "resolved": "https://registry.npmjs.org/tippy.js/-/tippy.js-6.3.7.tgz", + "integrity": "sha512-E1d3oP2emgJ9dRQZdf3Kkn0qJgI6ZLpyS5z6ZkY1DF3kaQaBsGZsndEpHwx+eC+tYM41HaSNvNtLx8tU57FzTQ==", + "dependencies": { + "@popperjs/core": "^2.9.0" + } + }, "node_modules/tmp": { "version": "0.0.33", "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", diff --git a/package.json b/package.json index dda8296a5..fb97e0b00 100644 --- a/package.json +++ b/package.json @@ -151,6 +151,7 @@ "lottie-web": "^5.9.5", "notyf": "^3.9.0", "sweetalert2": "^11.6.13", + "tippy.js": "^6.3.7", "v8-compile-cache": "^2.3.0" }, "devDependencies": { diff --git a/src/renderer/assets/css/demo.css b/src/renderer/assets/css/demo.css index 4d4eb688f..f959c0a4d 100755 --- a/src/renderer/assets/css/demo.css +++ b/src/renderer/assets/css/demo.css @@ -713,13 +713,6 @@ table.table-save-metadata { font-size: 14px; font-style: italic; } - -.info { - width: 18px; - height: 18px; - float: right; -} - .tooltipnew .tooltiptext { visibility: hidden; width: 400px; diff --git a/src/renderer/assets/css/global.css b/src/renderer/assets/css/global.css index bb44ffba5..7013f7d89 100755 --- a/src/renderer/assets/css/global.css +++ b/src/renderer/assets/css/global.css @@ -17,6 +17,15 @@ word-wrap: break-word; } +/* Tippy */ +.tippy-box[data-theme~="error"]{ + background-color: hsl(0, 100%, 70%); +} + +.tippy-box[data-theme~="warning"]{ + background-color: hsl(57, 100%, 70%); +} + /* Global ---------------------------- */ * { diff --git a/src/renderer/src/stories/Table.js b/src/renderer/src/stories/Table.js index 2707b2da2..22515257d 100644 --- a/src/renderer/src/stories/Table.js +++ b/src/renderer/src/stories/Table.js @@ -6,6 +6,10 @@ import { errorHue, warningHue } from "./globals"; import { checkStatus } from "../validation"; import { emojiFontFamily } from "./globals"; +import tippy from 'tippy.js'; +import 'tippy.js/dist/tippy.css'; + + const maxRows = 20; // Inject scoped stylesheet @@ -13,6 +17,7 @@ const styles = ` ${css} + .handsontable td[error] { background: hsl(${errorHue}, 100%, 90%) !important; } @@ -37,11 +42,8 @@ const styles = ` padding-left: 20px } - [title] .relative::after { - content: 'ℹ️'; - display: inline-block; + .relative .info { margin: 0px 5px; - text-align: center; font-size: 80%; font-family: ${emojiFontFamily} } @@ -283,7 +285,19 @@ export class Table extends LitElement { const onAfterGetHeader = function (index, TH) { const desc = entries[colHeaders[index]].description; - if (desc) TH.setAttribute("title", desc); + if (desc) { + const rel = TH.querySelector('.relative') + let span = rel.querySelector('.info') + if (!span) { + span = document.createElement('span') + span.classList.add('info') + span.innerText = 'ℹ️' + rel.append(span) + } + + if (span._tippy) span._tippy.destroy() + tippy(span, { content: `${desc}` }); + } }; const data = this.#getData(); @@ -425,17 +439,22 @@ export class Table extends LitElement { if (cell) { let title = ""; + let theme = "" if (warnings.length) { - cell.setAttribute("warning", ""); + theme = "warning", title = warnings.map((o) => o.message).join("\n"); } else cell.removeAttribute("warning"); if (errors.length) { - cell.setAttribute("error", ""); + theme = "error", title = errors.map((o) => o.message).join("\n"); // Class switching handled automatically } else cell.removeAttribute("error"); - if (title) cell.title = title; + if (theme) cell.setAttribute(theme, ""); + + if (cell._tippy) cell._tippy.destroy() + + if (title) tippy(cell, { content: title, theme }); } this.#checkStatus(); // Check status after every validation update From 18de71690165b8937da53e13291eb0d5be412afb Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Tue, 17 Oct 2023 16:48:09 +0000 Subject: [PATCH 2/3] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- src/renderer/assets/css/global.css | 4 ++-- src/renderer/src/stories/Table.js | 31 ++++++++++++++---------------- 2 files changed, 16 insertions(+), 19 deletions(-) diff --git a/src/renderer/assets/css/global.css b/src/renderer/assets/css/global.css index 7013f7d89..31734949f 100755 --- a/src/renderer/assets/css/global.css +++ b/src/renderer/assets/css/global.css @@ -18,11 +18,11 @@ } /* Tippy */ -.tippy-box[data-theme~="error"]{ +.tippy-box[data-theme~="error"] { background-color: hsl(0, 100%, 70%); } -.tippy-box[data-theme~="warning"]{ +.tippy-box[data-theme~="warning"] { background-color: hsl(57, 100%, 70%); } diff --git a/src/renderer/src/stories/Table.js b/src/renderer/src/stories/Table.js index 22515257d..eaa0f4948 100644 --- a/src/renderer/src/stories/Table.js +++ b/src/renderer/src/stories/Table.js @@ -6,9 +6,8 @@ import { errorHue, warningHue } from "./globals"; import { checkStatus } from "../validation"; import { emojiFontFamily } from "./globals"; -import tippy from 'tippy.js'; -import 'tippy.js/dist/tippy.css'; - +import tippy from "tippy.js"; +import "tippy.js/dist/tippy.css"; const maxRows = 20; @@ -286,16 +285,16 @@ export class Table extends LitElement { const onAfterGetHeader = function (index, TH) { const desc = entries[colHeaders[index]].description; if (desc) { - const rel = TH.querySelector('.relative') - let span = rel.querySelector('.info') + const rel = TH.querySelector(".relative"); + let span = rel.querySelector(".info"); if (!span) { - span = document.createElement('span') - span.classList.add('info') - span.innerText = 'ℹ️' - rel.append(span) + span = document.createElement("span"); + span.classList.add("info"); + span.innerText = "ℹ️"; + rel.append(span); } - if (span._tippy) span._tippy.destroy() + if (span._tippy) span._tippy.destroy(); tippy(span, { content: `${desc}` }); } }; @@ -439,22 +438,20 @@ export class Table extends LitElement { if (cell) { let title = ""; - let theme = "" + let theme = ""; if (warnings.length) { - theme = "warning", - title = warnings.map((o) => o.message).join("\n"); + (theme = "warning"), (title = warnings.map((o) => o.message).join("\n")); } else cell.removeAttribute("warning"); if (errors.length) { - theme = "error", - title = errors.map((o) => o.message).join("\n"); // Class switching handled automatically + (theme = "error"), (title = errors.map((o) => o.message).join("\n")); // Class switching handled automatically } else cell.removeAttribute("error"); if (theme) cell.setAttribute(theme, ""); - if (cell._tippy) cell._tippy.destroy() + if (cell._tippy) cell._tippy.destroy(); - if (title) tippy(cell, { content: title, theme }); + if (title) tippy(cell, { content: title, theme }); } this.#checkStatus(); // Check status after every validation update From 4dadf95e6f753486ffa6f8894432f0f239aabb78 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Tue, 17 Oct 2023 21:43:04 +0000 Subject: [PATCH 3/3] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- src/renderer/src/stories/pages/Page.js | 2 +- .../src/stories/pages/settings/SettingsPage.js | 5 ++--- src/renderer/src/stories/pages/uploads/UploadsPage.js | 10 ++++++++-- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/src/renderer/src/stories/pages/Page.js b/src/renderer/src/stories/pages/Page.js index 08e49c592..50f962a65 100644 --- a/src/renderer/src/stories/pages/Page.js +++ b/src/renderer/src/stories/pages/Page.js @@ -58,7 +58,7 @@ export class Page extends LitElement { notify = (...args) => { const ref = notify(...args); this.#notifications.push(ref); - return ref + return ref; }; to = async (transition) => { diff --git a/src/renderer/src/stories/pages/settings/SettingsPage.js b/src/renderer/src/stories/pages/settings/SettingsPage.js index b824b1872..d610f96ac 100644 --- a/src/renderer/src/stories/pages/settings/SettingsPage.js +++ b/src/renderer/src/stories/pages/settings/SettingsPage.js @@ -37,7 +37,7 @@ export class SettingsPage extends Page { #openNotyf = (message, type) => { if (this.#notification) notyf.dismiss(this.#notification); - return (this.#notification = this.notify(message,type)); + return (this.#notification = this.notify(message, type)); }; beforeSave = () => { @@ -60,8 +60,7 @@ export class SettingsPage extends Page { const button = new Button({ label: "Save Changes", onClick: async () => { - if (!this.unsavedUpdates) - return this.#openNotyf("All changes were already saved", "success"); + if (!this.unsavedUpdates) return this.#openNotyf("All changes were already saved", "success"); this.save(); }, }); diff --git a/src/renderer/src/stories/pages/uploads/UploadsPage.js b/src/renderer/src/stories/pages/uploads/UploadsPage.js index 0c53b7b7b..6ddefb19c 100644 --- a/src/renderer/src/stories/pages/uploads/UploadsPage.js +++ b/src/renderer/src/stories/pages/uploads/UploadsPage.js @@ -48,11 +48,17 @@ export async function uploadToDandi(info, type = "project" in info ? "project" : }, { title: "Uploading to DANDI" } ).catch((e) => { - this.notify(e.message, 'error'); + this.notify(e.message, "error"); throw e; }); - if (result) this.notify(`${info.project ?? `${info[folderPathKey].length} filesystem entries`} successfully uploaded to Dandiset ${dandiset_id}`, "success"); + if (result) + this.notify( + `${ + info.project ?? `${info[folderPathKey].length} filesystem entries` + } successfully uploaded to Dandiset ${dandiset_id}`, + "success" + ); return result; }