2023-11-02 06:20:34 +00:00
|
|
|
|
|
|
|
|
|
import { describe, expect, it } from "vitest";
|
|
|
|
|
import {
|
|
|
|
|
Delta,
|
|
|
|
|
Loro,
|
|
|
|
|
setPanicHook,
|
|
|
|
|
} from "../src";
|
2023-11-05 08:13:40 +00:00
|
|
|
|
import { setDebug } from "loro-wasm";
|
2023-11-02 06:20:34 +00:00
|
|
|
|
|
|
|
|
|
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>[])
|
|
|
|
|
})
|
|
|
|
|
|
2023-11-04 04:24:05 +00:00
|
|
|
|
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")
|
|
|
|
|
})
|
|
|
|
|
|
2023-11-02 06:20:34 +00:00
|
|
|
|
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", () => {
|
|
|
|
|
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());
|
|
|
|
|
expect(called).toBeTruthy();
|
|
|
|
|
})
|
2023-11-05 08:13:40 +00:00
|
|
|
|
|
|
|
|
|
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 }
|
|
|
|
|
}]);
|
|
|
|
|
});
|
|
|
|
|
|
2023-11-02 06:20:34 +00:00
|
|
|
|
})
|