@pdfme/ui 2.2.0 → 3.0.0-beta.2

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 (94) hide show
  1. package/README.md +33 -35
  2. package/__mocks__/form-render.js +7 -0
  3. package/dist/index.js +1 -1
  4. package/dist/index.js.LICENSE.txt +42 -4
  5. package/dist/index.js.map +1 -1
  6. package/dist/types/Designer.d.ts +3 -0
  7. package/dist/types/builtInPropPanel.d.ts +3 -0
  8. package/dist/types/builtInRenderer.d.ts +3 -0
  9. package/dist/types/class.d.ts +18 -38
  10. package/dist/types/components/CtlBar/Pager.d.ts +3 -2
  11. package/dist/types/components/CtlBar/Zoom.d.ts +3 -2
  12. package/dist/types/components/CtlBar/index.d.ts +3 -2
  13. package/dist/types/components/Designer/{Main → Canvas}/Guides.d.ts +2 -2
  14. package/dist/types/components/Designer/Canvas/Mask.d.ts +4 -0
  15. package/dist/types/components/Designer/Canvas/Moveable.d.ts +37 -0
  16. package/dist/types/components/Designer/{Main → Canvas}/Selecto.d.ts +2 -1
  17. package/dist/types/components/Designer/{Main → Canvas}/index.d.ts +3 -6
  18. package/dist/types/components/Designer/Sidebar/DetailView/AlignWidget.d.ts +4 -0
  19. package/dist/types/components/Designer/Sidebar/DetailView/WidgetRenderer.d.ts +7 -0
  20. package/dist/types/components/Designer/Sidebar/DetailView/index.d.ts +5 -4
  21. package/dist/types/components/Designer/Sidebar/ListView/SelectableSortableContainer.d.ts +3 -2
  22. package/dist/types/components/Designer/Sidebar/ListView/SelectableSortableItem.d.ts +1 -1
  23. package/dist/types/components/Designer/Sidebar/ListView/index.d.ts +3 -2
  24. package/dist/types/components/Designer/Sidebar/index.d.ts +3 -23
  25. package/dist/types/components/Designer/index.d.ts +6 -107
  26. package/dist/types/components/Divider.d.ts +2 -1
  27. package/dist/types/components/ErrorScreen.d.ts +7 -0
  28. package/dist/types/components/Paper.d.ts +3 -2
  29. package/dist/types/components/Preview.d.ts +10 -2
  30. package/dist/types/components/Renderer.d.ts +10 -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/constants.d.ts +3 -3
  35. package/dist/types/contexts.d.ts +4 -1
  36. package/dist/types/helper.d.ts +4 -46
  37. package/dist/types/hooks.d.ts +2 -2
  38. package/dist/types/i18n.d.ts +4 -2
  39. package/dist/types/index.d.ts +1 -4
  40. package/dist/types/types.d.ts +25 -0
  41. package/package.json +19 -8
  42. package/src/Designer.tsx +69 -21
  43. package/src/Form.tsx +18 -14
  44. package/src/Viewer.tsx +6 -2
  45. package/src/builtInPropPanel.ts +5 -0
  46. package/src/builtInRenderer.ts +5 -0
  47. package/src/class.ts +25 -2
  48. package/src/components/CtlBar/index.tsx +4 -7
  49. package/src/components/Designer/{Main → Canvas}/Guides.tsx +2 -2
  50. package/src/components/Designer/{Main → Canvas}/Moveable.tsx +23 -19
  51. package/src/components/Designer/{Main → Canvas}/index.tsx +77 -30
  52. package/src/components/Designer/Sidebar/DetailView/AlignWidget.tsx +182 -0
  53. package/src/components/Designer/Sidebar/DetailView/WidgetRenderer.tsx +28 -0
  54. package/src/components/Designer/Sidebar/DetailView/index.tsx +153 -22
  55. package/src/components/Designer/Sidebar/ListView/Item.tsx +1 -1
  56. package/src/components/Designer/Sidebar/ListView/SelectableSortableContainer.tsx +6 -6
  57. package/src/components/Designer/Sidebar/ListView/index.tsx +1 -4
  58. package/src/components/Designer/Sidebar/index.tsx +26 -60
  59. package/src/components/Designer/index.tsx +53 -32
  60. package/src/components/{Error.tsx → ErrorScreen.tsx} +2 -2
  61. package/src/components/Paper.tsx +35 -9
  62. package/src/components/Preview.tsx +48 -50
  63. package/src/components/Renderer.tsx +90 -0
  64. package/src/components/Root.tsx +5 -1
  65. package/src/constants.ts +4 -4
  66. package/src/contexts.ts +7 -0
  67. package/src/helper.ts +19 -122
  68. package/src/hooks.ts +6 -5
  69. package/src/i18n.ts +48 -11
  70. package/src/index.ts +1 -76
  71. package/src/types.ts +36 -0
  72. package/tsconfig.json +2 -1
  73. package/webpack.config.js +6 -1
  74. package/dist/types/components/Designer/Main/Mask.d.ts +0 -3
  75. package/dist/types/components/Designer/Main/Moveable.d.ts +0 -31
  76. package/dist/types/components/Designer/Sidebar/DetailView/ExampleInputEditor.d.ts +0 -6
  77. package/dist/types/components/Designer/Sidebar/DetailView/PositionAndSizeEditor.d.ts +0 -6
  78. package/dist/types/components/Designer/Sidebar/DetailView/TextPropEditor.d.ts +0 -6
  79. package/dist/types/components/Designer/Sidebar/DetailView/TypeAndKeyEditor.d.ts +0 -6
  80. package/dist/types/components/Error.d.ts +0 -6
  81. package/dist/types/components/Schemas/BarcodeSchema.d.ts +0 -15
  82. package/dist/types/components/Schemas/ImageSchema.d.ts +0 -15
  83. package/dist/types/components/Schemas/SchemaUI.d.ts +0 -15
  84. package/dist/types/components/Schemas/TextSchema.d.ts +0 -28
  85. package/src/components/Designer/Sidebar/DetailView/ExampleInputEditor.tsx +0 -85
  86. package/src/components/Designer/Sidebar/DetailView/PositionAndSizeEditor.tsx +0 -275
  87. package/src/components/Designer/Sidebar/DetailView/TextPropEditor.tsx +0 -357
  88. package/src/components/Designer/Sidebar/DetailView/TypeAndKeyEditor.tsx +0 -87
  89. package/src/components/Schemas/BarcodeSchema.tsx +0 -124
  90. package/src/components/Schemas/ImageSchema.tsx +0 -87
  91. package/src/components/Schemas/SchemaUI.tsx +0 -62
  92. package/src/components/Schemas/TextSchema.tsx +0 -175
  93. /package/src/components/Designer/{Main → Canvas}/Mask.tsx +0 -0
  94. /package/src/components/Designer/{Main → Canvas}/Selecto.tsx +0 -0
@@ -1,357 +0,0 @@
1
- import React, { useContext } from 'react';
2
- import {
3
- SchemaForUI,
4
- getFallbackFontName,
5
- DEFAULT_FONT_SIZE,
6
- DEFAULT_LINE_HEIGHT,
7
- DEFAULT_CHARACTER_SPACING,
8
- DEFAULT_FONT_COLOR,
9
- VERTICAL_ALIGN_TOP,
10
- VERTICAL_ALIGN_MIDDLE,
11
- VERTICAL_ALIGN_BOTTOM,
12
- DEFAULT_VERTICAL_ALIGNMENT,
13
- DYNAMIC_FIT_VERTICAL,
14
- DYNAMIC_FIT_HORIZONTAL,
15
- DEFAULT_DYNAMIC_FIT,
16
- } from '@pdfme/common';
17
- import { FontContext } from '../../../../contexts';
18
- import { SidebarProps } from '..';
19
- import { XMarkIcon } from '@heroicons/react/24/outline';
20
-
21
- const inputStyle = {
22
- width: '90%',
23
- color: '#333',
24
- background: 'none',
25
- borderRadius: 2,
26
- border: '1px solid #767676',
27
- };
28
- const selectStyle = inputStyle;
29
-
30
- const NumberInputSet = (props: {
31
- width: string;
32
- label: string;
33
- value: number;
34
- step?: number;
35
- minNumber?: number;
36
- maxNumber?: number;
37
- disabled?: boolean;
38
- style?: object;
39
- onChange: (e: React.ChangeEvent<HTMLInputElement>) => void;
40
- }) => {
41
- const { label, step, value, width, minNumber, maxNumber, disabled, style, onChange } = props;
42
- const formattedLabel = label.replace(/\s/g, '');
43
-
44
- return (
45
- <div style={{ width }}>
46
- <label htmlFor={`input-${formattedLabel}`}>{label}</label>
47
- <input
48
- id={`input-${formattedLabel}`}
49
- name={`input-${formattedLabel}`}
50
- style={{ ...inputStyle, ...style }}
51
- onChange={onChange}
52
- value={isNaN(value) ? '' : value}
53
- type="number"
54
- step={step ?? 1}
55
- disabled={disabled}
56
- {...(minNumber && { min: minNumber })}
57
- {...(maxNumber && { max: maxNumber })}
58
- />
59
- </div>
60
- );
61
- };
62
-
63
- const ColorInputSet = (props: {
64
- label: string;
65
- value: string;
66
- onChange: (e: React.ChangeEvent<HTMLInputElement>) => void;
67
- onClear: () => void;
68
- }) => {
69
- const { label, value, onChange, onClear } = props;
70
- const formattedLabel = label.replace(/\s/g, '');
71
-
72
- return (
73
- <div style={{ width: '45%' }}>
74
- <label htmlFor={`input-${formattedLabel}`}>{label}</label>
75
- <div style={{ display: 'flex' }}>
76
- <input
77
- id={`input-${formattedLabel}`}
78
- name={`input-${formattedLabel}`}
79
- onChange={onChange}
80
- value={value || '#ffffff'}
81
- type="color"
82
- style={inputStyle}
83
- />
84
- <button
85
- onClick={onClear}
86
- style={{
87
- display: 'flex',
88
- alignItems: 'center',
89
- justifyContent: 'center',
90
- background: 'none',
91
- borderRadius: 2,
92
- border: '1px solid #767676',
93
- cursor: 'pointer',
94
- }}
95
- >
96
- <XMarkIcon width={10} height={10} />
97
- </button>
98
- </div>
99
- </div>
100
- );
101
- };
102
-
103
- const SelectSet = (props: {
104
- label: string;
105
- value: string;
106
- options: string[];
107
- width?: string;
108
- onChange: (e: React.ChangeEvent<HTMLSelectElement>) => void;
109
- }) => {
110
- const { label, value, options, width, onChange } = props;
111
- const formattedLabel = label.replace(/\s/g, '');
112
-
113
- return (
114
- <div style={{ width: width ?? '45%' }}>
115
- <label htmlFor={`select-${formattedLabel}`}>{label}:</label>
116
- <select
117
- id={`select-${formattedLabel}`}
118
- name={`select-${formattedLabel}`}
119
- style={selectStyle}
120
- onChange={onChange}
121
- value={value}
122
- >
123
- {options.map((o) => (
124
- <option key={o} value={o}>
125
- {o}
126
- </option>
127
- ))}
128
- </select>
129
- </div>
130
- );
131
- };
132
-
133
- const CheckboxSet = (props: {
134
- width: string;
135
- label: string;
136
- onChange: React.ChangeEventHandler<HTMLInputElement>;
137
- checked: boolean | undefined;
138
- }) => {
139
- const { width, label, onChange, checked } = props;
140
-
141
- return (
142
- <label
143
- style={{
144
- display: 'flex',
145
- alignItems: 'center',
146
- gap: '5px',
147
- width: `${width}`,
148
- }}
149
- >
150
- <input type="checkbox" checked={checked} onChange={onChange} />
151
- {label}
152
- </label>
153
- );
154
- };
155
-
156
- const TextPropEditor = (
157
- props: Pick<SidebarProps, 'changeSchemas'> & { activeSchema: SchemaForUI }
158
- ) => {
159
- const { changeSchemas, activeSchema } = props;
160
- const alignments = ['left', 'center', 'right'];
161
- const verticalAlignments = [VERTICAL_ALIGN_TOP, VERTICAL_ALIGN_MIDDLE, VERTICAL_ALIGN_BOTTOM];
162
- const dynamicFits = [DYNAMIC_FIT_HORIZONTAL, DYNAMIC_FIT_VERTICAL];
163
- const font = useContext(FontContext);
164
- const fallbackFontName = getFallbackFontName(font);
165
-
166
- if (activeSchema.type !== 'text') return <></>;
167
-
168
- return (
169
- <section style={{ fontSize: '0.7rem' }}>
170
- <div
171
- style={{
172
- display: 'flex',
173
- alignItems: 'center',
174
- justifyContent: 'space-between',
175
- marginBottom: '0.25rem',
176
- }}
177
- >
178
- <SelectSet
179
- label={'FontName'}
180
- value={activeSchema.fontName ?? fallbackFontName}
181
- options={Object.keys(font)}
182
- onChange={(e) => {
183
- changeSchemas([{ key: 'fontName', value: e.target.value, schemaId: activeSchema.id }]);
184
- }}
185
- />
186
-
187
- <SelectSet
188
- label={'Horizontal Align'}
189
- value={activeSchema.alignment ?? 'left'}
190
- options={alignments}
191
- onChange={(e) =>
192
- changeSchemas([{ key: 'alignment', value: e.target.value, schemaId: activeSchema.id }])
193
- }
194
- />
195
-
196
- <SelectSet
197
- label={'Vertical Align'}
198
- value={activeSchema.verticalAlignment ?? DEFAULT_VERTICAL_ALIGNMENT}
199
- options={verticalAlignments}
200
- onChange={(e) => {
201
- changeSchemas([{ key: 'verticalAlignment', value: e.target.value, schemaId: activeSchema.id }]);
202
- }}
203
- />
204
- </div>
205
- <div
206
- style={{
207
- display: 'flex',
208
- alignItems: 'center',
209
- justifyContent: 'space-between',
210
- marginBottom: '0.25rem',
211
- }}
212
- >
213
- <NumberInputSet
214
- width="30%"
215
- label={'FontSize(pt)'}
216
- value={activeSchema.dynamicFontSize ? NaN : (activeSchema.fontSize ?? DEFAULT_FONT_SIZE)}
217
- style={activeSchema.dynamicFontSize ? { background: '#ccc', cursor: 'not-allowed' } : {}}
218
- disabled={!!activeSchema.dynamicFontSize}
219
- onChange={(e) => {
220
- changeSchemas([{ key: 'fontSize', value: Number(e.target.value), schemaId: activeSchema.id }])
221
- }}
222
- />
223
- <NumberInputSet
224
- width="30%"
225
- label={'LineHeight(em)'}
226
- step={0.1}
227
- value={activeSchema.lineHeight ?? DEFAULT_LINE_HEIGHT}
228
- onChange={(e) =>
229
- changeSchemas([
230
- { key: 'lineHeight', value: Number(e.target.value), schemaId: activeSchema.id },
231
- ])
232
- }
233
- />
234
-
235
- <NumberInputSet
236
- width="40%"
237
- label={'CharacterSpacing(pt)'}
238
- step={0.1}
239
- value={activeSchema.characterSpacing ?? DEFAULT_CHARACTER_SPACING}
240
- onChange={async (e) => {
241
- const currentCharacterSpacing = Number(e.target.value);
242
- changeSchemas([
243
- { key: 'characterSpacing', value: currentCharacterSpacing, schemaId: activeSchema.id, },
244
- ]);
245
- }}
246
- />
247
- </div>
248
- <div
249
- style={{
250
- display: 'flex',
251
- alignItems: 'center',
252
- justifyContent: 'space-between',
253
- flexWrap: 'wrap',
254
- marginBottom: '0.25rem',
255
- }}
256
- >
257
- <CheckboxSet
258
- width="100%"
259
- label="Use dynamic font size"
260
- checked={Boolean(activeSchema.dynamicFontSize)}
261
- onChange={(e) => {
262
- changeSchemas([
263
- {
264
- key: 'dynamicFontSize', value: e.target.checked ? {
265
- min: activeSchema.fontSize || DEFAULT_FONT_SIZE,
266
- max: activeSchema.fontSize || DEFAULT_FONT_SIZE,
267
- } : undefined, schemaId: activeSchema.id,
268
- },
269
- ]);
270
- }}
271
- />
272
-
273
- {activeSchema.dynamicFontSize && (
274
- <>
275
- <NumberInputSet
276
- width="30%"
277
- label={'FontSize Min(pt)'}
278
- value={activeSchema.dynamicFontSize.min ?? Number(activeSchema.fontSize)}
279
- minNumber={0}
280
- style={
281
- activeSchema.dynamicFontSize &&
282
- activeSchema.dynamicFontSize.max < activeSchema.dynamicFontSize.min
283
- ? { background: 'rgb(200 0 0 / 30%)' }
284
- : {}
285
- }
286
- onChange={(e) => {
287
- changeSchemas([{ key: 'dynamicFontSize.min', value: Number(e.target.value), schemaId: activeSchema.id }])
288
- }}
289
- />
290
-
291
- <NumberInputSet
292
- width="30%"
293
- label={'FontSize Max(pt)'}
294
- value={activeSchema.dynamicFontSize.max ?? Number(activeSchema.fontSize)}
295
- minNumber={0}
296
- style={
297
- activeSchema.dynamicFontSize &&
298
- activeSchema.dynamicFontSize.max < activeSchema.dynamicFontSize.min
299
- ? { background: 'rgb(200 0 0 / 30%)' }
300
- : {}
301
- }
302
- onChange={(e) => {
303
- changeSchemas([{ key: 'dynamicFontSize.max', value: Number(e.target.value), schemaId: activeSchema.id }])
304
- }}
305
- />
306
-
307
- <SelectSet
308
- width="40%"
309
- label={'Fit'}
310
- value={activeSchema.dynamicFontSize.fit ?? DEFAULT_DYNAMIC_FIT}
311
- options={dynamicFits}
312
- onChange={(e) => {
313
- changeSchemas([{ key: 'dynamicFontSize.fit', value: e.target.value, schemaId: activeSchema.id }])
314
- }}
315
- />
316
- </>
317
- )}
318
- </div>
319
- <div
320
- style={{
321
- marginBottom: '0.25rem',
322
- display: 'flex',
323
- alignItems: 'center',
324
- justifyContent: 'space-between',
325
- }}
326
- >
327
- <ColorInputSet
328
- label={'FontColor'}
329
- value={activeSchema.fontColor ?? '#000000'}
330
- onChange={(e) =>
331
- changeSchemas([{ key: 'fontColor', value: e.target.value, schemaId: activeSchema.id }])
332
- }
333
- onClear={() =>
334
- changeSchemas([
335
- { key: 'fontColor', value: DEFAULT_FONT_COLOR, schemaId: activeSchema.id },
336
- ])
337
- }
338
- />
339
-
340
- <ColorInputSet
341
- label={'Background'}
342
- value={activeSchema.backgroundColor ?? '#ffffff'}
343
- onChange={(e) =>
344
- changeSchemas([
345
- { key: 'backgroundColor', value: e.target.value, schemaId: activeSchema.id },
346
- ])
347
- }
348
- onClear={() =>
349
- changeSchemas([{ key: 'backgroundColor', value: '', schemaId: activeSchema.id }])
350
- }
351
- />
352
- </div>
353
- </section>
354
- );
355
- };
356
-
357
- export default TextPropEditor;
@@ -1,87 +0,0 @@
1
- import React, { useContext, useRef, useCallback } from 'react';
2
- import { schemaTypes, SchemaForUI } from '@pdfme/common';
3
- import { SidebarProps } from '../index';
4
- import { I18nContext } from '../../../../contexts';
5
-
6
- const ErrorLabel = ({ isError, msg }: { isError: boolean; msg: string }) => (
7
- <span
8
- style={{ color: isError ? '#ffa19b' : 'inherit', fontWeight: isError ? 'bold' : 'inherit' }}
9
- >
10
- {msg}
11
- </span>
12
- );
13
-
14
- const TypeAndKeyEditor = (
15
- props: Pick<SidebarProps, 'schemas' | 'changeSchemas'> & { activeSchema: SchemaForUI }
16
- ) => {
17
- const { changeSchemas, activeSchema, schemas } = props;
18
- const i18n = useContext(I18nContext);
19
-
20
- const inputRef = useRef<HTMLInputElement>(null);
21
-
22
- const getHasSameKey = useCallback(() => {
23
- const schemaKeys = schemas.map((s) => s.key);
24
- const index = schemaKeys.indexOf(activeSchema.key);
25
- if (index > -1) {
26
- schemaKeys.splice(index, 1);
27
- }
28
-
29
- return schemaKeys.includes(activeSchema.key);
30
- }, [schemas, activeSchema]);
31
-
32
- const blankKey = !activeSchema.key;
33
- const hasSameKey = getHasSameKey();
34
-
35
- return (
36
- <div style={{ display: 'flex', alignItems: 'center' }}>
37
- <div>
38
- <label style={{ marginBottom: 0 }}>{i18n('type')}</label>
39
- <select
40
- style={{
41
- width: '100%',
42
- border: '1px solid #767676',
43
- borderRadius: 2,
44
- color: '#333',
45
- background: 'none',
46
- }}
47
- onChange={(e) =>
48
- changeSchemas([{ key: 'type', value: e.target.value, schemaId: activeSchema.id }])
49
- }
50
- value={activeSchema.type}
51
- >
52
- {schemaTypes.map((t) => (
53
- <option key={t} value={t}>
54
- {t}
55
- </option>
56
- ))}
57
- </select>
58
- </div>
59
- <div>
60
- <label style={{ marginBottom: 0 }}>
61
- {i18n('fieldName')}
62
- <u style={{ fontSize: '0.7rem' }}>
63
- (<ErrorLabel msg={i18n('require')} isError={blankKey} />+
64
- <ErrorLabel msg={i18n('uniq')} isError={hasSameKey} />)
65
- </u>
66
- </label>
67
-
68
- <input
69
- ref={inputRef}
70
- onChange={(e) =>
71
- changeSchemas([{ key: 'key', value: e.target.value, schemaId: activeSchema.id }])
72
- }
73
- style={{
74
- width: '100%',
75
- border: '1px solid #767676',
76
- borderRadius: 2,
77
- color: '#333',
78
- background: hasSameKey || blankKey ? '#ffa19b' : 'none',
79
- }}
80
- value={activeSchema.key}
81
- />
82
- </div>
83
- </div>
84
- );
85
- };
86
-
87
- export default TypeAndKeyEditor;
@@ -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);