@sme.up/doc-alchemist 1.5.0 → 1.6.0-20251215100834
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/dist/converters/excel/commons.d.ts +1 -0
- package/dist/converters/excel/commons.js +11 -1
- package/dist/converters/excel/commons.js.map +1 -1
- package/dist/converters/excel-converter.js +2 -1
- package/dist/converters/excel-converter.js.map +1 -1
- package/dist/converters/images/charts-converter-types.d.ts +15 -0
- package/dist/converters/images/charts-converter-types.js +11 -0
- package/dist/converters/images/charts-converter-types.js.map +1 -0
- package/dist/converters/images/{charts-generator.d.ts → charts-converter.d.ts} +4 -4
- package/dist/converters/images/charts-converter.js +82 -0
- package/dist/converters/images/charts-converter.js.map +1 -0
- package/dist/converters/images/charts-data-converter.d.ts +7 -0
- package/dist/converters/images/charts-data-converter.js +94 -0
- package/dist/converters/images/charts-data-converter.js.map +1 -0
- package/dist/converters/pdf/pdfmake/adapter-processor.js +4 -2
- package/dist/converters/pdf/pdfmake/adapter-processor.js.map +1 -1
- package/dist/converters/pdf/pdfmake/adapters/chart-adapter.d.ts +38 -0
- package/dist/converters/pdf/pdfmake/adapters/chart-adapter.js +117 -0
- package/dist/converters/pdf/pdfmake/adapters/chart-adapter.js.map +1 -0
- package/dist/converters/pdf/pdfmake/{image-adapter.d.ts → adapters/image-adapter.d.ts} +1 -1
- package/dist/converters/pdf/pdfmake/adapters/image-adapter.js.map +1 -0
- package/dist/converters/pdf/pdfmake/adapters/layout-adapter.d.ts +16 -0
- package/dist/converters/pdf/pdfmake/adapters/layout-adapter.js +76 -0
- package/dist/converters/pdf/pdfmake/adapters/layout-adapter.js.map +1 -0
- package/dist/converters/pdf/pdfmake/adapters/page-element-adapter.d.ts +9 -0
- package/dist/converters/pdf/pdfmake/{page-element-adapter.js → adapters/page-element-adapter.js} +14 -7
- package/dist/converters/pdf/pdfmake/adapters/page-element-adapter.js.map +1 -0
- package/dist/converters/pdf/pdfmake/{table-adapter.d.ts → adapters/table-adapter.d.ts} +1 -1
- package/dist/converters/pdf/pdfmake/{table-adapter.js → adapters/table-adapter.js} +5 -5
- package/dist/converters/pdf/pdfmake/adapters/table-adapter.js.map +1 -0
- package/dist/converters/pdf/pdfmake/pdfmake.types.d.ts +28 -2
- package/dist/converters/pdf/pdfmake/pdfmake.types.js.map +1 -1
- package/dist/converters/pdf-converter.d.ts +0 -2
- package/dist/converters/pdf-converter.js +13 -11
- package/dist/converters/pdf-converter.js.map +1 -1
- package/dist/index.d.ts +4 -4
- package/dist/index.js +5 -6
- package/dist/index.js.map +1 -1
- package/dist/types/component.d.ts +2 -2
- package/dist/types/component.js.map +1 -1
- package/dist/types/data-structures/smeupSch.d.ts +1 -1
- package/dist/types/data-structures/smeupSch.js.map +1 -1
- package/dist/types/general.d.ts +4 -0
- package/dist/types/general.js +6 -1
- package/dist/types/general.js.map +1 -1
- package/dist/types/index.d.ts +0 -5
- package/dist/types/index.js.map +1 -1
- package/dist/utils/datastructure-utility.js.map +1 -1
- package/package.json +1 -2
- package/dist/converters/images/charts-generator.js +0 -287
- package/dist/converters/images/charts-generator.js.map +0 -1
- package/dist/converters/pdf/pdfmake/image-adapter.js.map +0 -1
- package/dist/converters/pdf/pdfmake/page-element-adapter.d.ts +0 -8
- package/dist/converters/pdf/pdfmake/page-element-adapter.js.map +0 -1
- package/dist/converters/pdf/pdfmake/table-adapter.js.map +0 -1
- package/dist/converters/pdf/sch-converter.d.ts +0 -3
- package/dist/converters/pdf/sch-converter.js +0 -136
- package/dist/converters/pdf/sch-converter.js.map +0 -1
- package/dist/types/helpers.d.ts +0 -4
- package/dist/types/helpers.js +0 -9
- package/dist/types/helpers.js.map +0 -1
- /package/dist/converters/pdf/pdfmake/{image-adapter.js → adapters/image-adapter.js} +0 -0
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// ...
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.chartAdapter = exports.funToSmeupChartAdapter = exports.smeupChartToPdfMakeSvgAdapter = void 0;
|
|
5
|
+
const smeupDataStructure_1 = require("../../../../types/data-structures/smeupDataStructure");
|
|
6
|
+
const charts_converter_1 = require("../../../images/charts-converter");
|
|
7
|
+
const hasChartWithData = (element) => {
|
|
8
|
+
const chart = element
|
|
9
|
+
?.chart;
|
|
10
|
+
const data = chart?.smeup?.data;
|
|
11
|
+
return (data?.type === smeupDataStructure_1.SmeupDataStructureType.SmeupDataTable &&
|
|
12
|
+
Array.isArray(data?.rows) &&
|
|
13
|
+
Array.isArray(data?.columns));
|
|
14
|
+
};
|
|
15
|
+
const hasChartWithFun = (element) => {
|
|
16
|
+
const chart = element
|
|
17
|
+
?.chart;
|
|
18
|
+
const fun = chart?.smeup?.fun;
|
|
19
|
+
return typeof fun === "string" && fun.length > 0;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Adapts a Smeup chart structure to the PDFMake SVG format.
|
|
23
|
+
*
|
|
24
|
+
* This adapter function checks if the provided element contains a chart with data.
|
|
25
|
+
* If so, it generates an SVG representation from the chart data and replaces the chart
|
|
26
|
+
* object with an svg property. All properties of the original chart except `data` are preserved.
|
|
27
|
+
*
|
|
28
|
+
* @returns A function that takes an element and returns the adapted element for PDFMake,
|
|
29
|
+
* or the original element if it does not contain a valid chart with data.
|
|
30
|
+
*/
|
|
31
|
+
const smeupChartToPdfMakeSvgAdapter = () => {
|
|
32
|
+
return async (element, _context) => {
|
|
33
|
+
if (!hasChartWithData(element)) {
|
|
34
|
+
return element;
|
|
35
|
+
}
|
|
36
|
+
const elementWithChart = element;
|
|
37
|
+
const options = elementWithChart.chart.smeup.options;
|
|
38
|
+
const svg = await (0, charts_converter_1.dataTableToChart)(elementWithChart.chart.smeup.data, options);
|
|
39
|
+
const width = options.ForceWidth ? Number(options.ForceWidth) : undefined;
|
|
40
|
+
const height = options.ForceHeight
|
|
41
|
+
? Number(options.ForceHeight)
|
|
42
|
+
: undefined;
|
|
43
|
+
return {
|
|
44
|
+
...elementWithChart,
|
|
45
|
+
svg: svg,
|
|
46
|
+
...(width ? { width } : {}),
|
|
47
|
+
...(height ? { height } : {}),
|
|
48
|
+
};
|
|
49
|
+
};
|
|
50
|
+
};
|
|
51
|
+
exports.smeupChartToPdfMakeSvgAdapter = smeupChartToPdfMakeSvgAdapter;
|
|
52
|
+
/**
|
|
53
|
+
* Adapter function for converting a chart element with a `fun` property to a Smeup chart structure.
|
|
54
|
+
*
|
|
55
|
+
* This function returns an asynchronous converter that checks if the provided element contains
|
|
56
|
+
* a chart with a `fun` property. If present, it uses the `getSmeupDataStructure` function from
|
|
57
|
+
* the context to fetch the chart data corresponding to the `fun` string, and replaces the original
|
|
58
|
+
* chart's `fun` property with the fetched data under the `data` property. All other properties
|
|
59
|
+
* of the chart are preserved.
|
|
60
|
+
*
|
|
61
|
+
* @returns An asynchronous function that takes an element and a context, and returns the adapted element.
|
|
62
|
+
*
|
|
63
|
+
* @throws If the context does not provide a `getSmeupDataStructure` function when the `fun` property is used.
|
|
64
|
+
*
|
|
65
|
+
* @param element - The input element to be adapted.
|
|
66
|
+
* @param context - The conversion context, which must provide `getSmeupDataStructure` if the `fun` property is present.
|
|
67
|
+
*/
|
|
68
|
+
const funToSmeupChartAdapter = () => {
|
|
69
|
+
return async (element, context) => {
|
|
70
|
+
if (!hasChartWithFun(element)) {
|
|
71
|
+
return element;
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
if (!context.getSmeupDataStructure) {
|
|
75
|
+
throw new Error("getSmeupDataStructure function is required in context when the fun property is used");
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
const elementWithChart = element;
|
|
79
|
+
const funStr = elementWithChart.chart.smeup.fun;
|
|
80
|
+
const chartData = (await context.getSmeupDataStructure(funStr));
|
|
81
|
+
// Extract all properties except 'fun' from the smeup object
|
|
82
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
83
|
+
const { fun, ...smeupRest } = elementWithChart.chart.smeup;
|
|
84
|
+
// Extract all properties except 'smeup' from the chart object
|
|
85
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
86
|
+
const { smeup, ...chartRest } = elementWithChart.chart;
|
|
87
|
+
return {
|
|
88
|
+
...elementWithChart,
|
|
89
|
+
chart: {
|
|
90
|
+
...chartRest,
|
|
91
|
+
smeup: {
|
|
92
|
+
...smeupRest,
|
|
93
|
+
data: chartData,
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
exports.funToSmeupChartAdapter = funToSmeupChartAdapter;
|
|
102
|
+
/**
|
|
103
|
+
* Main chart adapter that chains all chart transformation adapters.
|
|
104
|
+
*
|
|
105
|
+
* This adapter first converts a `fun` property to chart data using funToSmeupChartAdapter,
|
|
106
|
+
* then transforms the chart data to an SVG format using smeupChartToPdfMakeSvgAdapter.
|
|
107
|
+
*
|
|
108
|
+
* @returns An asynchronous function that applies all chart adapters in sequence.
|
|
109
|
+
*/
|
|
110
|
+
const chartAdapter = () => {
|
|
111
|
+
return async (element, context) => {
|
|
112
|
+
const adaptedElement = await (0, exports.funToSmeupChartAdapter)()(element, context);
|
|
113
|
+
return (await (0, exports.smeupChartToPdfMakeSvgAdapter)()(adaptedElement, context));
|
|
114
|
+
};
|
|
115
|
+
};
|
|
116
|
+
exports.chartAdapter = chartAdapter;
|
|
117
|
+
//# sourceMappingURL=chart-adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chart-adapter.js","sourceRoot":"","sources":["../../../../../src/converters/pdf/pdfmake/adapters/chart-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["// ...\n\nimport {\n PdfMakeConverterContext,\n ContentChartExtension,\n ElementWithChartExtension,\n} from \"../pdfmake.types\";\n\nimport { SmeupDataStructureType } from \"../../../../types/data-structures/smeupDataStructure\";\nimport { SmeupDataTable } from \"../../../../types/data-structures/smeupDataTable\";\nimport { ChartOptions } from \"../../../images/charts-converter-types\";\nimport { dataTableToChart } from \"../../../images/charts-converter\";\n\nconst hasChartWithData = (\n element: unknown,\n): element is ElementWithChartExtension => {\n const chart = (element as Record<string, unknown>)\n ?.chart as ContentChartExtension;\n const data = chart?.smeup?.data as SmeupDataTable | undefined;\n return (\n data?.type === SmeupDataStructureType.SmeupDataTable &&\n Array.isArray(data?.rows) &&\n Array.isArray(data?.columns)\n );\n};\n\nconst hasChartWithFun = (\n element: unknown,\n): element is ElementWithChartExtension => {\n const chart = (element as Record<string, unknown>)\n ?.chart as ContentChartExtension;\n const fun = chart?.smeup?.fun;\n return typeof fun === \"string\" && fun.length > 0;\n};\n\n/**\n * Adapts a Smeup chart structure to the PDFMake SVG format.\n *\n * This adapter function checks if the provided element contains a chart with data.\n * If so, it generates an SVG representation from the chart data and replaces the chart\n * object with an svg property. All properties of the original chart except `data` are preserved.\n *\n * @returns A function that takes an element and returns the adapted element for PDFMake,\n * or the original element if it does not contain a valid chart with data.\n */\nexport const smeupChartToPdfMakeSvgAdapter = () => {\n return async (\n element: unknown,\n _context: PdfMakeConverterContext,\n ): Promise<ElementWithChartExtension> => {\n if (!hasChartWithData(element)) {\n return element as ElementWithChartExtension;\n }\n\n const elementWithChart = element as ElementWithChartExtension;\n const options = elementWithChart.chart.smeup!.options as ChartOptions;\n\n const svg = await dataTableToChart(\n elementWithChart.chart.smeup!.data!,\n options,\n );\n\n const width = options.ForceWidth ? Number(options.ForceWidth) : undefined;\n const height = options.ForceHeight\n ? Number(options.ForceHeight)\n : undefined;\n\n return {\n ...elementWithChart,\n svg: svg,\n ...(width ? { width } : {}),\n ...(height ? { height } : {}),\n } as ElementWithChartExtension;\n };\n};\n\n/**\n * Adapter function for converting a chart element with a `fun` property to a Smeup chart structure.\n *\n * This function returns an asynchronous converter that checks if the provided element contains\n * a chart with a `fun` property. If present, it uses the `getSmeupDataStructure` function from\n * the context to fetch the chart data corresponding to the `fun` string, and replaces the original\n * chart's `fun` property with the fetched data under the `data` property. All other properties\n * of the chart are preserved.\n *\n * @returns An asynchronous function that takes an element and a context, and returns the adapted element.\n *\n * @throws If the context does not provide a `getSmeupDataStructure` function when the `fun` property is used.\n *\n * @param element - The input element to be adapted.\n * @param context - The conversion context, which must provide `getSmeupDataStructure` if the `fun` property is present.\n */\nexport const funToSmeupChartAdapter = () => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<ElementWithChartExtension> => {\n if (!hasChartWithFun(element)) {\n return element as ElementWithChartExtension;\n } else {\n if (!context.getSmeupDataStructure) {\n throw new Error(\n \"getSmeupDataStructure function is required in context when the fun property is used\",\n );\n } else {\n const elementWithChart = element as ElementWithChartExtension;\n const funStr = elementWithChart.chart.smeup!.fun!;\n const chartData = (await context.getSmeupDataStructure(\n funStr,\n )) as SmeupDataTable;\n\n // Extract all properties except 'fun' from the smeup object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { fun, ...smeupRest } = elementWithChart.chart.smeup!;\n // Extract all properties except 'smeup' from the chart object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { smeup, ...chartRest } = elementWithChart.chart;\n\n return {\n ...elementWithChart,\n chart: {\n ...chartRest,\n smeup: {\n ...smeupRest,\n data: chartData,\n },\n },\n };\n }\n }\n };\n};\n\n/**\n * Main chart adapter that chains all chart transformation adapters.\n *\n * This adapter first converts a `fun` property to chart data using funToSmeupChartAdapter,\n * then transforms the chart data to an SVG format using smeupChartToPdfMakeSvgAdapter.\n *\n * @returns An asynchronous function that applies all chart adapters in sequence.\n */\nexport const chartAdapter = () => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<ElementWithChartExtension> => {\n const adaptedElement = await funToSmeupChartAdapter()(element, context);\n return (await smeupChartToPdfMakeSvgAdapter()(\n adaptedElement,\n context,\n )) as ElementWithChartExtension;\n };\n};\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ContentImageExtension, ElementWithImageExtension, PdfMakeConverterContext } from "
|
|
1
|
+
import { ContentImageExtension, ElementWithImageExtension, PdfMakeConverterContext } from "../pdfmake.types";
|
|
2
2
|
/**
|
|
3
3
|
* Adapts a Smeup image structure to the PDFMake image format.
|
|
4
4
|
*
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image-adapter.js","sourceRoot":"","sources":["../../../../../src/converters/pdf/pdfmake/adapters/image-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { SmeupDataTree } from \"../../../../types/data-structures/smeupDataTree\";\nimport {\n ContentImageExtension,\n ElementWithImageExtension,\n PdfMakeConverterContext,\n} from \"../pdfmake.types\";\n\nconst hasSmeupUrl = (element: unknown): boolean => {\n const image = (element as Record<string, unknown>)\n .image as ContentImageExtension;\n const url = image?.smeup?.url;\n return typeof url === \"string\" && url.length > 0;\n};\n\nfunction hasSmeupObject(element: unknown): boolean {\n const image = (element as Record<string, unknown>)\n .image as ContentImageExtension;\n const obj = image?.smeup?.obj;\n return typeof obj === \"object\" && obj !== null;\n}\n\n/**\n * Downloads an image from a URL and converts it to a data URL format.\n * Validates that the content-type is an image MIME type.\n *\n * @param url - The URL of the image to download\n * @param fetchData - Callback function to fetch the image data\n * @returns A data URL string in the format: data:image/jpeg;base64,<base64>\n * @throws If the download fails, content-type is not an image, or network error occurs\n */\nconst downloadImageAsDataUrl = async (\n url: string,\n fetchData: (url: string) => Promise<Response>,\n): Promise<string> => {\n const response = await fetchData(url);\n\n if (!response.ok) {\n throw new Error(\n `Failed to download image from ${url}: ${response.status} ${response.statusText}`,\n );\n }\n\n // Extract content-type from headers\n const contentType = response.headers.get(\"content-type\") || \"image/jpeg\";\n\n // Validate that content-type is an image\n if (!contentType.startsWith(\"image/\")) {\n throw new Error(\n `Invalid content-type for image: expected image/*, got ${contentType}`,\n );\n }\n\n // Get image data and convert to base64\n const arrayBuffer = await response.arrayBuffer();\n const base64 = Buffer.from(arrayBuffer).toString(\"base64\");\n\n return `data:${contentType};base64,${base64}`;\n};\n\n/**\n * Adapts a Smeup image structure to the PDFMake image format.\n *\n * This adapter function checks if the provided element contains an image with a smeup URL.\n * If so, it downloads the image using the fetchData callback from context, validates the\n * content-type, and transforms it into a data URL format that PDFMake can use.\n * The data URL is stored in context.pdfDocument.images to avoid redundancy when the same\n * image is referenced multiple times.\n * All properties of the original image except `smeup` are preserved.\n *\n * @returns An async function that takes an element and returns the adapted element for PDFMake,\n * or the original element if it does not contain a valid smeup image.\n * @throws If the context does not provide a fetchData function when the smeup image is used.\n * @throws If the image download fails or the content-type is not a valid image MIME type.\n */\nexport const urlToImageAdapter = () => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<ContentImageExtension> => {\n if (!hasSmeupUrl(element)) {\n return element as ContentImageExtension;\n }\n\n if (!context.fetchData) {\n throw new Error(\n \"fetchData function is required in context when the smeup image property is used\",\n );\n }\n\n const elementImage = element as { image: { smeup: { url: string } } };\n const url = elementImage.image.smeup.url;\n\n // Ensure pdfDocument exists in context\n if (!context.pdfDocument) {\n throw new Error(\n \"pdfDocument is required in context when the smeup image property is used\",\n );\n }\n\n // Initialize images dictionary if not present\n if (!context.pdfDocument.images) {\n context.pdfDocument.images = {};\n }\n\n // Download and cache the image only if not already present\n if (!context.pdfDocument.images[url]) {\n const dataUrl = await downloadImageAsDataUrl(url, context.fetchData);\n context.pdfDocument.images[url] = dataUrl;\n }\n\n // Extract all properties except 'smeup' from the image object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { smeup, ...imageRest } = elementImage.image;\n\n return {\n ...elementImage,\n image: url,\n ...imageRest,\n };\n };\n};\n\nexport const objectToUrlAdapter = () => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<ElementWithImageExtension> => {\n if (!hasSmeupObject(element)) {\n return element as ElementWithImageExtension;\n }\n if (!context.getSmeupDataStructure || !context.damSvcEndpoint) {\n throw new Error(\n \"getSmeupDataStructure function and damSvcEndpoint prop are required in context when the smeup image obj property is used\",\n );\n } else {\n const elementImage = element as ElementWithImageExtension;\n const obj = elementImage.image.smeup?.obj;\n if (!obj || !obj.t || !obj.p || !obj.k) {\n throw new Error(\n \"Smeup object must have t, p, and k properties to build GET.PATH function\",\n );\n }\n const funToGetPATH = `F(TRE;JASER_12W;GET.PATH) 1(${obj.t};${obj.p};${obj.k})`;\n const dataTree = (await context.getSmeupDataStructure(\n funToGetPATH,\n )) as SmeupDataTree;\n if (dataTree.children?.length === 0) {\n throw new Error(`No data found for function ${funToGetPATH}`);\n } else {\n const pathNode = dataTree.children[0].value.replace(/\\\\/g, \"/\");\n const pathEncoded = encodeURIComponent(pathNode);\n const url = context.damSvcEndpoint + \"/\" + pathEncoded;\n\n // Extract all properties except 'smeup' from the image object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { smeup, ...imageRest } = elementImage.image;\n\n return {\n ...elementImage,\n image: {\n smeup: {\n url,\n },\n ...imageRest,\n },\n };\n }\n }\n };\n};\n\nexport const imageAdapter = () => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<ContentImageExtension> => {\n try {\n const adaptedElement = await objectToUrlAdapter()(element, context);\n return await urlToImageAdapter()(adaptedElement, context);\n } catch (error) {\n console.error(error);\n const errorMessage = (error as Error).message;\n const cause = (error as Error & { cause?: Error }).cause;\n const causeMessage = cause ? `\\nCause: ${cause.message || cause}` : \"\";\n return {\n text: `Error loading image: ${errorMessage}${causeMessage}`,\n fontSize: 10,\n color: \"#8B0000\",\n } as unknown as ContentImageExtension;\n }\n };\n};\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ElementWithLayout, PdfMakeConverterContext } from "../pdfmake.types";
|
|
2
|
+
/**
|
|
3
|
+
* Adapts a layout object by converting static values to functions.
|
|
4
|
+
*
|
|
5
|
+
* This adapter function checks if the provided element contains a layout with static values
|
|
6
|
+
* for hLineWidth, vLineWidth, hLineColor, and vLineColor properties.
|
|
7
|
+
* If so, it converts them to functions as required by PDFMake:
|
|
8
|
+
* - hLineWidth and vLineWidth (numbers) are converted to: function(i) { return value; }
|
|
9
|
+
* - hLineColor and vLineColor (strings) are converted to: function(i) { return value; }
|
|
10
|
+
*
|
|
11
|
+
* All other properties of the layout are preserved.
|
|
12
|
+
*
|
|
13
|
+
* @returns A function that takes an element and returns the adapted element for PDFMake,
|
|
14
|
+
* or the original element if it does not contain a layout that needs adaptation.
|
|
15
|
+
*/
|
|
16
|
+
export declare const layoutAdapter: () => (element: unknown, _context: PdfMakeConverterContext) => Promise<ElementWithLayout>;
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.layoutAdapter = void 0;
|
|
4
|
+
const hasLayout = (element) => {
|
|
5
|
+
const layout = element.layout;
|
|
6
|
+
return typeof layout === "object" && layout !== null;
|
|
7
|
+
};
|
|
8
|
+
const needsLayoutAdaptation = (element) => {
|
|
9
|
+
if (!hasLayout(element)) {
|
|
10
|
+
return false;
|
|
11
|
+
}
|
|
12
|
+
const layout = element.layout;
|
|
13
|
+
// Check if any of the properties needs conversion
|
|
14
|
+
const needsHLineWidthConversion = layout.hLineWidth !== undefined && typeof layout.hLineWidth !== "function";
|
|
15
|
+
const needsVLineWidthConversion = layout.vLineWidth !== undefined && typeof layout.vLineWidth !== "function";
|
|
16
|
+
const needsHLineColorConversion = layout.hLineColor !== undefined && typeof layout.hLineColor !== "function";
|
|
17
|
+
const needsVLineColorConversion = layout.vLineColor !== undefined && typeof layout.vLineColor !== "function";
|
|
18
|
+
return (needsHLineWidthConversion ||
|
|
19
|
+
needsVLineWidthConversion ||
|
|
20
|
+
needsHLineColorConversion ||
|
|
21
|
+
needsVLineColorConversion);
|
|
22
|
+
};
|
|
23
|
+
/**
|
|
24
|
+
* Adapts a layout object by converting static values to functions.
|
|
25
|
+
*
|
|
26
|
+
* This adapter function checks if the provided element contains a layout with static values
|
|
27
|
+
* for hLineWidth, vLineWidth, hLineColor, and vLineColor properties.
|
|
28
|
+
* If so, it converts them to functions as required by PDFMake:
|
|
29
|
+
* - hLineWidth and vLineWidth (numbers) are converted to: function(i) { return value; }
|
|
30
|
+
* - hLineColor and vLineColor (strings) are converted to: function(i) { return value; }
|
|
31
|
+
*
|
|
32
|
+
* All other properties of the layout are preserved.
|
|
33
|
+
*
|
|
34
|
+
* @returns A function that takes an element and returns the adapted element for PDFMake,
|
|
35
|
+
* or the original element if it does not contain a layout that needs adaptation.
|
|
36
|
+
*/
|
|
37
|
+
const layoutAdapter = () => {
|
|
38
|
+
return async (element, _context) => {
|
|
39
|
+
if (!needsLayoutAdaptation(element)) {
|
|
40
|
+
return element;
|
|
41
|
+
}
|
|
42
|
+
const elementWithLayout = element;
|
|
43
|
+
const originalLayout = elementWithLayout.layout;
|
|
44
|
+
const adaptedLayout = { ...originalLayout };
|
|
45
|
+
// Convert hLineWidth if it's a number
|
|
46
|
+
if (originalLayout.hLineWidth !== undefined &&
|
|
47
|
+
typeof originalLayout.hLineWidth === "number") {
|
|
48
|
+
const value = originalLayout.hLineWidth;
|
|
49
|
+
adaptedLayout.hLineWidth = ((_i) => value);
|
|
50
|
+
}
|
|
51
|
+
// Convert vLineWidth if it's a number
|
|
52
|
+
if (originalLayout.vLineWidth !== undefined &&
|
|
53
|
+
typeof originalLayout.vLineWidth === "number") {
|
|
54
|
+
const value = originalLayout.vLineWidth;
|
|
55
|
+
adaptedLayout.vLineWidth = ((_i) => value);
|
|
56
|
+
}
|
|
57
|
+
// Convert hLineColor if it's a string
|
|
58
|
+
if (originalLayout.hLineColor !== undefined &&
|
|
59
|
+
typeof originalLayout.hLineColor === "string") {
|
|
60
|
+
const value = originalLayout.hLineColor;
|
|
61
|
+
adaptedLayout.hLineColor = ((_i) => value);
|
|
62
|
+
}
|
|
63
|
+
// Convert vLineColor if it's a string
|
|
64
|
+
if (originalLayout.vLineColor !== undefined &&
|
|
65
|
+
typeof originalLayout.vLineColor === "string") {
|
|
66
|
+
const value = originalLayout.vLineColor;
|
|
67
|
+
adaptedLayout.vLineColor = ((_i) => value);
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
...elementWithLayout,
|
|
71
|
+
layout: adaptedLayout,
|
|
72
|
+
};
|
|
73
|
+
};
|
|
74
|
+
};
|
|
75
|
+
exports.layoutAdapter = layoutAdapter;
|
|
76
|
+
//# sourceMappingURL=layout-adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"layout-adapter.js","sourceRoot":"","sources":["../../../../../src/converters/pdf/pdfmake/adapters/layout-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n ElementWithLayout,\n Layout,\n LayoutColorFunction,\n LayoutLineFunction,\n PdfMakeConverterContext,\n} from \"../pdfmake.types\";\n\nconst hasLayout = (element: unknown): boolean => {\n const layout = (element as Record<string, unknown>).layout;\n return typeof layout === \"object\" && layout !== null;\n};\n\nconst needsLayoutAdaptation = (element: unknown): boolean => {\n if (!hasLayout(element)) {\n return false;\n }\n\n const layout = (element as ElementWithLayout).layout!;\n\n // Check if any of the properties needs conversion\n const needsHLineWidthConversion =\n layout.hLineWidth !== undefined && typeof layout.hLineWidth !== \"function\";\n const needsVLineWidthConversion =\n layout.vLineWidth !== undefined && typeof layout.vLineWidth !== \"function\";\n const needsHLineColorConversion =\n layout.hLineColor !== undefined && typeof layout.hLineColor !== \"function\";\n const needsVLineColorConversion =\n layout.vLineColor !== undefined && typeof layout.vLineColor !== \"function\";\n\n return (\n needsHLineWidthConversion ||\n needsVLineWidthConversion ||\n needsHLineColorConversion ||\n needsVLineColorConversion\n );\n};\n\n/**\n * Adapts a layout object by converting static values to functions.\n *\n * This adapter function checks if the provided element contains a layout with static values\n * for hLineWidth, vLineWidth, hLineColor, and vLineColor properties.\n * If so, it converts them to functions as required by PDFMake:\n * - hLineWidth and vLineWidth (numbers) are converted to: function(i) { return value; }\n * - hLineColor and vLineColor (strings) are converted to: function(i) { return value; }\n *\n * All other properties of the layout are preserved.\n *\n * @returns A function that takes an element and returns the adapted element for PDFMake,\n * or the original element if it does not contain a layout that needs adaptation.\n */\nexport const layoutAdapter = () => {\n return async (\n element: unknown,\n _context: PdfMakeConverterContext,\n ): Promise<ElementWithLayout> => {\n if (!needsLayoutAdaptation(element)) {\n return element as ElementWithLayout;\n }\n\n const elementWithLayout = element as ElementWithLayout;\n const originalLayout = elementWithLayout.layout!;\n const adaptedLayout: Layout = { ...originalLayout };\n\n // Convert hLineWidth if it's a number\n if (\n originalLayout.hLineWidth !== undefined &&\n typeof originalLayout.hLineWidth === \"number\"\n ) {\n const value = originalLayout.hLineWidth;\n adaptedLayout.hLineWidth = ((_i: number) => value) as LayoutLineFunction;\n }\n\n // Convert vLineWidth if it's a number\n if (\n originalLayout.vLineWidth !== undefined &&\n typeof originalLayout.vLineWidth === \"number\"\n ) {\n const value = originalLayout.vLineWidth;\n adaptedLayout.vLineWidth = ((_i: number) => value) as LayoutLineFunction;\n }\n\n // Convert hLineColor if it's a string\n if (\n originalLayout.hLineColor !== undefined &&\n typeof originalLayout.hLineColor === \"string\"\n ) {\n const value = originalLayout.hLineColor;\n adaptedLayout.hLineColor = ((_i: number) => value) as LayoutColorFunction;\n }\n\n // Convert vLineColor if it's a string\n if (\n originalLayout.vLineColor !== undefined &&\n typeof originalLayout.vLineColor === \"string\"\n ) {\n const value = originalLayout.vLineColor;\n adaptedLayout.vLineColor = ((_i: number) => value) as LayoutColorFunction;\n }\n\n return {\n ...elementWithLayout,\n layout: adaptedLayout,\n };\n };\n};\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { PdfMakeConverterContext } from "../pdfmake.types";
|
|
2
|
+
/**
|
|
3
|
+
* Adapter for header elements with page number placeholder support.
|
|
4
|
+
*/
|
|
5
|
+
export declare const headerAdapter: () => (element: unknown, context: PdfMakeConverterContext) => Promise<unknown>;
|
|
6
|
+
/**
|
|
7
|
+
* Adapter for footer elements with page number placeholder support.
|
|
8
|
+
*/
|
|
9
|
+
export declare const footerAdapter: () => (element: unknown, context: PdfMakeConverterContext) => Promise<unknown>;
|
package/dist/converters/pdf/pdfmake/{page-element-adapter.js → adapters/page-element-adapter.js}
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.footerAdapter = exports.headerAdapter = void 0;
|
|
4
|
+
const adapter_processor_1 = require("../adapter-processor");
|
|
4
5
|
/**
|
|
5
6
|
* Type guard to check if an element has a specific property
|
|
6
7
|
*/
|
|
@@ -42,16 +43,16 @@ const replacePlaceholders = (obj, currentPage, pageCount) => {
|
|
|
42
43
|
*
|
|
43
44
|
* This adapter function checks if the provided element contains the specified property (header or footer).
|
|
44
45
|
* - If the property is already a function, it leaves it unchanged.
|
|
45
|
-
* - If the property is an object, it
|
|
46
|
-
* [CurrentPage] with the current page number and
|
|
47
|
-
* page count at rendering time.
|
|
46
|
+
* - If the property is an object, it first recursively processes it with all registered adapters,
|
|
47
|
+
* then wraps it in a function that replaces [CurrentPage] with the current page number and
|
|
48
|
+
* [PageCount] with the total page count at rendering time.
|
|
48
49
|
*
|
|
49
50
|
* @param propertyName - The name of the property to adapt ('header' or 'footer')
|
|
50
51
|
* @returns A function that takes an element and returns the adapted element for PDFMake,
|
|
51
52
|
* or the original element if it does not contain the specified property.
|
|
52
53
|
*/
|
|
53
54
|
const createPageElementAdapter = (propertyName) => {
|
|
54
|
-
return (element) => {
|
|
55
|
+
return async (element, context) => {
|
|
55
56
|
if (!hasProperty(element, propertyName)) {
|
|
56
57
|
return element;
|
|
57
58
|
}
|
|
@@ -60,9 +61,15 @@ const createPageElementAdapter = (propertyName) => {
|
|
|
60
61
|
if (typeof propertyValue === "function") {
|
|
61
62
|
return element;
|
|
62
63
|
}
|
|
63
|
-
//
|
|
64
|
-
|
|
65
|
-
|
|
64
|
+
// First, recursively process the header/footer content with all adapters
|
|
65
|
+
// This ensures nested elements (like tables with layouts) are properly transformed
|
|
66
|
+
let processedValue = propertyValue;
|
|
67
|
+
if (context._adapters) {
|
|
68
|
+
processedValue = await (0, adapter_processor_1.processDocument)(propertyValue, context._adapters, context);
|
|
69
|
+
}
|
|
70
|
+
// Then wrap the processed content in a function that replaces placeholders at render time
|
|
71
|
+
const dynamicContent = (currentPage, pageCount, _pageSize) => {
|
|
72
|
+
return replacePlaceholders(processedValue, currentPage, pageCount);
|
|
66
73
|
};
|
|
67
74
|
return {
|
|
68
75
|
...element,
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-element-adapter.js","sourceRoot":"","sources":["../../../../../src/converters/pdf/pdfmake/adapters/page-element-adapter.ts"],"names":[],"mappings":";;;AACA,4DAAuD;AAGvD;;GAEG;AACH,MAAM,WAAW,GAAG,CAClB,OAAgB,EAChB,YAAe,EACiC,EAAE;IAClD,OAAO,CACL,OAAO,KAAK,IAAI;QAChB,OAAO,OAAO,KAAK,QAAQ;QAC3B,YAAY,IAAI,OAAO;QACtB,OAAmC,CAAC,YAAY,CAAC,KAAK,SAAS,CACjE,CAAC;AACJ,CAAC,CAAC;AAEF;;;;;;;;GAQG;AACH,MAAM,mBAAmB,GAAG,CAC1B,GAAY,EACZ,WAAmB,EACnB,SAAiB,EACR,EAAE;IACX,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC5B,OAAO,GAAG;aACP,OAAO,CAAC,kBAAkB,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;aAChD,OAAO,CAAC,gBAAgB,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QACvB,OAAO,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,mBAAmB,CAAC,IAAI,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED,IAAI,GAAG,KAAK,IAAI,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC5C,MAAM,MAAM,GAA4B,EAAE,CAAC;QAC3C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YAC/C,MAAM,CAAC,GAAG,CAAC,GAAG,mBAAmB,CAAC,KAAK,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;QACnE,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC,CAAC;AAEF;;;;;;;;;;;;GAYG;AACH,MAAM,wBAAwB,GAAG,CAAC,YAAiC,EAAE,EAAE;IACrE,OAAO,KAAK,EACV,OAAgB,EAChB,OAAgC,EACd,EAAE;QACpB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,YAAY,CAAC,EAAE,CAAC;YACxC,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,MAAM,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;QAE5C,oDAAoD;QACpD,IAAI,OAAO,aAAa,KAAK,UAAU,EAAE,CAAC;YACxC,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,yEAAyE;QACzE,mFAAmF;QACnF,IAAI,cAAc,GAAY,aAAa,CAAC;QAC5C,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,cAAc,GAAG,MAAM,IAAA,mCAAe,EACpC,aAAa,EACb,OAAO,CAAC,SAAS,EACjB,OAAO,CACR,CAAC;QACJ,CAAC;QAED,0FAA0F;QAC1F,MAAM,cAAc,GAAmB,CACrC,WAAW,EACX,SAAS,EACT,SAAS,EACT,EAAE;YACF,OAAO,mBAAmB,CACxB,cAAc,EACd,WAAW,EACX,SAAS,CACC,CAAC;QACf,CAAC,CAAC;QAEF,OAAO;YACL,GAAG,OAAO;YACV,CAAC,YAAY,CAAC,EAAE,cAAc;SAC/B,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC,CAAC;AAEF;;GAEG;AACI,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;AAAzD,QAAA,aAAa,iBAA4C;AAEtE;;GAEG;AACI,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAAC;AAAzD,QAAA,aAAa,iBAA4C","sourcesContent":["import { Content, DynamicContent } from \"pdfmake/interfaces\";\nimport { processDocument } from \"../adapter-processor\";\nimport { PdfMakeConverterContext } from \"../pdfmake.types\";\n\n/**\n * Type guard to check if an element has a specific property\n */\nconst hasProperty = <T extends string>(\n element: unknown,\n propertyName: T,\n): element is Record<T, Content | DynamicContent> => {\n return (\n element !== null &&\n typeof element === \"object\" &&\n propertyName in element &&\n (element as Record<string, unknown>)[propertyName] !== undefined\n );\n};\n\n/**\n * Recursively searches for [CurrentPage] and [PageCount] placeholders in an object\n * and replaces them with the actual values.\n *\n * @param obj - The object to process\n * @param currentPage - The current page number\n * @param pageCount - The total page count\n * @returns The processed object with replaced placeholders\n */\nconst replacePlaceholders = (\n obj: unknown,\n currentPage: number,\n pageCount: number,\n): unknown => {\n if (typeof obj === \"string\") {\n return obj\n .replace(/\\[CurrentPage\\]/g, String(currentPage))\n .replace(/\\[PageCount\\]/g, String(pageCount));\n }\n\n if (Array.isArray(obj)) {\n return obj.map(item => replacePlaceholders(item, currentPage, pageCount));\n }\n\n if (obj !== null && typeof obj === \"object\") {\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n result[key] = replacePlaceholders(value, currentPage, pageCount);\n }\n return result;\n }\n\n return obj;\n};\n\n/**\n * Adapts a header or footer to support dynamic page number placeholders.\n *\n * This adapter function checks if the provided element contains the specified property (header or footer).\n * - If the property is already a function, it leaves it unchanged.\n * - If the property is an object, it first recursively processes it with all registered adapters,\n * then wraps it in a function that replaces [CurrentPage] with the current page number and\n * [PageCount] with the total page count at rendering time.\n *\n * @param propertyName - The name of the property to adapt ('header' or 'footer')\n * @returns A function that takes an element and returns the adapted element for PDFMake,\n * or the original element if it does not contain the specified property.\n */\nconst createPageElementAdapter = (propertyName: \"header\" | \"footer\") => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<unknown> => {\n if (!hasProperty(element, propertyName)) {\n return element;\n }\n\n const propertyValue = element[propertyName];\n\n // If property is already a function, leave it as is\n if (typeof propertyValue === \"function\") {\n return element;\n }\n\n // First, recursively process the header/footer content with all adapters\n // This ensures nested elements (like tables with layouts) are properly transformed\n let processedValue: unknown = propertyValue;\n if (context._adapters) {\n processedValue = await processDocument(\n propertyValue,\n context._adapters,\n context,\n );\n }\n\n // Then wrap the processed content in a function that replaces placeholders at render time\n const dynamicContent: DynamicContent = (\n currentPage,\n pageCount,\n _pageSize,\n ) => {\n return replacePlaceholders(\n processedValue,\n currentPage,\n pageCount,\n ) as Content;\n };\n\n return {\n ...element,\n [propertyName]: dynamicContent,\n };\n };\n};\n\n/**\n * Adapter for header elements with page number placeholder support.\n */\nexport const headerAdapter = () => createPageElementAdapter(\"header\");\n\n/**\n * Adapter for footer elements with page number placeholder support.\n */\nexport const footerAdapter = () => createPageElementAdapter(\"footer\");\n"]}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.dataTableAdapter = exports.funToSmeupTableAdapter = exports.smeupTableToPdfMakeTableAdapter = void 0;
|
|
4
|
-
const types_1 = require("
|
|
5
|
-
const smeupDataStructure_1 = require("
|
|
6
|
-
const commons_utility_1 = require("
|
|
4
|
+
const types_1 = require("../../../../types");
|
|
5
|
+
const smeupDataStructure_1 = require("../../../../types/data-structures/smeupDataStructure");
|
|
6
|
+
const commons_utility_1 = require("../../../../utils/commons-utility");
|
|
7
7
|
const hasTableWithDataTable = (element) => {
|
|
8
8
|
const table = element?.table;
|
|
9
9
|
const data = table?.smeup?.data;
|
|
10
10
|
return (data?.type === smeupDataStructure_1.SmeupDataStructureType.SmeupDataTable &&
|
|
11
|
-
data?.rows
|
|
12
|
-
data?.columns
|
|
11
|
+
Array.isArray(data?.rows) &&
|
|
12
|
+
Array.isArray(data?.columns));
|
|
13
13
|
};
|
|
14
14
|
const hasTableWithFun = (element) => {
|
|
15
15
|
const table = element?.table;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-adapter.js","sourceRoot":"","sources":["../../../../../src/converters/pdf/pdfmake/adapters/table-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { TableCell } from \"pdfmake/interfaces\";\nimport { SupportedExportFormats } from \"../../../../types\";\nimport { SmeupDataStructureType } from \"../../../../types/data-structures/smeupDataStructure\";\nimport {\n SmeupDataCell,\n SmeupDataTable,\n} from \"../../../../types/data-structures/smeupDataTable\";\nimport { calculateCellValue } from \"../../../../utils/commons-utility\";\nimport {\n ElementWithTableExtension,\n PdfMakeConverterContext,\n TableExtension,\n} from \"../pdfmake.types\";\n\nconst hasTableWithDataTable = (\n element: unknown,\n): element is ElementWithTableExtension => {\n const table = (element as Record<string, unknown>)?.table as TableExtension;\n const data = table?.smeup?.data;\n return (\n data?.type === SmeupDataStructureType.SmeupDataTable &&\n Array.isArray(data?.rows) &&\n Array.isArray(data?.columns)\n );\n};\n\nconst hasTableWithFun = (\n element: unknown,\n): element is ElementWithTableExtension => {\n const table = (element as Record<string, unknown>)?.table as TableExtension;\n const fun = table?.smeup?.fun;\n return typeof fun === \"string\" && fun.length > 0;\n};\n\n/**\n * Adapts a Smeup table structure to the PDFMake table format.\n *\n * This adapter function checks if the provided element contains a table with data.\n * If so, it transforms the table's columns and rows into the PDFMake `body` format,\n * where the first row is the header (column titles) and subsequent rows are the data.\n * All properties of the original table except `data` are preserved.\n *\n * @returns A function that takes an element and returns the adapted element for PDFMake,\n * or the original element if it does not contain a valid table with data.\n */\nexport const smeupTableToPdfMakeTableAdapter = () => {\n return (\n element: unknown,\n context: PdfMakeConverterContext,\n ): ElementWithTableExtension => {\n if (!hasTableWithDataTable(element)) {\n return element as ElementWithTableExtension;\n }\n\n const { columns, rows } = element.table.smeup!.data!;\n\n // Build header row from column titles\n const headerRow = columns.map(col => col.title);\n\n // Build data rows by extracting values in column order\n const dataRows = rows.map(row =>\n columns.map(col => {\n const cell = row.cells?.[col.name] as SmeupDataCell;\n const value = calculateCellValue(\n cell,\n SupportedExportFormats.PDF,\n context.webupManagerData,\n );\n return {\n text: value != null ? String(value) : \"\",\n alignment: col.obj?.t === \"NR\" ? \"right\" : \"left\",\n };\n }),\n );\n\n // Combine header and data rows\n const body = [headerRow, ...dataRows] as TableCell[][];\n\n // Extract all properties except 'data' from the smeup object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { data, ...smeupRest } = element.table.smeup!;\n // Extract all properties except 'smeup' from the table object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { smeup, ...tableRest } = element.table;\n\n return {\n ...element,\n table: {\n ...tableRest,\n smeup: {\n ...smeupRest,\n },\n body,\n },\n };\n };\n};\n\n/**\n * Adapter function for converting a table element with a `fun` property to a Smeup table structure.\n *\n * This function returns an asynchronous converter that checks if the provided element contains\n * a table with a `fun` property. If present, it uses the `getSmeupDataStructure` function from\n * the context to fetch the table data corresponding to the `fun` string, and replaces the original\n * table's `fun` property with the fetched data under the `data` property. All other properties\n * of the table are preserved.\n *\n * @returns An asynchronous function that takes an element and a context, and returns the adapted element.\n *\n * @throws If the context does not provide a `getSmeupDataStructure` function when the `fun` property is used.\n *\n * @param element - The input element to be adapted.\n * @param context - The conversion context, which must provide `getSmeupDataStructure` if the `fun` property is present.\n */\nexport const funToSmeupTableAdapter = () => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<ElementWithTableExtension> => {\n if (!hasTableWithFun(element)) {\n return element as ElementWithTableExtension;\n } else {\n if (!context.getSmeupDataStructure) {\n throw new Error(\n \"getSmeupDataStructure function is required in context when the fun property is used\",\n );\n } else {\n const elementWithTable = element as ElementWithTableExtension;\n const funStr = elementWithTable.table.smeup!.fun!;\n const dataTable = (await context.getSmeupDataStructure(\n funStr,\n )) as SmeupDataTable;\n // Extract all properties except 'fun' from the smeup object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { fun, ...smeupRest } = elementWithTable.table.smeup!;\n // Extract all properties except 'smeup' from the table object\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { smeup, ...tableRest } = elementWithTable.table;\n\n return {\n ...elementWithTable,\n table: {\n ...tableRest,\n body: tableRest.body,\n smeup: {\n ...smeupRest,\n data: dataTable,\n },\n },\n };\n }\n }\n };\n};\n\nexport const dataTableAdapter = () => {\n return async (\n element: unknown,\n context: PdfMakeConverterContext,\n ): Promise<ElementWithTableExtension> => {\n const adaptedElement = await funToSmeupTableAdapter()(element, context);\n return (await smeupTableToPdfMakeTableAdapter()(\n adaptedElement,\n context,\n )) as ElementWithTableExtension;\n };\n};\n"]}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { ContentImage, Table, TDocumentDefinitions } from "pdfmake/interfaces";
|
|
1
|
+
import { ContentImage, Table, TDocumentDefinitions, ContentSvg } from "pdfmake/interfaces";
|
|
2
2
|
import { SmeupDataObj, WebupManagerData } from "../../../types";
|
|
3
3
|
import { SmeupDataStructure } from "../../../types/data-structures/smeupDataStructure";
|
|
4
4
|
import { SmeupDataTable } from "../../../types/data-structures/smeupDataTable";
|
|
5
|
+
import { ComponentOptions } from "../../../types/component";
|
|
5
6
|
/**
|
|
6
7
|
* Context passed to adapter functions during document processing.
|
|
7
8
|
*/
|
|
@@ -11,6 +12,12 @@ export interface PdfMakeConverterContext<T extends SmeupDataStructure = SmeupDat
|
|
|
11
12
|
damSvcEndpoint?: string;
|
|
12
13
|
getSmeupDataStructure?: (fun: string) => Promise<T>;
|
|
13
14
|
fetchData?: (url: string) => Promise<Response>;
|
|
15
|
+
/**
|
|
16
|
+
* Internal property used by adapters that need to recursively process content.
|
|
17
|
+
* This is populated by the adapter processor and should not be set by external code.
|
|
18
|
+
* @internal
|
|
19
|
+
*/
|
|
20
|
+
_adapters?: Map<string, PdfmakeAdapter>;
|
|
14
21
|
}
|
|
15
22
|
/**
|
|
16
23
|
* Function that transforms an element from custom format to pdfmake standard format.
|
|
@@ -37,9 +44,10 @@ interface SmeupExtensionImageMetadata {
|
|
|
37
44
|
url?: string;
|
|
38
45
|
obj?: SmeupDataObj;
|
|
39
46
|
}
|
|
40
|
-
interface SmeupExtensionTableMetadata {
|
|
47
|
+
interface SmeupExtensionTableMetadata<T = ComponentOptions> {
|
|
41
48
|
fun?: string;
|
|
42
49
|
data?: SmeupDataTable;
|
|
50
|
+
options?: T;
|
|
43
51
|
}
|
|
44
52
|
export interface ContentImageExtension extends ContentImage {
|
|
45
53
|
smeup?: SmeupExtensionImageMetadata;
|
|
@@ -57,4 +65,22 @@ export interface ElementWithTableExtension {
|
|
|
57
65
|
smeup?: SmeupExtensionTableMetadata;
|
|
58
66
|
};
|
|
59
67
|
}
|
|
68
|
+
export type LayoutLineFunction = (i: number, node?: unknown) => number;
|
|
69
|
+
export type LayoutColorFunction = (i: number, node?: unknown) => string;
|
|
70
|
+
export interface Layout {
|
|
71
|
+
hLineWidth?: number | LayoutLineFunction;
|
|
72
|
+
vLineWidth?: number | LayoutLineFunction;
|
|
73
|
+
hLineColor?: string | LayoutColorFunction;
|
|
74
|
+
vLineColor?: string | LayoutColorFunction;
|
|
75
|
+
}
|
|
76
|
+
export interface ElementWithLayout {
|
|
77
|
+
layout?: Layout;
|
|
78
|
+
[key: string]: unknown;
|
|
79
|
+
}
|
|
80
|
+
export interface ContentChartExtension extends ContentSvg {
|
|
81
|
+
smeup?: SmeupExtensionTableMetadata;
|
|
82
|
+
}
|
|
83
|
+
export interface ElementWithChartExtension {
|
|
84
|
+
chart: ContentChartExtension;
|
|
85
|
+
}
|
|
60
86
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pdfmake.types.js","sourceRoot":"","sources":["../../../../src/converters/pdf/pdfmake/pdfmake.types.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"pdfmake.types.js","sourceRoot":"","sources":["../../../../src/converters/pdf/pdfmake/pdfmake.types.ts"],"names":[],"mappings":";;;AAuDA,MAAa,YAAa,SAAQ,KAAK;IACrC,OAAO,CAAU;IACjB,YAAY,OAAe,EAAE,OAAgB;QAC3C,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC;IACtD,CAAC;CACF;AAPD,oCAOC","sourcesContent":["import {\n ContentImage,\n Table,\n TDocumentDefinitions,\n ContentSvg,\n} from \"pdfmake/interfaces\";\nimport { SmeupDataObj, WebupManagerData } from \"../../../types\";\nimport { SmeupDataStructure } from \"../../../types/data-structures/smeupDataStructure\";\nimport { SmeupDataTable } from \"../../../types/data-structures/smeupDataTable\";\nimport { ComponentOptions } from \"../../../types/component\";\n\n/**\n * Context passed to adapter functions during document processing.\n */\nexport interface PdfMakeConverterContext<\n T extends SmeupDataStructure = SmeupDataStructure,\n> {\n webupManagerData: WebupManagerData;\n pdfDocument?: TDocumentDefinitions;\n damSvcEndpoint?: string;\n getSmeupDataStructure?: (fun: string) => Promise<T>;\n fetchData?: (url: string) => Promise<Response>;\n /**\n * Internal property used by adapters that need to recursively process content.\n * This is populated by the adapter processor and should not be set by external code.\n * @internal\n */\n _adapters?: Map<string, PdfmakeAdapter>;\n}\n\n/**\n * Function that transforms an element from custom format to pdfmake standard format.\n * Adapters are pure functions that receive an element and context, and return the transformed element.\n * Can be synchronous or asynchronous.\n */\nexport type PdfmakeAdapter = (\n element: unknown,\n context: PdfMakeConverterContext,\n) => unknown | Promise<unknown>;\n\n/**\n * Registry interface for managing pdfmake adapters at runtime.\n */\nexport interface AdapterRegistry {\n /** Register an adapter for a specific element type */\n register: (elementType: string, adapter: PdfmakeAdapter) => void;\n /** Unregister an adapter for a specific element type */\n unregister: (elementType: string) => void;\n /** Process a document by applying registered adapters */\n process: (\n document: unknown,\n context: Partial<PdfMakeConverterContext>,\n ) => Promise<unknown>;\n}\n\nexport class AdapterError extends Error {\n element: unknown;\n constructor(message: string, element: unknown) {\n super(message);\n this.element = element;\n Object.setPrototypeOf(this, AdapterError.prototype);\n }\n}\n\ninterface SmeupExtensionImageMetadata {\n url?: string;\n obj?: SmeupDataObj;\n}\n\ninterface SmeupExtensionTableMetadata<T = ComponentOptions> {\n fun?: string;\n data?: SmeupDataTable;\n options?: T;\n}\n\nexport interface ContentImageExtension extends ContentImage {\n smeup?: SmeupExtensionImageMetadata;\n}\n\nexport interface TableExtension extends Table {\n smeup?: SmeupExtensionTableMetadata;\n}\n\nexport interface ElementWithImageExtension {\n image: ContentImage & { smeup?: SmeupExtensionImageMetadata };\n}\n\nexport interface ElementWithTableExtension {\n table: Table & { smeup?: SmeupExtensionTableMetadata };\n}\n\nexport type LayoutLineFunction = (i: number, node?: unknown) => number;\nexport type LayoutColorFunction = (i: number, node?: unknown) => string;\n\nexport interface Layout {\n hLineWidth?: number | LayoutLineFunction;\n vLineWidth?: number | LayoutLineFunction;\n hLineColor?: string | LayoutColorFunction;\n vLineColor?: string | LayoutColorFunction;\n}\n\nexport interface ElementWithLayout {\n layout?: Layout;\n [key: string]: unknown;\n}\n\nexport interface ContentChartExtension extends ContentSvg {\n smeup?: SmeupExtensionTableMetadata;\n}\n\nexport interface ElementWithChartExtension {\n chart: ContentChartExtension;\n}\n"]}
|
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
import { SmeupDataTable } from "../types/data-structures/smeupDataTable";
|
|
2
|
-
import { SmeupSch } from "../types/data-structures/smeupSch";
|
|
3
2
|
import { WebupManagerData, GenericObject } from "../types/index";
|
|
4
3
|
import type { PdfMakeConverterContext } from "./pdf/pdfmake/pdfmake.types";
|
|
5
4
|
import type { TDocumentDefinitions } from "pdfmake/interfaces";
|
|
6
5
|
import { fillPdfForm, FillPdfFormOptions } from "./pdf/form-filler";
|
|
7
|
-
export declare const schedaToPdfData: (sch: SmeupSch, webupManagerData: WebupManagerData) => Promise<Buffer>;
|
|
8
6
|
export declare const dataTableToPdfData: (component: {
|
|
9
7
|
smeupDataTable: SmeupDataTable;
|
|
10
8
|
props: GenericObject;
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.fillPdfForm = exports.pdfmakeDocumentToPdfData = exports.dataTableToPdfData =
|
|
4
|
+
exports.fillPdfForm = exports.pdfmakeDocumentToPdfData = exports.dataTableToPdfData = void 0;
|
|
5
5
|
const index_1 = require("../types/index");
|
|
6
6
|
const commons_utility_1 = require("../utils/commons-utility");
|
|
7
7
|
const matrix_converter_1 = require("./excel/matrix-converter");
|
|
8
8
|
const matrix_converter_2 = require("./pdf/matrix-converter");
|
|
9
|
-
const sch_converter_1 = require("./pdf/sch-converter");
|
|
10
9
|
const pdf_lib_1 = require("pdf-lib");
|
|
11
10
|
const cover_renderer_1 = require("./pdf/cover-renderer");
|
|
12
11
|
const gfx_data_1 = require("../assets/gfx-data");
|
|
@@ -15,14 +14,12 @@ const form_filler_1 = require("./pdf/form-filler");
|
|
|
15
14
|
Object.defineProperty(exports, "fillPdfForm", { enumerable: true, get: function () { return form_filler_1.fillPdfForm; } });
|
|
16
15
|
const adapter_processor_1 = require("./pdf/pdfmake/adapter-processor");
|
|
17
16
|
const adapter_registry_1 = require("./pdf/pdfmake/adapter-registry");
|
|
18
|
-
const table_adapter_1 = require("./pdf/pdfmake/table-adapter");
|
|
19
|
-
const image_adapter_1 = require("./pdf/pdfmake/image-adapter");
|
|
20
|
-
const
|
|
21
|
-
const
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
};
|
|
25
|
-
exports.schedaToPdfData = schedaToPdfData;
|
|
17
|
+
const table_adapter_1 = require("./pdf/pdfmake/adapters/table-adapter");
|
|
18
|
+
const image_adapter_1 = require("./pdf/pdfmake/adapters/image-adapter");
|
|
19
|
+
const chart_adapter_1 = require("./pdf/pdfmake/adapters/chart-adapter");
|
|
20
|
+
const page_element_adapter_1 = require("./pdf/pdfmake/adapters/page-element-adapter");
|
|
21
|
+
const layout_adapter_1 = require("./pdf/pdfmake/adapters/layout-adapter");
|
|
22
|
+
// `schedaToPdfData` removed: `sch-converter.ts` deleted and references removed
|
|
26
23
|
const dataTableToPdfData = async (component, webupManagerData) => {
|
|
27
24
|
const workbook = (0, matrix_converter_1.dataTableToExcelWorkbook)(component, index_1.SupportedExportFormats.XLSX, webupManagerData);
|
|
28
25
|
const worksheet = workbook.getWorksheet(1);
|
|
@@ -51,12 +48,17 @@ const pdfmakeDocumentToPdfData = async (documentDefinition, context) => {
|
|
|
51
48
|
const registry = (0, adapter_registry_1.createAdapterRegistry)();
|
|
52
49
|
registry.register("table", (0, table_adapter_1.dataTableAdapter)());
|
|
53
50
|
registry.register("image", (0, image_adapter_1.imageAdapter)());
|
|
51
|
+
registry.register("chart", (0, chart_adapter_1.chartAdapter)());
|
|
54
52
|
registry.register("footer", (0, page_element_adapter_1.footerAdapter)());
|
|
55
53
|
registry.register("header", (0, page_element_adapter_1.headerAdapter)());
|
|
54
|
+
registry.register("layout", (0, layout_adapter_1.layoutAdapter)());
|
|
56
55
|
context.pdfDocument = documentDefinition;
|
|
57
56
|
// Pre-process document with adapters
|
|
58
57
|
const processedDoc = await (0, adapter_processor_1.preProcessPdfMakeDocument)(documentDefinition, context, registry);
|
|
59
|
-
console.debug(
|
|
58
|
+
// console.debug(
|
|
59
|
+
// "Processed pdfmake document:",
|
|
60
|
+
// JSON.stringify(processedDoc, null, 2),
|
|
61
|
+
// );
|
|
60
62
|
// Render the document using pdfmake
|
|
61
63
|
return (0, pdfmake_renderer_1.renderPdfMakeDocument)(processedDoc);
|
|
62
64
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pdf-converter.js","sourceRoot":"","sources":["../../src/converters/pdf-converter.ts"],"names":[],"mappings":";AAAA,sDAAsD;;;AAItD,0CAIwB;AACxB,8DAA2D;AAC3D,+DAAoE;AACpE,6DAA2D;AAC3D,
|
|
1
|
+
{"version":3,"file":"pdf-converter.js","sourceRoot":"","sources":["../../src/converters/pdf-converter.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\n\nimport { SmeupDataTable } from \"../types/data-structures/smeupDataTable\";\nimport { SmeupSch } from \"../types/data-structures/smeupSch\";\nimport {\n WebupManagerData,\n GenericObject,\n SupportedExportFormats,\n} from \"../types/index\";\nimport { convertToBuffer } from \"../utils/commons-utility\";\nimport { dataTableToExcelWorkbook } from \"./excel/matrix-converter\";\nimport { dataTableToPdfDoc } from \"./pdf/matrix-converter\";\nimport { PDFDocument } from \"pdf-lib\";\nimport { createCoverPdf } from \"./pdf/cover-renderer\";\nimport { logoBase64 } from \"../assets/gfx-data\";\nimport { renderPdfMakeDocument } from \"./pdf/pdfmake-renderer\";\nimport type { PdfMakeConverterContext } from \"./pdf/pdfmake/pdfmake.types\";\nimport type { TDocumentDefinitions } from \"pdfmake/interfaces\";\nimport { fillPdfForm, FillPdfFormOptions } from \"./pdf/form-filler\";\nimport { preProcessPdfMakeDocument } from \"./pdf/pdfmake/adapter-processor\";\nimport { createAdapterRegistry } from \"./pdf/pdfmake/adapter-registry\";\nimport { dataTableAdapter } from \"./pdf/pdfmake/adapters/table-adapter\";\nimport { imageAdapter } from \"./pdf/pdfmake/adapters/image-adapter\";\nimport { chartAdapter } from \"./pdf/pdfmake/adapters/chart-adapter\";\nimport {\n footerAdapter,\n headerAdapter,\n} from \"./pdf/pdfmake/adapters/page-element-adapter\";\nimport { layoutAdapter } from \"./pdf/pdfmake/adapters/layout-adapter\";\n\n// `schedaToPdfData` removed: `sch-converter.ts` deleted and references removed\n\nexport const dataTableToPdfData = async (\n component: {\n smeupDataTable: SmeupDataTable;\n props: GenericObject;\n },\n webupManagerData: WebupManagerData,\n): Promise<Buffer | Uint8Array> => {\n const workbook = dataTableToExcelWorkbook(\n component,\n SupportedExportFormats.XLSX,\n webupManagerData,\n );\n\n const worksheet = workbook.getWorksheet(1);\n if (worksheet) {\n const title = component.smeupDataTable.cover?.titles?.[\"T01\"] ?? \"\";\n const subtitle = component.smeupDataTable.cover?.titles?.[\"T02\"] ?? \"\";\n const subtitle2 = component.smeupDataTable.cover?.titles?.[\"T03\"] ?? \"\";\n const image = component.smeupDataTable.cover?.image ?? \"\";\n const logo = component.smeupDataTable.cover?.logo ?? logoBase64;\n const cover = createCoverPdf(image, logo, title, subtitle, subtitle2);\n const pdfDoc = await dataTableToPdfDoc(worksheet, webupManagerData, {\n logoBase64: logo,\n title: title,\n subtitle: subtitle,\n });\n const pdfBuffer = pdfDoc.output(\"arraybuffer\");\n return convertToBuffer(await appendPdfDocs([cover, pdfBuffer]));\n } else {\n throw new Error(\"Worksheet not found in the workbook\");\n }\n};\n\nexport const pdfmakeDocumentToPdfData = async (\n documentDefinition: TDocumentDefinitions,\n context: Partial<PdfMakeConverterContext>,\n): Promise<Buffer> => {\n // Register adapters\n const registry = createAdapterRegistry();\n registry.register(\"table\", dataTableAdapter());\n registry.register(\"image\", imageAdapter());\n registry.register(\"chart\", chartAdapter());\n registry.register(\"footer\", footerAdapter());\n registry.register(\"header\", headerAdapter());\n registry.register(\"layout\", layoutAdapter());\n\n context.pdfDocument = documentDefinition;\n\n // Pre-process document with adapters\n const processedDoc = await preProcessPdfMakeDocument(\n documentDefinition,\n context,\n registry,\n );\n\n // console.debug(\n // \"Processed pdfmake document:\",\n // JSON.stringify(processedDoc, null, 2),\n // );\n // Render the document using pdfmake\n return renderPdfMakeDocument(processedDoc);\n};\n\n/**\n * Unisce più PDF (in formato ArrayBuffer/Uint8Array/Buffer) in un unico PDF.\n * @param pdfBuffers Array di buffer PDF (es. ottenuti da jsPDF.output(\"arraybuffer\"))\n * @returns Buffer del PDF unito\n */\nconst appendPdfDocs = async (\n pdfBuffers: (Uint8Array | ArrayBuffer | Buffer)[],\n): Promise<Uint8Array> => {\n if (!pdfBuffers.length) throw new Error(\"No PDF buffers to append\");\n\n // Crea un nuovo documento PDF vuoto\n const mergedPdf = await PDFDocument.create();\n\n for (const pdfBytes of pdfBuffers) {\n const srcPdf = await PDFDocument.load(pdfBytes);\n const copiedPages = await mergedPdf.copyPages(\n srcPdf,\n srcPdf.getPageIndices(),\n );\n copiedPages.forEach(page => mergedPdf.addPage(page));\n }\n\n const mergedBytes = await mergedPdf.save();\n return mergedBytes;\n};\n\n// Re-export form filler function and types\nexport { fillPdfForm };\nexport type { FillPdfFormOptions };\n"]}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
export { dataTableToExcelData, dataTreeToExcelData, } from "./converters/excel-converter";
|
|
2
|
-
export {
|
|
2
|
+
export { dataTableToPdfData, pdfmakeDocumentToPdfData, fillPdfForm, } from "./converters/pdf-converter";
|
|
3
3
|
export type { FillPdfFormOptions } from "./converters/pdf-converter";
|
|
4
|
-
export { dataTableToChart } from "./converters/images/charts-
|
|
4
|
+
export { dataTableToChart } from "./converters/images/charts-converter";
|
|
5
5
|
export { createAdapterRegistry } from "./converters/pdf/pdfmake/adapter-registry";
|
|
6
|
-
export { funToSmeupTableAdapter } from "./converters/pdf/pdfmake/table-adapter";
|
|
7
|
-
export { smeupTableToPdfMakeTableAdapter } from "./converters/pdf/pdfmake/table-adapter";
|
|
6
|
+
export { funToSmeupTableAdapter } from "./converters/pdf/pdfmake/adapters/table-adapter";
|
|
7
|
+
export { smeupTableToPdfMakeTableAdapter } from "./converters/pdf/pdfmake/adapters/table-adapter";
|
|
8
8
|
export { preProcessPdfMakeDocument } from "./converters/pdf/pdfmake/adapter-processor";
|
|
9
9
|
export type { PdfmakeAdapter, PdfMakeConverterContext, AdapterRegistry, AdapterError, } from "./converters/pdf/pdfmake/pdfmake.types";
|
|
10
10
|
export type { WebupManagerData, GenericObject } from "./types/index";
|