Clean up filter boxes
parent
ca796b9c95
commit
5705eb4cbe
|
@ -89,7 +89,7 @@ export function FilterList({
|
||||||
function updateFilter(originalPhrase: string) {
|
function updateFilter(originalPhrase: string) {
|
||||||
let foundExactMatch = false;
|
let foundExactMatch = false;
|
||||||
let results = fuzzySorter(originalPhrase, options);
|
let results = fuzzySorter(originalPhrase, options);
|
||||||
if (allowNew && !foundExactMatch) {
|
if (allowNew && !foundExactMatch && originalPhrase) {
|
||||||
results.push({
|
results.push({
|
||||||
name: originalPhrase,
|
name: originalPhrase,
|
||||||
hint: newHint,
|
hint: newHint,
|
||||||
|
@ -121,6 +121,8 @@ export function FilterList({
|
||||||
};
|
};
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
|
let exiting = false;
|
||||||
|
|
||||||
const returnEl = (
|
const returnEl = (
|
||||||
<div className="filter-wrapper">
|
<div className="filter-wrapper">
|
||||||
<div className="filter-box">
|
<div className="filter-box">
|
||||||
|
@ -133,7 +135,9 @@ export function FilterList({
|
||||||
ref={searchBoxRef}
|
ref={searchBoxRef}
|
||||||
onChange={filterUpdate}
|
onChange={filterUpdate}
|
||||||
onBlur={(e) => {
|
onBlur={(e) => {
|
||||||
searchBoxRef.current!.focus();
|
if (!exiting) {
|
||||||
|
searchBoxRef.current!.focus();
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
onKeyDown={(e: React.KeyboardEvent) => {
|
onKeyDown={(e: React.KeyboardEvent) => {
|
||||||
// console.log("Key up", e);
|
// console.log("Key up", e);
|
||||||
|
@ -150,10 +154,24 @@ export function FilterList({
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
case "Enter":
|
case "Enter":
|
||||||
|
exiting = true;
|
||||||
onSelect(matchingOptions[selectedOption]);
|
onSelect(matchingOptions[selectedOption]);
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
break;
|
break;
|
||||||
|
case "PageUp":
|
||||||
|
setSelectionOption(Math.max(0, selectedOption - 5));
|
||||||
|
break;
|
||||||
|
case "PageDown":
|
||||||
|
setSelectionOption(Math.max(0, selectedOption + 5));
|
||||||
|
break;
|
||||||
|
case "Home":
|
||||||
|
setSelectionOption(0);
|
||||||
|
break;
|
||||||
|
case "End":
|
||||||
|
setSelectionOption(matchingOptions.length - 1);
|
||||||
|
break;
|
||||||
case "Escape":
|
case "Escape":
|
||||||
|
exiting = true;
|
||||||
onSelect(undefined);
|
onSelect(undefined);
|
||||||
break;
|
break;
|
||||||
case " ":
|
case " ":
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
top: 0;
|
top: 0;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
max-height: 290px;
|
max-height: 290px;
|
||||||
overflow: hide;
|
// overflow: hide;
|
||||||
z-index: 100;
|
z-index: 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,7 +19,8 @@
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
border: rgb(103, 103, 103) 1px solid;
|
border: rgb(103, 103, 103) 1px solid;
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
|
box-shadow: rgba(0, 0, 0, 0.35) 0px 20px 20px;
|
||||||
|
overflow: hidden;
|
||||||
margin: 10px;
|
margin: 10px;
|
||||||
|
|
||||||
.header {
|
.header {
|
||||||
|
@ -55,7 +56,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.result-list {
|
.result-list {
|
||||||
max-height: 200px;
|
max-height: 216px;
|
||||||
overflow-y: scroll;
|
overflow-y: scroll;
|
||||||
|
|
||||||
.icon {
|
.icon {
|
||||||
|
@ -70,11 +71,14 @@
|
||||||
.selected-option {
|
.selected-option {
|
||||||
padding: 8px;
|
padding: 8px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
height: 20px;
|
||||||
|
line-height: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.selected-option {
|
.selected-option {
|
||||||
background-color: var(--highlight-color);
|
background-color: var(--highlight-color);
|
||||||
color: #eee;
|
color: #eee;
|
||||||
|
// border-radius: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.option .hint,
|
.option .hint,
|
||||||
|
|
|
@ -5,4 +5,10 @@ An attempt at documenting of the changes/new features introduced in each (pre) r
|
||||||
* Plugs can implement their own unfurlers by responding to the `unfurl:options` event (see the [Twitter plug](https://github.com/silverbulletmd/silverbullet-twitter) for an example).
|
* Plugs can implement their own unfurlers by responding to the `unfurl:options` event (see the [Twitter plug](https://github.com/silverbulletmd/silverbullet-twitter) for an example).
|
||||||
* Core implements only one unfurl option: “Extract title” which pulls the `<title>` tag from the linked URL and replaces it with a `[bla](URL)` style link.
|
* Core implements only one unfurl option: “Extract title” which pulls the `<title>` tag from the linked URL and replaces it with a `[bla](URL)` style link.
|
||||||
* Removed status bar: to further simplify the SB UI. You can still pull up the same stat on demand with the `Stats: Show` command.
|
* Removed status bar: to further simplify the SB UI. You can still pull up the same stat on demand with the `Stats: Show` command.
|
||||||
|
* The page switcher is now maintaining its ordering based on, in order:
|
||||||
|
1. Last opened pages (in current session)
|
||||||
|
2. Last modified date (on disk)
|
||||||
|
3. Everything else
|
||||||
|
4. The currently open page (at the bottom)
|
||||||
|
* Filter boxes (used for the page switching and command palette among other things) now also support PgUp, PgDown, Home and End and have some visual glitches fixed as well.
|
||||||
* Reverted exposing an empty `window` object to sandboxes running in workers and node.js (introduced in 0.0.28)
|
* Reverted exposing an empty `window` object to sandboxes running in workers and node.js (introduced in 0.0.28)
|
||||||
|
|
Loading…
Reference in New Issue