mirror of
https://github.com/mozilla/pdf.js.git
synced 2025-04-22 16:18:08 +02:00
Merge pull request #18419 from calixteman/reuse_old_dict_when_updating
[Editor] Update the freetext annotation dictionary instead of creating a new one when updating an existing freetext
This commit is contained in:
commit
9b1b5ff7e7
3 changed files with 67 additions and 6 deletions
|
@ -1711,18 +1711,28 @@ class MarkupAnnotation extends Annotation {
|
|||
}
|
||||
|
||||
static async createNewAnnotation(xref, annotation, dependencies, params) {
|
||||
const annotationRef = (annotation.ref ||= xref.getNewTemporaryRef());
|
||||
let oldAnnotation;
|
||||
if (annotation.ref) {
|
||||
oldAnnotation = (await xref.fetchIfRefAsync(annotation.ref)).clone();
|
||||
} else {
|
||||
annotation.ref = xref.getNewTemporaryRef();
|
||||
}
|
||||
|
||||
const annotationRef = annotation.ref;
|
||||
const ap = await this.createNewAppearanceStream(annotation, xref, params);
|
||||
const buffer = [];
|
||||
let annotationDict;
|
||||
|
||||
if (ap) {
|
||||
const apRef = xref.getNewTemporaryRef();
|
||||
annotationDict = this.createNewDict(annotation, xref, { apRef });
|
||||
annotationDict = this.createNewDict(annotation, xref, {
|
||||
apRef,
|
||||
oldAnnotation,
|
||||
});
|
||||
await writeObject(apRef, ap, buffer, xref);
|
||||
dependencies.push({ ref: apRef, data: buffer.join("") });
|
||||
} else {
|
||||
annotationDict = this.createNewDict(annotation, xref, {});
|
||||
annotationDict = this.createNewDict(annotation, xref, { oldAnnotation });
|
||||
}
|
||||
if (Number.isInteger(annotation.parentTreeId)) {
|
||||
annotationDict.set("StructParent", annotation.parentTreeId);
|
||||
|
@ -3826,12 +3836,19 @@ class FreeTextAnnotation extends MarkupAnnotation {
|
|||
return this._hasAppearance;
|
||||
}
|
||||
|
||||
static createNewDict(annotation, xref, { apRef, ap }) {
|
||||
static createNewDict(annotation, xref, { apRef, ap, oldAnnotation }) {
|
||||
const { color, fontSize, rect, rotation, user, value } = annotation;
|
||||
const freetext = new Dict(xref);
|
||||
const freetext = oldAnnotation || new Dict(xref);
|
||||
freetext.set("Type", Name.get("Annot"));
|
||||
freetext.set("Subtype", Name.get("FreeText"));
|
||||
freetext.set("CreationDate", `D:${getModificationDate()}`);
|
||||
if (oldAnnotation) {
|
||||
freetext.set("M", `D:${getModificationDate()}`);
|
||||
// TODO: We should try to generate a new RC from the content we've.
|
||||
// For now we can just remove it to avoid any issues.
|
||||
freetext.delete("RC");
|
||||
} else {
|
||||
freetext.set("CreationDate", `D:${getModificationDate()}`);
|
||||
}
|
||||
freetext.set("Rect", rect);
|
||||
const da = `/Helv ${fontSize} Tf ${getPdfColor(color, /* isFill */ true)}`;
|
||||
freetext.set("DA", da);
|
||||
|
|
|
@ -270,6 +270,10 @@ class Dict {
|
|||
}
|
||||
return dict;
|
||||
}
|
||||
|
||||
delete(key) {
|
||||
delete this._map[key];
|
||||
}
|
||||
}
|
||||
|
||||
class Ref {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue