mirror of
https://github.com/loro-dev/loro.git
synced 2025-01-23 05:24:51 +00:00
108 lines
2.7 KiB
TypeScript
108 lines
2.7 KiB
TypeScript
import { describe, expect, it } from "vitest";
|
||
import { Delta, Loro, setPanicHook } from "../src";
|
||
import { setDebug } from "loro-wasm";
|
||
|
||
setPanicHook();
|
||
|
||
describe("richtext", () => {
|
||
it("mark", () => {
|
||
const doc = new Loro();
|
||
const text = doc.getText("text");
|
||
text.insert(0, "Hello World!");
|
||
text.mark({ start: 0, end: 5 }, "bold", true);
|
||
expect(text.toDelta()).toStrictEqual([
|
||
{
|
||
insert: "Hello",
|
||
attributes: {
|
||
bold: true,
|
||
},
|
||
},
|
||
{
|
||
insert: " World!",
|
||
},
|
||
] as Delta<string>[]);
|
||
});
|
||
|
||
it("insert after emoji", () => {
|
||
const doc = new Loro();
|
||
const text = doc.getText("text");
|
||
text.insert(0, "👨👩👦");
|
||
text.insert(8, "a");
|
||
expect(text.toString()).toBe("👨👩👦a");
|
||
});
|
||
|
||
it("emit event correctly", () => {
|
||
const doc = new Loro();
|
||
const text = doc.getText("text");
|
||
text.subscribe(doc, (event) => {
|
||
if (event.diff.type == "text") {
|
||
expect(event.diff.diff).toStrictEqual([
|
||
{
|
||
insert: "Hello",
|
||
attributes: {
|
||
bold: true,
|
||
},
|
||
},
|
||
{
|
||
insert: " World!",
|
||
},
|
||
] as Delta<string>[]);
|
||
}
|
||
});
|
||
text.insert(0, "Hello World!");
|
||
text.mark({ start: 0, end: 5 }, "bold", true);
|
||
});
|
||
|
||
it("emit event from merging doc correctly", async () => {
|
||
const doc = new Loro();
|
||
const text = doc.getText("text");
|
||
let called = false;
|
||
text.subscribe(doc, (event) => {
|
||
if (event.diff.type == "text") {
|
||
called = true;
|
||
expect(event.diff.diff).toStrictEqual([
|
||
{
|
||
insert: "Hello",
|
||
attributes: {
|
||
bold: true,
|
||
},
|
||
},
|
||
{
|
||
insert: " World!",
|
||
},
|
||
] as Delta<string>[]);
|
||
}
|
||
});
|
||
|
||
const docB = new Loro();
|
||
const textB = docB.getText("text");
|
||
textB.insert(0, "Hello World!");
|
||
textB.mark({ start: 0, end: 5 }, "bold", true);
|
||
doc.import(docB.exportFrom());
|
||
await new Promise((r) => setTimeout(r, 1));
|
||
expect(called).toBeTruthy();
|
||
});
|
||
|
||
it("Delete emoji", async () => {
|
||
const doc = new Loro();
|
||
const text = doc.getText("text");
|
||
text.insert(0, "012345👨👩👦6789");
|
||
doc.commit();
|
||
text.mark({ start: 0, end: 18 }, "bold", true);
|
||
doc.commit();
|
||
expect(text.toDelta()).toStrictEqual([
|
||
{
|
||
insert: "012345👨👩👦6789",
|
||
attributes: { bold: true },
|
||
},
|
||
]);
|
||
text.delete(6, 8);
|
||
doc.commit();
|
||
expect(text.toDelta()).toStrictEqual([
|
||
{
|
||
insert: "0123456789",
|
||
attributes: { bold: true },
|
||
},
|
||
]);
|
||
});
|
||
});
|