Fix onboarding and cloud pages appearing in queries
parent
d23846cdbf
commit
a53ebbd2e1
|
@ -141,8 +141,8 @@ export class Space extends EventEmitter<SpaceEvents>
|
||||||
return this.spacePrimitives.invokeFunction(plug, env, name, args);
|
return this.spacePrimitives.invokeFunction(plug, env, name, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
listPages(): Set<PageMeta> {
|
listPages(): PageMeta[] {
|
||||||
return new Set(this.pageMetaCache.values());
|
return [...new Set(this.pageMetaCache.values())];
|
||||||
}
|
}
|
||||||
|
|
||||||
async listPlugs(): Promise<string[]> {
|
async listPlugs(): Promise<string[]> {
|
||||||
|
@ -254,7 +254,10 @@ export class Space extends EventEmitter<SpaceEvents>
|
||||||
}
|
}
|
||||||
|
|
||||||
private metaCacher(name: string, meta: PageMeta): PageMeta {
|
private metaCacher(name: string, meta: PageMeta): PageMeta {
|
||||||
this.pageMetaCache.set(name, meta);
|
if (meta.lastModified !== 0) {
|
||||||
|
// Don't cache metadata for pages with a 0 lastModified timestamp (usualy dynamically generated pages)
|
||||||
|
this.pageMetaCache.set(name, meta);
|
||||||
|
}
|
||||||
return meta;
|
return meta;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,7 @@ import { FileMeta as PlugFileMeta } from "../../plug-api/plugos-syscall/types.ts
|
||||||
export default (space: Space): SysCallMapping => {
|
export default (space: Space): SysCallMapping => {
|
||||||
return {
|
return {
|
||||||
"space.listPages": (): PageMeta[] => {
|
"space.listPages": (): PageMeta[] => {
|
||||||
return [...space.listPages()];
|
return space.listPages();
|
||||||
},
|
},
|
||||||
"space.readPage": async (
|
"space.readPage": async (
|
||||||
_ctx,
|
_ctx,
|
||||||
|
|
|
@ -65,9 +65,9 @@ export async function ensureAndLoadSettings(
|
||||||
settings.indexPage,
|
settings.indexPage,
|
||||||
`Hello! And welcome to your brand new SilverBullet space!
|
`Hello! And welcome to your brand new SilverBullet space!
|
||||||
|
|
||||||
<!-- #include [[💭 silverbullet.md/Getting Started]] -->
|
<!-- #use [[💭 silverbullet.md/Getting Started]] -->
|
||||||
Loading some onboarding content for you (but doing so does require a working internet connection)...
|
Loading some onboarding content for you (but doing so does require a working internet connection)...
|
||||||
<!-- /include -->`,
|
<!-- /use -->`,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -350,7 +350,7 @@
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
CURRENT_PROJECT_VERSION = 2;
|
CURRENT_PROJECT_VERSION = 4;
|
||||||
DEVELOPMENT_TEAM = Z92J6WM6X8;
|
DEVELOPMENT_TEAM = Z92J6WM6X8;
|
||||||
INFOPLIST_FILE = App/Info.plist;
|
INFOPLIST_FILE = App/Info.plist;
|
||||||
INFOPLIST_KEY_CFBundleDisplayName = SilverBullet;
|
INFOPLIST_KEY_CFBundleDisplayName = SilverBullet;
|
||||||
|
@ -376,7 +376,7 @@
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
CURRENT_PROJECT_VERSION = 2;
|
CURRENT_PROJECT_VERSION = 4;
|
||||||
DEVELOPMENT_TEAM = Z92J6WM6X8;
|
DEVELOPMENT_TEAM = Z92J6WM6X8;
|
||||||
INFOPLIST_FILE = App/Info.plist;
|
INFOPLIST_FILE = App/Info.plist;
|
||||||
INFOPLIST_KEY_CFBundleDisplayName = SilverBullet;
|
INFOPLIST_KEY_CFBundleDisplayName = SilverBullet;
|
||||||
|
|
|
@ -7,14 +7,14 @@ import type { FileMeta } from "../../common/types.ts";
|
||||||
import { parseMarkdown } from "$sb/silverbullet-syscall/markdown.ts";
|
import { parseMarkdown } from "$sb/silverbullet-syscall/markdown.ts";
|
||||||
import { base64EncodedDataUrl } from "../../plugos/asset_bundle/base64.ts";
|
import { base64EncodedDataUrl } from "../../plugos/asset_bundle/base64.ts";
|
||||||
|
|
||||||
const pagePrefix = "💭 ";
|
export const cloudPrefix = "💭 ";
|
||||||
|
|
||||||
export async function readFileCloud(
|
export async function readFileCloud(
|
||||||
name: string,
|
name: string,
|
||||||
encoding: FileEncoding,
|
encoding: FileEncoding,
|
||||||
): Promise<{ data: FileData; meta: FileMeta } | undefined> {
|
): Promise<{ data: FileData; meta: FileMeta } | undefined> {
|
||||||
const originalUrl = name.substring(
|
const originalUrl = name.substring(
|
||||||
pagePrefix.length,
|
cloudPrefix.length,
|
||||||
name.length - ".md".length,
|
name.length - ".md".length,
|
||||||
);
|
);
|
||||||
let url = originalUrl;
|
let url = originalUrl;
|
||||||
|
@ -29,7 +29,7 @@ export async function readFileCloud(
|
||||||
let text = "";
|
let text = "";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const r = await fetch(`${url}.md`);
|
const r = await fetch(`${encodeURI(url)}.md`);
|
||||||
text = await r.text();
|
text = await r.text();
|
||||||
if (!r.ok) {
|
if (!r.ok) {
|
||||||
text = `ERROR: ${text}`;
|
text = `ERROR: ${text}`;
|
||||||
|
@ -40,7 +40,7 @@ export async function readFileCloud(
|
||||||
}
|
}
|
||||||
text = await translateLinksWithPrefix(
|
text = await translateLinksWithPrefix(
|
||||||
text,
|
text,
|
||||||
`${pagePrefix}${originalUrl.split("/")[0]}/`,
|
`${cloudPrefix}${originalUrl.split("/")[0]}/`,
|
||||||
);
|
);
|
||||||
return {
|
return {
|
||||||
data: encoding === "utf8" ? text : base64EncodedDataUrl(
|
data: encoding === "utf8" ? text : base64EncodedDataUrl(
|
||||||
|
@ -65,7 +65,7 @@ async function translateLinksWithPrefix(
|
||||||
replaceNodesMatching(tree, (tree) => {
|
replaceNodesMatching(tree, (tree) => {
|
||||||
if (tree.type === "WikiLinkPage") {
|
if (tree.type === "WikiLinkPage") {
|
||||||
// Add the prefix in the link text
|
// Add the prefix in the link text
|
||||||
if (!tree.children![0].text!.startsWith(pagePrefix)) {
|
if (!tree.children![0].text!.startsWith(cloudPrefix)) {
|
||||||
// Only for links that aren't already cloud links
|
// Only for links that aren't already cloud links
|
||||||
tree.children![0].text = prefix + tree.children![0].text;
|
tree.children![0].text = prefix + tree.children![0].text;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,14 @@
|
||||||
An attempt at documenting the changes/new features introduced in each
|
An attempt at documenting the changes/new features introduced in each
|
||||||
release.
|
release.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 0.2.8
|
||||||
|
* [[Sync]] should now be usable and is documented
|
||||||
|
* Windows and Mac [[Desktop]] apps now have proper icons (only Linux left)
|
||||||
|
* [[Mobile]] app for iOS in TestFlight
|
||||||
|
* New onboarding index page when you create a new space, pulling content from [[Getting Started]].
|
||||||
|
* Various bug fixes
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,42 @@
|
||||||
There is a “native” mobile app under development (the code [lives here](https://github.com/silverbulletmd/silverbullet/tree/main/mobile)). Initially, it will be offered for iOS (and iPadOS), but soon thereafter an Android version is planned.
|
The SilverBullet mobile app is an (almost) full version of SilverBullet running on your mobile device. It keeps its content (pages, attachments) locally, so you have access to it even without an Internet connection. You can install [[🔌 Plugs]], and they run locally as well.
|
||||||
|
|
||||||
The mobile app is built using [CapacitorJS](https://capacitorjs.com/) and therefore cross-platform. It essentially wraps the existing web app, and swaps out the server calls to local on-device APIs, such as using the local filesystem to store content (pages and attachments), uses a local SQLite database, and it runs all [[🔌 Plugs]] code on device. It is capable of fully running offline.
|
The mobile app is still in beta and available via TestFlight, and initially only available for iOS. The [Android version is coming next](https://github.com/silverbulletmd/silverbullet/issues/310).
|
||||||
|
![](ios-app-screenshot.png)
|
||||||
|
|
||||||
|
[**Join the TestFlight iOS SilverBullet beta**](https://testflight.apple.com/join/QqYAVZcr)
|
||||||
|
|
||||||
|
## PWA vs “native” app
|
||||||
|
On mobile you essentially have two ways to run SilverBullet:
|
||||||
|
|
||||||
|
1. Run the [[Server]] and access it via your mobile browser
|
||||||
|
2. Run the [[Mobile]] app and either maintain a separate space there, or use [[Sync]] to synchronize your content with a [[Server]].
|
||||||
|
|
||||||
|
There are a few advantages to using the [[Server]] on a mobile browser:
|
||||||
|
|
||||||
|
1. No [[Sync]] required. Content is kept in one place (which you can backup separately).
|
||||||
|
2. You can access one SilverBullet from any browser on any device, so Android too.
|
||||||
|
3. Any “heavy lifting” (like indexing pages) happens on the server, not the device.
|
||||||
|
|
||||||
|
There are also disadvantages:
|
||||||
|
|
||||||
|
1. You need a network connection to the [[Server]] at all times.
|
||||||
|
2. PWAs don’t always work fully reliably on all devices (specifically iOS)
|
||||||
|
|
||||||
|
|
||||||
|
The advantages of using the “native” mobile app:
|
||||||
|
|
||||||
|
1. Fully offline capable: no need for an Internet connection, except for [[Sync]] or any [[🔌 Plugs]] that require one
|
||||||
|
2. Faster, local performance
|
||||||
|
|
||||||
|
The disadvantages:
|
||||||
|
|
||||||
|
1. Likely you’ll need to use [[Sync]] to synchronize your content with other devices, this comes with any drawbacks of sync: conflicts, forgetting to sync content etc.
|
||||||
|
|
||||||
|
## Implementation
|
||||||
|
The reason we’re quoting “native” app consistently, is that the mobile app is built using [CapacitorJS](https://capacitorjs.com/). A lightweight wrapper around a WebView exposing various native APIs, such as access to the local file system, SQLite database etc.
|
||||||
|
|
||||||
The mobile app keeps its files in the sandboxed file system of the SilverBullet app. These files are accessible via iOS file sharing capability (when you plug in your device via USB, you can see all files, copy new ones and remove them), and are included with the regular iOS backups.
|
The mobile app keeps its files in the sandboxed file system of the SilverBullet app. These files are accessible via iOS file sharing capability (when you plug in your device via USB, you can see all files, copy new ones and remove them), and are included with the regular iOS backups.
|
||||||
|
|
||||||
In the very likely scenario you’d like to synchronize with your space e.g. on [[Desktop]] or a [[Server]], you’ll need to use [[Sync]].
|
## Caveats
|
||||||
|
* Shell commands: on [[Server]] and [[Desktop]] [[🔌 Plugs]] have the ability to run shell commands, the [[🔌 Git]] plug uses this functionality for instance. This does not work on mobile.
|
||||||
|
* Local file system access (outside the space): on [[Server]] and [[Desktop]], plugs can get access to your local file system _outside_ the location where your space content is stored. This is used, for instance for [[🔌 Markdown]] sharing as well as `file:` URLs in your [[PLUGS]] file. This is not supported on mobile.
|
Binary file not shown.
After Width: | Height: | Size: 101 KiB |
Loading…
Reference in New Issue