mirror of
https://github.com/vrtmrz/obsidian-livesync.git
synced 2026-05-15 20:11:17 +00:00
74 lines
3.5 KiB
TypeScript
74 lines
3.5 KiB
TypeScript
import { App } from "@/deps.ts";
|
|
import { Logger } from "@lib/common/logger";
|
|
import { LOG_LEVEL_NOTICE, LOG_LEVEL_INFO } from "@lib/common/types";
|
|
import type { LiveSyncTrysteroReplicator } from "@/lib/src/replication/trystero/LiveSyncTrysteroReplicator";
|
|
import { P2POpenReplicationModal } from "./P2POpenReplicationModal";
|
|
|
|
/**
|
|
* Creates an openReplicationUI factory for Obsidian environments.
|
|
* Returns a per-replicator closure that opens the P2P Replication modal
|
|
* and performs bidirectional sync (pull then push on success).
|
|
*
|
|
* Usage:
|
|
* const factory = createOpenReplicationUI(app);
|
|
* useP2PReplicatorFeature(core, factory);
|
|
*/
|
|
export function createOpenReplicationUI(
|
|
app: App
|
|
): (replicator: LiveSyncTrysteroReplicator) => (showResult: boolean) => Promise<boolean | void> {
|
|
return (replicator: LiveSyncTrysteroReplicator) =>
|
|
(showResult: boolean): Promise<boolean | void> => {
|
|
const logLevel = showResult ? LOG_LEVEL_NOTICE : LOG_LEVEL_INFO;
|
|
return new Promise<boolean | void>((resolve) => {
|
|
const modal = new P2POpenReplicationModal(
|
|
app,
|
|
replicator,
|
|
{
|
|
onSync: async (peerId: string) => {
|
|
try {
|
|
// pull (replicateFrom) first; push only on success
|
|
const pullResult = await replicator.replicateFrom(peerId, showResult);
|
|
if (pullResult?.ok) {
|
|
const pushResult = await replicator.requestSynchroniseToPeer(peerId);
|
|
resolve(pushResult?.ok ?? true);
|
|
} else {
|
|
resolve(false);
|
|
}
|
|
} catch (e) {
|
|
Logger(
|
|
`Error in bidirectional sync with ${peerId}: ${e instanceof Error ? e.message : String(e)}`,
|
|
logLevel
|
|
);
|
|
resolve(false);
|
|
}
|
|
},
|
|
onSyncAndClose: async (peerId: string) => {
|
|
try {
|
|
const pullResult = await replicator.replicateFrom(peerId, showResult);
|
|
if (pullResult?.ok) {
|
|
const pushResult = await replicator.requestSynchroniseToPeer(peerId);
|
|
if (pushResult?.ok ?? true) {
|
|
await replicator.close();
|
|
resolve(true);
|
|
} else {
|
|
resolve(false);
|
|
}
|
|
} else {
|
|
resolve(false);
|
|
}
|
|
} catch (e) {
|
|
Logger(
|
|
`Error in bidirectional sync with ${peerId}: ${e instanceof Error ? e.message : String(e)}`,
|
|
logLevel
|
|
);
|
|
resolve(false);
|
|
}
|
|
},
|
|
},
|
|
showResult
|
|
);
|
|
modal.open();
|
|
});
|
|
};
|
|
}
|