Implement creation date only for markup annotations
The specification states that `CreationDate` is only available for markup annotations instead of for all annotation types. Moreover, popup annotations are not markup annotations according to the specification, so the creation date inheritance from the parent annotation is also removed there (note that only the modification date is used in e.g., the viewer).
This commit is contained in:
parent
cf07918ccb
commit
bc1eb49a77
@ -176,7 +176,6 @@ class Annotation {
|
|||||||
const dict = params.dict;
|
const dict = params.dict;
|
||||||
|
|
||||||
this.setContents(dict.get('Contents'));
|
this.setContents(dict.get('Contents'));
|
||||||
this.setCreationDate(dict.get('CreationDate'));
|
|
||||||
this.setModificationDate(dict.get('M'));
|
this.setModificationDate(dict.get('M'));
|
||||||
this.setFlags(dict.get('F'));
|
this.setFlags(dict.get('F'));
|
||||||
this.setRectangle(dict.getArray('Rect'));
|
this.setRectangle(dict.getArray('Rect'));
|
||||||
@ -190,7 +189,6 @@ class Annotation {
|
|||||||
borderStyle: this.borderStyle,
|
borderStyle: this.borderStyle,
|
||||||
color: this.color,
|
color: this.color,
|
||||||
contents: this.contents,
|
contents: this.contents,
|
||||||
creationDate: this.creationDate,
|
|
||||||
hasAppearance: !!this.appearance,
|
hasAppearance: !!this.appearance,
|
||||||
id: params.id,
|
id: params.id,
|
||||||
modificationDate: this.modificationDate,
|
modificationDate: this.modificationDate,
|
||||||
@ -257,18 +255,6 @@ class Annotation {
|
|||||||
this.contents = stringToPDFString(contents || '');
|
this.contents = stringToPDFString(contents || '');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the creation date.
|
|
||||||
*
|
|
||||||
* @public
|
|
||||||
* @memberof Annotation
|
|
||||||
* @param {string} creationDate - PDF date string that indicates when the
|
|
||||||
* annotation was originally created
|
|
||||||
*/
|
|
||||||
setCreationDate(creationDate) {
|
|
||||||
this.creationDate = isString(creationDate) ? creationDate : null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the modification date.
|
* Set the modification date.
|
||||||
*
|
*
|
||||||
@ -629,16 +615,31 @@ class AnnotationBorderStyle {
|
|||||||
class MarkupAnnotation extends Annotation {
|
class MarkupAnnotation extends Annotation {
|
||||||
constructor(parameters) {
|
constructor(parameters) {
|
||||||
super(parameters);
|
super(parameters);
|
||||||
const dict = parameters.dict;
|
|
||||||
|
|
||||||
|
const dict = parameters.dict;
|
||||||
if (!dict.has('C')) {
|
if (!dict.has('C')) {
|
||||||
// Fall back to the default background color.
|
// Fall back to the default background color.
|
||||||
this.data.color = null;
|
this.data.color = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.setCreationDate(dict.get('CreationDate'));
|
||||||
|
this.data.creationDate = this.creationDate;
|
||||||
|
|
||||||
this.data.hasPopup = dict.has('Popup');
|
this.data.hasPopup = dict.has('Popup');
|
||||||
this.data.title = stringToPDFString(dict.get('T') || '');
|
this.data.title = stringToPDFString(dict.get('T') || '');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the creation date.
|
||||||
|
*
|
||||||
|
* @public
|
||||||
|
* @memberof MarkupAnnotation
|
||||||
|
* @param {string} creationDate - PDF date string that indicates when the
|
||||||
|
* annotation was originally created
|
||||||
|
*/
|
||||||
|
setCreationDate(creationDate) {
|
||||||
|
this.creationDate = isString(creationDate) ? creationDate : null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class WidgetAnnotation extends Annotation {
|
class WidgetAnnotation extends Annotation {
|
||||||
@ -989,13 +990,6 @@ class PopupAnnotation extends Annotation {
|
|||||||
this.data.title = stringToPDFString(parentItem.get('T') || '');
|
this.data.title = stringToPDFString(parentItem.get('T') || '');
|
||||||
this.data.contents = stringToPDFString(parentItem.get('Contents') || '');
|
this.data.contents = stringToPDFString(parentItem.get('Contents') || '');
|
||||||
|
|
||||||
if (!parentItem.has('CreationDate')) {
|
|
||||||
this.data.creationDate = null;
|
|
||||||
} else {
|
|
||||||
this.setCreationDate(parentItem.get('CreationDate'));
|
|
||||||
this.data.creationDate = this.creationDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!parentItem.has('M')) {
|
if (!parentItem.has('M')) {
|
||||||
this.data.modificationDate = null;
|
this.data.modificationDate = null;
|
||||||
} else {
|
} else {
|
||||||
@ -1179,4 +1173,5 @@ export {
|
|||||||
Annotation,
|
Annotation,
|
||||||
AnnotationBorderStyle,
|
AnnotationBorderStyle,
|
||||||
AnnotationFactory,
|
AnnotationFactory,
|
||||||
|
MarkupAnnotation,
|
||||||
};
|
};
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Annotation, AnnotationBorderStyle, AnnotationFactory
|
Annotation, AnnotationBorderStyle, AnnotationFactory, MarkupAnnotation
|
||||||
} from '../../src/core/annotation';
|
} from '../../src/core/annotation';
|
||||||
import {
|
import {
|
||||||
AnnotationBorderStyleType, AnnotationFieldFlag, AnnotationFlag,
|
AnnotationBorderStyleType, AnnotationFieldFlag, AnnotationFlag,
|
||||||
@ -145,20 +145,6 @@ describe('annotation', function() {
|
|||||||
expect(annotation.contents).toEqual('');
|
expect(annotation.contents).toEqual('');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should set and get a valid creation date', function() {
|
|
||||||
const annotation = new Annotation({ dict, ref, });
|
|
||||||
annotation.setCreationDate('D:20190422');
|
|
||||||
|
|
||||||
expect(annotation.creationDate).toEqual('D:20190422');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should set and get an invalid creation date', function() {
|
|
||||||
const annotation = new Annotation({ dict, ref, });
|
|
||||||
annotation.setCreationDate(undefined);
|
|
||||||
|
|
||||||
expect(annotation.creationDate).toEqual(null);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should set and get a valid modification date', function() {
|
it('should set and get a valid modification date', function() {
|
||||||
const annotation = new Annotation({ dict, ref, });
|
const annotation = new Annotation({ dict, ref, });
|
||||||
annotation.setModificationDate('D:20190422');
|
annotation.setModificationDate('D:20190422');
|
||||||
@ -166,7 +152,7 @@ describe('annotation', function() {
|
|||||||
expect(annotation.modificationDate).toEqual('D:20190422');
|
expect(annotation.modificationDate).toEqual('D:20190422');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should set and get an invalid modification date', function() {
|
it('should not set and get an invalid modification date', function() {
|
||||||
const annotation = new Annotation({ dict, ref, });
|
const annotation = new Annotation({ dict, ref, });
|
||||||
annotation.setModificationDate(undefined);
|
annotation.setModificationDate(undefined);
|
||||||
|
|
||||||
@ -331,6 +317,34 @@ describe('annotation', function() {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('MarkupAnnotation', function() {
|
||||||
|
let dict, ref;
|
||||||
|
|
||||||
|
beforeAll(function(done) {
|
||||||
|
dict = new Dict();
|
||||||
|
ref = new Ref(1, 0);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
afterAll(function() {
|
||||||
|
dict = ref = null;
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should set and get a valid creation date', function() {
|
||||||
|
const markupAnnotation = new MarkupAnnotation({ dict, ref, });
|
||||||
|
markupAnnotation.setCreationDate('D:20190422');
|
||||||
|
|
||||||
|
expect(markupAnnotation.creationDate).toEqual('D:20190422');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not set and get an invalid creation date', function() {
|
||||||
|
const markupAnnotation = new MarkupAnnotation({ dict, ref, });
|
||||||
|
markupAnnotation.setCreationDate(undefined);
|
||||||
|
|
||||||
|
expect(markupAnnotation.creationDate).toEqual(null);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('LinkAnnotation', function() {
|
describe('LinkAnnotation', function() {
|
||||||
it('should correctly parse a URI action', function(done) {
|
it('should correctly parse a URI action', function(done) {
|
||||||
const actionDict = new Dict();
|
const actionDict = new Dict();
|
||||||
@ -1446,7 +1460,6 @@ describe('annotation', function() {
|
|||||||
const parentDict = new Dict();
|
const parentDict = new Dict();
|
||||||
parentDict.set('Type', Name.get('Annot'));
|
parentDict.set('Type', Name.get('Annot'));
|
||||||
parentDict.set('Subtype', Name.get('Text'));
|
parentDict.set('Subtype', Name.get('Text'));
|
||||||
parentDict.set('CreationDate', 'D:20190422');
|
|
||||||
parentDict.set('M', 'D:20190423');
|
parentDict.set('M', 'D:20190423');
|
||||||
parentDict.set('C', [0, 0, 1]);
|
parentDict.set('C', [0, 0, 1]);
|
||||||
|
|
||||||
@ -1463,7 +1476,6 @@ describe('annotation', function() {
|
|||||||
AnnotationFactory.create(xref, popupRef, pdfManagerMock,
|
AnnotationFactory.create(xref, popupRef, pdfManagerMock,
|
||||||
idFactoryMock).then(({ data, viewable, }) => {
|
idFactoryMock).then(({ data, viewable, }) => {
|
||||||
expect(data.annotationType).toEqual(AnnotationType.POPUP);
|
expect(data.annotationType).toEqual(AnnotationType.POPUP);
|
||||||
expect(data.creationDate).toEqual('D:20190422');
|
|
||||||
expect(data.modificationDate).toEqual('D:20190423');
|
expect(data.modificationDate).toEqual('D:20190423');
|
||||||
expect(data.color).toEqual(new Uint8ClampedArray([0, 0, 255]));
|
expect(data.color).toEqual(new Uint8ClampedArray([0, 0, 255]));
|
||||||
done();
|
done();
|
||||||
@ -1488,7 +1500,6 @@ describe('annotation', function() {
|
|||||||
AnnotationFactory.create(xref, popupRef, pdfManagerMock,
|
AnnotationFactory.create(xref, popupRef, pdfManagerMock,
|
||||||
idFactoryMock).then(({ data, viewable, }) => {
|
idFactoryMock).then(({ data, viewable, }) => {
|
||||||
expect(data.annotationType).toEqual(AnnotationType.POPUP);
|
expect(data.annotationType).toEqual(AnnotationType.POPUP);
|
||||||
expect(data.creationDate).toEqual(null);
|
|
||||||
expect(data.modificationDate).toEqual(null);
|
expect(data.modificationDate).toEqual(null);
|
||||||
expect(data.color).toEqual(null);
|
expect(data.color).toEqual(null);
|
||||||
done();
|
done();
|
||||||
|
Loading…
Reference in New Issue
Block a user