From 2e0ab94f34546edfd0e6b0b038cdb2cba65beb0e Mon Sep 17 00:00:00 2001 From: David Wertheimer Date: Wed, 18 Oct 2023 16:21:56 -0700 Subject: [PATCH 1/2] WIP before design tweaks --- dwertheimer.EventAutomations/plugin.json | 2 +- np.plugin-test/plugin.json | 2 +- np.plugin-test/requiredFiles/css.plugin.css | 11 ++++++++++- np.plugin-test/src/pluginCommandsPopup.js | 3 +-- np.plugin-test/src/react/PluginListingPage.jsx | 9 +++++---- np.plugin-test/src/react/support/filterFunctions.jsx | 2 +- 6 files changed, 19 insertions(+), 10 deletions(-) diff --git a/dwertheimer.EventAutomations/plugin.json b/dwertheimer.EventAutomations/plugin.json index 6b2d4c81b..3e2a8c623 100644 --- a/dwertheimer.EventAutomations/plugin.json +++ b/dwertheimer.EventAutomations/plugin.json @@ -3,7 +3,7 @@ "noteplan.minAppVersion": "3.6", "plugin.id": "dwertheimer.EventAutomations", "plugin.name": "🗓 AutoTimeBlocking / Events", - "plugin.description": "Various Event Automations:\n- Automatically find time in your calendar and create Time Blocks for items marked for >today,\n- Write out synced copies of Today's todos (without the AutoTimeBlocking), and\n- Create calendar events for all text items under a specific heading", + "plugin.description": "Various Event Automations:\n- Automatically find time in your calendar and create Time Blocks for items marked for today,\n- Write out synced copies of Today's todos (without the AutoTimeBlocking), and\n- Create calendar events for all text items under a specific heading", "plugin.author": "dwertheimer", "plugin.version": "1.17.4-notreleased", "plugin.lastUpdateInfo": "1.17.4: Minor calendar event improvement", diff --git a/np.plugin-test/plugin.json b/np.plugin-test/plugin.json index 5ebee0847..31f853733 100644 --- a/np.plugin-test/plugin.json +++ b/np.plugin-test/plugin.json @@ -6,7 +6,7 @@ "plugin.name": "🔌 Plugin Information & Tester", "plugin.description": "View Plugin Commands and Test that Plugins are working.", "plugin.author": "@dwertheimer", - "plugin.version": "1.4.0-beta4", + "plugin.version": "1.4.0-beta5", "plugin.lastUpdateInfo": "1.4.0-betaX: The beginning of a searchable plugin repository", "plugin.dependencies": [], "plugin.requiredFiles": [ diff --git a/np.plugin-test/requiredFiles/css.plugin.css b/np.plugin-test/requiredFiles/css.plugin.css index aa7d6c551..7823b63a2 100644 --- a/np.plugin-test/requiredFiles/css.plugin.css +++ b/np.plugin-test/requiredFiles/css.plugin.css @@ -11,6 +11,14 @@ h1, h2, h3, h4, h5, h6 { font-weight: 500; line-height: 1.2; } +h3 { + background-color: beige; + font-size: 1.4rem; + margin-left: -10px; + padding-left: 10px; + padding-top: 5px; + padding-bottom: 5px; +} .monospace { font-family: 'ui-monospace'; } .monospaceData { font-family: 'ui-monospace'; font-size: 10px; white-space: pre-wrap } /* loading spinner */ @@ -76,6 +84,7 @@ h1, h2, h3, h4, h5, h6 { .plugin-section { padding: 10px; + padding-top: 0px; } .pluginName { @@ -154,6 +163,6 @@ h1, h2, h3, h4, h5, h6 { } .PluginListingPage { - margin-top: 55px; + margin-top: 75px; } } \ No newline at end of file diff --git a/np.plugin-test/src/pluginCommandsPopup.js b/np.plugin-test/src/pluginCommandsPopup.js index 98ff3e813..abd17faf8 100644 --- a/np.plugin-test/src/pluginCommandsPopup.js +++ b/np.plugin-test/src/pluginCommandsPopup.js @@ -114,8 +114,7 @@ export async function openReactPluginCommandsWindow() { // The second line needs to be updated to your pluginID in order to load any specific CSS you want to include for the React Window (in requiredFiles) const cssTagsString = ` - - \n` + ` const windowOptions = { savedFilename: `../../${pluginJson['plugin.id']}/savedOutput.html` /* for saving a debug version of the html file */, headerTags: cssTagsString, diff --git a/np.plugin-test/src/react/PluginListingPage.jsx b/np.plugin-test/src/react/PluginListingPage.jsx index 37550e13a..69cee3b48 100644 --- a/np.plugin-test/src/react/PluginListingPage.jsx +++ b/np.plugin-test/src/react/PluginListingPage.jsx @@ -3,7 +3,7 @@ declare var NP_THEME: { editor: { backgroundColor: string, - altColor: string, + altBackgroundColor: string, }, } @@ -70,6 +70,10 @@ const viewOptions = [ { label: 'Commands Only', value: 'commandsOnly' }, ] +const colorDiff = howDifferentAreTheseColors(NP_THEME.editor.backgroundColor, NP_THEME.editor.altBackgroundColor) +logDebug(`PluginSection: howDifferentAreTheseColors background vs altBackground:${howDifferentAreTheseColors(NP_THEME.editor.backgroundColor, NP_THEME.editor.altBackgroundColor)}`) +const altColor = !colorDiff || colorDiff < 5 ? getAltColor(NP_THEME.editor.backgroundColor) : NP_THEME.editor.altBackgroundColor + /** * HTML OUTPUT FOR EACH COMMAND */ @@ -114,8 +118,6 @@ type PluginSectionProps = { function PluginSection({ plugin, viewOption, index }: PluginSectionProps): React$Node { const installedDisplayString = plugin.isInstalled ? 'installed' : 'install' const updateIsAvailableString = plugin.updateIsAvailable ? '(update available)' : '' - const colorDiff = howDifferentAreTheseColors(NP_THEME.editor.backgroundColor, NP_THEME.editor.altColor) - const altColor = !colorDiff || colorDiff < 20 ? getAltColor(NP_THEME.editor.backgroundColor) : NP_THEME.editor.altColor const pluginSectionStyle = { backgroundColor: index % 2 === 0 ? altColor : 'inherit', @@ -197,7 +199,6 @@ function PluginListingPage(props: Props): React$Node { } }) const filteredPluginsAndCommands = filterCommands({ pluginList: filteredPlugins ?? [], filter: filter, categoryFilter: categoryFilter, returnOnlyMatchingCommands: true }) - console.log('filteredPluginsAndCommands SAMPLE OUPUT', JSON.stringify(filteredPluginsAndCommands.filter((plugin, index) => index < 1))) const filterDivStyle = { backgroundColor: NP_THEME.editor.backgroundColor } return ( <> diff --git a/np.plugin-test/src/react/support/filterFunctions.jsx b/np.plugin-test/src/react/support/filterFunctions.jsx index 924003953..1f360bdc9 100644 --- a/np.plugin-test/src/react/support/filterFunctions.jsx +++ b/np.plugin-test/src/react/support/filterFunctions.jsx @@ -19,7 +19,7 @@ type FilterCommandsProps = { * Filter plugin list down to only plugins and (optionally only commands) that include the filter list */ export function filterCommands({ pluginList, filter = '', categoryFilter = '', returnOnlyMatchingCommands = false }: FilterCommandsProps): Array { - console.log('Variables passed to filterCommands:', { pluginList, filter, returnOnlyMatchingCommands, categoryFilter }) + // console.log('Variables passed to filterCommands:', { pluginList, filter, returnOnlyMatchingCommands, categoryFilter }) const filters = filter ? filter .toLowerCase() From 0b8e119c31ab98b99ddd181b1439ea2a41fdebf9 Mon Sep 17 00:00:00 2001 From: David Wertheimer Date: Wed, 18 Oct 2023 21:28:40 -0700 Subject: [PATCH 2/2] np.Shared and plugin-test updates for styling --- np.Shared/CHANGELOG.md | 4 + np.Shared/plugin.json | 2 +- np.Shared/src/NPReactLocal.js | 2 +- np.plugin-test/plugin.json | 2 +- np.plugin-test/requiredFiles/css.plugin.css | 316 ++++++++++-------- np.plugin-test/src/pluginCommandsPopup.js | 2 + .../src/react/PluginListingPage.jsx | 21 +- 7 files changed, 195 insertions(+), 154 deletions(-) diff --git a/np.Shared/CHANGELOG.md b/np.Shared/CHANGELOG.md index 68e820df9..8db7c839b 100644 --- a/np.Shared/CHANGELOG.md +++ b/np.Shared/CHANGELOG.md @@ -2,6 +2,10 @@ See [Shared Plugin's README](https://github.com/NotePlan/plugins/blob/main/np.Shared/README.md) for details on this plugin. +## [0.4.6] - 2023-10-16 @dwertheimer + +- update to remove CSS from React Windows if wanted + ## [0.4.5] - 2023-10-16 @dwertheimer - updates to React tooling using ShowHTMLV2 etc. diff --git a/np.Shared/plugin.json b/np.Shared/plugin.json index e9663d35a..19589a341 100644 --- a/np.Shared/plugin.json +++ b/np.Shared/plugin.json @@ -3,7 +3,7 @@ "noteplan.minAppVersion": "3.8.0", "plugin.id": "np.Shared", "plugin.name": "🤝 Shared Resources", - "plugin.version": "0.4.5", + "plugin.version": "0.4.6", "plugin.description": "Shared resources for NotePlan plugins. (There are no commands for users to run directly.)", "plugin.author": "jgclark + dwertheimer", "plugin.dependencies": [], diff --git a/np.Shared/src/NPReactLocal.js b/np.Shared/src/NPReactLocal.js index 635e82af2..5b6a41934 100644 --- a/np.Shared/src/NPReactLocal.js +++ b/np.Shared/src/NPReactLocal.js @@ -165,7 +165,7 @@ export function openReactWindow(globalData: any = null, windowOptions?: HtmlWind const reactRootComponent = `` const generatedOptions = { - includeCSSAsJS: true, + includeCSSAsJS: windowOptions.includeCSSAsJS === false ? false : true, headerTags: `${[cssTags].join('\n')}${windowOptions.headerTags || ''}` /* needs to be a string */, preBodyScript: addStringOrArrayItems( [pluginToHTMLCommsBridge, ENV_MODE === 'development' ? ReactDevToolsImport : '', ENV_MODE === 'production' ? reactJSmin : reactJSDev, globalSharedDataScriptStr], diff --git a/np.plugin-test/plugin.json b/np.plugin-test/plugin.json index 31f853733..170dd56c6 100644 --- a/np.plugin-test/plugin.json +++ b/np.plugin-test/plugin.json @@ -6,7 +6,7 @@ "plugin.name": "🔌 Plugin Information & Tester", "plugin.description": "View Plugin Commands and Test that Plugins are working.", "plugin.author": "@dwertheimer", - "plugin.version": "1.4.0-beta5", + "plugin.version": "1.4.0-beta6", "plugin.lastUpdateInfo": "1.4.0-betaX: The beginning of a searchable plugin repository", "plugin.dependencies": [], "plugin.requiredFiles": [ diff --git a/np.plugin-test/requiredFiles/css.plugin.css b/np.plugin-test/requiredFiles/css.plugin.css index 7823b63a2..bcdf9b650 100644 --- a/np.plugin-test/requiredFiles/css.plugin.css +++ b/np.plugin-test/requiredFiles/css.plugin.css @@ -1,168 +1,200 @@ -/* Plugin-specific CSS */ -/* This file is loaded last to override any other CSS */ -/* It's a file rather than baked into the plugin to make fast editing/visual changes easier */ -body { } - -element.style { - margin-top: 0px; -} -h1, h2, h3, h4, h5, h6 { - margin-top: 0px; - font-weight: 500; - line-height: 1.2; -} -h3 { - background-color: beige; - font-size: 1.4rem; - margin-left: -10px; - padding-left: 10px; - padding-top: 5px; - padding-bottom: 5px; -} -.monospace { font-family: 'ui-monospace'; } -.monospaceData { font-family: 'ui-monospace'; font-size: 10px; white-space: pre-wrap } -/* loading spinner */ -.loading { - -webkit-animation: sk-scaleout 1.0s infinite ease-in-out; - animation: sk-scaleout 1.0s infinite ease-in-out; - border-radius: 100%; - height: 6em; - width: 6em; - background-color: black; - } - .loading-text { - padding-left: 20px; - } - html, body { - max-width: 100vw; - overscroll-behavior-y: none; - } +body { + font-family: 'Arial', sans-serif; + line-height: 1.5; + color: #333; + background: linear-gradient(to right, #ffffff, #f2f2f2); + overscroll-behavior-y: none; /* remove spring effect */ + /* background-color: #f4f4f4; */ +} - .container { - padding: 1rem; - display: flex; - flex-wrap: wrap; - height: 100vh; - width: 100vw; - max-width: 100vw; - padding-left: 0px; /* edge to edge */ - padding-right: 0px; - /* align-items: center; */ /* vertical */ - justify-content: center; /* horizontal */ - } +.sticky { + background: linear-gradient(to bottom, #f0b785,#ffffff); + /* background-color: #f0b785; */ + border-bottom: 2px solid #e0e0e0; /* increase border thickness for distinction */ + box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.1); /* add a subtle shadow for depth */ + padding: 15px 20px; /* increase padding for a better look */ + position: -webkit-sticky; + position: sticky; + top: 0; + z-index: 100; + display: flex; + justify-content: flex-start; + align-items: center; + margin-top: 0; +} - @keyframes sk-scaleout { - 0% { - -webkit-transform: scale(0); - transform: scale(0); - } - 100% { - -webkit-transform: scale(1.0); - opacity: 0; - transform: scale(1.0); - } - } +select, input[type="text"] { + height: 30px; + padding: 5px 10px; + background-color: #fff; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + border: 1px solid #ccc; + border-radius: 4px; + font-size: 14px; + margin-right: 10px; + box-sizing: border-box; + transition: border-color 0.3s ease; /* added transition for a smooth hover effect */ +} - @font-face { - font-family: "noteplanstate"; - src: url('../np.Shared/noteplanstate-edited.otf') format('truetype'); - } +select { + padding-right: 10px; /* To ensure the text doesn't overlap the dropdown arrow */ + background-repeat: no-repeat; + background-position: right center; + background-image: url(); +} - .noteplanstate { - font-family: "noteplanstate"; - } +select:hover, input[type="text"]:hover { + border-color: #666; + transform: scale(1.02); /* scales the element slightly on hover */ + transition: transform 0.3s ease; +} - .fa-icon { - font-family: "FontAwesome6Pro-Regular"; - } +select:focus, input[type="text"]:focus { + border-color: #007BFF; + box-shadow: 0 0 5px rgba(0,123,255,0.5); +} - .PluginListingPage { - padding-top: 25px; - } +.sticky:hover { + transition: transform 0.3s ease; +} - .plugin-section { - padding: 10px; - padding-top: 0px; - } +/* Modify select arrow styles for better visibility */ +select:after { + content: "▼"; + position: absolute; + top: -83%; + right: 6%; + bottom: 0; + font-size: 60%; + line-height: 30px; + padding: 0 10px; + background: #03498A; + color: rgb(255, 255, 255); + height: 40px; + pointer-events: none; + border-radius: 0 6px 6px 0; +} - .pluginName { - } +.PluginListingPage { + max-width: 1200px; + /* margin: 20px auto; */ + background-color: #fff; + box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); + padding: 20px; +} - .pluginVersion, .pluginBy, .install, .installed { - margin-left: 5px; - font-size: 12px; - } +.plugin-section { + margin-bottom: 25px; + padding-top: 5px; + padding-left: 20px; + padding-bottom: 10px; /* Increased padding for top and bottom */ + border-radius: 5px; + transition: background-color 0.3s; + border-top: 1px solid #e4e4e4; /* Top border */ + border-bottom: 1px solid #e4e4e4; /* Bottom border */ + box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05); /* subtle shadow for depth */ +} - .pluginAuthor { - margin-left: 2px; - font-size: 12px; - } +.plugin-section:hover { + background-color: #f9f9f9; +} - .installed { - color: green; - } - .install { - color: blue; - } +.pluginName { + font-size: 1.5rem; + font-weight: bold; + color: #444; +} - .updateIsAvailable { - color: orange; - } +.pluginVersion, .pluginBy, .install, .installed { + margin-left: 15px; + font-size: 0.9rem; + color: #777; +} + +.updateIsAvailable { + color: #e74c3c; + font-weight: bold; +} + +.pluginAuthor { + font-size: 1.0rem; + font-style: italic; + color: #555; +} + +table.w3-table { + width: 100%; + border-collapse: collapse; + margin-top: 15px; +} + +table.w3-table th, table.w3-table td { + border: 1px solid #e0e0e0; + padding: 8px 12px; +} + +table.w3-table thead { + background-color: #f2f2f2; +} - .lastUpdate { +.noPluginsFound { + text-align: center; + padding: 30px 0; + color: #999; +} + +.noPluginsFound h3 { + font-size: 1.6rem; +} + +.noPluginsFound a { + color: #3498db; + text-decoration: none; +} + +.noPluginsFound a:hover { + text-decoration: underline; +} + +/* Making the sticky header responsive */ + +@media (max-width: 768px) { + .sticky select, .sticky input[type="text"], .plugin-title, .plugin-description { + color: #333; /* Making text darker */ + font-weight: bold; /* Adding boldness for better visibility */ } - .aboutPlugin { + .PluginListingPage .command, .PluginListingPage .description { + padding: 5px 10px; /* Reducing the padding to decrease the gray box size */ + background-color: #f6f6f6; /* Slightly lighter gray for better contrast */ + } + .PluginListingPage .plugin-title, .PluginListingPage .plugin-description { + margin-top: 5px; /* Adjusting margin for better spacing */ + margin-bottom: 5px; /* Adjusting margin for better spacing */ } .sticky { - width: 100vw; - position: fixed; - top: 0; - z-index: 100; /* optional: to ensure the div stays on top of other elements */ - display: flex; - justify-content: flex-start; - padding-right: '20px; - flex-wrap: wrap; /* allow to wrap on phone */ + flex-direction: column; + align-items: flex-start; + padding-top: 10px; + padding-bottom: 5px; +} + + select, input[type="text"] { + width: 90%; + max-width: 90%; + margin-bottom: 5px; } + .PluginListingPage { + margin-top: 5px; /* Increased margin to ensure space for the extended sticky header */ + } - /** - * Responsive - * for phones - */ - - @media only screen and (min-width: 375px) - and (max-width: 767px) { - .container { - padding-left: 0px; /* edge to edge */ - padding-right: 0px; } - - h1 { - font-size: 1.5rem; - } - - .button { - padding: 0.5rem 1rem; - font-size: 0.875rem; - } - - .sticky { - position: fixed; - top: 0; - z-index: 100; - justify-content: flex-end; - padding-top: 5px; - padding-right: 40px; /* make room for X */ - flex-wrap: wrap; /* allow to wrap on phone */ - } - - .PluginListingPage { - margin-top: 75px; - } - } \ No newline at end of file +} \ No newline at end of file diff --git a/np.plugin-test/src/pluginCommandsPopup.js b/np.plugin-test/src/pluginCommandsPopup.js index abd17faf8..7c32d018b 100644 --- a/np.plugin-test/src/pluginCommandsPopup.js +++ b/np.plugin-test/src/pluginCommandsPopup.js @@ -119,6 +119,8 @@ export async function openReactPluginCommandsWindow() { savedFilename: `../../${pluginJson['plugin.id']}/savedOutput.html` /* for saving a debug version of the html file */, headerTags: cssTagsString, windowTitle: `Plugin Commands`, + includeCSSAsJS: false /* don't want CSS because we are doing this page non-themed */, + generalCSSIn: ' ' /* don't want CSS because we are doing this page non-themed, needs to be non '' */, } logDebug(`===== testReactWindow Calling React after ${timer(data.startTime || new Date())} =====`) logDebug(pluginJson, `testReactWindow invoking window. testReactWindow stopping here. It's all React from this point forward`) diff --git a/np.plugin-test/src/react/PluginListingPage.jsx b/np.plugin-test/src/react/PluginListingPage.jsx index 69cee3b48..0af52d267 100644 --- a/np.plugin-test/src/react/PluginListingPage.jsx +++ b/np.plugin-test/src/react/PluginListingPage.jsx @@ -8,7 +8,7 @@ declare var NP_THEME: { } import React, { useState } from 'react' -import { howDifferentAreTheseColors, getAltColor } from '../../../helpers/colors' +// import { howDifferentAreTheseColors, getAltColor } from '../../../helpers/colors' import { filterCommands } from './support/filterFunctions.jsx' /**************************************************************************************************************************** @@ -51,10 +51,10 @@ const Dropdown = ({ options, selectedValue, onValueChange }: DropdownProps) => { const categoryFilterOptions = [ { label: 'Show Plugins which contain...', value: '' }, { label: 'Tools for Events', value: 'event' }, - { label: 'Tools for Timeblocks and planning your day', value: 'time blocks,timeblocks' }, + { label: 'Tools for Timeblocks / Day Planning', value: 'time blocks,timeblocks,planning' }, { label: 'Tools for Projects', value: 'projects' }, - { label: 'Tools for tracking Habits', value: 'habits' }, - { label: 'Getting stats', value: 'stats,statistics' }, + { label: 'Tools for Tracking Habits', value: 'habits' }, + { label: 'Getting Stats', value: 'stats,statistics' }, ] const installationOptions = [ @@ -70,9 +70,10 @@ const viewOptions = [ { label: 'Commands Only', value: 'commandsOnly' }, ] -const colorDiff = howDifferentAreTheseColors(NP_THEME.editor.backgroundColor, NP_THEME.editor.altBackgroundColor) -logDebug(`PluginSection: howDifferentAreTheseColors background vs altBackground:${howDifferentAreTheseColors(NP_THEME.editor.backgroundColor, NP_THEME.editor.altBackgroundColor)}`) -const altColor = !colorDiff || colorDiff < 5 ? getAltColor(NP_THEME.editor.backgroundColor) : NP_THEME.editor.altBackgroundColor +// commenting out for now because I think we will make it static styling +// const colorDiff = howDifferentAreTheseColors(NP_THEME.editor.backgroundColor, NP_THEME.editor.altBackgroundColor) +// logDebug(`PluginSection: howDifferentAreTheseColors background vs altBackground:${howDifferentAreTheseColors(NP_THEME.editor.backgroundColor, NP_THEME.editor.altBackgroundColor)}`) +// const altColor = !colorDiff || colorDiff < 5 ? getAltColor(NP_THEME.editor.backgroundColor) : NP_THEME.editor.altBackgroundColor /** * HTML OUTPUT FOR EACH COMMAND @@ -120,7 +121,7 @@ function PluginSection({ plugin, viewOption, index }: PluginSectionProps): React const updateIsAvailableString = plugin.updateIsAvailable ? '(update available)' : '' const pluginSectionStyle = { - backgroundColor: index % 2 === 0 ? altColor : 'inherit', + /* backgroundColor: index % 2 === 0 ? altColor : 'inherit', */ } return (
@@ -199,7 +200,9 @@ function PluginListingPage(props: Props): React$Node { } }) const filteredPluginsAndCommands = filterCommands({ pluginList: filteredPlugins ?? [], filter: filter, categoryFilter: categoryFilter, returnOnlyMatchingCommands: true }) - const filterDivStyle = { backgroundColor: NP_THEME.editor.backgroundColor } + const filterDivStyle = { + /* backgroundColor: NP_THEME.editor.backgroundColor */ + } return ( <>