Switch to feather icons (#175)

Switch to feather icons
pull/177/head
Zef Hemel 2022-12-08 17:04:07 +01:00 committed by GitHub
parent 698a669e7a
commit 2d6a24dc49
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 53 additions and 48 deletions

View File

@ -1,6 +1,6 @@
import { isMacLike } from "../../common/util.ts"; import { isMacLike } from "../../common/util.ts";
import { FilterList } from "./filter.tsx"; import { FilterList } from "./filter.tsx";
import { faPersonRunning } from "../deps.ts"; import { TerminalIcon } from "../deps.ts";
import { AppCommand } from "../hooks/command.ts"; import { AppCommand } from "../hooks/command.ts";
import { FilterOption } from "../../common/types.ts"; import { FilterOption } from "../../common/types.ts";
@ -30,7 +30,7 @@ export function CommandPalette({
placeholder="Command" placeholder="Command"
options={options} options={options}
allowNew={false} allowNew={false}
icon={faPersonRunning} icon={TerminalIcon}
helpText="Start typing the command name to filter results, press <code>Return</code> to run." helpText="Start typing the command name to filter results, press <code>Return</code> to run."
onSelect={(opt) => { onSelect={(opt) => {
if (opt) { if (opt) {

View File

@ -1,8 +1,8 @@
import { useEffect, useRef, useState } from "../deps.ts"; import { useEffect, useRef, useState } from "../deps.ts";
import { FontAwesomeIcon } from "../deps.ts";
import type { IconDefinition } from "../deps.ts";
import { FilterOption } from "../../common/types.ts"; import { FilterOption } from "../../common/types.ts";
import fuzzysort from "https://esm.sh/fuzzysort@2.0.1"; import fuzzysort from "https://esm.sh/fuzzysort@2.0.1";
import { FunctionalComponent } from "https://esm.sh/v99/preact@10.11.3/src/index";
import { FeatherProps } from "https://esm.sh/v99/preact-feather@4.2.1/dist/types";
function magicSorter(a: FilterOption, b: FilterOption): number { function magicSorter(a: FilterOption, b: FilterOption): number {
if (a.orderId && b.orderId) { if (a.orderId && b.orderId) {
@ -59,7 +59,7 @@ export function FilterList({
allowNew = false, allowNew = false,
helpText = "", helpText = "",
completePrefix, completePrefix,
icon, icon: Icon,
newHint, newHint,
}: { }: {
placeholder: string; placeholder: string;
@ -71,7 +71,7 @@ export function FilterList({
completePrefix?: string; completePrefix?: string;
helpText: string; helpText: string;
newHint?: string; newHint?: string;
icon?: IconDefinition; icon?: FunctionalComponent<FeatherProps>;
}) { }) {
const searchBoxRef = useRef<HTMLInputElement>(null); const searchBoxRef = useRef<HTMLInputElement>(null);
const [text, setText] = useState(""); const [text, setText] = useState("");
@ -210,7 +210,7 @@ export function FilterList({
}} }}
> >
<span className="sb-icon"> <span className="sb-icon">
{icon && <FontAwesomeIcon icon={icon} />} {Icon && <Icon width={16} height={16} />}
</span> </span>
<span <span
className="sb-name" className="sb-name"

View File

@ -1,15 +1,8 @@
// import { Fragment, h } from "../deps.ts"; import { useRef } from "../deps.ts";
import { ComponentChildren } from "../deps.ts";
import { FontAwesomeIcon, useRef } from "../deps.ts";
import {
ComponentChildren,
IconDefinition,
useEffect,
useState,
} from "../deps.ts";
import { Notification } from "../types.ts"; import { Notification } from "../types.ts";
import { isMacLike } from "../../common/util.ts"; import { FunctionalComponent } from "https://esm.sh/v99/preact@10.11.1/src/index";
import { FeatherProps } from "https://esm.sh/v99/preact-feather@4.2.1/dist/types";
function prettyName(s: string | undefined): string { function prettyName(s: string | undefined): string {
if (!s) { if (!s) {
@ -19,7 +12,7 @@ function prettyName(s: string | undefined): string {
} }
export type ActionButton = { export type ActionButton = {
icon: IconDefinition; icon: FunctionalComponent<FeatherProps>;
description: string; description: string;
callback: () => void; callback: () => void;
}; };
@ -45,7 +38,6 @@ export function TopBar({
}) { }) {
// const [theme, setTheme] = useState<string>(localStorage.theme ?? "light"); // const [theme, setTheme] = useState<string>(localStorage.theme ?? "light");
const inputRef = useRef<HTMLInputElement>(null); const inputRef = useRef<HTMLInputElement>(null);
// const isMac = isMacLike();
return ( return (
<div id="sb-top"> <div id="sb-top">
@ -103,7 +95,7 @@ export function TopBar({
}} }}
title={actionButton.description} title={actionButton.description}
> >
<FontAwesomeIcon icon={actionButton.icon} /> <actionButton.icon size={18} />
</button> </button>
))} ))}
</div> </div>

View File

@ -13,9 +13,13 @@ export {
useState, useState,
} from "https://esm.sh/preact@10.11.1/hooks"; } from "https://esm.sh/preact@10.11.1/hooks";
export { FontAwesomeIcon } from "https://esm.sh/@aduh95/preact-fontawesome@0.1.5?external=@fortawesome/fontawesome-common-types"; export {
export { faPersonRunning } from "https://esm.sh/@fortawesome/free-solid-svg-icons@6.2.0"; Book as BookIcon,
export type { IconDefinition } from "https://esm.sh/@fortawesome/free-solid-svg-icons@6.2.0"; Home as HomeIcon,
Moon as MoonIcon,
Sun as SunIcon,
Terminal as TerminalIcon,
} from "https://esm.sh/preact-feather@4.2.1";
// Y collab // Y collab
export * as Y from "yjs"; export * as Y from "yjs";

View File

@ -1,20 +1,16 @@
// Third party web dependencies // Third party web dependencies
import { import {
BookIcon,
HomeIcon,
MoonIcon,
preactRender, preactRender,
SunIcon,
TerminalIcon,
useEffect, useEffect,
useReducer, useReducer,
yUndoManagerKeymap, yUndoManagerKeymap,
} from "./deps.ts"; } from "./deps.ts";
// Iconography
import {
faFolderTree,
faHome,
faMoon,
faRunning,
faSun,
} from "https://esm.sh/@fortawesome/free-solid-svg-icons@6.2.0";
// Third-party dependencies // Third-party dependencies
import { import {
autocompletion, autocompletion,
@ -123,7 +119,7 @@ export class Editor {
openPages = new Map<string, PageState>(); openPages = new Map<string, PageState>();
editorView?: EditorView; editorView?: EditorView;
viewState: AppViewState; viewState: AppViewState;
viewDispatch: React.Dispatch<Action>; viewDispatch: Function;
space: Space; space: Space;
pageNavigator: PathPageNavigator; pageNavigator: PathPageNavigator;
eventHook: EventHook; eventHook: EventHook;
@ -395,7 +391,7 @@ export class Editor {
options, options,
placeHolder, placeHolder,
helpText, helpText,
onSelect: (option) => { onSelect: (option: any) => {
this.viewDispatch({ type: "hide-filterbox" }); this.viewDispatch({ type: "hide-filterbox" });
this.focus(); this.focus();
resolve(option); resolve(option);
@ -856,28 +852,28 @@ export class Editor {
}} }}
actionButtons={[ actionButtons={[
{ {
icon: faHome, icon: HomeIcon,
description: `Go home (Alt-h)`, description: `Go home (Alt-h)`,
callback: () => { callback: () => {
editor.navigate(""); editor.navigate("");
}, },
}, },
{ {
icon: faFolderTree, icon: BookIcon,
description: `Open page (${isMacLike() ? "Cmd-k" : "Ctrl-k"})`, description: `Open page (${isMacLike() ? "Cmd-k" : "Ctrl-k"})`,
callback: () => { callback: () => {
dispatch({ type: "start-navigate" }); dispatch({ type: "start-navigate" });
}, },
}, },
{ {
icon: faRunning, icon: TerminalIcon,
description: `Run command (${isMacLike() ? "Cmd-/" : "Ctrl-/"})`, description: `Run command (${isMacLike() ? "Cmd-/" : "Ctrl-/"})`,
callback: () => { callback: () => {
dispatch({ type: "show-palette" }); dispatch({ type: "show-palette" });
}, },
}, },
{ {
icon: localStorage.theme === "dark" ? faSun : faMoon, icon: localStorage.theme === "dark" ? SunIcon : MoonIcon,
description: "Toggle dark mode", description: "Toggle dark mode",
callback: () => { callback: () => {
if (localStorage.theme === "dark") { if (localStorage.theme === "dark") {

View File

@ -44,9 +44,8 @@
.sb-icon { .sb-icon {
padding: 0 8px 0 5px; padding: 0 8px 0 5px;
} position: relative;
.sb-name { top: 3px;
padding-top: -3px;
} }
} }

View File

@ -50,12 +50,16 @@
} }
.sb-actions button { .sb-actions button {
border: 1px solid #7897d0; border: 0;
border-radius: 3px;
margin: 3px; margin: 3px;
font-size: 15px;
padding: 5px; padding: 5px;
background-color: #e6e6e6; background-color: transparent;
color: #292929;
cursor: pointer;
}
.sb-actions button:hover {
color: #0772be;
} }
/* Filter boxes */ /* Filter boxes */
@ -74,6 +78,7 @@
color: #000; color: #000;
} }
.sb-filter-box .sb-header input::placeholder { .sb-filter-box .sb-header input::placeholder {
color: rgb(199, 199, 199); color: rgb(199, 199, 199);
font-weight: normal; font-weight: normal;
@ -404,6 +409,14 @@ html[data-theme="dark"] {
color: rgb(200, 200, 200); color: rgb(200, 200, 200);
} }
.sb-actions button {
color: #adadad;
}
.sb-actions button:hover {
color: #37a1ed;
}
.sb-line-h1, .sb-line-h2, .sb-line-h3, .sb-line-h4 { .sb-line-h1, .sb-line-h2, .sb-line-h3, .sb-line-h4 {
color: #d1d1d1; color: #d1d1d1;
} }

View File

@ -7,6 +7,7 @@ release.
* Replaced the `--password` flag with `--user` taking a basic auth combination of username and password, e.g. `--user pete:1234`. Authentication now uses standard basic auth. This should fix attachments not working with password-protected setups. * Replaced the `--password` flag with `--user` taking a basic auth combination of username and password, e.g. `--user pete:1234`. Authentication now uses standard basic auth. This should fix attachments not working with password-protected setups.
* Added support for ~~strikethrough~~ syntax. * Added support for ~~strikethrough~~ syntax.
* New button icons, from [feather](https://feathericons.com/)
--- ---

View File

@ -31,8 +31,8 @@ On this site, everything is editable just none of it persists (the back-end is r
Dont just sit there, try it! Dont just sit there, try it!
* Click on the page picker (folder tree) icon at the top right, or hit `Cmd-k` (Mac) or `Ctrl-k` (Linux and Windows) to open the **page switcher**. Type the name of a non-existent page to create it (although it wont save in this environment). * Click on the page picker (book icon) icon at the top right, or hit `Cmd-k` (Mac) or `Ctrl-k` (Linux and Windows) to open the **page switcher**. Type the name of a non-existent page to create it (although it wont save in this environment).
* Click on the run button (top right) or hit `Cmd-/` (Mac) or `Ctrl-/` (Linux and Windows) to open the **command palette** (note that not all commands will work in this mode). * Click on the terminal button (top right) or hit `Cmd-/` (Mac) or `Ctrl-/` (Linux and Windows) to open the **command palette** (note that not all commands will work in this mode).
* Select some text and hit `Alt-m` to ==highlight== it, or `Cmd-b` (Mac) or `Ctrl-b` (Windows/Linux) to make it **bold**, or `Cmd-i` (Mac) or `Ctrl-i` (Windows/Linux) to make it _italic_. * Select some text and hit `Alt-m` to ==highlight== it, or `Cmd-b` (Mac) or `Ctrl-b` (Windows/Linux) to make it **bold**, or `Cmd-i` (Mac) or `Ctrl-i` (Windows/Linux) to make it _italic_.
* Click a link somewhere on this page to navigate there. * Click a link somewhere on this page to navigate there.
* Start typing `[[` somewhere to insert a page link (with completion). * Start typing `[[` somewhere to insert a page link (with completion).