@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
|
+
'data:image/png;base64,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';
|
|
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
|
+
};
|