mirror of
https://github.com/zadam/trilium.git
synced 2025-11-02 19:36:12 +01:00
chore(react/note_title): bring back styles
This commit is contained in:
@@ -9,36 +9,6 @@ import shortcutService from "../services/shortcuts.js";
|
|||||||
import utils from "../services/utils.js";
|
import utils from "../services/utils.js";
|
||||||
import type FNote from "../entities/fnote.js";
|
import type FNote from "../entities/fnote.js";
|
||||||
|
|
||||||
const TPL = /*html*/`
|
|
||||||
<div class="note-title-widget">
|
|
||||||
<style>
|
|
||||||
.note-title-widget {
|
|
||||||
flex-grow: 1000;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.note-title-widget input.note-title {
|
|
||||||
font-size: 110%;
|
|
||||||
border: 0;
|
|
||||||
margin: 2px 0px;
|
|
||||||
min-width: 5em;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
body.mobile .note-title-widget input.note-title {
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
body.desktop .note-title-widget input.note-title {
|
|
||||||
font-size: 180%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.note-title-widget input.note-title.protected {
|
|
||||||
text-shadow: 4px 4px 4px var(--muted-text-color);
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</div>`;
|
|
||||||
|
|
||||||
export default class NoteTitleWidget extends NoteContextAwareWidget {
|
export default class NoteTitleWidget extends NoteContextAwareWidget {
|
||||||
|
|
||||||
private $noteTitle!: JQuery<HTMLElement>;
|
private $noteTitle!: JQuery<HTMLElement>;
|
||||||
@@ -48,10 +18,6 @@ export default class NoteTitleWidget extends NoteContextAwareWidget {
|
|||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
this.spacedUpdate = new SpacedUpdate(async () => {
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
this.deleteNoteOnEscape = false;
|
this.deleteNoteOnEscape = false;
|
||||||
|
|
||||||
appContext.addBeforeUnloadListener(this);
|
appContext.addBeforeUnloadListener(this);
|
||||||
@@ -92,10 +58,6 @@ export default class NoteTitleWidget extends NoteContextAwareWidget {
|
|||||||
this.setProtectedStatus(note);
|
this.setProtectedStatus(note);
|
||||||
}
|
}
|
||||||
|
|
||||||
setProtectedStatus(note: FNote) {
|
|
||||||
this.$noteTitle.toggleClass("protected", !!note.isProtected);
|
|
||||||
}
|
|
||||||
|
|
||||||
async beforeNoteSwitchEvent({ noteContext }: EventData<"beforeNoteSwitch">) {
|
async beforeNoteSwitchEvent({ noteContext }: EventData<"beforeNoteSwitch">) {
|
||||||
if (this.isNoteContext(noteContext.ntxId)) {
|
if (this.isNoteContext(noteContext.ntxId)) {
|
||||||
await this.spacedUpdate.updateNowIfNecessary();
|
await this.spacedUpdate.updateNowIfNecessary();
|
||||||
@@ -122,17 +84,6 @@ export default class NoteTitleWidget extends NoteContextAwareWidget {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
entitiesReloadedEvent({ loadResults }: EventData<"entitiesReloaded">) {
|
|
||||||
if (loadResults.isNoteReloaded(this.noteId) && this.note) {
|
|
||||||
// not updating the title specifically since the synced title might be older than what the user is currently typing
|
|
||||||
this.setProtectedStatus(this.note);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (loadResults.isNoteReloaded(this.noteId, this.componentId)) {
|
|
||||||
this.refresh();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
beforeUnloadEvent() {
|
beforeUnloadEvent() {
|
||||||
return this.spacedUpdate.isAllSavedAndTriggerUpdate();
|
return this.spacedUpdate.isAllSavedAndTriggerUpdate();
|
||||||
}
|
}
|
||||||
|
|||||||
24
apps/client/src/widgets/note_title.css
Normal file
24
apps/client/src/widgets/note_title.css
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
.note-title-widget {
|
||||||
|
flex-grow: 1000;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note-title-widget input.note-title {
|
||||||
|
font-size: 110%;
|
||||||
|
border: 0;
|
||||||
|
margin: 2px 0px;
|
||||||
|
min-width: 5em;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note-title-widget input.note-title.protected {
|
||||||
|
text-shadow: 4px 4px 4px var(--muted-text-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
body.mobile .note-title-widget input.note-title {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
body.desktop .note-title-widget input.note-title {
|
||||||
|
font-size: 180%;
|
||||||
|
}
|
||||||
@@ -1,14 +1,17 @@
|
|||||||
import { useEffect, useRef, useState } from "preact/hooks";
|
import { useEffect, useRef, useState } from "preact/hooks";
|
||||||
import { t } from "../services/i18n";
|
import { t } from "../services/i18n";
|
||||||
import FormTextBox from "./react/FormTextBox";
|
import FormTextBox from "./react/FormTextBox";
|
||||||
import { useNoteContext, useSpacedUpdate } from "./react/hooks";
|
import { useNoteContext, useSpacedUpdate, useTriliumEventBeta } from "./react/hooks";
|
||||||
import protected_session_holder from "../services/protected_session_holder";
|
import protected_session_holder from "../services/protected_session_holder";
|
||||||
import server from "../services/server";
|
import server from "../services/server";
|
||||||
|
import "./note_title.css";
|
||||||
|
|
||||||
export default function NoteTitleWidget() {
|
export default function NoteTitleWidget() {
|
||||||
const { note, noteId, componentId } = useNoteContext();
|
const { note, noteId, componentId } = useNoteContext();
|
||||||
const [ title, setTitle ] = useState(note?.title);
|
const [ title, setTitle ] = useState(note?.title);
|
||||||
useEffect(() => setTitle(note?.title), [ note?.title ]);
|
const [ isProtected, setProtected ] = useState(note?.isProtected);
|
||||||
|
useEffect(() => setTitle(note?.title), [ note?.noteId ]);
|
||||||
|
useEffect(() => setProtected(note?.isProtected), [ note?.isProtected ]);
|
||||||
|
|
||||||
const spacedUpdate = useSpacedUpdate(async () => {
|
const spacedUpdate = useSpacedUpdate(async () => {
|
||||||
if (!note) {
|
if (!note) {
|
||||||
@@ -18,19 +21,28 @@ export default function NoteTitleWidget() {
|
|||||||
await server.put<void>(`notes/${noteId}/title`, { title: title }, componentId);
|
await server.put<void>(`notes/${noteId}/title`, { title: title }, componentId);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
useTriliumEventBeta("entitiesReloaded", ({ loadResults }) => {
|
||||||
|
if (loadResults.isNoteReloaded(noteId) && note) {
|
||||||
|
setProtected(note.isProtected);
|
||||||
|
}
|
||||||
|
if (loadResults.isNoteReloaded(noteId, componentId)) {
|
||||||
|
setTitle(note?.title);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<div className="note-title-widget">
|
||||||
<FormTextBox
|
<FormTextBox
|
||||||
autocomplete="off"
|
autocomplete="off"
|
||||||
currentValue={title}
|
currentValue={title}
|
||||||
placeholder={t("note_title.placeholder")}
|
placeholder={t("note_title.placeholder")}
|
||||||
className="note-title"
|
className={`note-title ${isProtected ? "protected" : ""}`}
|
||||||
tabIndex={100}
|
tabIndex={100}
|
||||||
onChange={(newValue) => {
|
onChange={(newValue) => {
|
||||||
setTitle(newValue);
|
setTitle(newValue);
|
||||||
spacedUpdate.scheduleUpdate();
|
spacedUpdate.scheduleUpdate();
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
</>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user