@pdfme/ui 2.1.0 → 2.2.1

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.
Files changed (73) hide show
  1. package/README.md +7 -3
  2. package/dist/index.js +1 -1
  3. package/dist/index.js.LICENSE.txt +1 -1
  4. package/dist/index.js.map +1 -1
  5. package/dist/types/builtInRenderer.d.ts +3 -0
  6. package/dist/types/class.d.ts +10 -1
  7. package/dist/types/components/CtlBar/Pager.d.ts +3 -2
  8. package/dist/types/components/CtlBar/Zoom.d.ts +3 -2
  9. package/dist/types/components/CtlBar/index.d.ts +3 -2
  10. package/dist/types/components/Designer/Main/Guides.d.ts +2 -2
  11. package/dist/types/components/Designer/Main/Mask.d.ts +2 -1
  12. package/dist/types/components/Designer/Main/Moveable.d.ts +1 -1
  13. package/dist/types/components/Designer/Main/Selecto.d.ts +2 -1
  14. package/dist/types/components/Designer/Sidebar/DetailView/BarCodePropEditor.d.ts +7 -0
  15. package/dist/types/components/Designer/Sidebar/DetailView/ExampleInputEditor.d.ts +2 -1
  16. package/dist/types/components/Designer/Sidebar/DetailView/FormComponents/ColorInputSet.d.ts +9 -0
  17. package/dist/types/components/Designer/Sidebar/DetailView/PositionAndSizeEditor.d.ts +2 -1
  18. package/dist/types/components/Designer/Sidebar/DetailView/TextPropEditor.d.ts +2 -1
  19. package/dist/types/components/Designer/Sidebar/DetailView/TypeAndKeyEditor.d.ts +2 -1
  20. package/dist/types/components/Designer/Sidebar/DetailView/index.d.ts +3 -2
  21. package/dist/types/components/Designer/Sidebar/ListView/SelectableSortableContainer.d.ts +2 -1
  22. package/dist/types/components/Designer/Sidebar/ListView/SelectableSortableItem.d.ts +1 -1
  23. package/dist/types/components/Designer/Sidebar/ListView/index.d.ts +2 -1
  24. package/dist/types/components/Designer/Sidebar/index.d.ts +4 -2
  25. package/dist/types/components/Designer/index.d.ts +11 -2
  26. package/dist/types/components/Divider.d.ts +2 -1
  27. package/dist/types/components/Error.d.ts +2 -1
  28. package/dist/types/components/Paper.d.ts +2 -2
  29. package/dist/types/components/Preview.d.ts +2 -1
  30. package/dist/types/components/Renderer.d.ts +4 -0
  31. package/dist/types/components/Root.d.ts +1 -1
  32. package/dist/types/components/Spinner.d.ts +2 -1
  33. package/dist/types/components/UnitPager.d.ts +3 -2
  34. package/dist/types/contexts.d.ts +3 -1
  35. package/dist/types/helper.d.ts +5 -0
  36. package/dist/types/hooks.d.ts +2 -2
  37. package/dist/types/i18n.d.ts +4 -1
  38. package/dist/types/renders/barcodes.d.ts +2 -0
  39. package/dist/types/renders/image.d.ts +2 -0
  40. package/dist/types/renders/text.d.ts +2 -0
  41. package/dist/types/types.d.ts +25 -0
  42. package/package.json +2 -1
  43. package/src/Designer.tsx +21 -17
  44. package/src/Form.tsx +18 -14
  45. package/src/Viewer.tsx +6 -2
  46. package/src/builtInRenderer.ts +14 -0
  47. package/src/class.ts +22 -2
  48. package/src/components/Designer/Main/index.tsx +4 -15
  49. package/src/components/Designer/Sidebar/DetailView/BarCodePropEditor.tsx +81 -0
  50. package/src/components/Designer/Sidebar/DetailView/ExampleInputEditor.tsx +1 -2
  51. package/src/components/Designer/Sidebar/DetailView/FormComponents/ColorInputSet.tsx +50 -0
  52. package/src/components/Designer/Sidebar/DetailView/PositionAndSizeEditor.tsx +1 -3
  53. package/src/components/Designer/Sidebar/DetailView/TextPropEditor.tsx +189 -209
  54. package/src/components/Designer/Sidebar/DetailView/index.tsx +16 -8
  55. package/src/components/Designer/Sidebar/index.tsx +3 -2
  56. package/src/components/Designer/index.tsx +1 -0
  57. package/src/components/Preview.tsx +6 -6
  58. package/src/components/Renderer.tsx +80 -0
  59. package/src/contexts.ts +5 -0
  60. package/src/helper.ts +8 -0
  61. package/src/i18n.ts +44 -1
  62. package/src/renders/barcodes.ts +117 -0
  63. package/src/renders/image.ts +101 -0
  64. package/src/renders/text.ts +138 -0
  65. package/src/types.ts +28 -0
  66. package/dist/types/components/Schemas/BarcodeSchema.d.ts +0 -15
  67. package/dist/types/components/Schemas/ImageSchema.d.ts +0 -15
  68. package/dist/types/components/Schemas/SchemaUI.d.ts +0 -15
  69. package/dist/types/components/Schemas/TextSchema.d.ts +0 -27
  70. package/src/components/Schemas/BarcodeSchema.tsx +0 -124
  71. package/src/components/Schemas/ImageSchema.tsx +0 -87
  72. package/src/components/Schemas/SchemaUI.tsx +0 -62
  73. package/src/components/Schemas/TextSchema.tsx +0 -117
@@ -1,124 +0,0 @@
1
- import React, { forwardRef, Ref } from 'react';
2
- import { validateBarcodeInput, BarCodeType, BarcodeSchema, } from '@pdfme/common';
3
- import { ZOOM } from '../../constants';
4
- import { SchemaUIProps } from './SchemaUI';
5
-
6
- const barcodeExampleImageObj: { [K in BarCodeType]: string } = {
7
- qrcode:
8
- '',
9
- japanpost:
10
- '',
11
- ean13:
12
- '',
13
- ean8: '',
14
- code39:
15
- '',
16
- code128:
17
- '',
18
- nw7: '',
19
- itf14:
20
- '',
21
- upca: '',
22
- upce: '',
23
- gs1datamatrix: '',
24
- };
25
-
26
- const SampleBarcode = ({ schema }: { schema: BarcodeSchema }) => (
27
- <img
28
- style={{
29
- width: schema.width * ZOOM,
30
- height: schema.height * ZOOM,
31
- position: 'absolute',
32
- borderRadius: 0,
33
- opacity: 0.5,
34
- }}
35
- src={barcodeExampleImageObj[schema.type]}
36
- />
37
- );
38
-
39
- const ErrorBarcode = () => (
40
- <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center', height: '100%' }}>
41
- <span
42
- style={{
43
- color: 'white',
44
- background: 'red',
45
- padding: '0.25rem',
46
- fontSize: '12pt',
47
- fontWeight: 'bold',
48
- borderRadius: 2,
49
- }}
50
- >
51
- ERROR
52
- </span>
53
- </div>
54
- );
55
-
56
- const BarcodePreview = (props: { schema: BarcodeSchema; value: string }) => {
57
- const { schema, value } = props;
58
-
59
- if (value.length === 0) {
60
- return null;
61
- }
62
-
63
- return validateBarcodeInput(schema.type as BarCodeType, value) ? (
64
- <SampleBarcode schema={schema} />
65
- ) : (
66
- <ErrorBarcode />
67
- );
68
- };
69
- type Props = SchemaUIProps & { schema: BarcodeSchema };
70
-
71
- const BarcodeSchemaUI = (
72
- { schema, editable, placeholder, tabIndex, onChange, onStopEditing }: Props,
73
- ref: Ref<HTMLInputElement>
74
- ) => {
75
- const value = schema.data;
76
-
77
- const style: React.CSSProperties = {
78
- textAlign: 'center',
79
- position: 'absolute',
80
- zIndex: 2,
81
- fontSize: '1rem',
82
- color: '#000',
83
- height: Number(schema.height) * ZOOM,
84
- width: Number(schema.width) * ZOOM,
85
- backgroundColor: editable || value ? 'rgb(242 244 255 / 75%)' : 'none',
86
- border: 'none',
87
- display: 'flex',
88
- alignItems: 'center',
89
- justifyContent: 'center',
90
- overflow: 'auto',
91
- };
92
-
93
- return (
94
- <div
95
- style={{
96
- width: '100%',
97
- height: '100%',
98
- display: 'flex',
99
- alignItems: 'center',
100
- justifyContent: 'center',
101
- fontFamily: "'Open Sans', sans-serif",
102
- }}
103
- >
104
- {editable ? (
105
- <input
106
- ref={ref}
107
- tabIndex={tabIndex}
108
- placeholder={placeholder}
109
- style={style}
110
- value={value}
111
- onChange={(e) => onChange(e.target.value)}
112
- onBlur={onStopEditing}
113
- />
114
- ) : (
115
- <div style={style}>
116
- <span>{value}</span>
117
- </div>
118
- )}
119
- <BarcodePreview value={value} schema={schema} />
120
- </div>
121
- );
122
- };
123
-
124
- export default forwardRef<HTMLInputElement, Props>(BarcodeSchemaUI);
@@ -1,87 +0,0 @@
1
- import React, { useState, forwardRef, ChangeEvent, Ref } from 'react';
2
- import { ImageSchema } from '@pdfme/common';
3
- import { SchemaUIProps } from './SchemaUI';
4
- import { readFiles } from '../../helper';
5
- import { ZOOM } from '../../constants';
6
- import { XMarkIcon } from '@heroicons/react/24/outline';
7
-
8
- type Props = SchemaUIProps & { schema: ImageSchema };
9
-
10
- const ImageSchemaUI = (props: Props, ref: Ref<HTMLInputElement>) => {
11
- const { editable, placeholder, tabIndex, schema, onChange, onStopEditing } = props;
12
- const [fileName, setFileName] = useState<string>('');
13
- const hasData = Boolean(schema.data);
14
-
15
- const size: React.CSSProperties = { width: schema.width * ZOOM, height: schema.height * ZOOM };
16
-
17
- return (
18
- <>
19
- <div
20
- style={{
21
- ...size,
22
- opacity: hasData ? 1 : 0.5,
23
- backgroundImage: hasData || !editable ? 'none' : `url(${placeholder})`,
24
- backgroundSize: `${size.width}px ${size.height}px`,
25
- }}
26
- onClick={(e) => {
27
- if (editable) {
28
- e.stopPropagation();
29
- }
30
- }}
31
- >
32
- {hasData && <img style={{ ...size, borderRadius: 0 }} src={schema.data} />}
33
- {hasData && editable && (
34
- <button
35
- tabIndex={tabIndex}
36
- style={{
37
- position: 'absolute',
38
- top: 0,
39
- left: 0,
40
- zIndex: 1,
41
- display: 'flex',
42
- justifyContent: 'center',
43
- alignItems: 'center',
44
- color: '#333',
45
- background: '#f2f2f2',
46
- borderRadius: 2,
47
- border: '1px solid #767676',
48
- cursor: 'pointer',
49
- height: 24,
50
- width: 24,
51
- }}
52
- aria-label="close"
53
- onClick={() => {
54
- setFileName('');
55
- onChange('');
56
- }}
57
- >
58
- <XMarkIcon width={10} height={10} />
59
- </button>
60
- )}
61
- </div>
62
- <label
63
- style={{
64
- display: editable ? 'flex' : 'none',
65
- position: 'absolute',
66
- top: '50%',
67
- width: '100%',
68
- cursor: 'pointer',
69
- }}
70
- >
71
- <input
72
- ref={ref}
73
- tabIndex={tabIndex}
74
- value={fileName}
75
- onChange={(event: ChangeEvent<HTMLInputElement>) =>
76
- readFiles(event.target.files, 'dataURL').then((result) => onChange(result as string))
77
- }
78
- onBlur={onStopEditing}
79
- type="file"
80
- accept="image/jpeg, image/png"
81
- />
82
- </label>
83
- </>
84
- );
85
- };
86
-
87
- export default forwardRef<HTMLInputElement, Props>(ImageSchemaUI);
@@ -1,62 +0,0 @@
1
- import React, { forwardRef, RefObject, Ref, ReactNode } from 'react';
2
- import { SchemaForUI, isTextSchema, isImageSchema, isBarcodeSchema } from '@pdfme/common';
3
- import { ZOOM, SELECTABLE_CLASSNAME } from '../../constants';
4
- import TextSchema from './TextSchema';
5
- import ImageSchema from './ImageSchema';
6
- import BarcodeSchema from './BarcodeSchema';
7
-
8
- export interface SchemaUIProps {
9
- schema: SchemaForUI;
10
- editable: boolean;
11
- onChange: (value: string) => void;
12
- onStopEditing: () => void;
13
- tabIndex?: number;
14
- placeholder?: string;
15
- }
16
-
17
- type Props = SchemaUIProps & {
18
- outline: string;
19
- onChangeHoveringSchemaId?: (id: string | null) => void;
20
- };
21
-
22
- const Wrapper = ({
23
- children,
24
- outline,
25
- onChangeHoveringSchemaId,
26
- schema,
27
- }: Props & { children: ReactNode }) => (
28
- <div
29
- title={schema.key}
30
- onMouseEnter={() => onChangeHoveringSchemaId && onChangeHoveringSchemaId(schema.id)}
31
- onMouseLeave={() => onChangeHoveringSchemaId && onChangeHoveringSchemaId(null)}
32
- className={SELECTABLE_CLASSNAME}
33
- id={schema.id}
34
- style={{
35
- position: 'absolute',
36
- cursor: 'pointer',
37
- height: schema.height * ZOOM,
38
- width: schema.width * ZOOM,
39
- top: schema.position.y * ZOOM,
40
- left: schema.position.x * ZOOM,
41
- outline,
42
- }}
43
- >
44
- {children}
45
- </div>
46
- );
47
-
48
- const SchemaUI = (props: Props, ref: Ref<HTMLTextAreaElement | HTMLInputElement>) => {
49
- const r = {
50
- [props.editable ? 'ref' : '']: ref as RefObject<HTMLTextAreaElement | HTMLInputElement>,
51
- };
52
- const { schema } = props;
53
-
54
- return (
55
- <Wrapper {...props}>
56
- {isTextSchema(schema) && <TextSchema {...r} {...props} schema={schema} />}
57
- {isImageSchema(schema) && <ImageSchema {...r} {...props} schema={schema} />}
58
- {isBarcodeSchema(schema) && <BarcodeSchema {...r} {...props} schema={schema} />}
59
- </Wrapper>
60
- );
61
- };
62
- export default forwardRef<HTMLTextAreaElement | HTMLInputElement, Props>(SchemaUI);
@@ -1,117 +0,0 @@
1
- import React, { useContext, forwardRef, Ref, useState, useEffect } from 'react';
2
- import {
3
- DEFAULT_FONT_SIZE,
4
- DEFAULT_ALIGNMENT,
5
- DEFAULT_LINE_HEIGHT,
6
- DEFAULT_CHARACTER_SPACING,
7
- DEFAULT_FONT_COLOR,
8
- TextSchema,
9
- calculateDynamicFontSize,
10
- getFontKitFont,
11
- getFontAlignmentValue,
12
- } from '@pdfme/common';
13
- import { SchemaUIProps } from './SchemaUI';
14
- import { ZOOM } from '../../constants';
15
- import { FontContext } from '../../contexts';
16
-
17
- type Props = SchemaUIProps & { schema: TextSchema };
18
-
19
- const TextSchemaUI = (
20
- { schema, editable, placeholder, tabIndex, onChange, onStopEditing }: Props,
21
- ref: Ref<HTMLTextAreaElement>
22
- ) => {
23
- const font = useContext(FontContext);
24
- const [dynamicFontSize, setDynamicFontSize] = useState<number | undefined>(undefined);
25
- const [fontAlignmentValue, setFontAlignmentValue] = useState<number>(0);
26
-
27
-
28
- useEffect(() => {
29
- if (schema.dynamicFontSize && schema.data) {
30
- calculateDynamicFontSize({
31
- textSchema: schema,
32
- font,
33
- input: schema.data,
34
- startingFontSize: dynamicFontSize,
35
- }).then(setDynamicFontSize);
36
- } else {
37
- setDynamicFontSize(undefined);
38
- }
39
- }, [
40
- schema.data,
41
- schema.width,
42
- schema.height,
43
- schema.dynamicFontSize?.min,
44
- schema.dynamicFontSize?.max,
45
- schema.dynamicFontSize?.fit,
46
- schema.characterSpacing,
47
- schema.lineHeight,
48
- font
49
- ]);
50
-
51
- useEffect(() => {
52
- getFontKitFont(schema, font).then(fontKitFont => {
53
- const fav = getFontAlignmentValue(fontKitFont, dynamicFontSize ?? schema.fontSize ?? DEFAULT_FONT_SIZE);
54
- setFontAlignmentValue(fav);
55
- });
56
- }, [
57
- schema.width,
58
- schema.height,
59
- schema.fontName,
60
- schema.fontSize,
61
- schema.dynamicFontSize?.max,
62
- schema.dynamicFontSize?.min,
63
- schema.dynamicFontSize?.fit,
64
- schema.characterSpacing,
65
- schema.lineHeight,
66
- font,
67
- dynamicFontSize
68
- ]);
69
-
70
-
71
- const style: React.CSSProperties = {
72
- position: 'absolute',
73
- top: 0,
74
- padding: 0,
75
- height: fontAlignmentValue < 0 ? schema.height * ZOOM + Math.abs(fontAlignmentValue) : schema.height * ZOOM,
76
- width: schema.width * ZOOM,
77
- resize: 'none',
78
- marginTop: fontAlignmentValue < 0 ? fontAlignmentValue : 0,
79
- paddingTop: fontAlignmentValue >= 0 ? fontAlignmentValue : 0,
80
- fontFamily: schema.fontName ? `'${schema.fontName}'` : 'inherit',
81
- color: schema.fontColor ? schema.fontColor : DEFAULT_FONT_COLOR,
82
- fontSize: `${dynamicFontSize ?? schema.fontSize ?? DEFAULT_FONT_SIZE}pt`,
83
- letterSpacing: `${schema.characterSpacing ?? DEFAULT_CHARACTER_SPACING}pt`,
84
- lineHeight: `${schema.lineHeight ?? DEFAULT_LINE_HEIGHT}em`,
85
- textAlign: schema.alignment ?? DEFAULT_ALIGNMENT,
86
- whiteSpace: 'pre-wrap',
87
- wordBreak: 'break-word',
88
- backgroundColor:
89
- schema.data && schema.backgroundColor ? schema.backgroundColor : 'rgb(242 244 255 / 75%)',
90
- border: 'none',
91
- };
92
-
93
- return editable ? (
94
- <textarea
95
- ref={ref}
96
- placeholder={placeholder}
97
- tabIndex={tabIndex}
98
- style={style}
99
- onChange={(e) => onChange(e.target.value)}
100
- onBlur={onStopEditing}
101
- value={schema.data}
102
- ></textarea>
103
- ) : (
104
- <div style={{ ...style, height: schema.height * ZOOM, marginTop: 0, paddingTop: 0 }}>
105
- <div style={{ marginTop: style.marginTop, paddingTop: style.paddingTop }}>
106
- {/* Set the letterSpacing of the last character to 0. */}
107
- {schema.data.split('').map((l, i) => (
108
- <span key={i} style={{ letterSpacing: String(schema.data).length === i + 1 ? 0 : 'inherit', }} >
109
- {l}
110
- </span>
111
- ))}
112
- </div>
113
- </div>
114
- );
115
- };
116
-
117
- export default forwardRef<HTMLTextAreaElement, Props>(TextSchemaUI);