Annotations - Avoid empty value in text field when storage contains something for it (bug 1719148)

- it aims to fix https://bugzilla.mozilla.org/show_bug.cgi?id=1719148;
  - JS can set a property for a non-rendered annotation using the annotationStorage but the other unset default properties must be used when the annotation is finally rendered;
  - so this patch just adds the properties already set in the annotationStorage to the default value.
This commit is contained in:
Calixte Denizet 2021-09-18 14:55:38 +02:00
parent 7082ff9bf8
commit eb762ad624
2 changed files with 24 additions and 1 deletions

View File

@ -42,7 +42,12 @@ class AnnotationStorage {
* @returns {Object} * @returns {Object}
*/ */
getValue(key, defaultValue) { getValue(key, defaultValue) {
return this._storage.get(key) ?? defaultValue; const value = this._storage.get(key);
if (value === undefined) {
return defaultValue;
}
return Object.assign(defaultValue, value);
} }
/** /**

View File

@ -35,6 +35,24 @@ describe("AnnotationStorage", function () {
}).value; }).value;
expect(value).toEqual("hello world"); expect(value).toEqual("hello world");
}); });
it("should get set values and default ones in the annotation storage", function () {
const annotationStorage = new AnnotationStorage();
annotationStorage.setValue("123A", {
value: "hello world",
hello: "world",
});
const result = annotationStorage.getValue("123A", {
value: "an other string",
world: "hello",
});
expect(result).toEqual({
value: "hello world",
hello: "world",
world: "hello",
});
});
}); });
describe("SetValue", function () { describe("SetValue", function () {