@pdfme/schemas 0.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -0
- package/dist/cjs/__tests__/barcode.test.js +354 -0
- package/dist/cjs/__tests__/barcode.test.js.map +1 -0
- package/dist/cjs/__tests__/multiVariableText.test.js +102 -0
- package/dist/cjs/__tests__/multiVariableText.test.js.map +1 -0
- package/dist/cjs/__tests__/text.test.js +419 -0
- package/dist/cjs/__tests__/text.test.js.map +1 -0
- package/dist/cjs/__tests__/utils.test.js +193 -0
- package/dist/cjs/__tests__/utils.test.js.map +1 -0
- package/dist/cjs/src/barcodes/constants.js +21 -0
- package/dist/cjs/src/barcodes/constants.js.map +1 -0
- package/dist/cjs/src/barcodes/helper.js +161 -0
- package/dist/cjs/src/barcodes/helper.js.map +1 -0
- package/dist/cjs/src/barcodes/index.js +18 -0
- package/dist/cjs/src/barcodes/index.js.map +1 -0
- package/dist/cjs/src/barcodes/pdfRender.js +29 -0
- package/dist/cjs/src/barcodes/pdfRender.js.map +1 -0
- package/dist/cjs/src/barcodes/propPanel.js +241 -0
- package/dist/cjs/src/barcodes/propPanel.js.map +1 -0
- package/dist/cjs/src/barcodes/types.js +3 -0
- package/dist/cjs/src/barcodes/types.js.map +1 -0
- package/dist/cjs/src/barcodes/uiRender.js +91 -0
- package/dist/cjs/src/barcodes/uiRender.js.map +1 -0
- package/dist/cjs/src/checkbox/index.js +62 -0
- package/dist/cjs/src/checkbox/index.js.map +1 -0
- package/dist/cjs/src/constants.js +6 -0
- package/dist/cjs/src/constants.js.map +1 -0
- package/dist/cjs/src/date/date.js +9 -0
- package/dist/cjs/src/date/date.js.map +1 -0
- package/dist/cjs/src/date/dateTime.js +9 -0
- package/dist/cjs/src/date/dateTime.js.map +1 -0
- package/dist/cjs/src/date/helper.js +462 -0
- package/dist/cjs/src/date/helper.js.map +1 -0
- package/dist/cjs/src/date/time.js +9 -0
- package/dist/cjs/src/date/time.js.map +1 -0
- package/dist/cjs/src/date/types.js +3 -0
- package/dist/cjs/src/date/types.js.map +1 -0
- package/dist/cjs/src/graphics/image.js +172 -0
- package/dist/cjs/src/graphics/image.js.map +1 -0
- package/dist/cjs/src/graphics/imagehelper.js +124 -0
- package/dist/cjs/src/graphics/imagehelper.js.map +1 -0
- package/dist/cjs/src/graphics/svg.js +109 -0
- package/dist/cjs/src/graphics/svg.js.map +1 -0
- package/dist/cjs/src/index.js +41 -0
- package/dist/cjs/src/index.js.map +1 -0
- package/dist/cjs/src/multiVariableText/helper.js +55 -0
- package/dist/cjs/src/multiVariableText/helper.js.map +1 -0
- package/dist/cjs/src/multiVariableText/index.js +16 -0
- package/dist/cjs/src/multiVariableText/index.js.map +1 -0
- package/dist/cjs/src/multiVariableText/pdfRender.js +20 -0
- package/dist/cjs/src/multiVariableText/pdfRender.js.map +1 -0
- package/dist/cjs/src/multiVariableText/propPanel.js +148 -0
- package/dist/cjs/src/multiVariableText/propPanel.js.map +1 -0
- package/dist/cjs/src/multiVariableText/types.js +3 -0
- package/dist/cjs/src/multiVariableText/types.js.map +1 -0
- package/dist/cjs/src/multiVariableText/uiRender.js +146 -0
- package/dist/cjs/src/multiVariableText/uiRender.js.map +1 -0
- package/dist/cjs/src/radioGroup/index.js +93 -0
- package/dist/cjs/src/radioGroup/index.js.map +1 -0
- package/dist/cjs/src/select/index.js +170 -0
- package/dist/cjs/src/select/index.js.map +1 -0
- package/dist/cjs/src/shapes/line.js +76 -0
- package/dist/cjs/src/shapes/line.js.map +1 -0
- package/dist/cjs/src/shapes/rectAndEllipse.js +140 -0
- package/dist/cjs/src/shapes/rectAndEllipse.js.map +1 -0
- package/dist/cjs/src/tables/cell.js +126 -0
- package/dist/cjs/src/tables/cell.js.map +1 -0
- package/dist/cjs/src/tables/classes.js +467 -0
- package/dist/cjs/src/tables/classes.js.map +1 -0
- package/dist/cjs/src/tables/dynamicTemplate.js +66 -0
- package/dist/cjs/src/tables/dynamicTemplate.js.map +1 -0
- package/dist/cjs/src/tables/helper.js +189 -0
- package/dist/cjs/src/tables/helper.js.map +1 -0
- package/dist/cjs/src/tables/index.js +15 -0
- package/dist/cjs/src/tables/index.js.map +1 -0
- package/dist/cjs/src/tables/pdfRender.js +109 -0
- package/dist/cjs/src/tables/pdfRender.js.map +1 -0
- package/dist/cjs/src/tables/propPanel.js +108 -0
- package/dist/cjs/src/tables/propPanel.js.map +1 -0
- package/dist/cjs/src/tables/tableHelper.js +200 -0
- package/dist/cjs/src/tables/tableHelper.js.map +1 -0
- package/dist/cjs/src/tables/types.js +3 -0
- package/dist/cjs/src/tables/types.js.map +1 -0
- package/dist/cjs/src/tables/uiRender.js +368 -0
- package/dist/cjs/src/tables/uiRender.js.map +1 -0
- package/dist/cjs/src/text/constants.js +97 -0
- package/dist/cjs/src/text/constants.js.map +1 -0
- package/dist/cjs/src/text/extraFormatter.js +49 -0
- package/dist/cjs/src/text/extraFormatter.js.map +1 -0
- package/dist/cjs/src/text/helper.js +498 -0
- package/dist/cjs/src/text/helper.js.map +1 -0
- package/dist/cjs/src/text/icons/index.js +16 -0
- package/dist/cjs/src/text/icons/index.js.map +1 -0
- package/dist/cjs/src/text/index.js +15 -0
- package/dist/cjs/src/text/index.js.map +1 -0
- package/dist/cjs/src/text/pdfRender.js +167 -0
- package/dist/cjs/src/text/pdfRender.js.map +1 -0
- package/dist/cjs/src/text/propPanel.js +161 -0
- package/dist/cjs/src/text/propPanel.js.map +1 -0
- package/dist/cjs/src/text/types.js +3 -0
- package/dist/cjs/src/text/types.js.map +1 -0
- package/dist/cjs/src/text/uiRender.js +224 -0
- package/dist/cjs/src/text/uiRender.js.map +1 -0
- package/dist/cjs/src/utils.js +230 -0
- package/dist/cjs/src/utils.js.map +1 -0
- package/dist/esm/__tests__/barcode.test.js +349 -0
- package/dist/esm/__tests__/barcode.test.js.map +1 -0
- package/dist/esm/__tests__/multiVariableText.test.js +100 -0
- package/dist/esm/__tests__/multiVariableText.test.js.map +1 -0
- package/dist/esm/__tests__/text.test.js +384 -0
- package/dist/esm/__tests__/text.test.js.map +1 -0
- package/dist/esm/__tests__/utils.test.js +191 -0
- package/dist/esm/__tests__/utils.test.js.map +1 -0
- package/dist/esm/src/barcodes/constants.js +18 -0
- package/dist/esm/src/barcodes/constants.js.map +1 -0
- package/dist/esm/src/barcodes/helper.js +151 -0
- package/dist/esm/src/barcodes/helper.js.map +1 -0
- package/dist/esm/src/barcodes/index.js +16 -0
- package/dist/esm/src/barcodes/index.js.map +1 -0
- package/dist/esm/src/barcodes/pdfRender.js +25 -0
- package/dist/esm/src/barcodes/pdfRender.js.map +1 -0
- package/dist/esm/src/barcodes/propPanel.js +237 -0
- package/dist/esm/src/barcodes/propPanel.js.map +1 -0
- package/dist/esm/src/barcodes/types.js +2 -0
- package/dist/esm/src/barcodes/types.js.map +1 -0
- package/dist/esm/src/barcodes/uiRender.js +87 -0
- package/dist/esm/src/barcodes/uiRender.js.map +1 -0
- package/dist/esm/src/checkbox/index.js +57 -0
- package/dist/esm/src/checkbox/index.js.map +1 -0
- package/dist/esm/src/constants.js +3 -0
- package/dist/esm/src/constants.js.map +1 -0
- package/dist/esm/src/date/date.js +7 -0
- package/dist/esm/src/date/date.js.map +1 -0
- package/dist/esm/src/date/dateTime.js +7 -0
- package/dist/esm/src/date/dateTime.js.map +1 -0
- package/dist/esm/src/date/helper.js +422 -0
- package/dist/esm/src/date/helper.js.map +1 -0
- package/dist/esm/src/date/time.js +7 -0
- package/dist/esm/src/date/time.js.map +1 -0
- package/dist/esm/src/date/types.js +2 -0
- package/dist/esm/src/date/types.js.map +1 -0
- package/dist/esm/src/graphics/image.js +170 -0
- package/dist/esm/src/graphics/image.js.map +1 -0
- package/dist/esm/src/graphics/imagehelper.js +120 -0
- package/dist/esm/src/graphics/imagehelper.js.map +1 -0
- package/dist/esm/src/graphics/svg.js +107 -0
- package/dist/esm/src/graphics/svg.js.map +1 -0
- package/dist/esm/src/index.js +21 -0
- package/dist/esm/src/index.js.map +1 -0
- package/dist/esm/src/multiVariableText/helper.js +50 -0
- package/dist/esm/src/multiVariableText/helper.js.map +1 -0
- package/dist/esm/src/multiVariableText/index.js +14 -0
- package/dist/esm/src/multiVariableText/index.js.map +1 -0
- package/dist/esm/src/multiVariableText/pdfRender.js +16 -0
- package/dist/esm/src/multiVariableText/pdfRender.js.map +1 -0
- package/dist/esm/src/multiVariableText/propPanel.js +145 -0
- package/dist/esm/src/multiVariableText/propPanel.js.map +1 -0
- package/dist/esm/src/multiVariableText/types.js +2 -0
- package/dist/esm/src/multiVariableText/types.js.map +1 -0
- package/dist/esm/src/multiVariableText/uiRender.js +142 -0
- package/dist/esm/src/multiVariableText/uiRender.js.map +1 -0
- package/dist/esm/src/radioGroup/index.js +88 -0
- package/dist/esm/src/radioGroup/index.js.map +1 -0
- package/dist/esm/src/select/index.js +165 -0
- package/dist/esm/src/select/index.js.map +1 -0
- package/dist/esm/src/shapes/line.js +74 -0
- package/dist/esm/src/shapes/line.js.map +1 -0
- package/dist/esm/src/shapes/rectAndEllipse.js +137 -0
- package/dist/esm/src/shapes/rectAndEllipse.js.map +1 -0
- package/dist/esm/src/tables/cell.js +121 -0
- package/dist/esm/src/tables/cell.js.map +1 -0
- package/dist/esm/src/tables/classes.js +460 -0
- package/dist/esm/src/tables/classes.js.map +1 -0
- package/dist/esm/src/tables/dynamicTemplate.js +62 -0
- package/dist/esm/src/tables/dynamicTemplate.js.map +1 -0
- package/dist/esm/src/tables/helper.js +181 -0
- package/dist/esm/src/tables/helper.js.map +1 -0
- package/dist/esm/src/tables/index.js +13 -0
- package/dist/esm/src/tables/index.js.map +1 -0
- package/dist/esm/src/tables/pdfRender.js +102 -0
- package/dist/esm/src/tables/pdfRender.js.map +1 -0
- package/dist/esm/src/tables/propPanel.js +105 -0
- package/dist/esm/src/tables/propPanel.js.map +1 -0
- package/dist/esm/src/tables/tableHelper.js +197 -0
- package/dist/esm/src/tables/tableHelper.js.map +1 -0
- package/dist/esm/src/tables/types.js +2 -0
- package/dist/esm/src/tables/types.js.map +1 -0
- package/dist/esm/src/tables/uiRender.js +361 -0
- package/dist/esm/src/tables/uiRender.js.map +1 -0
- package/dist/esm/src/text/constants.js +94 -0
- package/dist/esm/src/text/constants.js.map +1 -0
- package/dist/esm/src/text/extraFormatter.js +45 -0
- package/dist/esm/src/text/extraFormatter.js.map +1 -0
- package/dist/esm/src/text/helper.js +451 -0
- package/dist/esm/src/text/helper.js.map +1 -0
- package/dist/esm/src/text/icons/index.js +13 -0
- package/dist/esm/src/text/icons/index.js.map +1 -0
- package/dist/esm/src/text/index.js +13 -0
- package/dist/esm/src/text/index.js.map +1 -0
- package/dist/esm/src/text/pdfRender.js +163 -0
- package/dist/esm/src/text/pdfRender.js.map +1 -0
- package/dist/esm/src/text/propPanel.js +158 -0
- package/dist/esm/src/text/propPanel.js.map +1 -0
- package/dist/esm/src/text/types.js +2 -0
- package/dist/esm/src/text/types.js.map +1 -0
- package/dist/esm/src/text/uiRender.js +217 -0
- package/dist/esm/src/text/uiRender.js.map +1 -0
- package/dist/esm/src/utils.js +218 -0
- package/dist/esm/src/utils.js.map +1 -0
- package/dist/node/__tests__/barcode.test.js +354 -0
- package/dist/node/__tests__/barcode.test.js.map +1 -0
- package/dist/node/__tests__/multiVariableText.test.js +102 -0
- package/dist/node/__tests__/multiVariableText.test.js.map +1 -0
- package/dist/node/__tests__/text.test.js +419 -0
- package/dist/node/__tests__/text.test.js.map +1 -0
- package/dist/node/__tests__/utils.test.js +193 -0
- package/dist/node/__tests__/utils.test.js.map +1 -0
- package/dist/node/src/barcodes/constants.js +21 -0
- package/dist/node/src/barcodes/constants.js.map +1 -0
- package/dist/node/src/barcodes/helper.js +161 -0
- package/dist/node/src/barcodes/helper.js.map +1 -0
- package/dist/node/src/barcodes/index.js +18 -0
- package/dist/node/src/barcodes/index.js.map +1 -0
- package/dist/node/src/barcodes/pdfRender.js +29 -0
- package/dist/node/src/barcodes/pdfRender.js.map +1 -0
- package/dist/node/src/barcodes/propPanel.js +241 -0
- package/dist/node/src/barcodes/propPanel.js.map +1 -0
- package/dist/node/src/barcodes/types.js +3 -0
- package/dist/node/src/barcodes/types.js.map +1 -0
- package/dist/node/src/barcodes/uiRender.js +91 -0
- package/dist/node/src/barcodes/uiRender.js.map +1 -0
- package/dist/node/src/checkbox/index.js +62 -0
- package/dist/node/src/checkbox/index.js.map +1 -0
- package/dist/node/src/constants.js +6 -0
- package/dist/node/src/constants.js.map +1 -0
- package/dist/node/src/date/date.js +9 -0
- package/dist/node/src/date/date.js.map +1 -0
- package/dist/node/src/date/dateTime.js +9 -0
- package/dist/node/src/date/dateTime.js.map +1 -0
- package/dist/node/src/date/helper.js +462 -0
- package/dist/node/src/date/helper.js.map +1 -0
- package/dist/node/src/date/time.js +9 -0
- package/dist/node/src/date/time.js.map +1 -0
- package/dist/node/src/date/types.js +3 -0
- package/dist/node/src/date/types.js.map +1 -0
- package/dist/node/src/graphics/image.js +172 -0
- package/dist/node/src/graphics/image.js.map +1 -0
- package/dist/node/src/graphics/imagehelper.js +124 -0
- package/dist/node/src/graphics/imagehelper.js.map +1 -0
- package/dist/node/src/graphics/svg.js +109 -0
- package/dist/node/src/graphics/svg.js.map +1 -0
- package/dist/node/src/index.js +41 -0
- package/dist/node/src/index.js.map +1 -0
- package/dist/node/src/multiVariableText/helper.js +55 -0
- package/dist/node/src/multiVariableText/helper.js.map +1 -0
- package/dist/node/src/multiVariableText/index.js +16 -0
- package/dist/node/src/multiVariableText/index.js.map +1 -0
- package/dist/node/src/multiVariableText/pdfRender.js +20 -0
- package/dist/node/src/multiVariableText/pdfRender.js.map +1 -0
- package/dist/node/src/multiVariableText/propPanel.js +148 -0
- package/dist/node/src/multiVariableText/propPanel.js.map +1 -0
- package/dist/node/src/multiVariableText/types.js +3 -0
- package/dist/node/src/multiVariableText/types.js.map +1 -0
- package/dist/node/src/multiVariableText/uiRender.js +146 -0
- package/dist/node/src/multiVariableText/uiRender.js.map +1 -0
- package/dist/node/src/radioGroup/index.js +93 -0
- package/dist/node/src/radioGroup/index.js.map +1 -0
- package/dist/node/src/select/index.js +170 -0
- package/dist/node/src/select/index.js.map +1 -0
- package/dist/node/src/shapes/line.js +76 -0
- package/dist/node/src/shapes/line.js.map +1 -0
- package/dist/node/src/shapes/rectAndEllipse.js +140 -0
- package/dist/node/src/shapes/rectAndEllipse.js.map +1 -0
- package/dist/node/src/tables/cell.js +126 -0
- package/dist/node/src/tables/cell.js.map +1 -0
- package/dist/node/src/tables/classes.js +467 -0
- package/dist/node/src/tables/classes.js.map +1 -0
- package/dist/node/src/tables/dynamicTemplate.js +66 -0
- package/dist/node/src/tables/dynamicTemplate.js.map +1 -0
- package/dist/node/src/tables/helper.js +189 -0
- package/dist/node/src/tables/helper.js.map +1 -0
- package/dist/node/src/tables/index.js +15 -0
- package/dist/node/src/tables/index.js.map +1 -0
- package/dist/node/src/tables/pdfRender.js +109 -0
- package/dist/node/src/tables/pdfRender.js.map +1 -0
- package/dist/node/src/tables/propPanel.js +108 -0
- package/dist/node/src/tables/propPanel.js.map +1 -0
- package/dist/node/src/tables/tableHelper.js +200 -0
- package/dist/node/src/tables/tableHelper.js.map +1 -0
- package/dist/node/src/tables/types.js +3 -0
- package/dist/node/src/tables/types.js.map +1 -0
- package/dist/node/src/tables/uiRender.js +368 -0
- package/dist/node/src/tables/uiRender.js.map +1 -0
- package/dist/node/src/text/constants.js +97 -0
- package/dist/node/src/text/constants.js.map +1 -0
- package/dist/node/src/text/extraFormatter.js +49 -0
- package/dist/node/src/text/extraFormatter.js.map +1 -0
- package/dist/node/src/text/helper.js +498 -0
- package/dist/node/src/text/helper.js.map +1 -0
- package/dist/node/src/text/icons/index.js +16 -0
- package/dist/node/src/text/icons/index.js.map +1 -0
- package/dist/node/src/text/index.js +15 -0
- package/dist/node/src/text/index.js.map +1 -0
- package/dist/node/src/text/pdfRender.js +167 -0
- package/dist/node/src/text/pdfRender.js.map +1 -0
- package/dist/node/src/text/propPanel.js +161 -0
- package/dist/node/src/text/propPanel.js.map +1 -0
- package/dist/node/src/text/types.js +3 -0
- package/dist/node/src/text/types.js.map +1 -0
- package/dist/node/src/text/uiRender.js +224 -0
- package/dist/node/src/text/uiRender.js.map +1 -0
- package/dist/node/src/utils.js +230 -0
- package/dist/node/src/utils.js.map +1 -0
- package/dist/types/__tests__/barcode.test.d.ts +1 -0
- package/dist/types/__tests__/multiVariableText.test.d.ts +1 -0
- package/dist/types/__tests__/text.test.d.ts +1 -0
- package/dist/types/__tests__/utils.test.d.ts +1 -0
- package/dist/types/src/barcodes/constants.d.ts +4 -0
- package/dist/types/src/barcodes/helper.d.ts +21 -0
- package/dist/types/src/barcodes/index.d.ts +4 -0
- package/dist/types/src/barcodes/pdfRender.d.ts +3 -0
- package/dist/types/src/barcodes/propPanel.d.ts +3 -0
- package/dist/types/src/barcodes/types.d.ts +10 -0
- package/dist/types/src/barcodes/uiRender.d.ts +3 -0
- package/dist/types/src/checkbox/index.d.ts +6 -0
- package/dist/types/src/constants.d.ts +2 -0
- package/dist/types/src/date/date.d.ts +2 -0
- package/dist/types/src/date/dateTime.d.ts +2 -0
- package/dist/types/src/date/helper.d.ts +8 -0
- package/dist/types/src/date/time.d.ts +2 -0
- package/dist/types/src/date/types.d.ts +17 -0
- package/dist/types/src/graphics/image.d.ts +5 -0
- package/dist/types/src/graphics/imagehelper.d.ts +4 -0
- package/dist/types/src/graphics/svg.d.ts +4 -0
- package/dist/types/src/index.d.ts +19 -0
- package/dist/types/src/multiVariableText/helper.d.ts +3 -0
- package/dist/types/src/multiVariableText/index.d.ts +4 -0
- package/dist/types/src/multiVariableText/pdfRender.d.ts +3 -0
- package/dist/types/src/multiVariableText/propPanel.d.ts +3 -0
- package/dist/types/src/multiVariableText/types.d.ts +5 -0
- package/dist/types/src/multiVariableText/uiRender.d.ts +3 -0
- package/dist/types/src/radioGroup/index.d.ts +7 -0
- package/dist/types/src/select/index.d.ts +7 -0
- package/dist/types/src/shapes/line.d.ts +6 -0
- package/dist/types/src/shapes/rectAndEllipse.d.ts +175 -0
- package/dist/types/src/tables/cell.d.ts +4 -0
- package/dist/types/src/tables/classes.d.ts +69 -0
- package/dist/types/src/tables/dynamicTemplate.d.ts +7 -0
- package/dist/types/src/tables/helper.d.ts +265 -0
- package/dist/types/src/tables/index.d.ts +4 -0
- package/dist/types/src/tables/pdfRender.d.ts +3 -0
- package/dist/types/src/tables/propPanel.d.ts +3 -0
- package/dist/types/src/tables/tableHelper.d.ts +10 -0
- package/dist/types/src/tables/types.d.ts +88 -0
- package/dist/types/src/tables/uiRender.d.ts +3 -0
- package/dist/types/src/text/constants.d.ts +23 -0
- package/dist/types/src/text/extraFormatter.d.ts +25 -0
- package/dist/types/src/text/helper.d.ts +39 -0
- package/dist/types/src/text/icons/index.d.ts +9 -0
- package/dist/types/src/text/index.d.ts +4 -0
- package/dist/types/src/text/pdfRender.d.ts +3 -0
- package/dist/types/src/text/propPanel.d.ts +3 -0
- package/dist/types/src/text/types.d.ts +28 -0
- package/dist/types/src/text/uiRender.d.ts +11 -0
- package/dist/types/src/utils.d.ts +40 -0
- package/eslint.config.mjs +22 -0
- package/package.json +97 -0
- package/src/barcodes/constants.ts +20 -0
- package/src/barcodes/helper.ts +187 -0
- package/src/barcodes/index.ts +23 -0
- package/src/barcodes/pdfRender.ts +37 -0
- package/src/barcodes/propPanel.ts +249 -0
- package/src/barcodes/types.ts +12 -0
- package/src/barcodes/uiRender.ts +94 -0
- package/src/checkbox/index.ts +70 -0
- package/src/constants.ts +2 -0
- package/src/date/date.ts +9 -0
- package/src/date/dateTime.ts +9 -0
- package/src/date/helper.ts +496 -0
- package/src/date/time.ts +9 -0
- package/src/date/types.ts +19 -0
- package/src/graphics/image.ts +201 -0
- package/src/graphics/imagehelper.ts +156 -0
- package/src/graphics/svg.ts +118 -0
- package/src/index.ts +39 -0
- package/src/multiVariableText/helper.ts +65 -0
- package/src/multiVariableText/index.ts +16 -0
- package/src/multiVariableText/pdfRender.ts +21 -0
- package/src/multiVariableText/propPanel.ts +160 -0
- package/src/multiVariableText/types.ts +6 -0
- package/src/multiVariableText/uiRender.ts +170 -0
- package/src/radioGroup/index.ts +115 -0
- package/src/select/index.ts +204 -0
- package/src/shapes/line.ts +94 -0
- package/src/shapes/rectAndEllipse.ts +152 -0
- package/src/tables/cell.ts +152 -0
- package/src/tables/classes.ts +402 -0
- package/src/tables/dynamicTemplate.ts +88 -0
- package/src/tables/helper.ts +216 -0
- package/src/tables/index.ts +15 -0
- package/src/tables/pdfRender.ts +144 -0
- package/src/tables/propPanel.ts +111 -0
- package/src/tables/tableHelper.ts +288 -0
- package/src/tables/types.ts +87 -0
- package/src/tables/uiRender.ts +436 -0
- package/src/text/constants.ts +104 -0
- package/src/text/extraFormatter.ts +83 -0
- package/src/text/helper.ts +550 -0
- package/src/text/icons/index.ts +30 -0
- package/src/text/index.ts +16 -0
- package/src/text/pdfRender.ts +239 -0
- package/src/text/propPanel.ts +184 -0
- package/src/text/types.ts +30 -0
- package/src/text/uiRender.ts +288 -0
- package/src/utils.ts +281 -0
- package/tsconfig.cjs.json +10 -0
- package/tsconfig.esm.json +11 -0
- package/tsconfig.json +6 -0
- package/tsconfig.node.json +11 -0
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
import type { ChangeEvent } from 'react';
|
|
2
|
+
import type { PDFImage } from '@pdfme/pdf-lib';
|
|
3
|
+
import type { Plugin } from '@pdfme/common';
|
|
4
|
+
import type { Schema } from '@pdfme/common';
|
|
5
|
+
import type * as CSS from 'csstype';
|
|
6
|
+
import { px2mm } from '@pdfme/common';
|
|
7
|
+
import { Image } from 'lucide';
|
|
8
|
+
import {
|
|
9
|
+
convertForPdfLayoutProps,
|
|
10
|
+
addAlphaToHex,
|
|
11
|
+
isEditable,
|
|
12
|
+
readFile,
|
|
13
|
+
createSvgStr,
|
|
14
|
+
} from '../utils.js';
|
|
15
|
+
import { DEFAULT_OPACITY } from '../constants.js';
|
|
16
|
+
import { getImageDimension } from './imagehelper.js';
|
|
17
|
+
|
|
18
|
+
const getCacheKey = (schema: Schema, input: string) => `${schema.type}${input}`;
|
|
19
|
+
const fullSize = { width: '100%', height: '100%' };
|
|
20
|
+
const defaultValue =
|
|
21
|
+
'';
|
|
22
|
+
|
|
23
|
+
type ImageSchema = Schema;
|
|
24
|
+
|
|
25
|
+
const imageSchema: Plugin<ImageSchema> = {
|
|
26
|
+
pdf: async (arg) => {
|
|
27
|
+
const { value, schema, pdfDoc, page, _cache } = arg;
|
|
28
|
+
if (!value) return;
|
|
29
|
+
|
|
30
|
+
const inputImageCacheKey = getCacheKey(schema, value);
|
|
31
|
+
let image = _cache.get(inputImageCacheKey) as PDFImage;
|
|
32
|
+
if (!image) {
|
|
33
|
+
const isPng = value.startsWith('data:image/png;');
|
|
34
|
+
image = await (isPng ? pdfDoc.embedPng(value) : pdfDoc.embedJpg(value));
|
|
35
|
+
_cache.set(inputImageCacheKey, image);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
const _schema = { ...schema, position: { ...schema.position } };
|
|
39
|
+
const dimension = getImageDimension(value);
|
|
40
|
+
const imageWidth = px2mm(dimension.width);
|
|
41
|
+
const imageHeight = px2mm(dimension.height);
|
|
42
|
+
const boxWidth = _schema.width;
|
|
43
|
+
const boxHeight = _schema.height;
|
|
44
|
+
|
|
45
|
+
const imageRatio = imageWidth / imageHeight;
|
|
46
|
+
const boxRatio = boxWidth / boxHeight;
|
|
47
|
+
|
|
48
|
+
if (imageRatio > boxRatio) {
|
|
49
|
+
_schema.width = boxWidth;
|
|
50
|
+
_schema.height = boxWidth / imageRatio;
|
|
51
|
+
_schema.position.y += (boxHeight - _schema.height) / 2;
|
|
52
|
+
} else {
|
|
53
|
+
_schema.width = boxHeight * imageRatio;
|
|
54
|
+
_schema.height = boxHeight;
|
|
55
|
+
_schema.position.x += (boxWidth - _schema.width) / 2;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
const pageHeight = page.getHeight();
|
|
59
|
+
const lProps = convertForPdfLayoutProps({ schema: _schema, pageHeight });
|
|
60
|
+
const { width, height, rotate, position, opacity } = lProps;
|
|
61
|
+
const { x, y } = position;
|
|
62
|
+
|
|
63
|
+
const drawOptions = { x, y, rotate, width, height, opacity };
|
|
64
|
+
page.drawImage(image, drawOptions);
|
|
65
|
+
},
|
|
66
|
+
ui: (arg) => {
|
|
67
|
+
const {
|
|
68
|
+
value,
|
|
69
|
+
rootElement,
|
|
70
|
+
mode,
|
|
71
|
+
onChange,
|
|
72
|
+
stopEditing,
|
|
73
|
+
tabIndex,
|
|
74
|
+
placeholder,
|
|
75
|
+
theme,
|
|
76
|
+
schema,
|
|
77
|
+
} = arg;
|
|
78
|
+
const editable = isEditable(mode, schema);
|
|
79
|
+
const isDefault = value === defaultValue;
|
|
80
|
+
|
|
81
|
+
const container = document.createElement('div');
|
|
82
|
+
const backgroundStyle = placeholder ? `url(${placeholder})` : 'none';
|
|
83
|
+
const containerStyle: CSS.Properties = {
|
|
84
|
+
...fullSize,
|
|
85
|
+
backgroundImage: value ? 'none' : backgroundStyle,
|
|
86
|
+
backgroundSize: `contain`,
|
|
87
|
+
backgroundRepeat: 'no-repeat',
|
|
88
|
+
backgroundPosition: 'center',
|
|
89
|
+
};
|
|
90
|
+
Object.assign(container.style, containerStyle);
|
|
91
|
+
container.addEventListener('click', (e) => {
|
|
92
|
+
if (editable) {
|
|
93
|
+
e.stopPropagation();
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
rootElement.appendChild(container);
|
|
97
|
+
|
|
98
|
+
// image tag
|
|
99
|
+
if (value) {
|
|
100
|
+
const img = document.createElement('img');
|
|
101
|
+
const imgStyle: CSS.Properties = {
|
|
102
|
+
height: '100%',
|
|
103
|
+
width: '100%',
|
|
104
|
+
borderRadius: 0,
|
|
105
|
+
objectFit: 'contain',
|
|
106
|
+
};
|
|
107
|
+
Object.assign(img.style, imgStyle);
|
|
108
|
+
img.src = value;
|
|
109
|
+
container.appendChild(img);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
// remove button
|
|
113
|
+
if (value && !isDefault && editable) {
|
|
114
|
+
const button = document.createElement('button');
|
|
115
|
+
button.textContent = 'x';
|
|
116
|
+
const buttonStyle: CSS.Properties = {
|
|
117
|
+
position: 'absolute',
|
|
118
|
+
top: 0,
|
|
119
|
+
left: 0,
|
|
120
|
+
zIndex: 1,
|
|
121
|
+
display: 'flex',
|
|
122
|
+
justifyContent: 'center',
|
|
123
|
+
alignItems: 'center',
|
|
124
|
+
color: '#333',
|
|
125
|
+
background: '#f2f2f2',
|
|
126
|
+
borderRadius: '2px',
|
|
127
|
+
border: '1px solid #767676',
|
|
128
|
+
cursor: 'pointer',
|
|
129
|
+
height: '24px',
|
|
130
|
+
width: '24px',
|
|
131
|
+
};
|
|
132
|
+
Object.assign(button.style, buttonStyle);
|
|
133
|
+
button.addEventListener('click', () => {
|
|
134
|
+
if (onChange) onChange({ key: 'content', value: '' });
|
|
135
|
+
});
|
|
136
|
+
container.appendChild(button);
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
// file input
|
|
140
|
+
if ((!value || isDefault) && editable) {
|
|
141
|
+
const label = document.createElement('label');
|
|
142
|
+
const labelStyle: CSS.Properties = {
|
|
143
|
+
...fullSize,
|
|
144
|
+
display: editable ? 'flex' : 'none',
|
|
145
|
+
position: 'absolute',
|
|
146
|
+
top: 0,
|
|
147
|
+
backgroundColor: editable || value ? addAlphaToHex(theme.colorPrimaryBg, 30) : 'none',
|
|
148
|
+
cursor: 'pointer',
|
|
149
|
+
};
|
|
150
|
+
Object.assign(label.style, labelStyle);
|
|
151
|
+
container.appendChild(label);
|
|
152
|
+
const input = document.createElement('input');
|
|
153
|
+
const inputStyle: CSS.Properties = {
|
|
154
|
+
...fullSize,
|
|
155
|
+
position: 'absolute',
|
|
156
|
+
top: '50%',
|
|
157
|
+
left: '50%',
|
|
158
|
+
width: '180px',
|
|
159
|
+
height: '30px',
|
|
160
|
+
marginLeft: '-90px',
|
|
161
|
+
marginTop: '-15px',
|
|
162
|
+
};
|
|
163
|
+
Object.assign(input.style, inputStyle);
|
|
164
|
+
input.tabIndex = tabIndex || 0;
|
|
165
|
+
input.type = 'file';
|
|
166
|
+
input.accept = 'image/jpeg, image/png';
|
|
167
|
+
input.addEventListener('change', (event: Event) => {
|
|
168
|
+
const changeEvent = event as unknown as ChangeEvent<HTMLInputElement>;
|
|
169
|
+
readFile(changeEvent.target.files)
|
|
170
|
+
.then((result) => {
|
|
171
|
+
if (onChange) onChange({ key: 'content', value: result as string });
|
|
172
|
+
})
|
|
173
|
+
.catch((error) => {
|
|
174
|
+
console.error('Error reading file:', error);
|
|
175
|
+
});
|
|
176
|
+
});
|
|
177
|
+
input.addEventListener('blur', () => {
|
|
178
|
+
if (stopEditing) stopEditing();
|
|
179
|
+
});
|
|
180
|
+
label.appendChild(input);
|
|
181
|
+
}
|
|
182
|
+
},
|
|
183
|
+
propPanel: {
|
|
184
|
+
schema: {},
|
|
185
|
+
defaultSchema: {
|
|
186
|
+
name: '',
|
|
187
|
+
type: 'image',
|
|
188
|
+
content: defaultValue,
|
|
189
|
+
position: { x: 0, y: 0 },
|
|
190
|
+
width: 40,
|
|
191
|
+
height: 40,
|
|
192
|
+
// If the value of "rotate" is set to undefined or not set at all, rotation will be disabled in the UI.
|
|
193
|
+
// Check this document: https://pdfme.com//docs/custom-schemas#learning-how-to-create-from-pdfmeschemas-code
|
|
194
|
+
rotate: 0,
|
|
195
|
+
opacity: DEFAULT_OPACITY,
|
|
196
|
+
},
|
|
197
|
+
},
|
|
198
|
+
icon: createSvgStr(Image),
|
|
199
|
+
};
|
|
200
|
+
|
|
201
|
+
export default imageSchema;
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
// ref: https://github.com/image-size/image-size ----------------------------
|
|
2
|
+
// The following code is adapted from the image-size code. Unnecessary formats and dependencies on Node have been removed.
|
|
3
|
+
import { Buffer } from 'buffer';
|
|
4
|
+
|
|
5
|
+
type IImage = {
|
|
6
|
+
validate: (input: Uint8Array) => boolean;
|
|
7
|
+
calculate: (input: Uint8Array) => { width: number; height: number } | undefined;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
const decoder = new TextDecoder();
|
|
11
|
+
const toUTF8String = (input: Uint8Array, start = 0, end = input.length) =>
|
|
12
|
+
decoder.decode(input.slice(start, end));
|
|
13
|
+
|
|
14
|
+
const toHexString = (input: Uint8Array, start = 0, end = input.length) =>
|
|
15
|
+
input.slice(start, end).reduce((memo, i) => memo + ('0' + i.toString(16)).slice(-2), '');
|
|
16
|
+
|
|
17
|
+
const readUInt16BE = (input: Uint8Array, offset = 0) => input[offset] * 2 ** 8 + input[offset + 1];
|
|
18
|
+
|
|
19
|
+
const readUInt32BE = (input: Uint8Array, offset = 0) =>
|
|
20
|
+
input[offset] * 2 ** 24 +
|
|
21
|
+
input[offset + 1] * 2 ** 16 +
|
|
22
|
+
input[offset + 2] * 2 ** 8 +
|
|
23
|
+
input[offset + 3];
|
|
24
|
+
|
|
25
|
+
const extractSize = (input: Uint8Array, index: number) => {
|
|
26
|
+
return {
|
|
27
|
+
height: readUInt16BE(input, index),
|
|
28
|
+
width: readUInt16BE(input, index + 2),
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
const validateInput = (input: Uint8Array, index: number): void => {
|
|
33
|
+
// index should be within buffer limits
|
|
34
|
+
if (index > input.length) {
|
|
35
|
+
throw new TypeError('Corrupt JPG, exceeded buffer limits');
|
|
36
|
+
}
|
|
37
|
+
// Every JPEG block must begin with a 0xFF
|
|
38
|
+
if (input[index] !== 0xff) {
|
|
39
|
+
throw new TypeError('Invalid JPG, marker table corrupted');
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const JPG: IImage = {
|
|
44
|
+
validate: (input) => toHexString(input, 0, 2) === 'ffd8',
|
|
45
|
+
|
|
46
|
+
calculate(input) {
|
|
47
|
+
// Skip 4 chars, they are for signature
|
|
48
|
+
input = input.slice(4);
|
|
49
|
+
|
|
50
|
+
let next: number;
|
|
51
|
+
while (input.length) {
|
|
52
|
+
// read length of the next block
|
|
53
|
+
const i = readUInt16BE(input, 0);
|
|
54
|
+
|
|
55
|
+
// ensure correct format
|
|
56
|
+
validateInput(input, i);
|
|
57
|
+
|
|
58
|
+
// 0xFFC0 is baseline standard(SOF)
|
|
59
|
+
// 0xFFC1 is baseline optimized(SOF)
|
|
60
|
+
// 0xFFC2 is progressive(SOF2)
|
|
61
|
+
next = input[i + 1];
|
|
62
|
+
if (next === 0xc0 || next === 0xc1 || next === 0xc2) {
|
|
63
|
+
const size = extractSize(input, i + 5);
|
|
64
|
+
|
|
65
|
+
return size;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// move to the next block
|
|
69
|
+
input = input.slice(i + 2);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
throw new TypeError('Invalid JPG, no size found');
|
|
73
|
+
},
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
const pngSignature = 'PNG\r\n\x1a\n';
|
|
77
|
+
const pngImageHeaderChunkName = 'IHDR';
|
|
78
|
+
|
|
79
|
+
// Used to detect "fried" png's: http://www.jongware.com/pngdefry.html
|
|
80
|
+
const pngFriedChunkName = 'CgBI';
|
|
81
|
+
|
|
82
|
+
const PNG: IImage = {
|
|
83
|
+
validate(input) {
|
|
84
|
+
if (pngSignature === toUTF8String(input, 1, 8)) {
|
|
85
|
+
let chunkName = toUTF8String(input, 12, 16);
|
|
86
|
+
if (chunkName === pngFriedChunkName) {
|
|
87
|
+
chunkName = toUTF8String(input, 28, 32);
|
|
88
|
+
}
|
|
89
|
+
if (chunkName !== pngImageHeaderChunkName) {
|
|
90
|
+
throw new TypeError('Invalid PNG');
|
|
91
|
+
}
|
|
92
|
+
return true;
|
|
93
|
+
}
|
|
94
|
+
return false;
|
|
95
|
+
},
|
|
96
|
+
|
|
97
|
+
calculate(input) {
|
|
98
|
+
if (toUTF8String(input, 12, 16) === pngFriedChunkName) {
|
|
99
|
+
return {
|
|
100
|
+
height: readUInt32BE(input, 36),
|
|
101
|
+
width: readUInt32BE(input, 32),
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
return {
|
|
105
|
+
height: readUInt32BE(input, 20),
|
|
106
|
+
width: readUInt32BE(input, 16),
|
|
107
|
+
};
|
|
108
|
+
},
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
const typeHandlers = {
|
|
112
|
+
jpg: JPG,
|
|
113
|
+
png: PNG,
|
|
114
|
+
};
|
|
115
|
+
|
|
116
|
+
type imageType = keyof typeof typeHandlers;
|
|
117
|
+
|
|
118
|
+
function detector(input: Uint8Array): imageType | undefined {
|
|
119
|
+
const firstBytes: { [byte: number]: imageType } = {
|
|
120
|
+
0x89: 'png',
|
|
121
|
+
0xff: 'jpg',
|
|
122
|
+
};
|
|
123
|
+
const byte = input[0];
|
|
124
|
+
if (byte in firstBytes) {
|
|
125
|
+
const type = firstBytes[byte];
|
|
126
|
+
if (type && typeHandlers[type].validate(input)) {
|
|
127
|
+
return type;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
const keys = Object.keys(typeHandlers) as imageType[];
|
|
132
|
+
return keys.find((key: imageType) => typeHandlers[key].validate(input));
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
export const getImageDimension = (value: string): { height: number; width: number } => {
|
|
136
|
+
const dataUriPrefix = ';base64,';
|
|
137
|
+
const idx = value.indexOf(dataUriPrefix);
|
|
138
|
+
const imgBase64 = value.substring(idx + dataUriPrefix.length, value.length);
|
|
139
|
+
return imageSize(Buffer.from(imgBase64, 'base64'));
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
const imageSize = (imgBuffer: Buffer): { height: number; width: number } => {
|
|
143
|
+
const type = detector(imgBuffer);
|
|
144
|
+
|
|
145
|
+
if (typeof type !== 'undefined' && type in typeHandlers) {
|
|
146
|
+
const size = typeHandlers[type].calculate(imgBuffer);
|
|
147
|
+
if (size !== undefined) {
|
|
148
|
+
return size;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
throw new TypeError(
|
|
153
|
+
'[@pdfme/schemas/images] Unsupported file type: ' + (type === undefined ? 'undefined' : type),
|
|
154
|
+
);
|
|
155
|
+
};
|
|
156
|
+
// ----------------------------
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { Plugin, Schema } from '@pdfme/common';
|
|
2
|
+
import {
|
|
3
|
+
convertForPdfLayoutProps,
|
|
4
|
+
isEditable,
|
|
5
|
+
addAlphaToHex,
|
|
6
|
+
createErrorElm,
|
|
7
|
+
createSvgStr,
|
|
8
|
+
} from '../utils.js';
|
|
9
|
+
import { Route } from 'lucide';
|
|
10
|
+
|
|
11
|
+
const isValidSVG = (svgString: string): boolean => {
|
|
12
|
+
try {
|
|
13
|
+
// Basic validation checks that work in both Node.js and browser
|
|
14
|
+
if (!svgString || typeof svgString !== 'string') {
|
|
15
|
+
return false;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
// Check for basic SVG structure
|
|
19
|
+
if (!svgString.includes('<svg') || !svgString.includes('</svg>')) {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// Additional browser-specific validation if DOMParser is available
|
|
24
|
+
if (typeof DOMParser !== 'undefined') {
|
|
25
|
+
const parser = new DOMParser();
|
|
26
|
+
const doc = parser.parseFromString(svgString, 'image/svg+xml');
|
|
27
|
+
const parserError = doc.querySelector('parsererror');
|
|
28
|
+
if (parserError !== null) {
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return true;
|
|
34
|
+
} catch {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
const defaultValue = `<svg viewBox="0 0 488 600" version="1.1" xmlns="http://www.w3.org/2000/svg">
|
|
40
|
+
<g transform="matrix(1,0,0,1,-56,0)" fill="#000000" stroke="none">
|
|
41
|
+
<path d="M228.667,0L56,172.667L56.267,345.334L56.667,518L59.733,527.334C65.867,545.467 72.933,557.067 86,570.134C96.133,580.4 100,583.2 110.667,588.4C134.533,600.134 120,599.334 300,599.334C480,599.334 465.467,600.134 489.334,588.4C500,583.2 503.867,580.4 514,570.134C527.334,556.8 534.534,544.8 540.267,526.667L543.334,516.667L543.334,83.333L540.267,73.333C534.534,55.2 527.334,43.2 514,29.867C503.867,19.6 500,16.8 489.334,11.6C465.734,0 475.467,0.8 344.667,0.267L228.667,0ZM466.4,41.6C483.334,48.933 496.267,61.867 502.934,78.4L506,86L506,514L502.934,521.734C496,538.934 480.267,553.867 463.334,559.334C455.6,561.867 450.8,562 300,562C149.2,562 144.4,561.867 136.667,559.334C119.733,553.867 104,538.934 97.067,521.734L94,514L93.6,351.067L93.333,188.133L149.067,187.733L204.667,187.333L213.6,182.933C224.8,177.467 235.867,165.867 240.267,155.067C243.333,147.467 243.333,146.4 243.733,92.267L244.133,37.2L458,38L466.4,41.6ZM195.067,304C175.6,306.8 164,320.667 165.6,339.467C166,343.6 167.6,348.667 169.733,352.4C174.4,360.267 185.2,365.734 201.867,368.534C208.4,369.734 215.067,371.467 216.8,372.667C224,377.334 221.467,389.067 212.533,392C205.6,394.4 193.733,392.934 185.6,388.8C173.333,382.534 164,385.334 164,395.2C164,400.934 170.133,406.667 180.267,410.134C190.933,413.867 217.067,413.734 225.467,409.867C238.933,403.6 246.667,390 244.8,375.6C242.667,359.734 232.8,351.334 212.267,347.867C193.6,344.8 189.333,342.4 189.333,334.533C189.333,324.267 201.867,320.933 218.267,326.667C228.667,330.267 232.533,330.133 235.867,325.867C242.133,318 237.6,310.667 224.267,306.8C213.333,303.6 204.267,302.8 195.067,304ZM386,304.133C377.6,305.333 374,306.8 367.334,311.6C355.734,320.133 351.2,336.4 352.4,365.334C353.2,385.334 356,394.4 364.134,402.534C372.267,410.667 381.734,413.734 396.667,413.067C406.8,412.667 409.734,412 415.734,408.667C429.2,401.334 434.534,390.934 435.6,370.667C436.4,353.734 436,353.067 420.934,352.267C401.867,351.334 396,353.467 396,361.867C396,367.867 399.467,370.667 407.067,370.667C413.2,370.667 413.334,370.667 413.334,374.934C413.334,394 386.267,400.534 378.534,383.467C374.934,375.334 374.934,341.867 378.534,333.733C382,326.4 387.467,323.467 396.8,324.267C403.067,324.8 404.667,325.6 410.534,331.067C414.267,334.533 418.4,337.333 419.867,337.333C427.334,337.333 433.334,330.267 431.334,323.733C427.2,310.133 406.4,301.2 386,304.133ZM258.4,308C255.067,311.467 254.533,312.8 255.2,316.4C257.067,326.667 285.333,405.867 288.133,408.8C289.733,410.534 293.067,412.267 295.333,412.8C303.867,414.4 310.667,407.867 314.4,394.667C315.067,392.134 321.2,374.134 327.867,354.8C334.8,334.533 340,317.467 340,314.533C340,303.733 325.067,299.867 319.867,309.467C318.533,312.133 309.467,340.933 302.667,364C301.067,369.467 299.333,374.4 298.8,375.067C298.267,375.6 292.933,360.8 286.933,342C275.333,306 274.133,304 266.267,304C263.867,304 261.067,305.467 258.4,308Z" style="fill-rule:nonzero;"/>
|
|
42
|
+
</g>
|
|
43
|
+
</svg>`;
|
|
44
|
+
|
|
45
|
+
export type SVGSchema = Schema;
|
|
46
|
+
|
|
47
|
+
const svgSchema: Plugin<SVGSchema> = {
|
|
48
|
+
ui: (arg) => {
|
|
49
|
+
const { rootElement, value, mode, onChange, theme, schema } = arg;
|
|
50
|
+
const container = document.createElement(isEditable(mode, schema) ? 'textarea' : 'div');
|
|
51
|
+
container.style.width = '100%';
|
|
52
|
+
container.style.height = '100%';
|
|
53
|
+
container.style.boxSizing = 'border-box';
|
|
54
|
+
if (isEditable(mode, schema)) {
|
|
55
|
+
const textarea = container as HTMLTextAreaElement;
|
|
56
|
+
textarea.value = value;
|
|
57
|
+
textarea.style.position = 'absolute';
|
|
58
|
+
textarea.style.backgroundColor = addAlphaToHex(theme.colorPrimaryBg, 30);
|
|
59
|
+
|
|
60
|
+
if (isValidSVG(value)) {
|
|
61
|
+
const svgElement = new DOMParser().parseFromString(value, 'text/xml').childNodes[0];
|
|
62
|
+
if (svgElement instanceof SVGElement) {
|
|
63
|
+
svgElement.setAttribute('width', '100%');
|
|
64
|
+
svgElement.setAttribute('height', '100%');
|
|
65
|
+
svgElement.style.position = 'absolute';
|
|
66
|
+
}
|
|
67
|
+
rootElement.appendChild(svgElement);
|
|
68
|
+
} else if (value) {
|
|
69
|
+
const errorElm = createErrorElm();
|
|
70
|
+
errorElm.style.position = 'absolute';
|
|
71
|
+
rootElement.appendChild(errorElm);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
textarea.addEventListener('change', (e: Event) => {
|
|
75
|
+
const newValue = (e.target as HTMLTextAreaElement).value;
|
|
76
|
+
if (onChange) onChange({ key: 'content', value: newValue });
|
|
77
|
+
});
|
|
78
|
+
rootElement.appendChild(container);
|
|
79
|
+
textarea.setSelectionRange(value.length, value.length);
|
|
80
|
+
textarea.focus();
|
|
81
|
+
} else {
|
|
82
|
+
if (!value) return;
|
|
83
|
+
if (!isValidSVG(value)) {
|
|
84
|
+
rootElement.appendChild(createErrorElm());
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
container.innerHTML = value;
|
|
88
|
+
const svgElement = container.childNodes[0];
|
|
89
|
+
if (svgElement instanceof SVGElement) {
|
|
90
|
+
svgElement.setAttribute('width', '100%');
|
|
91
|
+
svgElement.setAttribute('height', '100%');
|
|
92
|
+
rootElement.appendChild(container);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
},
|
|
96
|
+
pdf: async (arg) => {
|
|
97
|
+
const { page, schema, value } = arg;
|
|
98
|
+
if (!value || !isValidSVG(value)) return;
|
|
99
|
+
const pageHeight = page.getHeight();
|
|
100
|
+
const { width, height, position } = convertForPdfLayoutProps({ schema, pageHeight });
|
|
101
|
+
const { x, y } = position;
|
|
102
|
+
await page.drawSvg(value, { x, y: y + height, width, height });
|
|
103
|
+
},
|
|
104
|
+
propPanel: {
|
|
105
|
+
schema: {},
|
|
106
|
+
defaultSchema: {
|
|
107
|
+
name: '',
|
|
108
|
+
type: 'svg',
|
|
109
|
+
content: defaultValue,
|
|
110
|
+
position: { x: 0, y: 0 },
|
|
111
|
+
width: 40,
|
|
112
|
+
height: 50,
|
|
113
|
+
},
|
|
114
|
+
},
|
|
115
|
+
icon: createSvgStr(Route),
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
export default svgSchema;
|
package/src/index.ts
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import multiVariableText from './multiVariableText/index.js';
|
|
2
|
+
import text from './text/index.js';
|
|
3
|
+
import image from './graphics/image.js';
|
|
4
|
+
import svg from './graphics/svg.js';
|
|
5
|
+
import barcodes from './barcodes/index.js';
|
|
6
|
+
import line from './shapes/line.js';
|
|
7
|
+
import table from './tables/index.js';
|
|
8
|
+
import { rectangle, ellipse } from './shapes/rectAndEllipse.js';
|
|
9
|
+
import dateTime from './date/dateTime.js';
|
|
10
|
+
import date from './date/date.js';
|
|
11
|
+
import time from './date/time.js';
|
|
12
|
+
import select from './select/index.js';
|
|
13
|
+
import radioGroup from './radioGroup/index.js';
|
|
14
|
+
import checkbox from './checkbox/index.js';
|
|
15
|
+
|
|
16
|
+
const builtInPlugins = { Text: text };
|
|
17
|
+
|
|
18
|
+
export {
|
|
19
|
+
builtInPlugins,
|
|
20
|
+
// schemas
|
|
21
|
+
text,
|
|
22
|
+
multiVariableText,
|
|
23
|
+
image,
|
|
24
|
+
svg,
|
|
25
|
+
table,
|
|
26
|
+
barcodes,
|
|
27
|
+
line,
|
|
28
|
+
rectangle,
|
|
29
|
+
ellipse,
|
|
30
|
+
dateTime,
|
|
31
|
+
date,
|
|
32
|
+
time,
|
|
33
|
+
select,
|
|
34
|
+
radioGroup,
|
|
35
|
+
checkbox,
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
// Export utility functions
|
|
39
|
+
export { getDynamicHeightsForTable } from './tables/dynamicTemplate.js';
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { MultiVariableTextSchema } from './types.js';
|
|
2
|
+
|
|
3
|
+
export const substituteVariables = (
|
|
4
|
+
text: string,
|
|
5
|
+
variablesIn: string | Record<string, string>,
|
|
6
|
+
): string => {
|
|
7
|
+
if (!text) {
|
|
8
|
+
return '';
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
let substitutedText = text;
|
|
12
|
+
|
|
13
|
+
if (variablesIn) {
|
|
14
|
+
let variables: Record<string, string>;
|
|
15
|
+
try {
|
|
16
|
+
variables =
|
|
17
|
+
typeof variablesIn === 'string'
|
|
18
|
+
? (JSON.parse(variablesIn || '{}') as Record<string, string>)
|
|
19
|
+
: variablesIn;
|
|
20
|
+
} catch {
|
|
21
|
+
throw new SyntaxError(`[@pdfme/schemas] MVT: invalid JSON string '${variablesIn as string}'`);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
Object.keys(variables).forEach((variableName) => {
|
|
25
|
+
// handle special characters in variable name
|
|
26
|
+
const variableForRegex = variableName.replace(/[/\-\\^$*+?.()|[\]{}]/g, '\\$&');
|
|
27
|
+
const regex = new RegExp('\\{' + variableForRegex + '\\}', 'g');
|
|
28
|
+
substitutedText = substitutedText.replace(regex, variables[variableName]);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// Remove any variables that were not substituted from inputs
|
|
33
|
+
substitutedText = substitutedText.replace(/{[^{}]+}/g, '');
|
|
34
|
+
|
|
35
|
+
return substitutedText;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
export const validateVariables = (value: string, schema: MultiVariableTextSchema): boolean => {
|
|
39
|
+
if (schema.variables.length === 0) {
|
|
40
|
+
return true;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
let values;
|
|
44
|
+
try {
|
|
45
|
+
values = value ? (JSON.parse(value) as Record<string, string>) : {};
|
|
46
|
+
} catch {
|
|
47
|
+
throw new SyntaxError(
|
|
48
|
+
`[@pdfme/generator] invalid JSON string '${value}' for variables in field ${schema.name}`,
|
|
49
|
+
);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
for (const variable of schema.variables) {
|
|
53
|
+
if (!values[variable]) {
|
|
54
|
+
if (schema.required) {
|
|
55
|
+
throw new Error(
|
|
56
|
+
`[@pdfme/generator] variable ${variable} is missing for field ${schema.name}`,
|
|
57
|
+
);
|
|
58
|
+
}
|
|
59
|
+
// If not required, then simply don't render this field if an input is missing
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return true;
|
|
65
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Plugin } from '@pdfme/common';
|
|
2
|
+
import { pdfRender } from './pdfRender.js';
|
|
3
|
+
import { propPanel } from './propPanel.js';
|
|
4
|
+
import { uiRender } from './uiRender.js';
|
|
5
|
+
import type { MultiVariableTextSchema } from './types.js';
|
|
6
|
+
import { Type } from 'lucide';
|
|
7
|
+
import { createSvgStr } from '../utils.js';
|
|
8
|
+
|
|
9
|
+
const schema: Plugin<MultiVariableTextSchema> = {
|
|
10
|
+
pdf: pdfRender,
|
|
11
|
+
ui: uiRender,
|
|
12
|
+
propPanel,
|
|
13
|
+
icon: createSvgStr(Type),
|
|
14
|
+
uninterruptedEditMode: true,
|
|
15
|
+
};
|
|
16
|
+
export default schema;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { PDFRenderProps } from '@pdfme/common';
|
|
2
|
+
import { MultiVariableTextSchema } from './types.js';
|
|
3
|
+
import { pdfRender as parentPdfRender } from '../text/pdfRender.js';
|
|
4
|
+
import { substituteVariables, validateVariables } from './helper.js';
|
|
5
|
+
|
|
6
|
+
export const pdfRender = async (arg: PDFRenderProps<MultiVariableTextSchema>) => {
|
|
7
|
+
const { value, schema, ...rest } = arg;
|
|
8
|
+
|
|
9
|
+
if (!validateVariables(value, schema)) {
|
|
10
|
+
// Don't render if a required variable is missing
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const renderArgs = {
|
|
15
|
+
value: substituteVariables(schema.text || '', value),
|
|
16
|
+
schema,
|
|
17
|
+
...rest,
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
await parentPdfRender(renderArgs);
|
|
21
|
+
};
|