|
|
|
@ -106,6 +106,8 @@ AnnotationFactory.prototype = /** @lends AnnotationFactory.prototype */ {
@@ -106,6 +106,8 @@ AnnotationFactory.prototype = /** @lends AnnotationFactory.prototype */ {
|
|
|
|
|
switch (fieldType) { |
|
|
|
|
case 'Tx': |
|
|
|
|
return new TextWidgetAnnotation(parameters); |
|
|
|
|
case 'Ch': |
|
|
|
|
return new ChoiceWidgetAnnotation(parameters); |
|
|
|
|
} |
|
|
|
|
warn('Unimplemented widget field type "' + fieldType + '", ' + |
|
|
|
|
'falling back to base field type.'); |
|
|
|
@ -619,8 +621,8 @@ var WidgetAnnotation = (function WidgetAnnotationClosure() {
@@ -619,8 +621,8 @@ var WidgetAnnotation = (function WidgetAnnotationClosure() {
|
|
|
|
|
var data = this.data; |
|
|
|
|
|
|
|
|
|
data.annotationType = AnnotationType.WIDGET; |
|
|
|
|
data.fieldValue = stringToPDFString( |
|
|
|
|
Util.getInheritableProperty(dict, 'V') || ''); |
|
|
|
|
data.fieldValue = Util.getInheritableProperty(dict, 'V', |
|
|
|
|
/* getArray = */ true); |
|
|
|
|
data.alternativeText = stringToPDFString(dict.get('TU') || ''); |
|
|
|
|
data.defaultAppearance = Util.getInheritableProperty(dict, 'DA') || ''; |
|
|
|
|
var fieldType = Util.getInheritableProperty(dict, 'FT'); |
|
|
|
@ -632,6 +634,8 @@ var WidgetAnnotation = (function WidgetAnnotationClosure() {
@@ -632,6 +634,8 @@ var WidgetAnnotation = (function WidgetAnnotationClosure() {
|
|
|
|
|
data.fieldFlags = 0; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
data.readOnly = this.hasFieldFlag(AnnotationFieldFlag.READONLY); |
|
|
|
|
|
|
|
|
|
// Hide signatures because we cannot validate them.
|
|
|
|
|
if (data.fieldType === 'Sig') { |
|
|
|
|
this.setFlags(AnnotationFlag.HIDDEN); |
|
|
|
@ -693,6 +697,9 @@ var TextWidgetAnnotation = (function TextWidgetAnnotationClosure() {
@@ -693,6 +697,9 @@ var TextWidgetAnnotation = (function TextWidgetAnnotationClosure() {
|
|
|
|
|
function TextWidgetAnnotation(params) { |
|
|
|
|
WidgetAnnotation.call(this, params); |
|
|
|
|
|
|
|
|
|
// The field value is always a string.
|
|
|
|
|
this.data.fieldValue = stringToPDFString(this.data.fieldValue || ''); |
|
|
|
|
|
|
|
|
|
// Determine the alignment of text in the field.
|
|
|
|
|
var alignment = Util.getInheritableProperty(params.dict, 'Q'); |
|
|
|
|
if (!isInt(alignment) || alignment < 0 || alignment > 2) { |
|
|
|
@ -708,7 +715,6 @@ var TextWidgetAnnotation = (function TextWidgetAnnotationClosure() {
@@ -708,7 +715,6 @@ var TextWidgetAnnotation = (function TextWidgetAnnotationClosure() {
|
|
|
|
|
this.data.maxLen = maximumLength; |
|
|
|
|
|
|
|
|
|
// Process field flags for the display layer.
|
|
|
|
|
this.data.readOnly = this.hasFieldFlag(AnnotationFieldFlag.READONLY); |
|
|
|
|
this.data.multiLine = this.hasFieldFlag(AnnotationFieldFlag.MULTILINE); |
|
|
|
|
this.data.comb = this.hasFieldFlag(AnnotationFieldFlag.COMB) && |
|
|
|
|
!this.hasFieldFlag(AnnotationFieldFlag.MULTILINE) && |
|
|
|
@ -752,6 +758,62 @@ var TextWidgetAnnotation = (function TextWidgetAnnotationClosure() {
@@ -752,6 +758,62 @@ var TextWidgetAnnotation = (function TextWidgetAnnotationClosure() {
|
|
|
|
|
return TextWidgetAnnotation; |
|
|
|
|
})(); |
|
|
|
|
|
|
|
|
|
var ChoiceWidgetAnnotation = (function ChoiceWidgetAnnotationClosure() { |
|
|
|
|
function ChoiceWidgetAnnotation(params) { |
|
|
|
|
WidgetAnnotation.call(this, params); |
|
|
|
|
|
|
|
|
|
// Determine the options. The options array may consist of strings or
|
|
|
|
|
// arrays. If the array consists of arrays, then the first element of
|
|
|
|
|
// each array is the export value and the second element of each array is
|
|
|
|
|
// the display value. If the array consists of strings, then these
|
|
|
|
|
// represent both the export and display value. In this case, we convert
|
|
|
|
|
// it to an array of arrays as well for convenience in the display layer.
|
|
|
|
|
this.data.options = []; |
|
|
|
|
|
|
|
|
|
var options = params.dict.getArray('Opt'); |
|
|
|
|
if (isArray(options)) { |
|
|
|
|
for (var i = 0, ii = options.length; i < ii; i++) { |
|
|
|
|
var option = options[i]; |
|
|
|
|
|
|
|
|
|
this.data.options[i] = { |
|
|
|
|
exportValue: isArray(option) ? option[0] : option, |
|
|
|
|
displayValue: isArray(option) ? option[1] : option, |
|
|
|
|
}; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Determine the field value. In this case, it may be a string or an
|
|
|
|
|
// array of strings. For convenience in the display layer, convert the
|
|
|
|
|
// string to an array of one string as well.
|
|
|
|
|
if (!isArray(this.data.fieldValue)) { |
|
|
|
|
this.data.fieldValue = [this.data.fieldValue]; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Process field flags for the display layer.
|
|
|
|
|
this.data.combo = this.hasFieldFlag(AnnotationFieldFlag.COMBO); |
|
|
|
|
this.data.multiSelect = this.hasFieldFlag(AnnotationFieldFlag.MULTISELECT); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
Util.inherit(ChoiceWidgetAnnotation, WidgetAnnotation, { |
|
|
|
|
getOperatorList: |
|
|
|
|
function ChoiceWidgetAnnotation_getOperatorList(evaluator, task, |
|
|
|
|
renderForms) { |
|
|
|
|
var operatorList = new OperatorList(); |
|
|
|
|
|
|
|
|
|
// Do not render form elements on the canvas when interactive forms are
|
|
|
|
|
// enabled. The display layer is responsible for rendering them instead.
|
|
|
|
|
if (renderForms) { |
|
|
|
|
return Promise.resolve(operatorList); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
return Annotation.prototype.getOperatorList.call(this, evaluator, task, |
|
|
|
|
renderForms); |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
return ChoiceWidgetAnnotation; |
|
|
|
|
})(); |
|
|
|
|
|
|
|
|
|
var TextAnnotation = (function TextAnnotationClosure() { |
|
|
|
|
var DEFAULT_ICON_SIZE = 22; // px
|
|
|
|
|
|
|
|
|
|