XFA - Fix auto-sized fields (bug 1722030)
- In order to better compute text fields size, use line height with no gaps (and consequently guessed height for text are slightly better in general). - Fix default background color in fields.
This commit is contained in:
		
							parent
							
								
									336a74a0e5
								
							
						
					
					
						commit
						76d882b560
					
				| @ -81,7 +81,7 @@ const CalibriBoldFactors = [ | |||||||
|   0.95794, 0.95794, 0.82616, 0.86513, 0.85162, 0.85162, 0.85162, 0.85162, |   0.95794, 0.95794, 0.82616, 0.86513, 0.85162, 0.85162, 0.85162, 0.85162, | ||||||
|   0.91133, 0.85162, 0.79492, 0.79492, 0.79492, 0.79492, 0.91133, 0.79109, |   0.91133, 0.85162, 0.79492, 0.79492, 0.79492, 0.79492, 0.91133, 0.79109, | ||||||
| ]; | ]; | ||||||
| const CalibriBoldLineHeight = 1.2207; | const CalibriBoldMetrics = { lineHeight: 1.2207, lineGap: 0.2207 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | ||||||
| // metrics as calibriz.ttf.
 | // metrics as calibriz.ttf.
 | ||||||
| @ -153,7 +153,7 @@ const CalibriBoldItalicFactors = [ | |||||||
|   0.84548, 0.84548, 0.91133, 0.84548, 0.79492, 0.79492, 0.79492, 0.79492, |   0.84548, 0.84548, 0.91133, 0.84548, 0.79492, 0.79492, 0.79492, 0.79492, | ||||||
|   0.91133, 0.74081, |   0.91133, 0.74081, | ||||||
| ]; | ]; | ||||||
| const CalibriBoldItalicLineHeight = 1.2207; | const CalibriBoldItalicMetrics = { lineHeight: 1.2207, lineGap: 0.2207 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Italic.ttf to have the same
 | // Factors to rescale LiberationSans-Italic.ttf to have the same
 | ||||||
| // metrics as calibrii.ttf.
 | // metrics as calibrii.ttf.
 | ||||||
| @ -223,7 +223,7 @@ const CalibriItalicFactors = [ | |||||||
|   0.84153, 0.89453, 0.89453, 0.89453, 0.89453, 0.91133, 0.89453, 0.79004, |   0.84153, 0.89453, 0.89453, 0.89453, 0.89453, 0.91133, 0.89453, 0.79004, | ||||||
|   0.79004, 0.79004, 0.79004, 0.91133, 0.75026, |   0.79004, 0.79004, 0.79004, 0.91133, 0.75026, | ||||||
| ]; | ]; | ||||||
| const CalibriItalicLineHeight = 1.2207; | const CalibriItalicMetrics = { lineHeight: 1.2207, lineGap: 0.2207 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Regular.ttf to have the same
 | // Factors to rescale LiberationSans-Regular.ttf to have the same
 | ||||||
| // metrics as calibri.ttf.
 | // metrics as calibri.ttf.
 | ||||||
| @ -294,15 +294,15 @@ const CalibriRegularFactors = [ | |||||||
|   0.83969, 0.90527, 0.90527, 0.90527, 0.90527, 0.91133, 0.90527, 0.79004, |   0.83969, 0.90527, 0.90527, 0.90527, 0.90527, 0.91133, 0.90527, 0.79004, | ||||||
|   0.79004, 0.79004, 0.79004, 0.91133, 0.78848, |   0.79004, 0.79004, 0.79004, 0.91133, 0.78848, | ||||||
| ]; | ]; | ||||||
| const CalibriRegularLineHeight = 1.2207; | const CalibriRegularMetrics = { lineHeight: 1.2207, lineGap: 0.2207 }; | ||||||
| 
 | 
 | ||||||
| export { | export { | ||||||
|   CalibriBoldFactors, |   CalibriBoldFactors, | ||||||
|   CalibriBoldItalicFactors, |   CalibriBoldItalicFactors, | ||||||
|   CalibriBoldItalicLineHeight, |   CalibriBoldItalicMetrics, | ||||||
|   CalibriBoldLineHeight, |   CalibriBoldMetrics, | ||||||
|   CalibriItalicFactors, |   CalibriItalicFactors, | ||||||
|   CalibriItalicLineHeight, |   CalibriItalicMetrics, | ||||||
|   CalibriRegularFactors, |   CalibriRegularFactors, | ||||||
|   CalibriRegularLineHeight, |   CalibriRegularMetrics, | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -3924,7 +3924,7 @@ class PartialEvaluator { | |||||||
|       const standardFontName = getXfaFontName(fontName.name); |       const standardFontName = getXfaFontName(fontName.name); | ||||||
|       if (standardFontName) { |       if (standardFontName) { | ||||||
|         cssFontInfo.fontFamily = `${cssFontInfo.fontFamily}-PdfJS-XFA`; |         cssFontInfo.fontFamily = `${cssFontInfo.fontFamily}-PdfJS-XFA`; | ||||||
|         cssFontInfo.lineHeight = standardFontName.lineHeight || null; |         cssFontInfo.metrics = standardFontName.metrics || null; | ||||||
|         glyphScaleFactors = standardFontName.factors || null; |         glyphScaleFactors = standardFontName.factors || null; | ||||||
|         fontFile = await this.fetchStandardFontData(standardFontName.name); |         fontFile = await this.fetchStandardFontData(standardFontName.name); | ||||||
|         isInternalFont = !!fontFile; |         isInternalFont = !!fontFile; | ||||||
|  | |||||||
| @ -2550,7 +2550,8 @@ class Font { | |||||||
|     this.lineGap = metricsOverride.lineGap / metricsOverride.unitsPerEm; |     this.lineGap = metricsOverride.lineGap / metricsOverride.unitsPerEm; | ||||||
| 
 | 
 | ||||||
|     if (this.cssFontInfo && this.cssFontInfo.lineHeight) { |     if (this.cssFontInfo && this.cssFontInfo.lineHeight) { | ||||||
|       this.lineHeight = this.cssFontInfo.lineHeight; |       this.lineHeight = this.cssFontInfo.metrics.lineHeight; | ||||||
|  |       this.lineGap = this.cssFontInfo.metrics.lineGap; | ||||||
|     } else { |     } else { | ||||||
|       this.lineHeight = this.ascent - this.descent + this.lineGap; |       this.lineHeight = this.ascent - this.descent + this.lineGap; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -94,7 +94,7 @@ const HelveticaBoldFactors = [ | |||||||
|   1.00022, 1.00022, 0.99973, 0.9993, 0.99973, 0.99973, 0.99973, 0.99973, |   1.00022, 1.00022, 0.99973, 0.9993, 0.99973, 0.99973, 0.99973, 0.99973, | ||||||
|   0.99973, 0.99973, 1, 1, 1, 1, 0.99973, 0.99902, |   0.99973, 0.99973, 1, 1, 1, 1, 0.99973, 0.99902, | ||||||
| ]; | ]; | ||||||
| const HelveticaBoldLineHeight = 1.2; | const HelveticaBoldMetrics = { lineHeight: 1.2, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | ||||||
| // metrics as NimbusSans-BoldItalic.otf.
 | // metrics as NimbusSans-BoldItalic.otf.
 | ||||||
| @ -177,7 +177,7 @@ const HelveticaBoldItalicFactors = [ | |||||||
|   0.99973, 1.00065, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 1, 1, |   0.99973, 1.00065, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 0.99973, 1, 1, | ||||||
|   1, 1, 0.99973, 1.00061, |   1, 1, 0.99973, 1.00061, | ||||||
| ]; | ]; | ||||||
| const HelveticaBoldItalicLineHeight = 1.35; | const HelveticaBoldItalicMetrics = { lineHeight: 1.35, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Italic.ttf to have the same
 | // Factors to rescale LiberationSans-Italic.ttf to have the same
 | ||||||
| // metrics as NimbusSans-Italic.otf.
 | // metrics as NimbusSans-Italic.otf.
 | ||||||
| @ -258,7 +258,7 @@ const HelveticaItalicFactors = [ | |||||||
|   0.99973, 0.99973, 1, 0.99977, 0.99977, 0.99977, 0.99977, 0.99977, 1, 1.0005, |   0.99973, 0.99973, 1, 0.99977, 0.99977, 0.99977, 0.99977, 0.99977, 1, 1.0005, | ||||||
|   1, 1, 1, 1, 0.99973, 1, 1, 1, 1, 1, 0.99973, 0.99918, |   1, 1, 1, 1, 0.99973, 1, 1, 1, 1, 1, 0.99973, 0.99918, | ||||||
| ]; | ]; | ||||||
| const HelveticaItalicLineHeight = 1.35; | const HelveticaItalicMetrics = { lineHeight: 1.35, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Regular.ttf to have the same
 | // Factors to rescale LiberationSans-Regular.ttf to have the same
 | ||||||
| // metrics as NimbusSans-Regular.otf.
 | // metrics as NimbusSans-Regular.otf.
 | ||||||
| @ -339,15 +339,15 @@ const HelveticaRegularFactors = [ | |||||||
|   0.99977, 0.99977, 0.99977, 1, 1.00055, 1, 1, 1, 1, 0.99973, 1, 1, 1, 1, 1, |   0.99977, 0.99977, 0.99977, 1, 1.00055, 1, 1, 1, 1, 0.99973, 1, 1, 1, 1, 1, | ||||||
|   0.99973, 1.00019, |   0.99973, 1.00019, | ||||||
| ]; | ]; | ||||||
| const HelveticaRegularLineHeight = 1.2; | const HelveticaRegularMetrics = { lineHeight: 1.2, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| export { | export { | ||||||
|   HelveticaBoldFactors, |   HelveticaBoldFactors, | ||||||
|   HelveticaBoldItalicFactors, |   HelveticaBoldItalicFactors, | ||||||
|   HelveticaBoldItalicLineHeight, |   HelveticaBoldItalicMetrics, | ||||||
|   HelveticaBoldLineHeight, |   HelveticaBoldMetrics, | ||||||
|   HelveticaItalicFactors, |   HelveticaItalicFactors, | ||||||
|   HelveticaItalicLineHeight, |   HelveticaItalicMetrics, | ||||||
|   HelveticaRegularFactors, |   HelveticaRegularFactors, | ||||||
|   HelveticaRegularLineHeight, |   HelveticaRegularMetrics, | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -77,7 +77,7 @@ const MyriadProBoldFactors = [ | |||||||
|   0.97579, 0.97579, 0.97579, 0.9332, 1.05993, 0.94039, 0.94039, 0.94039, |   0.97579, 0.97579, 0.97579, 0.9332, 1.05993, 0.94039, 0.94039, 0.94039, | ||||||
|   0.94039, 0.99793, 0.94039, 0.938, 0.938, 0.938, 0.938, 0.99793, 0.95776, |   0.94039, 0.99793, 0.94039, 0.938, 0.938, 0.938, 0.938, 0.99793, 0.95776, | ||||||
| ]; | ]; | ||||||
| const MyriadProBoldLineHeight = 1.2; | const MyriadProBoldMetrics = { lineHeight: 1.2, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | ||||||
| // metrics as MyriadPro-BoldIt.otf.
 | // metrics as MyriadPro-BoldIt.otf.
 | ||||||
| @ -144,7 +144,7 @@ const MyriadProBoldItalicFactors = [ | |||||||
|   0.89544, 1.0051, 0.89364, 0.89364, 0.89364, 0.89364, 0.97276, 0.89364, 0.9, |   0.89544, 1.0051, 0.89364, 0.89364, 0.89364, 0.89364, 0.97276, 0.89364, 0.9, | ||||||
|   0.9, 0.9, 0.9, 0.97276, 0.86842, |   0.9, 0.9, 0.9, 0.97276, 0.86842, | ||||||
| ]; | ]; | ||||||
| const MyriadProBoldItalicLineHeight = 1.2; | const MyriadProBoldItalicMetrics = { lineHeight: 1.2, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Italic.ttf to have the same
 | // Factors to rescale LiberationSans-Italic.ttf to have the same
 | ||||||
| // metrics as MyriadPro-It.otf.
 | // metrics as MyriadPro-It.otf.
 | ||||||
| @ -210,7 +210,7 @@ const MyriadProItalicFactors = [ | |||||||
|   0.979, 0.979, 0.979, 0.979, 0.882, 0.93559, 0.882, 0.882, 0.882, 0.882, |   0.979, 0.979, 0.979, 0.979, 0.882, 0.93559, 0.882, 0.882, 0.882, 0.882, | ||||||
|   0.88465, 0.882, 0.83, 0.83, 0.83, 0.83, 0.88465, 0.84596, |   0.88465, 0.882, 0.83, 0.83, 0.83, 0.83, 0.88465, 0.84596, | ||||||
| ]; | ]; | ||||||
| const MyriadProItalicLineHeight = 1.2; | const MyriadProItalicMetrics = { lineHeight: 1.2, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Regular.ttf to have the same
 | // Factors to rescale LiberationSans-Regular.ttf to have the same
 | ||||||
| // metrics as MyriadPro-Regular.otf.
 | // metrics as MyriadPro-Regular.otf.
 | ||||||
| @ -276,15 +276,15 @@ const MyriadProRegularFactors = [ | |||||||
|   1.01915, 0.926, 0.96705, 0.942, 0.942, 0.942, 0.942, 0.92241, 0.942, 0.856, |   1.01915, 0.926, 0.96705, 0.942, 0.942, 0.942, 0.942, 0.92241, 0.942, 0.856, | ||||||
|   0.856, 0.856, 0.856, 0.92241, 0.92761, |   0.856, 0.856, 0.856, 0.92241, 0.92761, | ||||||
| ]; | ]; | ||||||
| const MyriadProRegularLineHeight = 1.2; | const MyriadProRegularMetrics = { lineHeight: 1.2, lineGap: 0.2 }; | ||||||
| 
 | 
 | ||||||
| export { | export { | ||||||
|   MyriadProBoldFactors, |   MyriadProBoldFactors, | ||||||
|   MyriadProBoldItalicFactors, |   MyriadProBoldItalicFactors, | ||||||
|   MyriadProBoldItalicLineHeight, |   MyriadProBoldItalicMetrics, | ||||||
|   MyriadProBoldLineHeight, |   MyriadProBoldMetrics, | ||||||
|   MyriadProItalicFactors, |   MyriadProItalicFactors, | ||||||
|   MyriadProItalicLineHeight, |   MyriadProItalicMetrics, | ||||||
|   MyriadProRegularFactors, |   MyriadProRegularFactors, | ||||||
|   MyriadProRegularLineHeight, |   MyriadProRegularMetrics, | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -81,7 +81,7 @@ const SegoeuiBoldFactors = [ | |||||||
|   1.02511, 0.99298, 1.07237, 0.96752, 0.96752, 0.96752, 0.96752, 1.03424, |   1.02511, 0.99298, 1.07237, 0.96752, 0.96752, 0.96752, 0.96752, 1.03424, | ||||||
|   0.96752, 0.95801, 0.95801, 0.95801, 0.95801, 1.03424, 1.0106, |   0.96752, 0.95801, 0.95801, 0.95801, 0.95801, 1.03424, 1.0106, | ||||||
| ]; | ]; | ||||||
| const SegoeuiBoldLineHeight = 1.33008; | const SegoeuiBoldMetrics = { lineHeight: 1.33008, lineGap: 0 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | // Factors to rescale LiberationSans-BoldItalic.ttf to have the same
 | ||||||
| // metrics as segoeuiz.ttf.
 | // metrics as segoeuiz.ttf.
 | ||||||
| @ -152,7 +152,7 @@ const SegoeuiBoldItalicFactors = [ | |||||||
|   0.96752, 0.96752, 1.036, 0.96752, 0.97168, 0.97168, 0.97168, 0.97168, 1.036, |   0.96752, 0.96752, 1.036, 0.96752, 0.97168, 0.97168, 0.97168, 0.97168, 1.036, | ||||||
|   0.95134, |   0.95134, | ||||||
| ]; | ]; | ||||||
| const SegoeuiBoldItalicLineHeight = 1.33008; | const SegoeuiBoldItalicMetrics = { lineHeight: 1.33008, lineGap: 0 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Italic.ttf to have the same
 | // Factors to rescale LiberationSans-Italic.ttf to have the same
 | ||||||
| // metrics as segoeuii.ttf.
 | // metrics as segoeuii.ttf.
 | ||||||
| @ -223,7 +223,7 @@ const SegoeuiItalicFactors = [ | |||||||
|   0.96777, 0.96777, 0.96777, 0.96927, 0.96777, 0.9043, 0.9043, 0.9043, 0.9043, |   0.96777, 0.96777, 0.96777, 0.96927, 0.96777, 0.9043, 0.9043, 0.9043, 0.9043, | ||||||
|   0.96927, 0.95364, |   0.96927, 0.95364, | ||||||
| ]; | ]; | ||||||
| const SegoeuiItalicLineHeight = 1.33008; | const SegoeuiItalicMetrics = { lineHeight: 1.33008, lineGap: 0 }; | ||||||
| 
 | 
 | ||||||
| // Factors to rescale LiberationSans-Regular.ttf to have the same
 | // Factors to rescale LiberationSans-Regular.ttf to have the same
 | ||||||
| // metrics as segoeui.ttf.
 | // metrics as segoeui.ttf.
 | ||||||
| @ -294,15 +294,15 @@ const SegoeuiRegularFactors = [ | |||||||
|   1.00068, 0.91797, 0.99346, 0.96777, 0.96777, 0.96777, 0.96777, 0.96927, |   1.00068, 0.91797, 0.99346, 0.96777, 0.96777, 0.96777, 0.96777, 0.96927, | ||||||
|   0.96777, 0.9043, 0.9043, 0.9043, 0.9043, 0.96927, 1.00221, |   0.96777, 0.9043, 0.9043, 0.9043, 0.9043, 0.96927, 1.00221, | ||||||
| ]; | ]; | ||||||
| const SegoeuiRegularLineHeight = 1.33008; | const SegoeuiRegularMetrics = { lineHeight: 1.33008, lineGap: 0 }; | ||||||
| 
 | 
 | ||||||
| export { | export { | ||||||
|   SegoeuiBoldFactors, |   SegoeuiBoldFactors, | ||||||
|   SegoeuiBoldItalicFactors, |   SegoeuiBoldItalicFactors, | ||||||
|   SegoeuiBoldItalicLineHeight, |   SegoeuiBoldItalicMetrics, | ||||||
|   SegoeuiBoldLineHeight, |   SegoeuiBoldMetrics, | ||||||
|   SegoeuiItalicFactors, |   SegoeuiItalicFactors, | ||||||
|   SegoeuiItalicLineHeight, |   SegoeuiItalicMetrics, | ||||||
|   SegoeuiRegularFactors, |   SegoeuiRegularFactors, | ||||||
|   SegoeuiRegularLineHeight, |   SegoeuiRegularMetrics, | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -13,6 +13,8 @@ | |||||||
|  * limitations under the License. |  * limitations under the License. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
|  | import { $globalData } from "./xfa_object.js"; | ||||||
|  | import { stripQuotes } from "./utils.js"; | ||||||
| import { warn } from "../../shared/util.js"; | import { warn } from "../../shared/util.js"; | ||||||
| 
 | 
 | ||||||
| class FontFinder { | class FontFinder { | ||||||
| @ -178,4 +180,32 @@ function selectFont(xfaFont, typeface) { | |||||||
|   return typeface.regular; |   return typeface.regular; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export { FontFinder, selectFont }; | function getMetrics(xfaFont, real = false) { | ||||||
|  |   let pdfFont = null; | ||||||
|  |   if (xfaFont) { | ||||||
|  |     const name = stripQuotes(xfaFont.typeface); | ||||||
|  |     const typeface = xfaFont[$globalData].fontFinder.find(name); | ||||||
|  |     pdfFont = selectFont(xfaFont, typeface); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   if (!pdfFont) { | ||||||
|  |     return { | ||||||
|  |       lineHeight: 12, | ||||||
|  |       lineGap: 2, | ||||||
|  |       lineNoGap: 10, | ||||||
|  |     }; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const size = xfaFont.size || 10; | ||||||
|  |   const lineHeight = pdfFont.lineHeight | ||||||
|  |     ? Math.max(real ? 0 : 1.2, pdfFont.lineHeight) | ||||||
|  |     : 1.2; | ||||||
|  |   const lineGap = pdfFont.lineGap === undefined ? 0.2 : pdfFont.lineGap; | ||||||
|  |   return { | ||||||
|  |     lineHeight: lineHeight * size, | ||||||
|  |     lineGap: lineGap * size, | ||||||
|  |     lineNoGap: Math.max(1, lineHeight - lineGap) * size, | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export { FontFinder, getMetrics, selectFont }; | ||||||
|  | |||||||
| @ -247,7 +247,7 @@ function layoutNode(node, availableSpace) { | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const maxWidth = !node.w ? availableSpace.width : node.w; |     const maxWidth = (!node.w ? availableSpace.width : node.w) - marginH; | ||||||
|     const fontFinder = node[$globalData].fontFinder; |     const fontFinder = node[$globalData].fontFinder; | ||||||
|     if ( |     if ( | ||||||
|       node.value.exData && |       node.value.exData && | ||||||
| @ -614,10 +614,8 @@ function setFontFamily(xfaFont, fontFinder, style) { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const pdfFont = selectFont(xfaFont, typeface); |     const pdfFont = selectFont(xfaFont, typeface); | ||||||
|     if (pdfFont && pdfFont.lineHeight > 0) { |     if (pdfFont) { | ||||||
|       style.lineHeight = Math.max(1.2, pdfFont.lineHeight); |       style.lineHeight = Math.max(1.2, pdfFont.lineHeight); | ||||||
|     } else { |  | ||||||
|       style.lineHeight = 1.2; |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -97,6 +97,7 @@ import { | |||||||
|   HTMLResult, |   HTMLResult, | ||||||
| } from "./utils.js"; | } from "./utils.js"; | ||||||
| import { stringToBytes, Util, warn } from "../../shared/util.js"; | import { stringToBytes, Util, warn } from "../../shared/util.js"; | ||||||
|  | import { getMetrics } from "./fonts.js"; | ||||||
| import { searchNode } from "./som.js"; | import { searchNode } from "./som.js"; | ||||||
| 
 | 
 | ||||||
| const TEMPLATE_NS_ID = NamespaceIds.template.id; | const TEMPLATE_NS_ID = NamespaceIds.template.id; | ||||||
| @ -115,6 +116,30 @@ const MAX_ATTEMPTS_FOR_LRTB_LAYOUT = 2; | |||||||
| // the loop after having MAX_EMPTY_PAGES empty pages.
 | // the loop after having MAX_EMPTY_PAGES empty pages.
 | ||||||
| const MAX_EMPTY_PAGES = 3; | const MAX_EMPTY_PAGES = 3; | ||||||
| 
 | 
 | ||||||
|  | function getBorderDims(node) { | ||||||
|  |   if (!node || !node.border) { | ||||||
|  |     return { w: 0, h: 0 }; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const borderExtra = node.border[$getExtra](); | ||||||
|  |   if (!borderExtra) { | ||||||
|  |     return { w: 0, h: 0 }; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return { | ||||||
|  |     w: | ||||||
|  |       borderExtra.widths[0] + | ||||||
|  |       borderExtra.widths[2] + | ||||||
|  |       borderExtra.insets[0] + | ||||||
|  |       borderExtra.insets[2], | ||||||
|  |     h: | ||||||
|  |       borderExtra.widths[1] + | ||||||
|  |       borderExtra.widths[3] + | ||||||
|  |       borderExtra.insets[1] + | ||||||
|  |       borderExtra.insets[3], | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| function hasMargin(node) { | function hasMargin(node) { | ||||||
|   return ( |   return ( | ||||||
|     node.margin && |     node.margin && | ||||||
| @ -773,8 +798,8 @@ class Border extends XFAObject { | |||||||
|     this.margin = null; |     this.margin = null; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   [$toStyle]() { |   [$getExtra]() { | ||||||
|     // TODO: incomplete.
 |     if (!this[$extra]) { | ||||||
|       const edges = this.edge.children.slice(); |       const edges = this.edge.children.slice(); | ||||||
|       if (edges.length < 4) { |       if (edges.length < 4) { | ||||||
|         const defaultEdge = edges[edges.length - 1] || new Edge({}); |         const defaultEdge = edges[edges.length - 1] || new Edge({}); | ||||||
| @ -783,12 +808,6 @@ class Border extends XFAObject { | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|     const edgeStyles = edges.map(node => { |  | ||||||
|       const style = node[$toStyle](); |  | ||||||
|       style.color = style.color || "#000000"; |  | ||||||
|       return style; |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|       const widths = edges.map(edge => edge.thickness); |       const widths = edges.map(edge => edge.thickness); | ||||||
|       const insets = [0, 0, 0, 0]; |       const insets = [0, 0, 0, 0]; | ||||||
|       if (this.margin) { |       if (this.margin) { | ||||||
| @ -797,8 +816,19 @@ class Border extends XFAObject { | |||||||
|         insets[2] = this.margin.bottomInset; |         insets[2] = this.margin.bottomInset; | ||||||
|         insets[3] = this.margin.leftInset; |         insets[3] = this.margin.leftInset; | ||||||
|       } |       } | ||||||
|     this[$extra] = { widths, insets }; |       this[$extra] = { widths, insets, edges }; | ||||||
|     // TODO: hand.
 |     } | ||||||
|  |     return this[$extra]; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   [$toStyle]() { | ||||||
|  |     // TODO: incomplete (hand).
 | ||||||
|  |     const { edges } = this[$getExtra](); | ||||||
|  |     const edgeStyles = edges.map(node => { | ||||||
|  |       const style = node[$toStyle](); | ||||||
|  |       style.color = style.color || "#000000"; | ||||||
|  |       return style; | ||||||
|  |     }); | ||||||
| 
 | 
 | ||||||
|     const style = Object.create(null); |     const style = Object.create(null); | ||||||
|     if (this.margin) { |     if (this.margin) { | ||||||
| @ -2580,7 +2610,6 @@ class Field extends XFAObject { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     setTabIndex(this); |     setTabIndex(this); | ||||||
| 
 |  | ||||||
|     if ( |     if ( | ||||||
|       !this.ui || |       !this.ui || | ||||||
|       this.presence === "hidden" || |       this.presence === "hidden" || | ||||||
| @ -2603,7 +2632,6 @@ class Field extends XFAObject { | |||||||
|       : null; |       : null; | ||||||
|     const savedW = this.w; |     const savedW = this.w; | ||||||
|     const savedH = this.h; |     const savedH = this.h; | ||||||
|     if (this.w === "" || this.h === "") { |  | ||||||
|     let marginH = 0; |     let marginH = 0; | ||||||
|     let marginV = 0; |     let marginV = 0; | ||||||
|     if (this.margin) { |     if (this.margin) { | ||||||
| @ -2611,9 +2639,29 @@ class Field extends XFAObject { | |||||||
|       marginV = this.margin.topInset + this.margin.bottomInset; |       marginV = this.margin.topInset + this.margin.bottomInset; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     let borderDims = null; | ||||||
|  |     if (this.w === "" || this.h === "") { | ||||||
|       let width = null; |       let width = null; | ||||||
|       let height = null; |       let height = null; | ||||||
| 
 | 
 | ||||||
|  |       let uiW = 0; | ||||||
|  |       let uiH = 0; | ||||||
|  |       if (this.ui.checkButton) { | ||||||
|  |         uiW = uiH = this.ui.checkButton.size; | ||||||
|  |       } else { | ||||||
|  |         const { w, h } = layoutNode(this, availableSpace); | ||||||
|  |         if (w !== null) { | ||||||
|  |           uiW = w; | ||||||
|  |           uiH = h; | ||||||
|  |         } else { | ||||||
|  |           uiH = getMetrics(this.font, /* real = */ true).lineNoGap; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       borderDims = getBorderDims(this.ui[$getExtra]()); | ||||||
|  |       uiW += borderDims.w; | ||||||
|  |       uiH += borderDims.h; | ||||||
|  | 
 | ||||||
|       if (this.caption) { |       if (this.caption) { | ||||||
|         const { w, h, isBroken } = this.caption[$getExtra](availableSpace); |         const { w, h, isBroken } = this.caption[$getExtra](availableSpace); | ||||||
|         // See comment in Draw::[$toHTML] to have an explanation
 |         // See comment in Draw::[$toHTML] to have an explanation
 | ||||||
| @ -2624,32 +2672,36 @@ class Field extends XFAObject { | |||||||
| 
 | 
 | ||||||
|         width = w; |         width = w; | ||||||
|         height = h; |         height = h; | ||||||
|         if (this.ui.checkButton) { | 
 | ||||||
|         switch (this.caption.placement) { |         switch (this.caption.placement) { | ||||||
|           case "left": |           case "left": | ||||||
|           case "right": |           case "right": | ||||||
|           case "inline": |           case "inline": | ||||||
|               width += this.ui.checkButton.size; |             width += uiW; | ||||||
|             break; |             break; | ||||||
|           case "top": |           case "top": | ||||||
|           case "bottom": |           case "bottom": | ||||||
|               height += this.ui.checkButton.size; |             height += uiH; | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         } |       } else { | ||||||
|  |         width = uiW; | ||||||
|  |         height = uiH; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if (width && this.w === "") { |       if (width && this.w === "") { | ||||||
|  |         width += marginH; | ||||||
|         this.w = Math.min( |         this.w = Math.min( | ||||||
|           this.maxW <= 0 ? Infinity : this.maxW, |           this.maxW <= 0 ? Infinity : this.maxW, | ||||||
|           Math.max(this.minW, width + marginH) |           this.minW + 1 < width ? width : this.minW | ||||||
|         ); |         ); | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if (height && this.h === "") { |       if (height && this.h === "") { | ||||||
|  |         height += marginV; | ||||||
|         this.h = Math.min( |         this.h = Math.min( | ||||||
|           this.maxH <= 0 ? Infinity : this.maxH, |           this.maxH <= 0 ? Infinity : this.maxH, | ||||||
|           Math.max(this.minH, height + marginV) |           this.minH + 1 < height ? height : this.minH | ||||||
|         ); |         ); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @ -2718,7 +2770,6 @@ class Field extends XFAObject { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const borderStyle = this.border ? this.border[$toStyle]() : null; |     const borderStyle = this.border ? this.border[$toStyle]() : null; | ||||||
| 
 |  | ||||||
|     const bbox = computeBbox(this, html, availableSpace); |     const bbox = computeBbox(this, html, availableSpace); | ||||||
|     const ui = this.ui[$toHTML]().html; |     const ui = this.ui[$toHTML]().html; | ||||||
|     if (!ui) { |     if (!ui) { | ||||||
| @ -2775,6 +2826,22 @@ class Field extends XFAObject { | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     if (!this.ui.imageEdit && ui.children && ui.children[0] && this.h) { | ||||||
|  |       borderDims = borderDims || getBorderDims(this.ui[$getExtra]()); | ||||||
|  | 
 | ||||||
|  |       let captionHeight = 0; | ||||||
|  |       if (this.caption && ["top", "bottom"].includes(this.caption.placement)) { | ||||||
|  |         captionHeight = this.caption.reserve; | ||||||
|  |         if (captionHeight <= 0) { | ||||||
|  |           captionHeight = this.caption[$getExtra](availableSpace).h; | ||||||
|  |         } | ||||||
|  |         const inputHeight = this.h - captionHeight - marginV - borderDims.h; | ||||||
|  |         ui.children[0].attributes.style.height = measureToString(inputHeight); | ||||||
|  |       } else { | ||||||
|  |         ui.children[0].attributes.style.height = "100%"; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     if (!caption) { |     if (!caption) { | ||||||
|       if (ui.attributes.class) { |       if (ui.attributes.class) { | ||||||
|         // Even if no caption this class will help to center the ui.
 |         // Even if no caption this class will help to center the ui.
 | ||||||
| @ -2803,22 +2870,20 @@ class Field extends XFAObject { | |||||||
|       ui.attributes.class = []; |       ui.attributes.class = []; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     ui.children.splice(0, 0, caption); | ||||||
|  | 
 | ||||||
|     switch (this.caption.placement) { |     switch (this.caption.placement) { | ||||||
|       case "left": |       case "left": | ||||||
|         ui.children.splice(0, 0, caption); |  | ||||||
|         ui.attributes.class.push("xfaLeft"); |         ui.attributes.class.push("xfaLeft"); | ||||||
|         break; |         break; | ||||||
|       case "right": |       case "right": | ||||||
|         ui.children.push(caption); |         ui.attributes.class.push("xfaRight"); | ||||||
|         ui.attributes.class.push("xfaLeft"); |  | ||||||
|         break; |         break; | ||||||
|       case "top": |       case "top": | ||||||
|         ui.children.splice(0, 0, caption); |  | ||||||
|         ui.attributes.class.push("xfaTop"); |         ui.attributes.class.push("xfaTop"); | ||||||
|         break; |         break; | ||||||
|       case "bottom": |       case "bottom": | ||||||
|         ui.children.push(caption); |         ui.attributes.class.push("xfaBottom"); | ||||||
|         ui.attributes.class.push("xfaTop"); |  | ||||||
|         break; |         break; | ||||||
|       case "inline": |       case "inline": | ||||||
|         // TODO;
 |         // TODO;
 | ||||||
| @ -2857,11 +2922,17 @@ class Fill extends XFAObject { | |||||||
| 
 | 
 | ||||||
|   [$toStyle]() { |   [$toStyle]() { | ||||||
|     const parent = this[$getParent](); |     const parent = this[$getParent](); | ||||||
|  |     const grandpa = parent[$getParent](); | ||||||
|  |     const ggrandpa = grandpa[$getParent](); | ||||||
|     const style = Object.create(null); |     const style = Object.create(null); | ||||||
| 
 | 
 | ||||||
|     let propName = "color"; |     let propName = "color"; | ||||||
|     if (parent instanceof Border) { |     if (parent instanceof Border) { | ||||||
|       propName = "background"; |       propName = "background"; | ||||||
|  |       if (ggrandpa instanceof Ui) { | ||||||
|  |         // The default fill color is white.
 | ||||||
|  |         style.background = "white"; | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|     if (parent instanceof Rectangle || parent instanceof Arc) { |     if (parent instanceof Rectangle || parent instanceof Arc) { | ||||||
|       propName = "fill"; |       propName = "fill"; | ||||||
| @ -5515,7 +5586,11 @@ class TextEdit extends XFAObject { | |||||||
|       "on", |       "on", | ||||||
|     ]); |     ]); | ||||||
|     this.id = attributes.id || ""; |     this.id = attributes.id || ""; | ||||||
|     this.multiLine = attributes.multiLine || ""; |     this.multiLine = getInteger({ | ||||||
|  |       data: attributes.multiLine, | ||||||
|  |       defaultValue: "", | ||||||
|  |       validate: x => x === 0 || x === 1, | ||||||
|  |     }); | ||||||
|     this.use = attributes.use || ""; |     this.use = attributes.use || ""; | ||||||
|     this.usehref = attributes.usehref || ""; |     this.usehref = attributes.usehref || ""; | ||||||
|     this.vScrollPolicy = getStringOption(attributes.vScrollPolicy, [ |     this.vScrollPolicy = getStringOption(attributes.vScrollPolicy, [ | ||||||
| @ -5529,22 +5604,14 @@ class TextEdit extends XFAObject { | |||||||
|     this.margin = null; |     this.margin = null; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   [$clean](builder) { |  | ||||||
|     super[$clean](builder); |  | ||||||
|     const parent = this[$getParent](); |  | ||||||
|     const defaultValue = parent instanceof Draw ? 1 : 0; |  | ||||||
|     this.multiLine = getInteger({ |  | ||||||
|       data: this.multiLine, |  | ||||||
|       defaultValue, |  | ||||||
|       validate: x => x === 0 || x === 1, |  | ||||||
|     }); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   [$toHTML](availableSpace) { |   [$toHTML](availableSpace) { | ||||||
|     // TODO: incomplete.
 |     // TODO: incomplete.
 | ||||||
|     const style = toStyle(this, "border", "font", "margin"); |     const style = toStyle(this, "border", "font", "margin"); | ||||||
|     let html; |     let html; | ||||||
|     const field = this[$getParent]()[$getParent](); |     const field = this[$getParent]()[$getParent](); | ||||||
|  |     if (this.multiLine === "") { | ||||||
|  |       this.multiLine = field instanceof Draw ? 1 : 0; | ||||||
|  |     } | ||||||
|     if (this.multiLine === 1) { |     if (this.multiLine === 1) { | ||||||
|       html = { |       html = { | ||||||
|         name: "textarea", |         name: "textarea", | ||||||
| @ -5683,8 +5750,8 @@ class Ui extends XFAObject { | |||||||
|     this.textEdit = null; |     this.textEdit = null; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   [$toHTML](availableSpace) { |   [$getExtra]() { | ||||||
|     // TODO: picture.
 |     if (this[$extra] === undefined) { | ||||||
|       for (const name of Object.getOwnPropertyNames(this)) { |       for (const name of Object.getOwnPropertyNames(this)) { | ||||||
|         if (name === "extras" || name === "picture") { |         if (name === "extras" || name === "picture") { | ||||||
|           continue; |           continue; | ||||||
| @ -5694,6 +5761,18 @@ class Ui extends XFAObject { | |||||||
|           continue; |           continue; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         this[$extra] = obj; | ||||||
|  |         return obj; | ||||||
|  |       } | ||||||
|  |       this[$extra] = null; | ||||||
|  |     } | ||||||
|  |     return this[$extra]; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   [$toHTML](availableSpace) { | ||||||
|  |     // TODO: picture.
 | ||||||
|  |     const obj = this[$getExtra](); | ||||||
|  |     if (obj) { | ||||||
|       return obj[$toHTML](availableSpace); |       return obj[$toHTML](availableSpace); | ||||||
|     } |     } | ||||||
|     return HTMLResult.EMPTY; |     return HTMLResult.EMPTY; | ||||||
|  | |||||||
| @ -181,9 +181,12 @@ class TextMeasure { | |||||||
|     if (lastFont.pdfFont) { |     if (lastFont.pdfFont) { | ||||||
|       const letterSpacing = lastFont.xfaFont.letterSpacing; |       const letterSpacing = lastFont.xfaFont.letterSpacing; | ||||||
|       const pdfFont = lastFont.pdfFont; |       const pdfFont = lastFont.pdfFont; | ||||||
|  |       const fontLineHeight = pdfFont.lineHeight || 1.2; | ||||||
|       const lineHeight = |       const lineHeight = | ||||||
|         lastFont.lineHeight || |         lastFont.lineHeight || Math.max(1.2, fontLineHeight) * fontSize; | ||||||
|         Math.ceil(Math.max(1.2, pdfFont.lineHeight) * fontSize); |       const lineGap = pdfFont.lineGap === undefined ? 0.2 : pdfFont.lineGap; | ||||||
|  |       const noGap = fontLineHeight - lineGap; | ||||||
|  |       const firstLineHeight = Math.max(1, noGap) * fontSize; | ||||||
|       const scale = fontSize / 1000; |       const scale = fontSize / 1000; | ||||||
| 
 | 
 | ||||||
|       for (const line of str.split(/[\u2029\n]/)) { |       for (const line of str.split(/[\u2029\n]/)) { | ||||||
| @ -194,12 +197,13 @@ class TextMeasure { | |||||||
|           this.glyphs.push([ |           this.glyphs.push([ | ||||||
|             glyph.width * scale + letterSpacing, |             glyph.width * scale + letterSpacing, | ||||||
|             lineHeight, |             lineHeight, | ||||||
|  |             firstLineHeight, | ||||||
|             glyph.unicode === " ", |             glyph.unicode === " ", | ||||||
|             false, |             false, | ||||||
|           ]); |           ]); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         this.glyphs.push([0, 0, false, true]); |         this.glyphs.push([0, 0, 0, false, true]); | ||||||
|       } |       } | ||||||
|       this.glyphs.pop(); |       this.glyphs.pop(); | ||||||
|       return; |       return; | ||||||
| @ -208,10 +212,16 @@ class TextMeasure { | |||||||
|     // When we have no font in the pdf, just use the font size as default width.
 |     // When we have no font in the pdf, just use the font size as default width.
 | ||||||
|     for (const line of str.split(/[\u2029\n]/)) { |     for (const line of str.split(/[\u2029\n]/)) { | ||||||
|       for (const char of line.split("")) { |       for (const char of line.split("")) { | ||||||
|         this.glyphs.push([fontSize, fontSize, char === " ", false]); |         this.glyphs.push([ | ||||||
|  |           fontSize, | ||||||
|  |           1.2 * fontSize, | ||||||
|  |           fontSize, | ||||||
|  |           char === " ", | ||||||
|  |           false, | ||||||
|  |         ]); | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       this.glyphs.push([0, 0, false, true]); |       this.glyphs.push([0, 0, 0, false, true]); | ||||||
|     } |     } | ||||||
|     this.glyphs.pop(); |     this.glyphs.pop(); | ||||||
|   } |   } | ||||||
| @ -224,9 +234,12 @@ class TextMeasure { | |||||||
|       currentLineWidth = 0, |       currentLineWidth = 0, | ||||||
|       currentLineHeight = 0; |       currentLineHeight = 0; | ||||||
|     let isBroken = false; |     let isBroken = false; | ||||||
|  |     let isFirstLine = true; | ||||||
| 
 | 
 | ||||||
|     for (let i = 0, ii = this.glyphs.length; i < ii; i++) { |     for (let i = 0, ii = this.glyphs.length; i < ii; i++) { | ||||||
|       const [glyphWidth, glyphHeight, isSpace, isEOL] = this.glyphs[i]; |       const [glyphWidth, lineHeight, firstLineHeight, isSpace, isEOL] = | ||||||
|  |         this.glyphs[i]; | ||||||
|  |       const glyphHeight = isFirstLine ? firstLineHeight : lineHeight; | ||||||
|       if (isEOL) { |       if (isEOL) { | ||||||
|         width = Math.max(width, currentLineWidth); |         width = Math.max(width, currentLineWidth); | ||||||
|         currentLineWidth = 0; |         currentLineWidth = 0; | ||||||
| @ -234,6 +247,7 @@ class TextMeasure { | |||||||
|         currentLineHeight = glyphHeight; |         currentLineHeight = glyphHeight; | ||||||
|         lastSpacePos = -1; |         lastSpacePos = -1; | ||||||
|         lastSpaceWidth = 0; |         lastSpaceWidth = 0; | ||||||
|  |         isFirstLine = false; | ||||||
|         continue; |         continue; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -247,6 +261,7 @@ class TextMeasure { | |||||||
|           lastSpacePos = -1; |           lastSpacePos = -1; | ||||||
|           lastSpaceWidth = 0; |           lastSpaceWidth = 0; | ||||||
|           isBroken = true; |           isBroken = true; | ||||||
|  |           isFirstLine = false; | ||||||
|         } else { |         } else { | ||||||
|           currentLineHeight = Math.max(glyphHeight, currentLineHeight); |           currentLineHeight = Math.max(glyphHeight, currentLineHeight); | ||||||
|           lastSpaceWidth = currentLineWidth; |           lastSpaceWidth = currentLineWidth; | ||||||
| @ -272,6 +287,7 @@ class TextMeasure { | |||||||
|           currentLineWidth = glyphWidth; |           currentLineWidth = glyphWidth; | ||||||
|         } |         } | ||||||
|         isBroken = true; |         isBroken = true; | ||||||
|  |         isFirstLine = false; | ||||||
| 
 | 
 | ||||||
|         continue; |         continue; | ||||||
|       } |       } | ||||||
|  | |||||||
| @ -16,22 +16,22 @@ | |||||||
| import { | import { | ||||||
|   CalibriBoldFactors, |   CalibriBoldFactors, | ||||||
|   CalibriBoldItalicFactors, |   CalibriBoldItalicFactors, | ||||||
|   CalibriBoldItalicLineHeight, |   CalibriBoldItalicMetrics, | ||||||
|   CalibriBoldLineHeight, |   CalibriBoldMetrics, | ||||||
|   CalibriItalicFactors, |   CalibriItalicFactors, | ||||||
|   CalibriItalicLineHeight, |   CalibriItalicMetrics, | ||||||
|   CalibriRegularFactors, |   CalibriRegularFactors, | ||||||
|   CalibriRegularLineHeight, |   CalibriRegularMetrics, | ||||||
| } from "./calibri_factors.js"; | } from "./calibri_factors.js"; | ||||||
| import { | import { | ||||||
|   HelveticaBoldFactors, |   HelveticaBoldFactors, | ||||||
|   HelveticaBoldItalicFactors, |   HelveticaBoldItalicFactors, | ||||||
|   HelveticaBoldItalicLineHeight, |   HelveticaBoldItalicMetrics, | ||||||
|   HelveticaBoldLineHeight, |   HelveticaBoldMetrics, | ||||||
|   HelveticaItalicFactors, |   HelveticaItalicFactors, | ||||||
|   HelveticaItalicLineHeight, |   HelveticaItalicMetrics, | ||||||
|   HelveticaRegularFactors, |   HelveticaRegularFactors, | ||||||
|   HelveticaRegularLineHeight, |   HelveticaRegularMetrics, | ||||||
| } from "./helvetica_factors.js"; | } from "./helvetica_factors.js"; | ||||||
| import { | import { | ||||||
|   LiberationSansBoldItalicWidths, |   LiberationSansBoldItalicWidths, | ||||||
| @ -42,22 +42,22 @@ import { | |||||||
| import { | import { | ||||||
|   MyriadProBoldFactors, |   MyriadProBoldFactors, | ||||||
|   MyriadProBoldItalicFactors, |   MyriadProBoldItalicFactors, | ||||||
|   MyriadProBoldItalicLineHeight, |   MyriadProBoldItalicMetrics, | ||||||
|   MyriadProBoldLineHeight, |   MyriadProBoldMetrics, | ||||||
|   MyriadProItalicFactors, |   MyriadProItalicFactors, | ||||||
|   MyriadProItalicLineHeight, |   MyriadProItalicMetrics, | ||||||
|   MyriadProRegularFactors, |   MyriadProRegularFactors, | ||||||
|   MyriadProRegularLineHeight, |   MyriadProRegularMetrics, | ||||||
| } from "./myriadpro_factors.js"; | } from "./myriadpro_factors.js"; | ||||||
| import { | import { | ||||||
|   SegoeuiBoldFactors, |   SegoeuiBoldFactors, | ||||||
|   SegoeuiBoldItalicFactors, |   SegoeuiBoldItalicFactors, | ||||||
|   SegoeuiBoldItalicLineHeight, |   SegoeuiBoldItalicMetrics, | ||||||
|   SegoeuiBoldLineHeight, |   SegoeuiBoldMetrics, | ||||||
|   SegoeuiItalicFactors, |   SegoeuiItalicFactors, | ||||||
|   SegoeuiItalicLineHeight, |   SegoeuiItalicMetrics, | ||||||
|   SegoeuiRegularFactors, |   SegoeuiRegularFactors, | ||||||
|   SegoeuiRegularLineHeight, |   SegoeuiRegularMetrics, | ||||||
| } from "./segoeui_factors.js"; | } from "./segoeui_factors.js"; | ||||||
| import { getLookupTableFactory } from "./core_utils.js"; | import { getLookupTableFactory } from "./core_utils.js"; | ||||||
| import { normalizeFontName } from "./fonts_utils.js"; | import { normalizeFontName } from "./fonts_utils.js"; | ||||||
| @ -67,13 +67,13 @@ const getXFAFontMap = getLookupTableFactory(function (t) { | |||||||
|     name: "LiberationSans-Regular", |     name: "LiberationSans-Regular", | ||||||
|     factors: MyriadProRegularFactors, |     factors: MyriadProRegularFactors, | ||||||
|     baseWidths: LiberationSansRegularWidths, |     baseWidths: LiberationSansRegularWidths, | ||||||
|     lineHeight: MyriadProRegularLineHeight, |     metrics: MyriadProRegularMetrics, | ||||||
|   }; |   }; | ||||||
|   t["MyriadPro-Bold"] = t["PdfJS-Fallback-Bold"] = { |   t["MyriadPro-Bold"] = t["PdfJS-Fallback-Bold"] = { | ||||||
|     name: "LiberationSans-Bold", |     name: "LiberationSans-Bold", | ||||||
|     factors: MyriadProBoldFactors, |     factors: MyriadProBoldFactors, | ||||||
|     baseWidths: LiberationSansBoldWidths, |     baseWidths: LiberationSansBoldWidths, | ||||||
|     lineHeight: MyriadProBoldLineHeight, |     metrics: MyriadProBoldMetrics, | ||||||
|   }; |   }; | ||||||
|   t["MyriadPro-It"] = |   t["MyriadPro-It"] = | ||||||
|     t["MyriadPro-Italic"] = |     t["MyriadPro-Italic"] = | ||||||
| @ -82,7 +82,7 @@ const getXFAFontMap = getLookupTableFactory(function (t) { | |||||||
|         name: "LiberationSans-Italic", |         name: "LiberationSans-Italic", | ||||||
|         factors: MyriadProItalicFactors, |         factors: MyriadProItalicFactors, | ||||||
|         baseWidths: LiberationSansItalicWidths, |         baseWidths: LiberationSansItalicWidths, | ||||||
|         lineHeight: MyriadProItalicLineHeight, |         metrics: MyriadProItalicMetrics, | ||||||
|       }; |       }; | ||||||
|   t["MyriadPro-BoldIt"] = |   t["MyriadPro-BoldIt"] = | ||||||
|     t["MyriadPro-BoldItalic"] = |     t["MyriadPro-BoldItalic"] = | ||||||
| @ -91,7 +91,7 @@ const getXFAFontMap = getLookupTableFactory(function (t) { | |||||||
|         name: "LiberationSans-BoldItalic", |         name: "LiberationSans-BoldItalic", | ||||||
|         factors: MyriadProBoldItalicFactors, |         factors: MyriadProBoldItalicFactors, | ||||||
|         baseWidths: LiberationSansBoldItalicWidths, |         baseWidths: LiberationSansBoldItalicWidths, | ||||||
|         lineHeight: MyriadProBoldItalicLineHeight, |         metrics: MyriadProBoldItalicMetrics, | ||||||
|       }; |       }; | ||||||
|   t.ArialMT = |   t.ArialMT = | ||||||
|     t.Arial = |     t.Arial = | ||||||
| @ -116,73 +116,73 @@ const getXFAFontMap = getLookupTableFactory(function (t) { | |||||||
|     name: "LiberationSans-Regular", |     name: "LiberationSans-Regular", | ||||||
|     factors: CalibriRegularFactors, |     factors: CalibriRegularFactors, | ||||||
|     baseWidths: LiberationSansRegularWidths, |     baseWidths: LiberationSansRegularWidths, | ||||||
|     lineHeight: CalibriRegularLineHeight, |     metrics: CalibriRegularMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Calibri-Bold"] = { |   t["Calibri-Bold"] = { | ||||||
|     name: "LiberationSans-Bold", |     name: "LiberationSans-Bold", | ||||||
|     factors: CalibriBoldFactors, |     factors: CalibriBoldFactors, | ||||||
|     baseWidths: LiberationSansBoldWidths, |     baseWidths: LiberationSansBoldWidths, | ||||||
|     lineHeight: CalibriBoldLineHeight, |     metrics: CalibriBoldMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Calibri-Italic"] = { |   t["Calibri-Italic"] = { | ||||||
|     name: "LiberationSans-Italic", |     name: "LiberationSans-Italic", | ||||||
|     factors: CalibriItalicFactors, |     factors: CalibriItalicFactors, | ||||||
|     baseWidths: LiberationSansItalicWidths, |     baseWidths: LiberationSansItalicWidths, | ||||||
|     lineHeight: CalibriItalicLineHeight, |     metrics: CalibriItalicMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Calibri-BoldItalic"] = { |   t["Calibri-BoldItalic"] = { | ||||||
|     name: "LiberationSans-BoldItalic", |     name: "LiberationSans-BoldItalic", | ||||||
|     factors: CalibriBoldItalicFactors, |     factors: CalibriBoldItalicFactors, | ||||||
|     baseWidths: LiberationSansBoldItalicWidths, |     baseWidths: LiberationSansBoldItalicWidths, | ||||||
|     lineHeight: CalibriBoldItalicLineHeight, |     metrics: CalibriBoldItalicMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Segoeui-Regular"] = { |   t["Segoeui-Regular"] = { | ||||||
|     name: "LiberationSans-Regular", |     name: "LiberationSans-Regular", | ||||||
|     factors: SegoeuiRegularFactors, |     factors: SegoeuiRegularFactors, | ||||||
|     baseWidths: LiberationSansRegularWidths, |     baseWidths: LiberationSansRegularWidths, | ||||||
|     lineHeight: SegoeuiRegularLineHeight, |     metrics: SegoeuiRegularMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Segoeui-Bold"] = { |   t["Segoeui-Bold"] = { | ||||||
|     name: "LiberationSans-Bold", |     name: "LiberationSans-Bold", | ||||||
|     factors: SegoeuiBoldFactors, |     factors: SegoeuiBoldFactors, | ||||||
|     baseWidths: LiberationSansBoldWidths, |     baseWidths: LiberationSansBoldWidths, | ||||||
|     lineHeight: SegoeuiBoldLineHeight, |     metrics: SegoeuiBoldMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Segoeui-Italic"] = { |   t["Segoeui-Italic"] = { | ||||||
|     name: "LiberationSans-Italic", |     name: "LiberationSans-Italic", | ||||||
|     factors: SegoeuiItalicFactors, |     factors: SegoeuiItalicFactors, | ||||||
|     baseWidths: LiberationSansItalicWidths, |     baseWidths: LiberationSansItalicWidths, | ||||||
|     lineHeight: SegoeuiItalicLineHeight, |     metrics: SegoeuiItalicMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Segoeui-BoldItalic"] = { |   t["Segoeui-BoldItalic"] = { | ||||||
|     name: "LiberationSans-BoldItalic", |     name: "LiberationSans-BoldItalic", | ||||||
|     factors: SegoeuiBoldItalicFactors, |     factors: SegoeuiBoldItalicFactors, | ||||||
|     baseWidths: LiberationSansBoldItalicWidths, |     baseWidths: LiberationSansBoldItalicWidths, | ||||||
|     lineHeight: SegoeuiBoldItalicLineHeight, |     metrics: SegoeuiBoldItalicMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Helvetica-Regular"] = t.Helvetica = { |   t["Helvetica-Regular"] = t.Helvetica = { | ||||||
|     name: "LiberationSans-Regular", |     name: "LiberationSans-Regular", | ||||||
|     factors: HelveticaRegularFactors, |     factors: HelveticaRegularFactors, | ||||||
|     baseWidths: LiberationSansRegularWidths, |     baseWidths: LiberationSansRegularWidths, | ||||||
|     lineHeight: HelveticaRegularLineHeight, |     metrics: HelveticaRegularMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Helvetica-Bold"] = { |   t["Helvetica-Bold"] = { | ||||||
|     name: "LiberationSans-Bold", |     name: "LiberationSans-Bold", | ||||||
|     factors: HelveticaBoldFactors, |     factors: HelveticaBoldFactors, | ||||||
|     baseWidths: LiberationSansBoldWidths, |     baseWidths: LiberationSansBoldWidths, | ||||||
|     lineHeight: HelveticaBoldLineHeight, |     metrics: HelveticaBoldMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Helvetica-Italic"] = { |   t["Helvetica-Italic"] = { | ||||||
|     name: "LiberationSans-Italic", |     name: "LiberationSans-Italic", | ||||||
|     factors: HelveticaItalicFactors, |     factors: HelveticaItalicFactors, | ||||||
|     baseWidths: LiberationSansItalicWidths, |     baseWidths: LiberationSansItalicWidths, | ||||||
|     lineHeight: HelveticaItalicLineHeight, |     metrics: HelveticaItalicMetrics, | ||||||
|   }; |   }; | ||||||
|   t["Helvetica-BoldItalic"] = { |   t["Helvetica-BoldItalic"] = { | ||||||
|     name: "LiberationSans-BoldItalic", |     name: "LiberationSans-BoldItalic", | ||||||
|     factors: HelveticaBoldItalicFactors, |     factors: HelveticaBoldItalicFactors, | ||||||
|     baseWidths: LiberationSansBoldItalicWidths, |     baseWidths: LiberationSansBoldItalicWidths, | ||||||
|     lineHeight: HelveticaBoldItalicLineHeight, |     metrics: HelveticaBoldItalicMetrics, | ||||||
|   }; |   }; | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								test/pdfs/xfa_bug1722030_1.pdf.link
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								test/pdfs/xfa_bug1722030_1.pdf.link
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | |||||||
|  | https://bug1722030.bmoattachments.org/attachment.cgi?id=9232840 | ||||||
| @ -952,6 +952,15 @@ | |||||||
|        "enableXfa": true, |        "enableXfa": true, | ||||||
|        "type": "eq" |        "type": "eq" | ||||||
|     }, |     }, | ||||||
|  |     {  "id": "xfa_bug1722030_1", | ||||||
|  |        "file": "pdfs/xfa_bug1722030_1.pdf", | ||||||
|  |        "md5": "0baf149f21536ebb2bfc636a95e1d62d", | ||||||
|  |        "link": true, | ||||||
|  |        "rounds": 1, | ||||||
|  |        "lastPage": 3, | ||||||
|  |        "enableXfa": true, | ||||||
|  |        "type": "eq" | ||||||
|  |     }, | ||||||
|     {  "id": "xfa_bug1722029", |     {  "id": "xfa_bug1722029", | ||||||
|        "file": "pdfs/xfa_bug1722029.pdf", |        "file": "pdfs/xfa_bug1722029.pdf", | ||||||
|        "md5": "d8dd6bb20599fc777b4c7ff7b74dd5e3", |        "md5": "d8dd6bb20599fc777b4c7ff7b74dd5e3", | ||||||
|  | |||||||
| @ -84,7 +84,7 @@ | |||||||
| 
 | 
 | ||||||
| .xfaCaption { | .xfaCaption { | ||||||
|   overflow: hidden; |   overflow: hidden; | ||||||
|   flex: 0 1 auto; |   flex: 0 0 auto; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .xfaCaptionForCheckButton { | .xfaCaptionForCheckButton { | ||||||
| @ -103,8 +103,16 @@ | |||||||
|   align-items: center; |   align-items: center; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .xfaRight { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: row-reverse; | ||||||
|  |   align-items: center; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .xfaLeft > .xfaCaption, | .xfaLeft > .xfaCaption, | ||||||
| .xfaLeft > .xfaCaptionForCheckButton { | .xfaLeft > .xfaCaptionForCheckButton, | ||||||
|  | .xfaRight > .xfaCaption, | ||||||
|  | .xfaRight > .xfaCaptionForCheckButton { | ||||||
|   max-height: 100%; |   max-height: 100%; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -114,8 +122,16 @@ | |||||||
|   align-items: flex-start; |   align-items: flex-start; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .xfaBottom { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column-reverse; | ||||||
|  |   align-items: flex-start; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .xfaTop > .xfaCaption, | .xfaTop > .xfaCaption, | ||||||
| .xfaTop > .xfaCaptionForCheckButton { | .xfaTop > .xfaCaptionForCheckButton, | ||||||
|  | .xfaBottom > .xfaCaption, | ||||||
|  | .xfaBottom > .xfaCaptionForCheckButton { | ||||||
|   width: 100%; |   width: 100%; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -130,24 +146,27 @@ | |||||||
|   height: 100%; |   height: 100%; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .xfaTextfield, |  | ||||||
| .xfaSelect { |  | ||||||
|   background-color: rgba(0, 54, 255, 0.13); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .xfaTextfield:focus, | .xfaTextfield:focus, | ||||||
| .xfaSelect:focus { | .xfaSelect:focus { | ||||||
|   background-color: transparent; |   background: transparent; | ||||||
|   outline: none; |   outline: none; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .xfaTextfield, | .xfaTextfield, | ||||||
| .xfaSelect { | .xfaSelect { | ||||||
|   width: 100%; |  | ||||||
|   height: 100%; |   height: 100%; | ||||||
|   flex: 1 1 0; |   width: 100%; | ||||||
|  |   flex: 1 1 auto; | ||||||
|   border: none; |   border: none; | ||||||
|   resize: none; |   resize: none; | ||||||
|  |   background: rgba(0, 54, 255, 0.13); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .xfaTop > .xfaTextfield, | ||||||
|  | .xfaTop > .xfaSelect, | ||||||
|  | .xfaBottom > .xfaTextfield, | ||||||
|  | .xfaBottom > .xfaSelect { | ||||||
|  |   flex: 0 1 auto; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .xfaButton { | .xfaButton { | ||||||
| @ -158,10 +177,6 @@ | |||||||
|   text-align: center; |   text-align: center; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .xfaButton:hover { |  | ||||||
|   background: Highlight; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .xfaCheckbox, | .xfaCheckbox, | ||||||
| .xfaRadio { | .xfaRadio { | ||||||
|   width: 100%; |   width: 100%; | ||||||
| @ -255,7 +270,7 @@ | |||||||
| @media print { | @media print { | ||||||
|   .xfaTextfield, |   .xfaTextfield, | ||||||
|   .xfaSelect { |   .xfaSelect { | ||||||
|     background-color: transparent; |     background: transparent; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   .xfaSelect { |   .xfaSelect { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user