react-id-card-generator 1.0.9 → 1.0.10
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.
|
@@ -31,6 +31,7 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
31
31
|
const { template, updateField, addField, removeField, setBackground, setCardSize, setOrientation, setSides, isValid, validationErrors, } = useIDCardTemplate.useIDCardTemplate(initialTemplate);
|
|
32
32
|
const [activeSide, setActiveSide] = react.useState('front');
|
|
33
33
|
const [selectedFieldId, setSelectedFieldId] = react.useState(null);
|
|
34
|
+
const [lineHeightInputFocused, setLineHeightInputFocused] = react.useState(false);
|
|
34
35
|
const [showGrid, setShowGrid] = react.useState(true);
|
|
35
36
|
const [isDragging, setIsDragging] = react.useState(false);
|
|
36
37
|
const [isResizing, setIsResizing] = react.useState(false);
|
|
@@ -313,9 +314,16 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
313
314
|
}, [selectedFieldId, removeField]);
|
|
314
315
|
// Keyboard shortcuts
|
|
315
316
|
react.useEffect(() => {
|
|
317
|
+
// Listen for focus/blur on line height input
|
|
318
|
+
const lhInput = document.getElementById('line-height-input');
|
|
319
|
+
if (lhInput) {
|
|
320
|
+
lhInput.addEventListener('focus', () => { });
|
|
321
|
+
lhInput.addEventListener('blur', () => { });
|
|
322
|
+
}
|
|
316
323
|
const handleKeyDown = (e) => {
|
|
317
324
|
if (selectedFieldId) {
|
|
318
|
-
|
|
325
|
+
const field = template.fields.find(f => f.id === selectedFieldId);
|
|
326
|
+
// Arrow key movement for position
|
|
319
327
|
const step = e.shiftKey ? 5 : 1;
|
|
320
328
|
let dx = 0, dy = 0;
|
|
321
329
|
if (e.key === 'ArrowLeft')
|
|
@@ -326,16 +334,29 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
326
334
|
dy = -step;
|
|
327
335
|
if (e.key === 'ArrowDown')
|
|
328
336
|
dy = step;
|
|
329
|
-
if (dx !== 0 || dy !== 0) {
|
|
330
|
-
|
|
331
|
-
if (field) {
|
|
337
|
+
if ((dx !== 0 || dy !== 0) && field) {
|
|
338
|
+
// If text field and Ctrl is pressed, adjust line height instead
|
|
339
|
+
if (field.type === 'text' && (e.ctrlKey || e.metaKey)) {
|
|
340
|
+
let lh = field.style?.lineHeight ? Number(field.style.lineHeight) : 1;
|
|
341
|
+
if (e.key === 'ArrowUp')
|
|
342
|
+
lh = Math.round((lh + 0.1) * 10) / 10;
|
|
343
|
+
if (e.key === 'ArrowDown')
|
|
344
|
+
lh = Math.max(0.1, Math.round((lh - 0.1) * 10) / 10);
|
|
345
|
+
updateField(field.id, {
|
|
346
|
+
style: { ...field.style, lineHeight: lh.toString() },
|
|
347
|
+
});
|
|
348
|
+
e.preventDefault();
|
|
349
|
+
return;
|
|
350
|
+
}
|
|
351
|
+
else {
|
|
332
352
|
let newX = Math.max(0, Math.min(template.cardSize.width - field.position.width, field.position.x + dx));
|
|
333
353
|
let newY = Math.max(0, Math.min(template.cardSize.height - field.position.height, field.position.y + dy));
|
|
334
354
|
updateField(field.id, {
|
|
335
355
|
position: { ...field.position, x: newX, y: newY },
|
|
336
356
|
});
|
|
357
|
+
e.preventDefault();
|
|
358
|
+
return;
|
|
337
359
|
}
|
|
338
|
-
e.preventDefault();
|
|
339
360
|
}
|
|
340
361
|
// Delete and Escape
|
|
341
362
|
if (e.key === 'Delete') {
|
|
@@ -356,7 +377,7 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
356
377
|
removeField(field.id);
|
|
357
378
|
if (field.id === selectedFieldId)
|
|
358
379
|
setSelectedFieldId(null);
|
|
359
|
-
}, children: "\u00D7" })] }, field.id)))] })] }), jsxRuntime.jsxs("div", { className: "designer-sidebar right-sidebar", children: [jsxRuntime.jsx("h3", { children: "Field Properties" }), selectedField ? (jsxRuntime.jsxs("div", { className: "field-properties", children: [jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Field Key" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.fieldKey, onChange: (e) => handleFieldPropertyUpdate('fieldKey', e.target.value) })] }), selectedField.type !== 'label' && (jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.label || '', onChange: (e) => handleFieldPropertyUpdate('label', e.target.value) })] })), selectedField.type === 'text' && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("button", { className: "btn btn-outline btn-sm", style: { marginBottom: 12 }, onClick: handleDuplicateField, children: "Duplicate Field" }), jsxRuntime.jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsxRuntime.jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Label Style" }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Position" }), jsxRuntime.jsxs("select", { value: selectedField.style?.labelPosition || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value), children: [jsxRuntime.jsx("option", { value: "top", children: "Top" }), jsxRuntime.jsx("option", { value: "left", children: "Left (Side)" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Vertical Align" }), jsxRuntime.jsxs("select", { value: selectedField.style?.labelVerticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value), children: [jsxRuntime.jsx("option", { value: "top", children: "Top" }), jsxRuntime.jsx("option", { value: "middle", children: "Middle" }), jsxRuntime.jsx("option", { value: "bottom", children: "Bottom" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Font Size" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.style?.labelFontSize || '0.75em', onChange: (e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value) })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Font Weight" }), jsxRuntime.jsxs("select", { value: selectedField.style?.labelFontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value), children: [jsxRuntime.jsx("option", { value: "normal", children: "Normal" }), jsxRuntime.jsx("option", { value: "bold", children: "Bold" }), jsxRuntime.jsx("option", { value: "100", children: "100" }), jsxRuntime.jsx("option", { value: "200", children: "200" }), jsxRuntime.jsx("option", { value: "300", children: "300" }), jsxRuntime.jsx("option", { value: "400", children: "400" }), jsxRuntime.jsx("option", { value: "500", children: "500" }), jsxRuntime.jsx("option", { value: "600", children: "600" }), jsxRuntime.jsx("option", { value: "700", children: "700" }), jsxRuntime.jsx("option", { value: "800", children: "800" }), jsxRuntime.jsx("option", { value: "900", children: "900" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Color" }), jsxRuntime.jsx("input", { type: "color", value: selectedField.style?.labelColor || '#666666', onChange: (e) => handleFieldPropertyUpdate('style.labelColor', e.target.value) })] })] }), jsxRuntime.jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsxRuntime.jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Text Style" }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Font Size" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.style?.fontSize || '12px', onChange: (e) => handleFieldPropertyUpdate('style.fontSize', e.target.value) })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Font Weight" }), jsxRuntime.jsxs("select", { value: selectedField.style?.fontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value), children: [jsxRuntime.jsx("option", { value: "normal", children: "Normal" }), jsxRuntime.jsx("option", { value: "bold", children: "Bold" }), jsxRuntime.jsx("option", { value: "100", children: "100" }), jsxRuntime.jsx("option", { value: "200", children: "200" }), jsxRuntime.jsx("option", { value: "300", children: "300" }), jsxRuntime.jsx("option", { value: "400", children: "400" }), jsxRuntime.jsx("option", { value: "500", children: "500" }), jsxRuntime.jsx("option", { value: "600", children: "600" }), jsxRuntime.jsx("option", { value: "700", children: "700" }), jsxRuntime.jsx("option", { value: "800", children: "800" }), jsxRuntime.jsx("option", { value: "900", children: "900" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Text Color" }), jsxRuntime.jsx("input", { type: "color", value: selectedField.style?.color || '#000000', onChange: (e) => handleFieldPropertyUpdate('style.color', e.target.value) })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Text Align" }), jsxRuntime.jsxs("select", { value: selectedField.style?.textAlign || 'left', onChange: (e) => handleFieldPropertyUpdate('style.textAlign', e.target.value), children: [jsxRuntime.jsx("option", { value: "left", children: "Left" }), jsxRuntime.jsx("option", { value: "center", children: "Center" }), jsxRuntime.jsx("option", { value: "right", children: "Right" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Text Transform" }), jsxRuntime.jsxs("select", { value: selectedField.style?.textTransform || 'none', onChange: (e) => handleFieldPropertyUpdate('style.textTransform', e.target.value), children: [jsxRuntime.jsx("option", { value: "none", children: "None" }), jsxRuntime.jsx("option", { value: "uppercase", children: "UPPERCASE" }), jsxRuntime.jsx("option", { value: "lowercase", children: "lowercase" }), jsxRuntime.jsx("option", { value: "capitalize", children: "Capitalize" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Vertical Align" }), jsxRuntime.jsxs("select", { value: selectedField.style?.verticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value), children: [jsxRuntime.jsx("option", { value: "top", children: "Top" }), jsxRuntime.jsx("option", { value: "middle", children: "Middle" }), jsxRuntime.jsx("option", { value: "bottom", children: "Bottom" })] })] })] })] })), selectedField.type === 'label' && (jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Static Text" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.staticText || '', onChange: (e) => handleFieldPropertyUpdate('staticText', e.target.value) })] })), selectedField.type === 'qrcode' && (jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "QR Code Data Fields" }), jsxRuntime.jsx("small", { className: "hint", children: "Select which fields to encode in the QR code:" }), jsxRuntime.jsx("div", { style: { marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }, children: template.fields
|
|
380
|
+
}, children: "\u00D7" })] }, field.id)))] })] }), jsxRuntime.jsxs("div", { className: "designer-sidebar right-sidebar", children: [jsxRuntime.jsx("h3", { children: "Field Properties" }), selectedField ? (jsxRuntime.jsxs("div", { className: "field-properties", children: [jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Field Key" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.fieldKey, onChange: (e) => handleFieldPropertyUpdate('fieldKey', e.target.value) })] }), selectedField.type !== 'label' && (jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.label || '', onChange: (e) => handleFieldPropertyUpdate('label', e.target.value) })] })), selectedField.type === 'text' && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("button", { className: "btn btn-outline btn-sm", style: { marginBottom: 12 }, onClick: handleDuplicateField, children: "Duplicate Field" }), jsxRuntime.jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsxRuntime.jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Label Style" }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Position" }), jsxRuntime.jsxs("select", { value: selectedField.style?.labelPosition || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value), children: [jsxRuntime.jsx("option", { value: "top", children: "Top" }), jsxRuntime.jsx("option", { value: "left", children: "Left (Side)" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Vertical Align" }), jsxRuntime.jsxs("select", { value: selectedField.style?.labelVerticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value), children: [jsxRuntime.jsx("option", { value: "top", children: "Top" }), jsxRuntime.jsx("option", { value: "middle", children: "Middle" }), jsxRuntime.jsx("option", { value: "bottom", children: "Bottom" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Font Size" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.style?.labelFontSize || '0.75em', onChange: (e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value) })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Font Weight" }), jsxRuntime.jsxs("select", { value: selectedField.style?.labelFontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value), children: [jsxRuntime.jsx("option", { value: "normal", children: "Normal" }), jsxRuntime.jsx("option", { value: "bold", children: "Bold" }), jsxRuntime.jsx("option", { value: "100", children: "100" }), jsxRuntime.jsx("option", { value: "200", children: "200" }), jsxRuntime.jsx("option", { value: "300", children: "300" }), jsxRuntime.jsx("option", { value: "400", children: "400" }), jsxRuntime.jsx("option", { value: "500", children: "500" }), jsxRuntime.jsx("option", { value: "600", children: "600" }), jsxRuntime.jsx("option", { value: "700", children: "700" }), jsxRuntime.jsx("option", { value: "800", children: "800" }), jsxRuntime.jsx("option", { value: "900", children: "900" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Label Color" }), jsxRuntime.jsx("input", { type: "color", value: selectedField.style?.labelColor || '#666666', onChange: (e) => handleFieldPropertyUpdate('style.labelColor', e.target.value) })] })] }), jsxRuntime.jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsxRuntime.jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Text Style" }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Font Size" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.style?.fontSize || '12px', onChange: (e) => handleFieldPropertyUpdate('style.fontSize', e.target.value) })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Font Weight" }), jsxRuntime.jsxs("select", { value: selectedField.style?.fontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value), children: [jsxRuntime.jsx("option", { value: "normal", children: "Normal" }), jsxRuntime.jsx("option", { value: "bold", children: "Bold" }), jsxRuntime.jsx("option", { value: "100", children: "100" }), jsxRuntime.jsx("option", { value: "200", children: "200" }), jsxRuntime.jsx("option", { value: "300", children: "300" }), jsxRuntime.jsx("option", { value: "400", children: "400" }), jsxRuntime.jsx("option", { value: "500", children: "500" }), jsxRuntime.jsx("option", { value: "600", children: "600" }), jsxRuntime.jsx("option", { value: "700", children: "700" }), jsxRuntime.jsx("option", { value: "800", children: "800" }), jsxRuntime.jsx("option", { value: "900", children: "900" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Text Color" }), jsxRuntime.jsx("input", { type: "color", value: selectedField.style?.color || '#000000', onChange: (e) => handleFieldPropertyUpdate('style.color', e.target.value) })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Text Align" }), jsxRuntime.jsxs("select", { value: selectedField.style?.textAlign || 'left', onChange: (e) => handleFieldPropertyUpdate('style.textAlign', e.target.value), children: [jsxRuntime.jsx("option", { value: "left", children: "Left" }), jsxRuntime.jsx("option", { value: "center", children: "Center" }), jsxRuntime.jsx("option", { value: "right", children: "Right" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Line Height" }), jsxRuntime.jsx("input", { id: "line-height-input", type: "number", min: 0.1, step: 0.1, value: selectedField.style?.lineHeight ? Number(selectedField.style.lineHeight) : 1, onChange: (e) => handleFieldPropertyUpdate('style.lineHeight', e.target.value), style: { width: 80 }, onFocus: () => setLineHeightInputFocused(true), onBlur: () => setLineHeightInputFocused(false) })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Text Transform" }), jsxRuntime.jsxs("select", { value: selectedField.style?.textTransform || 'none', onChange: (e) => handleFieldPropertyUpdate('style.textTransform', e.target.value), children: [jsxRuntime.jsx("option", { value: "none", children: "None" }), jsxRuntime.jsx("option", { value: "uppercase", children: "UPPERCASE" }), jsxRuntime.jsx("option", { value: "lowercase", children: "lowercase" }), jsxRuntime.jsx("option", { value: "capitalize", children: "Capitalize" })] })] }), jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Vertical Align" }), jsxRuntime.jsxs("select", { value: selectedField.style?.verticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value), children: [jsxRuntime.jsx("option", { value: "top", children: "Top" }), jsxRuntime.jsx("option", { value: "middle", children: "Middle" }), jsxRuntime.jsx("option", { value: "bottom", children: "Bottom" })] })] })] })] })), selectedField.type === 'label' && (jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "Static Text" }), jsxRuntime.jsx("input", { type: "text", value: selectedField.staticText || '', onChange: (e) => handleFieldPropertyUpdate('staticText', e.target.value) })] })), selectedField.type === 'qrcode' && (jsxRuntime.jsxs("div", { className: "property-group", children: [jsxRuntime.jsx("label", { children: "QR Code Data Fields" }), jsxRuntime.jsx("small", { className: "hint", children: "Select which fields to encode in the QR code:" }), jsxRuntime.jsx("div", { style: { marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }, children: template.fields
|
|
360
381
|
.filter(f => f.type !== 'qrcode' && f.type !== 'label')
|
|
361
382
|
.map((field) => (jsxRuntime.jsxs("label", { style: { display: 'block', marginBottom: '6px', cursor: 'pointer' }, children: [jsxRuntime.jsx("input", { type: "checkbox", checked: selectedField.qrFields?.includes(field.fieldKey) || false, onChange: (e) => {
|
|
362
383
|
const currentFields = selectedField.qrFields || [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IDCardDesigner.js","sources":["../../../src/components/IDCardDesigner.tsx"],"sourcesContent":["\r\nimport React, { useState, useCallback, useRef, useEffect } from 'react';\r\nimport type {\r\n IDCardDesignerProps,\r\n FieldMapping,\r\n FieldType,\r\n CardOrientation,\r\n CardSides,\r\n IDCardData,\r\n} from '../types';\r\nimport { useIDCardTemplate } from '../hooks/useIDCardTemplate';\r\nimport { deepCleanUndefined } from '../utils/deepCleanUndefined';\r\nimport { IDCardPreview } from './IDCardPreview';\r\nimport { generateId, imageFileToBase64 } from '../storage/templateStorage';\r\nimport './IDCardDesigner.css';\r\n\r\n// Available field types in the designer\r\nconst defaultFieldTypes: { type: FieldType; label: string; icon: string }[] = [\r\n { type: 'text', label: 'Text Field', icon: '📝' },\r\n { type: 'label', label: 'Static Label', icon: '🏷️' },\r\n { type: 'image', label: 'Image/Photo', icon: '🖼️' },\r\n { type: 'qrcode', label: 'QR Code', icon: '📱' },\r\n];\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop template builder\r\n * \r\n * Allows users to:\r\n * - Add and position fields on the card\r\n * - Upload background images\r\n * - Configure field styles (fonts, colors, etc.)\r\n * - Choose card orientation and sides\r\n * - Preview the card with sample data\r\n */\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop ID card template builder\r\n */\r\nexport const IDCardDesigner: React.FC<IDCardDesignerProps> = ({\r\n initialTemplate,\r\n onSave,\r\n onCancel,\r\n className = '',\r\n style = {},\r\n}) => {\r\n const {\r\n template,\r\n updateField,\r\n addField,\r\n removeField,\r\n setBackground,\r\n setCardSize,\r\n setOrientation,\r\n setSides,\r\n isValid,\r\n validationErrors,\r\n } = useIDCardTemplate(initialTemplate);\r\n\r\n const [activeSide, setActiveSide] = useState<'front' | 'back'>('front');\r\n const [selectedFieldId, setSelectedFieldId] = useState<string | null>(null);\r\n const [showGrid, setShowGrid] = useState(true);\r\n const [isDragging, setIsDragging] = useState(false);\r\n const [isResizing, setIsResizing] = useState(false);\r\n const [templateName, setTemplateName] = useState(template.name);\r\n\r\n const previewContainerRef = useRef<HTMLDivElement>(null);\r\n const dragStartRef = useRef({ x: 0, y: 0, fieldX: 0, fieldY: 0 });\r\n const resizeStartRef = useRef({\r\n x: 0,\r\n y: 0,\r\n width: 0,\r\n height: 0,\r\n fieldX: 0,\r\n fieldY: 0,\r\n handle: '',\r\n });\r\n\r\n // Sample data for preview\r\n const [sampleData, setSampleData] = useState<IDCardData>({\r\n name: 'John Doe',\r\n idno: 'ID12345',\r\n department: 'Computer Science',\r\n designation: 'Student',\r\n dob: '01-01-2000',\r\n bloodgroup: 'O+',\r\n phoneno: '9876543210',\r\n address: 'Sample Address',\r\n });\r\n\r\n // Get selected field\r\n const selectedField = template.fields.find((f) => f.id === selectedFieldId);\r\n\r\n // Handle field selection\r\n const handleFieldSelect = useCallback((field: FieldMapping | null) => {\r\n setSelectedFieldId(field?.id || null);\r\n }, []);\r\n\r\n // Duplicate selected text field\r\n const handleDuplicateField = useCallback(() => {\r\n if (!selectedField || selectedField.type !== 'text') return;\r\n const { id, fieldKey, position, ...rest } = selectedField;\r\n const newField = {\r\n ...rest,\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n position: {\r\n ...position,\r\n x: Math.min(position.x + 20, template.cardSize.width - position.width),\r\n y: Math.min(position.y + 20, template.cardSize.height - position.height),\r\n },\r\n };\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n }, [selectedField, addField, setSelectedFieldId, template.cardSize.width, template.cardSize.height]);\r\n // Handle adding new field\r\n const handleAddField = useCallback(\r\n (type: FieldType) => {\r\n const newField: FieldMapping = {\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n label: type === 'label' ? 'Label' : '',\r\n type,\r\n side: activeSide,\r\n position: { x: 50, y: 50, width: 100, height: 30 },\r\n style: {\r\n fontSize: type === 'label' ? '10px' : '12px',\r\n fontWeight: type === 'label' ? 'bold' : 'normal',\r\n color: '#000000',\r\n textAlign: 'left',\r\n backgroundColor: 'transparent',\r\n },\r\n zIndex: template.fields.length + 1,\r\n staticText: type === 'label' ? 'Static Label' : '',\r\n ...(type === 'qrcode' ? { qrFields: [] } : {}),\r\n };\r\n\r\n // Adjust default sizes based on type\r\n if (type === 'image') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 100 };\r\n } else if (type === 'qrcode') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 80 };\r\n }\r\n\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n },\r\n [activeSide, addField, template.fields.length]\r\n );\r\n\r\n // Handle background upload\r\n const handleBackgroundUpload = useCallback(\r\n async (e: React.ChangeEvent<HTMLInputElement>) => {\r\n const file = e.target.files?.[0];\r\n if (!file) return;\r\n\r\n try {\r\n const base64 = await imageFileToBase64(file);\r\n setBackground(activeSide, base64);\r\n } catch (error) {\r\n console.error('Failed to load background:', error);\r\n }\r\n },\r\n [activeSide, setBackground]\r\n );\r\n\r\n // Handle orientation change\r\n const handleOrientationChange = useCallback(\r\n (orientation: CardOrientation) => {\r\n setOrientation(orientation);\r\n // Update card size based on orientation\r\n const baseWidth = 340;\r\n const baseHeight = 215;\r\n if (orientation === 'portrait') {\r\n setCardSize({ width: baseHeight, height: baseWidth, unit: 'px' });\r\n } else {\r\n setCardSize({ width: baseWidth, height: baseHeight, unit: 'px' });\r\n }\r\n },\r\n [setOrientation, setCardSize]\r\n );\r\n\r\n // Handle sides change\r\n const handleSidesChange = useCallback(\r\n (sides: CardSides) => {\r\n setSides(sides);\r\n if (sides === 'single' && activeSide === 'back') {\r\n setActiveSide('front');\r\n }\r\n },\r\n [setSides, activeSide]\r\n );\r\n\r\n // Drag and drop handling\r\n const handleMouseDown = useCallback(\r\n (e: React.MouseEvent) => {\r\n if (!selectedField || !previewContainerRef.current) return;\r\n\r\n const target = e.target as HTMLElement;\r\n\r\n // Check if clicking on resize handle\r\n if (target.classList.contains('resize-handle')) {\r\n const handle = target.dataset.handle || '';\r\n setIsResizing(true);\r\n resizeStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n width: selectedField.position.width,\r\n height: selectedField.position.height,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n handle,\r\n };\r\n return;\r\n }\r\n\r\n // Check if clicking on field (for dragging)\r\n if (target.closest('.preview-field')) {\r\n setIsDragging(true);\r\n dragStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n };\r\n }\r\n },\r\n [selectedField]\r\n );\r\n\r\n // Handle mouse move for dragging/resizing\r\n useEffect(() => {\r\n const handleMouseMove = (e: MouseEvent) => {\r\n if (!selectedField) return;\r\n\r\n if (isDragging) {\r\n const deltaX = e.clientX - dragStartRef.current.x;\r\n const deltaY = e.clientY - dragStartRef.current.y;\r\n\r\n // Unified drag logic for all field types\r\n const newX = Math.max(0, Math.min(\r\n template.cardSize.width - selectedField.position.width,\r\n dragStartRef.current.fieldX + deltaX\r\n ));\r\n const newY = Math.max(0, Math.min(\r\n template.cardSize.height - selectedField.position.height,\r\n dragStartRef.current.fieldY + deltaY\r\n ));\r\n\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, x: newX, y: newY },\r\n });\r\n }\r\n\r\n if (isResizing) {\r\n const { handle, x, y, width, height, fieldX, fieldY } = resizeStartRef.current;\r\n const deltaX = e.clientX - x;\r\n const deltaY = e.clientY - y;\r\n\r\n let newWidth = width;\r\n let newHeight = height;\r\n let newX = fieldX;\r\n let newY = fieldY;\r\n\r\n // Enforce fixed aspect ratio for QR code fields\r\n if (selectedField.type === 'qrcode') {\r\n // Use the larger delta for both width and height\r\n let delta = 0;\r\n if (handle.includes('e') || handle.includes('w')) {\r\n delta = deltaX;\r\n } else if (handle.includes('s') || handle.includes('n')) {\r\n delta = deltaY;\r\n }\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + delta);\r\n newHeight = newWidth;\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - delta);\r\n newHeight = newWidth;\r\n newX = Math.max(0, fieldX + delta);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + delta);\r\n newWidth = newHeight;\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - delta);\r\n newWidth = newHeight;\r\n newY = Math.max(0, fieldY + delta);\r\n }\r\n } else {\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + deltaX);\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - deltaX);\r\n newX = Math.max(0, fieldX + deltaX);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + deltaY);\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - deltaY);\r\n newY = Math.max(0, fieldY + deltaY);\r\n }\r\n }\r\n\r\n updateField(selectedField.id, {\r\n position: { x: newX, y: newY, width: newWidth, height: newHeight },\r\n });\r\n }\r\n };\r\n\r\n const handleMouseUp = () => {\r\n setIsDragging(false);\r\n setIsResizing(false);\r\n // Remove any accidental selection or pointer capture\r\n window.getSelection?.()?.removeAllRanges?.();\r\n if (previewContainerRef.current) {\r\n previewContainerRef.current.releasePointerCapture?.(0);\r\n }\r\n };\r\n\r\n if (isDragging || isResizing) {\r\n document.addEventListener('mousemove', handleMouseMove);\r\n window.addEventListener('mouseup', handleMouseUp);\r\n }\r\n\r\n return () => {\r\n document.removeEventListener('mousemove', handleMouseMove);\r\n window.removeEventListener('mouseup', handleMouseUp);\r\n };\r\n }, [isDragging, isResizing, selectedField, updateField, template.cardSize]);\r\n\r\n // Handle field property update\r\n const handleFieldPropertyUpdate = useCallback(\r\n (property: string, value: unknown) => {\r\n if (!selectedField) return;\r\n\r\n if (property.startsWith('style.')) {\r\n const styleKey = property.replace('style.', '');\r\n updateField(selectedField.id, {\r\n style: { ...selectedField.style, [styleKey]: value },\r\n });\r\n } else if (property.startsWith('position.')) {\r\n const posKey = property.replace('position.', '') as keyof typeof selectedField.position;\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, [posKey]: Number(value) },\r\n });\r\n } else {\r\n // Only allow qrFields property on QR code fields\r\n if (property === 'qrFields') {\r\n if (selectedField.type === 'qrcode') {\r\n updateField(selectedField.id, { qrFields: value as string[] });\r\n } else {\r\n // do nothing if not a qrcode field\r\n }\r\n } else {\r\n updateField(selectedField.id, { [property]: value });\r\n }\r\n }\r\n },\r\n [selectedField, updateField]\r\n );\r\n\r\n // Handle save\r\n const handleSave = useCallback(() => {\r\n const updatedTemplate = {\r\n ...template,\r\n name: templateName,\r\n updatedAt: new Date().toISOString(),\r\n };\r\n const cleanedTemplate = deepCleanUndefined(updatedTemplate);\r\n onSave(cleanedTemplate);\r\n }, [template, templateName, onSave]);\r\n\r\n // Handle delete field\r\n const handleDeleteField = useCallback(() => {\r\n if (selectedFieldId) {\r\n removeField(selectedFieldId);\r\n setSelectedFieldId(null);\r\n }\r\n }, [selectedFieldId, removeField]);\r\n\r\n // Keyboard shortcuts\r\n useEffect(() => {\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (selectedFieldId) {\r\n // Arrow key movement\r\n const step = e.shiftKey ? 5 : 1;\r\n let dx = 0, dy = 0;\r\n if (e.key === 'ArrowLeft') dx = -step;\r\n if (e.key === 'ArrowRight') dx = step;\r\n if (e.key === 'ArrowUp') dy = -step;\r\n if (e.key === 'ArrowDown') dy = step;\r\n if (dx !== 0 || dy !== 0) {\r\n const field = template.fields.find(f => f.id === selectedFieldId);\r\n if (field) {\r\n let newX = Math.max(0, Math.min(template.cardSize.width - field.position.width, field.position.x + dx));\r\n let newY = Math.max(0, Math.min(template.cardSize.height - field.position.height, field.position.y + dy));\r\n updateField(field.id, {\r\n position: { ...field.position, x: newX, y: newY },\r\n });\r\n }\r\n e.preventDefault();\r\n }\r\n // Delete and Escape\r\n if (e.key === 'Delete') {\r\n handleDeleteField();\r\n }\r\n if (e.key === 'Escape') {\r\n setSelectedFieldId(null);\r\n }\r\n }\r\n };\r\n\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => document.removeEventListener('keydown', handleKeyDown);\r\n }, [selectedFieldId, handleDeleteField, template.fields, template.cardSize, updateField]);\r\n\r\n return (\r\n <div className={`idcard-designer ${className}`} style={style}>\r\n {/* Header */}\r\n <div className=\"designer-header\">\r\n <input\r\n type=\"text\"\r\n value={templateName}\r\n onChange={(e) => setTemplateName(e.target.value)}\r\n className=\"template-name-input\"\r\n placeholder=\"Template Name\"\r\n />\r\n <div className=\"header-actions\">\r\n {onCancel && (\r\n <button onClick={onCancel} className=\"btn btn-secondary\">\r\n Cancel\r\n </button>\r\n )}\r\n <button onClick={handleSave} className=\"btn btn-primary\" disabled={!isValid}>\r\n Save Template\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"designer-body\">\r\n {/* Left Sidebar - Field Types */}\r\n <div className=\"designer-sidebar left-sidebar\">\r\n <h3>Add Fields</h3>\r\n <div className=\"field-types\">\r\n {defaultFieldTypes.map((fieldType) => (\r\n <button\r\n key={fieldType.type}\r\n onClick={() => handleAddField(fieldType.type)}\r\n className=\"field-type-btn\"\r\n >\r\n <span className=\"field-icon\">{fieldType.icon}</span>\r\n <span className=\"field-label\">{fieldType.label}</span>\r\n </button>\r\n ))}\r\n </div>\r\n\r\n <h3>Card Settings</h3>\r\n <div className=\"card-settings\">\r\n <div className=\"setting-group\">\r\n <label>Orientation</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.orientation === 'landscape' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('landscape')}\r\n >\r\n Landscape\r\n </button>\r\n <button\r\n className={`btn ${template.orientation === 'portrait' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('portrait')}\r\n >\r\n Portrait\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Sides</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.sides === 'single' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('single')}\r\n >\r\n Single\r\n </button>\r\n <button\r\n className={`btn ${template.sides === 'double' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('double')}\r\n >\r\n Double\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Size (px)</label>\r\n <div className=\"size-inputs\">\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.width}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, width: Number(e.target.value) })\r\n }\r\n placeholder=\"Width\"\r\n />\r\n <span>×</span>\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.height}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, height: Number(e.target.value) })\r\n }\r\n placeholder=\"Height\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <h3>Background</h3>\r\n <div className=\"background-upload\">\r\n <input\r\n type=\"file\"\r\n accept=\"image/*\"\r\n onChange={handleBackgroundUpload}\r\n id=\"bg-upload\"\r\n className=\"file-input\"\r\n />\r\n <label htmlFor=\"bg-upload\" className=\"btn btn-outline\">\r\n Upload {activeSide} Background\r\n </label>\r\n {template.backgrounds[activeSide] && (\r\n <button\r\n className=\"btn btn-danger btn-sm\"\r\n onClick={() => setBackground(activeSide, '')}\r\n >\r\n Remove\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Center - Preview */}\r\n <div className=\"designer-preview\">\r\n {/* Side tabs */}\r\n <div className=\"side-tabs\">\r\n <button\r\n className={`tab ${activeSide === 'front' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('front')}\r\n >\r\n Front\r\n </button>\r\n {template.sides === 'double' && (\r\n <button\r\n className={`tab ${activeSide === 'back' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('back')}\r\n >\r\n Back\r\n </button>\r\n )}\r\n <label className=\"grid-toggle\">\r\n <input\r\n type=\"checkbox\"\r\n checked={showGrid}\r\n onChange={(e) => setShowGrid(e.target.checked)}\r\n />\r\n Show Grid\r\n </label>\r\n </div>\r\n\r\n {/* Preview container */}\r\n <div\r\n ref={previewContainerRef}\r\n className=\"preview-wrapper\"\r\n onMouseDown={handleMouseDown}\r\n >\r\n <IDCardPreview\r\n template={template}\r\n data={sampleData}\r\n side={activeSide}\r\n showGrid={showGrid}\r\n onFieldSelect={handleFieldSelect}\r\n selectedFieldId={selectedFieldId}\r\n editable={true}\r\n />\r\n </div>\r\n\r\n {/* Field list */}\r\n <div className=\"fields-list\">\r\n <h4>Fields on {activeSide} side:</h4>\r\n {template.fields\r\n .filter((f) => f.side === activeSide)\r\n .map((field) => (\r\n <div\r\n key={field.id}\r\n className={`field-item ${field.id === selectedFieldId ? 'selected' : ''}`}\r\n onClick={() => setSelectedFieldId(field.id)}\r\n >\r\n <span className=\"field-type-icon\">\r\n {defaultFieldTypes.find((t) => t.type === field.type)?.icon}\r\n </span>\r\n <span className=\"field-key\">{field.fieldKey}</span>\r\n <button\r\n className=\"delete-btn\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n removeField(field.id);\r\n if (field.id === selectedFieldId) setSelectedFieldId(null);\r\n }}\r\n >\r\n ×\r\n </button>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n {/* Right Sidebar - Field Properties */}\r\n <div className=\"designer-sidebar right-sidebar\">\r\n <h3>Field Properties</h3>\r\n {selectedField ? (\r\n <div className=\"field-properties\">\r\n <div className=\"property-group\">\r\n <label>Field Key</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.fieldKey}\r\n onChange={(e) => handleFieldPropertyUpdate('fieldKey', e.target.value)}\r\n />\r\n </div>\r\n\r\n {selectedField.type !== 'label' && (\r\n <div className=\"property-group\">\r\n <label>Label</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.label || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('label', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {/* Vertical Align for text fields */}\r\n {selectedField.type === 'text' && (\r\n <>\r\n <button className=\"btn btn-outline btn-sm\" style={{ marginBottom: 12 }} onClick={handleDuplicateField}>\r\n Duplicate Field\r\n </button>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Label Style</strong>\r\n\r\n <div className=\"property-group\">\r\n <label>Label Position</label>\r\n <select\r\n value={selectedField.style?.labelPosition || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"left\">Left (Side)</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Vertical Align</label>\r\n <select\r\n value={selectedField.style?.labelVerticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.labelFontSize || '0.75em'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Weight</label>\r\n <select\r\n value={selectedField.style?.labelFontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.labelColor || '#666666'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelColor', e.target.value)}\r\n />\r\n </div>\r\n </div>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Text Style</strong>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Vertical Align</label>\r\n <select\r\n value={selectedField.style?.verticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n </div>\r\n </>\r\n )}\r\n\r\n {selectedField.type === 'label' && (\r\n <div className=\"property-group\">\r\n <label>Static Text</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.staticText || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('staticText', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {selectedField.type === 'qrcode' && (\r\n <div className=\"property-group\">\r\n <label>QR Code Data Fields</label>\r\n <small className=\"hint\">Select which fields to encode in the QR code:</small>\r\n <div style={{ marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }}>\r\n {template.fields\r\n .filter(f => f.type !== 'qrcode' && f.type !== 'label')\r\n .map((field) => (\r\n <label key={field.fieldKey} style={{ display: 'block', marginBottom: '6px', cursor: 'pointer' }}>\r\n <input\r\n type=\"checkbox\"\r\n checked={selectedField.qrFields?.includes(field.fieldKey) || false}\r\n onChange={(e) => {\r\n const currentFields = selectedField.qrFields || [];\r\n const newFields = e.target.checked\r\n ? [...currentFields, field.fieldKey]\r\n : currentFields.filter(f => f !== field.fieldKey);\r\n handleFieldPropertyUpdate('qrFields', newFields);\r\n }}\r\n style={{ marginRight: '6px' }}\r\n />\r\n {field.label || field.fieldKey}\r\n </label>\r\n ))}\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Border Radius for image fields */}\r\n {selectedField.type === 'image' && (\r\n <div className=\"property-group\">\r\n <label>Border Radius</label>\r\n <input\r\n type=\"text\"\r\n placeholder=\"e.g. 50% or 8px\"\r\n value={selectedField.style?.borderRadius || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('style.borderRadius', e.target.value)}\r\n />\r\n <small className=\"hint\">Use <b>50%</b> for a circle, <b>8px</b> for rounded corners, etc.</small>\r\n </div>\r\n )}\r\n\r\n {/* Only show these style controls for non-text fields */}\r\n {selectedField.type !== 'text' && <>\r\n <h4>Style</h4>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n </>}\r\n <div className=\"property-group\">\r\n <label>Background Color</label>\r\n <div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>\r\n <input\r\n type=\"checkbox\"\r\n id=\"transparent-bg-checkbox\"\r\n checked={selectedField.style?.backgroundColor === 'transparent'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.checked ? 'transparent' : '#ffffff')}\r\n />\r\n <label htmlFor=\"transparent-bg-checkbox\" style={{ margin: 0, fontWeight: 400, fontSize: '0.95em' }}>Transparent</label>\r\n {selectedField.style?.backgroundColor !== 'transparent' && (\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.backgroundColor || '#ffffff'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.value)}\r\n />\r\n )}\r\n </div>\r\n </div>\r\n\r\n <div className=\"property-group\">\r\n <label>Side</label>\r\n <select\r\n value={selectedField.side}\r\n onChange={(e) =>\r\n handleFieldPropertyUpdate('side', e.target.value as 'front' | 'back')\r\n }\r\n >\r\n <option value=\"front\">Front</option>\r\n {template.sides === 'double' && <option value=\"back\">Back</option>}\r\n </select>\r\n </div>\r\n\r\n <button className=\"btn btn-danger\" onClick={handleDeleteField}>\r\n Delete Field\r\n </button>\r\n </div>\r\n ) : (\r\n <p className=\"no-selection\">Select a field to edit its properties</p>\r\n )}\r\n\r\n <h3>Sample Data</h3>\r\n <div className=\"sample-data\">\r\n <p className=\"hint\">Edit sample data to preview:</p>\r\n {Object.entries(sampleData).map(([key, value]) => (\r\n <div key={key} className=\"property-group\">\r\n <label>{key}</label>\r\n <input\r\n type=\"text\"\r\n value={String(value)}\r\n onChange={(e) =>\r\n setSampleData((prev) => ({ ...prev, [key]: e.target.value }))\r\n }\r\n />\r\n </div>\r\n ))}\r\n <button\r\n className=\"btn btn-outline btn-sm\"\r\n onClick={() =>\r\n setSampleData((prev) => ({ ...prev, [`custom_${Date.now()}`]: '' }))\r\n }\r\n >\r\n + Add Field\r\n </button>\r\n </div>\r\n\r\n {/* Validation errors */}\r\n {validationErrors.length > 0 && (\r\n <div className=\"validation-errors\">\r\n <h4>⚠️ Validation Issues</h4>\r\n <ul>\r\n {validationErrors.map((error, index) => (\r\n <li key={index}>{error}</li>\r\n ))}\r\n </ul>\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\n\r\n"],"names":["useIDCardTemplate","useState","useRef","useCallback","generateId","imageFileToBase64","useEffect","deepCleanUndefined","_jsxs","_jsx","IDCardPreview","_Fragment"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"IDCardDesigner.js","sources":["../../../src/components/IDCardDesigner.tsx"],"sourcesContent":["\r\nimport React, { useState, useCallback, useRef, useEffect } from 'react';\r\nimport type {\r\n IDCardDesignerProps,\r\n FieldMapping,\r\n FieldType,\r\n CardOrientation,\r\n CardSides,\r\n IDCardData,\r\n} from '../types';\r\nimport { useIDCardTemplate } from '../hooks/useIDCardTemplate';\r\nimport { deepCleanUndefined } from '../utils/deepCleanUndefined';\r\nimport { IDCardPreview } from './IDCardPreview';\r\nimport { generateId, imageFileToBase64 } from '../storage/templateStorage';\r\nimport './IDCardDesigner.css';\r\n\r\n// Available field types in the designer\r\nconst defaultFieldTypes: { type: FieldType; label: string; icon: string }[] = [\r\n { type: 'text', label: 'Text Field', icon: '📝' },\r\n { type: 'label', label: 'Static Label', icon: '🏷️' },\r\n { type: 'image', label: 'Image/Photo', icon: '🖼️' },\r\n { type: 'qrcode', label: 'QR Code', icon: '📱' },\r\n];\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop template builder\r\n * \r\n * Allows users to:\r\n * - Add and position fields on the card\r\n * - Upload background images\r\n * - Configure field styles (fonts, colors, etc.)\r\n * - Choose card orientation and sides\r\n * - Preview the card with sample data\r\n */\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop ID card template builder\r\n */\r\nexport const IDCardDesigner: React.FC<IDCardDesignerProps> = ({\r\n initialTemplate,\r\n onSave,\r\n onCancel,\r\n className = '',\r\n style = {},\r\n}) => {\r\n const {\r\n template,\r\n updateField,\r\n addField,\r\n removeField,\r\n setBackground,\r\n setCardSize,\r\n setOrientation,\r\n setSides,\r\n isValid,\r\n validationErrors,\r\n } = useIDCardTemplate(initialTemplate);\r\n\r\n const [activeSide, setActiveSide] = useState<'front' | 'back'>('front');\r\n const [selectedFieldId, setSelectedFieldId] = useState<string | null>(null);\r\n const [lineHeightInputFocused, setLineHeightInputFocused] = useState(false);\r\n const [showGrid, setShowGrid] = useState(true);\r\n const [isDragging, setIsDragging] = useState(false);\r\n const [isResizing, setIsResizing] = useState(false);\r\n const [templateName, setTemplateName] = useState(template.name);\r\n\r\n const previewContainerRef = useRef<HTMLDivElement>(null);\r\n const dragStartRef = useRef({ x: 0, y: 0, fieldX: 0, fieldY: 0 });\r\n const resizeStartRef = useRef({\r\n x: 0,\r\n y: 0,\r\n width: 0,\r\n height: 0,\r\n fieldX: 0,\r\n fieldY: 0,\r\n handle: '',\r\n });\r\n\r\n // Sample data for preview\r\n const [sampleData, setSampleData] = useState<IDCardData>({\r\n name: 'John Doe',\r\n idno: 'ID12345',\r\n department: 'Computer Science',\r\n designation: 'Student',\r\n dob: '01-01-2000',\r\n bloodgroup: 'O+',\r\n phoneno: '9876543210',\r\n address: 'Sample Address',\r\n });\r\n\r\n // Get selected field\r\n const selectedField = template.fields.find((f) => f.id === selectedFieldId);\r\n\r\n // Handle field selection\r\n const handleFieldSelect = useCallback((field: FieldMapping | null) => {\r\n setSelectedFieldId(field?.id || null);\r\n }, []);\r\n\r\n // Duplicate selected text field\r\n const handleDuplicateField = useCallback(() => {\r\n if (!selectedField || selectedField.type !== 'text') return;\r\n const { id, fieldKey, position, ...rest } = selectedField;\r\n const newField = {\r\n ...rest,\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n position: {\r\n ...position,\r\n x: Math.min(position.x + 20, template.cardSize.width - position.width),\r\n y: Math.min(position.y + 20, template.cardSize.height - position.height),\r\n },\r\n };\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n }, [selectedField, addField, setSelectedFieldId, template.cardSize.width, template.cardSize.height]);\r\n // Handle adding new field\r\n const handleAddField = useCallback(\r\n (type: FieldType) => {\r\n const newField: FieldMapping = {\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n label: type === 'label' ? 'Label' : '',\r\n type,\r\n side: activeSide,\r\n position: { x: 50, y: 50, width: 100, height: 30 },\r\n style: {\r\n fontSize: type === 'label' ? '10px' : '12px',\r\n fontWeight: type === 'label' ? 'bold' : 'normal',\r\n color: '#000000',\r\n textAlign: 'left',\r\n backgroundColor: 'transparent',\r\n },\r\n zIndex: template.fields.length + 1,\r\n staticText: type === 'label' ? 'Static Label' : '',\r\n ...(type === 'qrcode' ? { qrFields: [] } : {}),\r\n };\r\n\r\n // Adjust default sizes based on type\r\n if (type === 'image') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 100 };\r\n } else if (type === 'qrcode') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 80 };\r\n }\r\n\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n },\r\n [activeSide, addField, template.fields.length]\r\n );\r\n\r\n // Handle background upload\r\n const handleBackgroundUpload = useCallback(\r\n async (e: React.ChangeEvent<HTMLInputElement>) => {\r\n const file = e.target.files?.[0];\r\n if (!file) return;\r\n\r\n try {\r\n const base64 = await imageFileToBase64(file);\r\n setBackground(activeSide, base64);\r\n } catch (error) {\r\n console.error('Failed to load background:', error);\r\n }\r\n },\r\n [activeSide, setBackground]\r\n );\r\n\r\n // Handle orientation change\r\n const handleOrientationChange = useCallback(\r\n (orientation: CardOrientation) => {\r\n setOrientation(orientation);\r\n // Update card size based on orientation\r\n const baseWidth = 340;\r\n const baseHeight = 215;\r\n if (orientation === 'portrait') {\r\n setCardSize({ width: baseHeight, height: baseWidth, unit: 'px' });\r\n } else {\r\n setCardSize({ width: baseWidth, height: baseHeight, unit: 'px' });\r\n }\r\n },\r\n [setOrientation, setCardSize]\r\n );\r\n\r\n // Handle sides change\r\n const handleSidesChange = useCallback(\r\n (sides: CardSides) => {\r\n setSides(sides);\r\n if (sides === 'single' && activeSide === 'back') {\r\n setActiveSide('front');\r\n }\r\n },\r\n [setSides, activeSide]\r\n );\r\n\r\n // Drag and drop handling\r\n const handleMouseDown = useCallback(\r\n (e: React.MouseEvent) => {\r\n if (!selectedField || !previewContainerRef.current) return;\r\n\r\n const target = e.target as HTMLElement;\r\n\r\n // Check if clicking on resize handle\r\n if (target.classList.contains('resize-handle')) {\r\n const handle = target.dataset.handle || '';\r\n setIsResizing(true);\r\n resizeStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n width: selectedField.position.width,\r\n height: selectedField.position.height,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n handle,\r\n };\r\n return;\r\n }\r\n\r\n // Check if clicking on field (for dragging)\r\n if (target.closest('.preview-field')) {\r\n setIsDragging(true);\r\n dragStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n };\r\n }\r\n },\r\n [selectedField]\r\n );\r\n\r\n // Handle mouse move for dragging/resizing\r\n useEffect(() => {\r\n const handleMouseMove = (e: MouseEvent) => {\r\n if (!selectedField) return;\r\n\r\n if (isDragging) {\r\n const deltaX = e.clientX - dragStartRef.current.x;\r\n const deltaY = e.clientY - dragStartRef.current.y;\r\n\r\n // Unified drag logic for all field types\r\n const newX = Math.max(0, Math.min(\r\n template.cardSize.width - selectedField.position.width,\r\n dragStartRef.current.fieldX + deltaX\r\n ));\r\n const newY = Math.max(0, Math.min(\r\n template.cardSize.height - selectedField.position.height,\r\n dragStartRef.current.fieldY + deltaY\r\n ));\r\n\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, x: newX, y: newY },\r\n });\r\n }\r\n\r\n if (isResizing) {\r\n const { handle, x, y, width, height, fieldX, fieldY } = resizeStartRef.current;\r\n const deltaX = e.clientX - x;\r\n const deltaY = e.clientY - y;\r\n\r\n let newWidth = width;\r\n let newHeight = height;\r\n let newX = fieldX;\r\n let newY = fieldY;\r\n\r\n // Enforce fixed aspect ratio for QR code fields\r\n if (selectedField.type === 'qrcode') {\r\n // Use the larger delta for both width and height\r\n let delta = 0;\r\n if (handle.includes('e') || handle.includes('w')) {\r\n delta = deltaX;\r\n } else if (handle.includes('s') || handle.includes('n')) {\r\n delta = deltaY;\r\n }\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + delta);\r\n newHeight = newWidth;\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - delta);\r\n newHeight = newWidth;\r\n newX = Math.max(0, fieldX + delta);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + delta);\r\n newWidth = newHeight;\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - delta);\r\n newWidth = newHeight;\r\n newY = Math.max(0, fieldY + delta);\r\n }\r\n } else {\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + deltaX);\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - deltaX);\r\n newX = Math.max(0, fieldX + deltaX);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + deltaY);\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - deltaY);\r\n newY = Math.max(0, fieldY + deltaY);\r\n }\r\n }\r\n\r\n updateField(selectedField.id, {\r\n position: { x: newX, y: newY, width: newWidth, height: newHeight },\r\n });\r\n }\r\n };\r\n\r\n const handleMouseUp = () => {\r\n setIsDragging(false);\r\n setIsResizing(false);\r\n // Remove any accidental selection or pointer capture\r\n window.getSelection?.()?.removeAllRanges?.();\r\n if (previewContainerRef.current) {\r\n previewContainerRef.current.releasePointerCapture?.(0);\r\n }\r\n };\r\n\r\n if (isDragging || isResizing) {\r\n document.addEventListener('mousemove', handleMouseMove);\r\n window.addEventListener('mouseup', handleMouseUp);\r\n }\r\n\r\n return () => {\r\n document.removeEventListener('mousemove', handleMouseMove);\r\n window.removeEventListener('mouseup', handleMouseUp);\r\n };\r\n }, [isDragging, isResizing, selectedField, updateField, template.cardSize]);\r\n\r\n // Handle field property update\r\n const handleFieldPropertyUpdate = useCallback(\r\n (property: string, value: unknown) => {\r\n if (!selectedField) return;\r\n\r\n if (property.startsWith('style.')) {\r\n const styleKey = property.replace('style.', '');\r\n updateField(selectedField.id, {\r\n style: { ...selectedField.style, [styleKey]: value },\r\n });\r\n } else if (property.startsWith('position.')) {\r\n const posKey = property.replace('position.', '') as keyof typeof selectedField.position;\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, [posKey]: Number(value) },\r\n });\r\n } else {\r\n // Only allow qrFields property on QR code fields\r\n if (property === 'qrFields') {\r\n if (selectedField.type === 'qrcode') {\r\n updateField(selectedField.id, { qrFields: value as string[] });\r\n } else {\r\n // do nothing if not a qrcode field\r\n }\r\n } else {\r\n updateField(selectedField.id, { [property]: value });\r\n }\r\n }\r\n },\r\n [selectedField, updateField]\r\n );\r\n\r\n // Handle save\r\n const handleSave = useCallback(() => {\r\n const updatedTemplate = {\r\n ...template,\r\n name: templateName,\r\n updatedAt: new Date().toISOString(),\r\n };\r\n const cleanedTemplate = deepCleanUndefined(updatedTemplate);\r\n onSave(cleanedTemplate);\r\n }, [template, templateName, onSave]);\r\n\r\n // Handle delete field\r\n const handleDeleteField = useCallback(() => {\r\n if (selectedFieldId) {\r\n removeField(selectedFieldId);\r\n setSelectedFieldId(null);\r\n }\r\n }, [selectedFieldId, removeField]);\r\n\r\n // Keyboard shortcuts\r\n useEffect(() => {\r\n let lineHeightInputFocused = false;\r\n // Listen for focus/blur on line height input\r\n const lhInput = document.getElementById('line-height-input');\r\n if (lhInput) {\r\n lhInput.addEventListener('focus', () => { lineHeightInputFocused = true; });\r\n lhInput.addEventListener('blur', () => { lineHeightInputFocused = false; });\r\n }\r\n\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (selectedFieldId) {\r\n const field = template.fields.find(f => f.id === selectedFieldId);\r\n // Arrow key movement for position\r\n const step = e.shiftKey ? 5 : 1;\r\n let dx = 0, dy = 0;\r\n if (e.key === 'ArrowLeft') dx = -step;\r\n if (e.key === 'ArrowRight') dx = step;\r\n if (e.key === 'ArrowUp') dy = -step;\r\n if (e.key === 'ArrowDown') dy = step;\r\n if ((dx !== 0 || dy !== 0) && field) {\r\n // If text field and Ctrl is pressed, adjust line height instead\r\n if (field.type === 'text' && (e.ctrlKey || e.metaKey)) {\r\n let lh = field.style?.lineHeight ? Number(field.style.lineHeight) : 1;\r\n if (e.key === 'ArrowUp') lh = Math.round((lh + 0.1) * 10) / 10;\r\n if (e.key === 'ArrowDown') lh = Math.max(0.1, Math.round((lh - 0.1) * 10) / 10);\r\n updateField(field.id, {\r\n style: { ...field.style, lineHeight: lh.toString() },\r\n });\r\n e.preventDefault();\r\n return;\r\n } else {\r\n let newX = Math.max(0, Math.min(template.cardSize.width - field.position.width, field.position.x + dx));\r\n let newY = Math.max(0, Math.min(template.cardSize.height - field.position.height, field.position.y + dy));\r\n updateField(field.id, {\r\n position: { ...field.position, x: newX, y: newY },\r\n });\r\n e.preventDefault();\r\n return;\r\n }\r\n }\r\n // Delete and Escape\r\n if (e.key === 'Delete') {\r\n handleDeleteField();\r\n }\r\n if (e.key === 'Escape') {\r\n setSelectedFieldId(null);\r\n }\r\n }\r\n };\r\n\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => document.removeEventListener('keydown', handleKeyDown);\r\n }, [selectedFieldId, handleDeleteField, template.fields, template.cardSize, updateField]);\r\n\r\n return (\r\n <div className={`idcard-designer ${className}`} style={style}>\r\n {/* Header */}\r\n <div className=\"designer-header\">\r\n <input\r\n type=\"text\"\r\n value={templateName}\r\n onChange={(e) => setTemplateName(e.target.value)}\r\n className=\"template-name-input\"\r\n placeholder=\"Template Name\"\r\n />\r\n <div className=\"header-actions\">\r\n {onCancel && (\r\n <button onClick={onCancel} className=\"btn btn-secondary\">\r\n Cancel\r\n </button>\r\n )}\r\n <button onClick={handleSave} className=\"btn btn-primary\" disabled={!isValid}>\r\n Save Template\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"designer-body\">\r\n {/* Left Sidebar - Field Types */}\r\n <div className=\"designer-sidebar left-sidebar\">\r\n <h3>Add Fields</h3>\r\n <div className=\"field-types\">\r\n {defaultFieldTypes.map((fieldType) => (\r\n <button\r\n key={fieldType.type}\r\n onClick={() => handleAddField(fieldType.type)}\r\n className=\"field-type-btn\"\r\n >\r\n <span className=\"field-icon\">{fieldType.icon}</span>\r\n <span className=\"field-label\">{fieldType.label}</span>\r\n </button>\r\n ))}\r\n </div>\r\n\r\n <h3>Card Settings</h3>\r\n <div className=\"card-settings\">\r\n <div className=\"setting-group\">\r\n <label>Orientation</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.orientation === 'landscape' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('landscape')}\r\n >\r\n Landscape\r\n </button>\r\n <button\r\n className={`btn ${template.orientation === 'portrait' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('portrait')}\r\n >\r\n Portrait\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Sides</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.sides === 'single' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('single')}\r\n >\r\n Single\r\n </button>\r\n <button\r\n className={`btn ${template.sides === 'double' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('double')}\r\n >\r\n Double\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Size (px)</label>\r\n <div className=\"size-inputs\">\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.width}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, width: Number(e.target.value) })\r\n }\r\n placeholder=\"Width\"\r\n />\r\n <span>×</span>\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.height}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, height: Number(e.target.value) })\r\n }\r\n placeholder=\"Height\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <h3>Background</h3>\r\n <div className=\"background-upload\">\r\n <input\r\n type=\"file\"\r\n accept=\"image/*\"\r\n onChange={handleBackgroundUpload}\r\n id=\"bg-upload\"\r\n className=\"file-input\"\r\n />\r\n <label htmlFor=\"bg-upload\" className=\"btn btn-outline\">\r\n Upload {activeSide} Background\r\n </label>\r\n {template.backgrounds[activeSide] && (\r\n <button\r\n className=\"btn btn-danger btn-sm\"\r\n onClick={() => setBackground(activeSide, '')}\r\n >\r\n Remove\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Center - Preview */}\r\n <div className=\"designer-preview\">\r\n {/* Side tabs */}\r\n <div className=\"side-tabs\">\r\n <button\r\n className={`tab ${activeSide === 'front' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('front')}\r\n >\r\n Front\r\n </button>\r\n {template.sides === 'double' && (\r\n <button\r\n className={`tab ${activeSide === 'back' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('back')}\r\n >\r\n Back\r\n </button>\r\n )}\r\n <label className=\"grid-toggle\">\r\n <input\r\n type=\"checkbox\"\r\n checked={showGrid}\r\n onChange={(e) => setShowGrid(e.target.checked)}\r\n />\r\n Show Grid\r\n </label>\r\n </div>\r\n\r\n {/* Preview container */}\r\n <div\r\n ref={previewContainerRef}\r\n className=\"preview-wrapper\"\r\n onMouseDown={handleMouseDown}\r\n >\r\n <IDCardPreview\r\n template={template}\r\n data={sampleData}\r\n side={activeSide}\r\n showGrid={showGrid}\r\n onFieldSelect={handleFieldSelect}\r\n selectedFieldId={selectedFieldId}\r\n editable={true}\r\n />\r\n </div>\r\n\r\n {/* Field list */}\r\n <div className=\"fields-list\">\r\n <h4>Fields on {activeSide} side:</h4>\r\n {template.fields\r\n .filter((f) => f.side === activeSide)\r\n .map((field) => (\r\n <div\r\n key={field.id}\r\n className={`field-item ${field.id === selectedFieldId ? 'selected' : ''}`}\r\n onClick={() => setSelectedFieldId(field.id)}\r\n >\r\n <span className=\"field-type-icon\">\r\n {defaultFieldTypes.find((t) => t.type === field.type)?.icon}\r\n </span>\r\n <span className=\"field-key\">{field.fieldKey}</span>\r\n <button\r\n className=\"delete-btn\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n removeField(field.id);\r\n if (field.id === selectedFieldId) setSelectedFieldId(null);\r\n }}\r\n >\r\n ×\r\n </button>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n {/* Right Sidebar - Field Properties */}\r\n <div className=\"designer-sidebar right-sidebar\">\r\n <h3>Field Properties</h3>\r\n {selectedField ? (\r\n <div className=\"field-properties\">\r\n <div className=\"property-group\">\r\n <label>Field Key</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.fieldKey}\r\n onChange={(e) => handleFieldPropertyUpdate('fieldKey', e.target.value)}\r\n />\r\n </div>\r\n\r\n {selectedField.type !== 'label' && (\r\n <div className=\"property-group\">\r\n <label>Label</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.label || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('label', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {/* Vertical Align for text fields */}\r\n {selectedField.type === 'text' && (\r\n <>\r\n <button className=\"btn btn-outline btn-sm\" style={{ marginBottom: 12 }} onClick={handleDuplicateField}>\r\n Duplicate Field\r\n </button>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Label Style</strong>\r\n\r\n <div className=\"property-group\">\r\n <label>Label Position</label>\r\n <select\r\n value={selectedField.style?.labelPosition || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"left\">Left (Side)</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Vertical Align</label>\r\n <select\r\n value={selectedField.style?.labelVerticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.labelFontSize || '0.75em'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Weight</label>\r\n <select\r\n value={selectedField.style?.labelFontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.labelColor || '#666666'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelColor', e.target.value)}\r\n />\r\n </div>\r\n </div>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Text Style</strong>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Line Height</label>\r\n <input\r\n id=\"line-height-input\"\r\n type=\"number\"\r\n min={0.1}\r\n step={0.1}\r\n value={selectedField.style?.lineHeight ? Number(selectedField.style.lineHeight) : 1}\r\n onChange={(e) => handleFieldPropertyUpdate('style.lineHeight', e.target.value)}\r\n style={{ width: 80 }}\r\n onFocus={() => setLineHeightInputFocused(true)}\r\n onBlur={() => setLineHeightInputFocused(false)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Vertical Align</label>\r\n <select\r\n value={selectedField.style?.verticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n </div>\r\n </>\r\n )}\r\n\r\n {selectedField.type === 'label' && (\r\n <div className=\"property-group\">\r\n <label>Static Text</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.staticText || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('staticText', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {selectedField.type === 'qrcode' && (\r\n <div className=\"property-group\">\r\n <label>QR Code Data Fields</label>\r\n <small className=\"hint\">Select which fields to encode in the QR code:</small>\r\n <div style={{ marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }}>\r\n {template.fields\r\n .filter(f => f.type !== 'qrcode' && f.type !== 'label')\r\n .map((field) => (\r\n <label key={field.fieldKey} style={{ display: 'block', marginBottom: '6px', cursor: 'pointer' }}>\r\n <input\r\n type=\"checkbox\"\r\n checked={selectedField.qrFields?.includes(field.fieldKey) || false}\r\n onChange={(e) => {\r\n const currentFields = selectedField.qrFields || [];\r\n const newFields = e.target.checked\r\n ? [...currentFields, field.fieldKey]\r\n : currentFields.filter(f => f !== field.fieldKey);\r\n handleFieldPropertyUpdate('qrFields', newFields);\r\n }}\r\n style={{ marginRight: '6px' }}\r\n />\r\n {field.label || field.fieldKey}\r\n </label>\r\n ))}\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Border Radius for image fields */}\r\n {selectedField.type === 'image' && (\r\n <div className=\"property-group\">\r\n <label>Border Radius</label>\r\n <input\r\n type=\"text\"\r\n placeholder=\"e.g. 50% or 8px\"\r\n value={selectedField.style?.borderRadius || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('style.borderRadius', e.target.value)}\r\n />\r\n <small className=\"hint\">Use <b>50%</b> for a circle, <b>8px</b> for rounded corners, etc.</small>\r\n </div>\r\n )}\r\n\r\n {/* Only show these style controls for non-text fields */}\r\n {selectedField.type !== 'text' && <>\r\n <h4>Style</h4>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n </>}\r\n <div className=\"property-group\">\r\n <label>Background Color</label>\r\n <div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>\r\n <input\r\n type=\"checkbox\"\r\n id=\"transparent-bg-checkbox\"\r\n checked={selectedField.style?.backgroundColor === 'transparent'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.checked ? 'transparent' : '#ffffff')}\r\n />\r\n <label htmlFor=\"transparent-bg-checkbox\" style={{ margin: 0, fontWeight: 400, fontSize: '0.95em' }}>Transparent</label>\r\n {selectedField.style?.backgroundColor !== 'transparent' && (\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.backgroundColor || '#ffffff'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.value)}\r\n />\r\n )}\r\n </div>\r\n </div>\r\n\r\n <div className=\"property-group\">\r\n <label>Side</label>\r\n <select\r\n value={selectedField.side}\r\n onChange={(e) =>\r\n handleFieldPropertyUpdate('side', e.target.value as 'front' | 'back')\r\n }\r\n >\r\n <option value=\"front\">Front</option>\r\n {template.sides === 'double' && <option value=\"back\">Back</option>}\r\n </select>\r\n </div>\r\n\r\n <button className=\"btn btn-danger\" onClick={handleDeleteField}>\r\n Delete Field\r\n </button>\r\n </div>\r\n ) : (\r\n <p className=\"no-selection\">Select a field to edit its properties</p>\r\n )}\r\n\r\n <h3>Sample Data</h3>\r\n <div className=\"sample-data\">\r\n <p className=\"hint\">Edit sample data to preview:</p>\r\n {Object.entries(sampleData).map(([key, value]) => (\r\n <div key={key} className=\"property-group\">\r\n <label>{key}</label>\r\n <input\r\n type=\"text\"\r\n value={String(value)}\r\n onChange={(e) =>\r\n setSampleData((prev) => ({ ...prev, [key]: e.target.value }))\r\n }\r\n />\r\n </div>\r\n ))}\r\n <button\r\n className=\"btn btn-outline btn-sm\"\r\n onClick={() =>\r\n setSampleData((prev) => ({ ...prev, [`custom_${Date.now()}`]: '' }))\r\n }\r\n >\r\n + Add Field\r\n </button>\r\n </div>\r\n\r\n {/* Validation errors */}\r\n {validationErrors.length > 0 && (\r\n <div className=\"validation-errors\">\r\n <h4>⚠️ Validation Issues</h4>\r\n <ul>\r\n {validationErrors.map((error, index) => (\r\n <li key={index}>{error}</li>\r\n ))}\r\n </ul>\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\n\r\n"],"names":["useIDCardTemplate","useState","useRef","useCallback","generateId","imageFileToBase64","useEffect","deepCleanUndefined","_jsxs","_jsx","IDCardPreview","_Fragment"],"mappings":"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"}
|
|
@@ -29,6 +29,7 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
29
29
|
const { template, updateField, addField, removeField, setBackground, setCardSize, setOrientation, setSides, isValid, validationErrors, } = useIDCardTemplate(initialTemplate);
|
|
30
30
|
const [activeSide, setActiveSide] = useState('front');
|
|
31
31
|
const [selectedFieldId, setSelectedFieldId] = useState(null);
|
|
32
|
+
const [lineHeightInputFocused, setLineHeightInputFocused] = useState(false);
|
|
32
33
|
const [showGrid, setShowGrid] = useState(true);
|
|
33
34
|
const [isDragging, setIsDragging] = useState(false);
|
|
34
35
|
const [isResizing, setIsResizing] = useState(false);
|
|
@@ -311,9 +312,16 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
311
312
|
}, [selectedFieldId, removeField]);
|
|
312
313
|
// Keyboard shortcuts
|
|
313
314
|
useEffect(() => {
|
|
315
|
+
// Listen for focus/blur on line height input
|
|
316
|
+
const lhInput = document.getElementById('line-height-input');
|
|
317
|
+
if (lhInput) {
|
|
318
|
+
lhInput.addEventListener('focus', () => { });
|
|
319
|
+
lhInput.addEventListener('blur', () => { });
|
|
320
|
+
}
|
|
314
321
|
const handleKeyDown = (e) => {
|
|
315
322
|
if (selectedFieldId) {
|
|
316
|
-
|
|
323
|
+
const field = template.fields.find(f => f.id === selectedFieldId);
|
|
324
|
+
// Arrow key movement for position
|
|
317
325
|
const step = e.shiftKey ? 5 : 1;
|
|
318
326
|
let dx = 0, dy = 0;
|
|
319
327
|
if (e.key === 'ArrowLeft')
|
|
@@ -324,16 +332,29 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
324
332
|
dy = -step;
|
|
325
333
|
if (e.key === 'ArrowDown')
|
|
326
334
|
dy = step;
|
|
327
|
-
if (dx !== 0 || dy !== 0) {
|
|
328
|
-
|
|
329
|
-
if (field) {
|
|
335
|
+
if ((dx !== 0 || dy !== 0) && field) {
|
|
336
|
+
// If text field and Ctrl is pressed, adjust line height instead
|
|
337
|
+
if (field.type === 'text' && (e.ctrlKey || e.metaKey)) {
|
|
338
|
+
let lh = field.style?.lineHeight ? Number(field.style.lineHeight) : 1;
|
|
339
|
+
if (e.key === 'ArrowUp')
|
|
340
|
+
lh = Math.round((lh + 0.1) * 10) / 10;
|
|
341
|
+
if (e.key === 'ArrowDown')
|
|
342
|
+
lh = Math.max(0.1, Math.round((lh - 0.1) * 10) / 10);
|
|
343
|
+
updateField(field.id, {
|
|
344
|
+
style: { ...field.style, lineHeight: lh.toString() },
|
|
345
|
+
});
|
|
346
|
+
e.preventDefault();
|
|
347
|
+
return;
|
|
348
|
+
}
|
|
349
|
+
else {
|
|
330
350
|
let newX = Math.max(0, Math.min(template.cardSize.width - field.position.width, field.position.x + dx));
|
|
331
351
|
let newY = Math.max(0, Math.min(template.cardSize.height - field.position.height, field.position.y + dy));
|
|
332
352
|
updateField(field.id, {
|
|
333
353
|
position: { ...field.position, x: newX, y: newY },
|
|
334
354
|
});
|
|
355
|
+
e.preventDefault();
|
|
356
|
+
return;
|
|
335
357
|
}
|
|
336
|
-
e.preventDefault();
|
|
337
358
|
}
|
|
338
359
|
// Delete and Escape
|
|
339
360
|
if (e.key === 'Delete') {
|
|
@@ -354,7 +375,7 @@ const IDCardDesigner = ({ initialTemplate, onSave, onCancel, className = '', sty
|
|
|
354
375
|
removeField(field.id);
|
|
355
376
|
if (field.id === selectedFieldId)
|
|
356
377
|
setSelectedFieldId(null);
|
|
357
|
-
}, children: "\u00D7" })] }, field.id)))] })] }), jsxs("div", { className: "designer-sidebar right-sidebar", children: [jsx("h3", { children: "Field Properties" }), selectedField ? (jsxs("div", { className: "field-properties", children: [jsxs("div", { className: "property-group", children: [jsx("label", { children: "Field Key" }), jsx("input", { type: "text", value: selectedField.fieldKey, onChange: (e) => handleFieldPropertyUpdate('fieldKey', e.target.value) })] }), selectedField.type !== 'label' && (jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label" }), jsx("input", { type: "text", value: selectedField.label || '', onChange: (e) => handleFieldPropertyUpdate('label', e.target.value) })] })), selectedField.type === 'text' && (jsxs(Fragment, { children: [jsx("button", { className: "btn btn-outline btn-sm", style: { marginBottom: 12 }, onClick: handleDuplicateField, children: "Duplicate Field" }), jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Label Style" }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Position" }), jsxs("select", { value: selectedField.style?.labelPosition || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value), children: [jsx("option", { value: "top", children: "Top" }), jsx("option", { value: "left", children: "Left (Side)" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Vertical Align" }), jsxs("select", { value: selectedField.style?.labelVerticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value), children: [jsx("option", { value: "top", children: "Top" }), jsx("option", { value: "middle", children: "Middle" }), jsx("option", { value: "bottom", children: "Bottom" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Font Size" }), jsx("input", { type: "text", value: selectedField.style?.labelFontSize || '0.75em', onChange: (e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value) })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Font Weight" }), jsxs("select", { value: selectedField.style?.labelFontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value), children: [jsx("option", { value: "normal", children: "Normal" }), jsx("option", { value: "bold", children: "Bold" }), jsx("option", { value: "100", children: "100" }), jsx("option", { value: "200", children: "200" }), jsx("option", { value: "300", children: "300" }), jsx("option", { value: "400", children: "400" }), jsx("option", { value: "500", children: "500" }), jsx("option", { value: "600", children: "600" }), jsx("option", { value: "700", children: "700" }), jsx("option", { value: "800", children: "800" }), jsx("option", { value: "900", children: "900" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Color" }), jsx("input", { type: "color", value: selectedField.style?.labelColor || '#666666', onChange: (e) => handleFieldPropertyUpdate('style.labelColor', e.target.value) })] })] }), jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Text Style" }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Font Size" }), jsx("input", { type: "text", value: selectedField.style?.fontSize || '12px', onChange: (e) => handleFieldPropertyUpdate('style.fontSize', e.target.value) })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Font Weight" }), jsxs("select", { value: selectedField.style?.fontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value), children: [jsx("option", { value: "normal", children: "Normal" }), jsx("option", { value: "bold", children: "Bold" }), jsx("option", { value: "100", children: "100" }), jsx("option", { value: "200", children: "200" }), jsx("option", { value: "300", children: "300" }), jsx("option", { value: "400", children: "400" }), jsx("option", { value: "500", children: "500" }), jsx("option", { value: "600", children: "600" }), jsx("option", { value: "700", children: "700" }), jsx("option", { value: "800", children: "800" }), jsx("option", { value: "900", children: "900" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Text Color" }), jsx("input", { type: "color", value: selectedField.style?.color || '#000000', onChange: (e) => handleFieldPropertyUpdate('style.color', e.target.value) })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Text Align" }), jsxs("select", { value: selectedField.style?.textAlign || 'left', onChange: (e) => handleFieldPropertyUpdate('style.textAlign', e.target.value), children: [jsx("option", { value: "left", children: "Left" }), jsx("option", { value: "center", children: "Center" }), jsx("option", { value: "right", children: "Right" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Text Transform" }), jsxs("select", { value: selectedField.style?.textTransform || 'none', onChange: (e) => handleFieldPropertyUpdate('style.textTransform', e.target.value), children: [jsx("option", { value: "none", children: "None" }), jsx("option", { value: "uppercase", children: "UPPERCASE" }), jsx("option", { value: "lowercase", children: "lowercase" }), jsx("option", { value: "capitalize", children: "Capitalize" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Vertical Align" }), jsxs("select", { value: selectedField.style?.verticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value), children: [jsx("option", { value: "top", children: "Top" }), jsx("option", { value: "middle", children: "Middle" }), jsx("option", { value: "bottom", children: "Bottom" })] })] })] })] })), selectedField.type === 'label' && (jsxs("div", { className: "property-group", children: [jsx("label", { children: "Static Text" }), jsx("input", { type: "text", value: selectedField.staticText || '', onChange: (e) => handleFieldPropertyUpdate('staticText', e.target.value) })] })), selectedField.type === 'qrcode' && (jsxs("div", { className: "property-group", children: [jsx("label", { children: "QR Code Data Fields" }), jsx("small", { className: "hint", children: "Select which fields to encode in the QR code:" }), jsx("div", { style: { marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }, children: template.fields
|
|
378
|
+
}, children: "\u00D7" })] }, field.id)))] })] }), jsxs("div", { className: "designer-sidebar right-sidebar", children: [jsx("h3", { children: "Field Properties" }), selectedField ? (jsxs("div", { className: "field-properties", children: [jsxs("div", { className: "property-group", children: [jsx("label", { children: "Field Key" }), jsx("input", { type: "text", value: selectedField.fieldKey, onChange: (e) => handleFieldPropertyUpdate('fieldKey', e.target.value) })] }), selectedField.type !== 'label' && (jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label" }), jsx("input", { type: "text", value: selectedField.label || '', onChange: (e) => handleFieldPropertyUpdate('label', e.target.value) })] })), selectedField.type === 'text' && (jsxs(Fragment, { children: [jsx("button", { className: "btn btn-outline btn-sm", style: { marginBottom: 12 }, onClick: handleDuplicateField, children: "Duplicate Field" }), jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Label Style" }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Position" }), jsxs("select", { value: selectedField.style?.labelPosition || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value), children: [jsx("option", { value: "top", children: "Top" }), jsx("option", { value: "left", children: "Left (Side)" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Vertical Align" }), jsxs("select", { value: selectedField.style?.labelVerticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value), children: [jsx("option", { value: "top", children: "Top" }), jsx("option", { value: "middle", children: "Middle" }), jsx("option", { value: "bottom", children: "Bottom" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Font Size" }), jsx("input", { type: "text", value: selectedField.style?.labelFontSize || '0.75em', onChange: (e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value) })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Font Weight" }), jsxs("select", { value: selectedField.style?.labelFontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value), children: [jsx("option", { value: "normal", children: "Normal" }), jsx("option", { value: "bold", children: "Bold" }), jsx("option", { value: "100", children: "100" }), jsx("option", { value: "200", children: "200" }), jsx("option", { value: "300", children: "300" }), jsx("option", { value: "400", children: "400" }), jsx("option", { value: "500", children: "500" }), jsx("option", { value: "600", children: "600" }), jsx("option", { value: "700", children: "700" }), jsx("option", { value: "800", children: "800" }), jsx("option", { value: "900", children: "900" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Label Color" }), jsx("input", { type: "color", value: selectedField.style?.labelColor || '#666666', onChange: (e) => handleFieldPropertyUpdate('style.labelColor', e.target.value) })] })] }), jsxs("div", { style: { border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }, children: [jsx("strong", { style: { fontSize: '1em', display: 'block', marginBottom: 6 }, children: "Text Style" }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Font Size" }), jsx("input", { type: "text", value: selectedField.style?.fontSize || '12px', onChange: (e) => handleFieldPropertyUpdate('style.fontSize', e.target.value) })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Font Weight" }), jsxs("select", { value: selectedField.style?.fontWeight || 'normal', onChange: (e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value), children: [jsx("option", { value: "normal", children: "Normal" }), jsx("option", { value: "bold", children: "Bold" }), jsx("option", { value: "100", children: "100" }), jsx("option", { value: "200", children: "200" }), jsx("option", { value: "300", children: "300" }), jsx("option", { value: "400", children: "400" }), jsx("option", { value: "500", children: "500" }), jsx("option", { value: "600", children: "600" }), jsx("option", { value: "700", children: "700" }), jsx("option", { value: "800", children: "800" }), jsx("option", { value: "900", children: "900" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Text Color" }), jsx("input", { type: "color", value: selectedField.style?.color || '#000000', onChange: (e) => handleFieldPropertyUpdate('style.color', e.target.value) })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Text Align" }), jsxs("select", { value: selectedField.style?.textAlign || 'left', onChange: (e) => handleFieldPropertyUpdate('style.textAlign', e.target.value), children: [jsx("option", { value: "left", children: "Left" }), jsx("option", { value: "center", children: "Center" }), jsx("option", { value: "right", children: "Right" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Line Height" }), jsx("input", { id: "line-height-input", type: "number", min: 0.1, step: 0.1, value: selectedField.style?.lineHeight ? Number(selectedField.style.lineHeight) : 1, onChange: (e) => handleFieldPropertyUpdate('style.lineHeight', e.target.value), style: { width: 80 }, onFocus: () => setLineHeightInputFocused(true), onBlur: () => setLineHeightInputFocused(false) })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Text Transform" }), jsxs("select", { value: selectedField.style?.textTransform || 'none', onChange: (e) => handleFieldPropertyUpdate('style.textTransform', e.target.value), children: [jsx("option", { value: "none", children: "None" }), jsx("option", { value: "uppercase", children: "UPPERCASE" }), jsx("option", { value: "lowercase", children: "lowercase" }), jsx("option", { value: "capitalize", children: "Capitalize" })] })] }), jsxs("div", { className: "property-group", children: [jsx("label", { children: "Vertical Align" }), jsxs("select", { value: selectedField.style?.verticalAlign || 'top', onChange: (e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value), children: [jsx("option", { value: "top", children: "Top" }), jsx("option", { value: "middle", children: "Middle" }), jsx("option", { value: "bottom", children: "Bottom" })] })] })] })] })), selectedField.type === 'label' && (jsxs("div", { className: "property-group", children: [jsx("label", { children: "Static Text" }), jsx("input", { type: "text", value: selectedField.staticText || '', onChange: (e) => handleFieldPropertyUpdate('staticText', e.target.value) })] })), selectedField.type === 'qrcode' && (jsxs("div", { className: "property-group", children: [jsx("label", { children: "QR Code Data Fields" }), jsx("small", { className: "hint", children: "Select which fields to encode in the QR code:" }), jsx("div", { style: { marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }, children: template.fields
|
|
358
379
|
.filter(f => f.type !== 'qrcode' && f.type !== 'label')
|
|
359
380
|
.map((field) => (jsxs("label", { style: { display: 'block', marginBottom: '6px', cursor: 'pointer' }, children: [jsx("input", { type: "checkbox", checked: selectedField.qrFields?.includes(field.fieldKey) || false, onChange: (e) => {
|
|
360
381
|
const currentFields = selectedField.qrFields || [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IDCardDesigner.js","sources":["../../../src/components/IDCardDesigner.tsx"],"sourcesContent":["\r\nimport React, { useState, useCallback, useRef, useEffect } from 'react';\r\nimport type {\r\n IDCardDesignerProps,\r\n FieldMapping,\r\n FieldType,\r\n CardOrientation,\r\n CardSides,\r\n IDCardData,\r\n} from '../types';\r\nimport { useIDCardTemplate } from '../hooks/useIDCardTemplate';\r\nimport { deepCleanUndefined } from '../utils/deepCleanUndefined';\r\nimport { IDCardPreview } from './IDCardPreview';\r\nimport { generateId, imageFileToBase64 } from '../storage/templateStorage';\r\nimport './IDCardDesigner.css';\r\n\r\n// Available field types in the designer\r\nconst defaultFieldTypes: { type: FieldType; label: string; icon: string }[] = [\r\n { type: 'text', label: 'Text Field', icon: '📝' },\r\n { type: 'label', label: 'Static Label', icon: '🏷️' },\r\n { type: 'image', label: 'Image/Photo', icon: '🖼️' },\r\n { type: 'qrcode', label: 'QR Code', icon: '📱' },\r\n];\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop template builder\r\n * \r\n * Allows users to:\r\n * - Add and position fields on the card\r\n * - Upload background images\r\n * - Configure field styles (fonts, colors, etc.)\r\n * - Choose card orientation and sides\r\n * - Preview the card with sample data\r\n */\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop ID card template builder\r\n */\r\nexport const IDCardDesigner: React.FC<IDCardDesignerProps> = ({\r\n initialTemplate,\r\n onSave,\r\n onCancel,\r\n className = '',\r\n style = {},\r\n}) => {\r\n const {\r\n template,\r\n updateField,\r\n addField,\r\n removeField,\r\n setBackground,\r\n setCardSize,\r\n setOrientation,\r\n setSides,\r\n isValid,\r\n validationErrors,\r\n } = useIDCardTemplate(initialTemplate);\r\n\r\n const [activeSide, setActiveSide] = useState<'front' | 'back'>('front');\r\n const [selectedFieldId, setSelectedFieldId] = useState<string | null>(null);\r\n const [showGrid, setShowGrid] = useState(true);\r\n const [isDragging, setIsDragging] = useState(false);\r\n const [isResizing, setIsResizing] = useState(false);\r\n const [templateName, setTemplateName] = useState(template.name);\r\n\r\n const previewContainerRef = useRef<HTMLDivElement>(null);\r\n const dragStartRef = useRef({ x: 0, y: 0, fieldX: 0, fieldY: 0 });\r\n const resizeStartRef = useRef({\r\n x: 0,\r\n y: 0,\r\n width: 0,\r\n height: 0,\r\n fieldX: 0,\r\n fieldY: 0,\r\n handle: '',\r\n });\r\n\r\n // Sample data for preview\r\n const [sampleData, setSampleData] = useState<IDCardData>({\r\n name: 'John Doe',\r\n idno: 'ID12345',\r\n department: 'Computer Science',\r\n designation: 'Student',\r\n dob: '01-01-2000',\r\n bloodgroup: 'O+',\r\n phoneno: '9876543210',\r\n address: 'Sample Address',\r\n });\r\n\r\n // Get selected field\r\n const selectedField = template.fields.find((f) => f.id === selectedFieldId);\r\n\r\n // Handle field selection\r\n const handleFieldSelect = useCallback((field: FieldMapping | null) => {\r\n setSelectedFieldId(field?.id || null);\r\n }, []);\r\n\r\n // Duplicate selected text field\r\n const handleDuplicateField = useCallback(() => {\r\n if (!selectedField || selectedField.type !== 'text') return;\r\n const { id, fieldKey, position, ...rest } = selectedField;\r\n const newField = {\r\n ...rest,\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n position: {\r\n ...position,\r\n x: Math.min(position.x + 20, template.cardSize.width - position.width),\r\n y: Math.min(position.y + 20, template.cardSize.height - position.height),\r\n },\r\n };\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n }, [selectedField, addField, setSelectedFieldId, template.cardSize.width, template.cardSize.height]);\r\n // Handle adding new field\r\n const handleAddField = useCallback(\r\n (type: FieldType) => {\r\n const newField: FieldMapping = {\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n label: type === 'label' ? 'Label' : '',\r\n type,\r\n side: activeSide,\r\n position: { x: 50, y: 50, width: 100, height: 30 },\r\n style: {\r\n fontSize: type === 'label' ? '10px' : '12px',\r\n fontWeight: type === 'label' ? 'bold' : 'normal',\r\n color: '#000000',\r\n textAlign: 'left',\r\n backgroundColor: 'transparent',\r\n },\r\n zIndex: template.fields.length + 1,\r\n staticText: type === 'label' ? 'Static Label' : '',\r\n ...(type === 'qrcode' ? { qrFields: [] } : {}),\r\n };\r\n\r\n // Adjust default sizes based on type\r\n if (type === 'image') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 100 };\r\n } else if (type === 'qrcode') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 80 };\r\n }\r\n\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n },\r\n [activeSide, addField, template.fields.length]\r\n );\r\n\r\n // Handle background upload\r\n const handleBackgroundUpload = useCallback(\r\n async (e: React.ChangeEvent<HTMLInputElement>) => {\r\n const file = e.target.files?.[0];\r\n if (!file) return;\r\n\r\n try {\r\n const base64 = await imageFileToBase64(file);\r\n setBackground(activeSide, base64);\r\n } catch (error) {\r\n console.error('Failed to load background:', error);\r\n }\r\n },\r\n [activeSide, setBackground]\r\n );\r\n\r\n // Handle orientation change\r\n const handleOrientationChange = useCallback(\r\n (orientation: CardOrientation) => {\r\n setOrientation(orientation);\r\n // Update card size based on orientation\r\n const baseWidth = 340;\r\n const baseHeight = 215;\r\n if (orientation === 'portrait') {\r\n setCardSize({ width: baseHeight, height: baseWidth, unit: 'px' });\r\n } else {\r\n setCardSize({ width: baseWidth, height: baseHeight, unit: 'px' });\r\n }\r\n },\r\n [setOrientation, setCardSize]\r\n );\r\n\r\n // Handle sides change\r\n const handleSidesChange = useCallback(\r\n (sides: CardSides) => {\r\n setSides(sides);\r\n if (sides === 'single' && activeSide === 'back') {\r\n setActiveSide('front');\r\n }\r\n },\r\n [setSides, activeSide]\r\n );\r\n\r\n // Drag and drop handling\r\n const handleMouseDown = useCallback(\r\n (e: React.MouseEvent) => {\r\n if (!selectedField || !previewContainerRef.current) return;\r\n\r\n const target = e.target as HTMLElement;\r\n\r\n // Check if clicking on resize handle\r\n if (target.classList.contains('resize-handle')) {\r\n const handle = target.dataset.handle || '';\r\n setIsResizing(true);\r\n resizeStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n width: selectedField.position.width,\r\n height: selectedField.position.height,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n handle,\r\n };\r\n return;\r\n }\r\n\r\n // Check if clicking on field (for dragging)\r\n if (target.closest('.preview-field')) {\r\n setIsDragging(true);\r\n dragStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n };\r\n }\r\n },\r\n [selectedField]\r\n );\r\n\r\n // Handle mouse move for dragging/resizing\r\n useEffect(() => {\r\n const handleMouseMove = (e: MouseEvent) => {\r\n if (!selectedField) return;\r\n\r\n if (isDragging) {\r\n const deltaX = e.clientX - dragStartRef.current.x;\r\n const deltaY = e.clientY - dragStartRef.current.y;\r\n\r\n // Unified drag logic for all field types\r\n const newX = Math.max(0, Math.min(\r\n template.cardSize.width - selectedField.position.width,\r\n dragStartRef.current.fieldX + deltaX\r\n ));\r\n const newY = Math.max(0, Math.min(\r\n template.cardSize.height - selectedField.position.height,\r\n dragStartRef.current.fieldY + deltaY\r\n ));\r\n\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, x: newX, y: newY },\r\n });\r\n }\r\n\r\n if (isResizing) {\r\n const { handle, x, y, width, height, fieldX, fieldY } = resizeStartRef.current;\r\n const deltaX = e.clientX - x;\r\n const deltaY = e.clientY - y;\r\n\r\n let newWidth = width;\r\n let newHeight = height;\r\n let newX = fieldX;\r\n let newY = fieldY;\r\n\r\n // Enforce fixed aspect ratio for QR code fields\r\n if (selectedField.type === 'qrcode') {\r\n // Use the larger delta for both width and height\r\n let delta = 0;\r\n if (handle.includes('e') || handle.includes('w')) {\r\n delta = deltaX;\r\n } else if (handle.includes('s') || handle.includes('n')) {\r\n delta = deltaY;\r\n }\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + delta);\r\n newHeight = newWidth;\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - delta);\r\n newHeight = newWidth;\r\n newX = Math.max(0, fieldX + delta);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + delta);\r\n newWidth = newHeight;\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - delta);\r\n newWidth = newHeight;\r\n newY = Math.max(0, fieldY + delta);\r\n }\r\n } else {\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + deltaX);\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - deltaX);\r\n newX = Math.max(0, fieldX + deltaX);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + deltaY);\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - deltaY);\r\n newY = Math.max(0, fieldY + deltaY);\r\n }\r\n }\r\n\r\n updateField(selectedField.id, {\r\n position: { x: newX, y: newY, width: newWidth, height: newHeight },\r\n });\r\n }\r\n };\r\n\r\n const handleMouseUp = () => {\r\n setIsDragging(false);\r\n setIsResizing(false);\r\n // Remove any accidental selection or pointer capture\r\n window.getSelection?.()?.removeAllRanges?.();\r\n if (previewContainerRef.current) {\r\n previewContainerRef.current.releasePointerCapture?.(0);\r\n }\r\n };\r\n\r\n if (isDragging || isResizing) {\r\n document.addEventListener('mousemove', handleMouseMove);\r\n window.addEventListener('mouseup', handleMouseUp);\r\n }\r\n\r\n return () => {\r\n document.removeEventListener('mousemove', handleMouseMove);\r\n window.removeEventListener('mouseup', handleMouseUp);\r\n };\r\n }, [isDragging, isResizing, selectedField, updateField, template.cardSize]);\r\n\r\n // Handle field property update\r\n const handleFieldPropertyUpdate = useCallback(\r\n (property: string, value: unknown) => {\r\n if (!selectedField) return;\r\n\r\n if (property.startsWith('style.')) {\r\n const styleKey = property.replace('style.', '');\r\n updateField(selectedField.id, {\r\n style: { ...selectedField.style, [styleKey]: value },\r\n });\r\n } else if (property.startsWith('position.')) {\r\n const posKey = property.replace('position.', '') as keyof typeof selectedField.position;\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, [posKey]: Number(value) },\r\n });\r\n } else {\r\n // Only allow qrFields property on QR code fields\r\n if (property === 'qrFields') {\r\n if (selectedField.type === 'qrcode') {\r\n updateField(selectedField.id, { qrFields: value as string[] });\r\n } else {\r\n // do nothing if not a qrcode field\r\n }\r\n } else {\r\n updateField(selectedField.id, { [property]: value });\r\n }\r\n }\r\n },\r\n [selectedField, updateField]\r\n );\r\n\r\n // Handle save\r\n const handleSave = useCallback(() => {\r\n const updatedTemplate = {\r\n ...template,\r\n name: templateName,\r\n updatedAt: new Date().toISOString(),\r\n };\r\n const cleanedTemplate = deepCleanUndefined(updatedTemplate);\r\n onSave(cleanedTemplate);\r\n }, [template, templateName, onSave]);\r\n\r\n // Handle delete field\r\n const handleDeleteField = useCallback(() => {\r\n if (selectedFieldId) {\r\n removeField(selectedFieldId);\r\n setSelectedFieldId(null);\r\n }\r\n }, [selectedFieldId, removeField]);\r\n\r\n // Keyboard shortcuts\r\n useEffect(() => {\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (selectedFieldId) {\r\n // Arrow key movement\r\n const step = e.shiftKey ? 5 : 1;\r\n let dx = 0, dy = 0;\r\n if (e.key === 'ArrowLeft') dx = -step;\r\n if (e.key === 'ArrowRight') dx = step;\r\n if (e.key === 'ArrowUp') dy = -step;\r\n if (e.key === 'ArrowDown') dy = step;\r\n if (dx !== 0 || dy !== 0) {\r\n const field = template.fields.find(f => f.id === selectedFieldId);\r\n if (field) {\r\n let newX = Math.max(0, Math.min(template.cardSize.width - field.position.width, field.position.x + dx));\r\n let newY = Math.max(0, Math.min(template.cardSize.height - field.position.height, field.position.y + dy));\r\n updateField(field.id, {\r\n position: { ...field.position, x: newX, y: newY },\r\n });\r\n }\r\n e.preventDefault();\r\n }\r\n // Delete and Escape\r\n if (e.key === 'Delete') {\r\n handleDeleteField();\r\n }\r\n if (e.key === 'Escape') {\r\n setSelectedFieldId(null);\r\n }\r\n }\r\n };\r\n\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => document.removeEventListener('keydown', handleKeyDown);\r\n }, [selectedFieldId, handleDeleteField, template.fields, template.cardSize, updateField]);\r\n\r\n return (\r\n <div className={`idcard-designer ${className}`} style={style}>\r\n {/* Header */}\r\n <div className=\"designer-header\">\r\n <input\r\n type=\"text\"\r\n value={templateName}\r\n onChange={(e) => setTemplateName(e.target.value)}\r\n className=\"template-name-input\"\r\n placeholder=\"Template Name\"\r\n />\r\n <div className=\"header-actions\">\r\n {onCancel && (\r\n <button onClick={onCancel} className=\"btn btn-secondary\">\r\n Cancel\r\n </button>\r\n )}\r\n <button onClick={handleSave} className=\"btn btn-primary\" disabled={!isValid}>\r\n Save Template\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"designer-body\">\r\n {/* Left Sidebar - Field Types */}\r\n <div className=\"designer-sidebar left-sidebar\">\r\n <h3>Add Fields</h3>\r\n <div className=\"field-types\">\r\n {defaultFieldTypes.map((fieldType) => (\r\n <button\r\n key={fieldType.type}\r\n onClick={() => handleAddField(fieldType.type)}\r\n className=\"field-type-btn\"\r\n >\r\n <span className=\"field-icon\">{fieldType.icon}</span>\r\n <span className=\"field-label\">{fieldType.label}</span>\r\n </button>\r\n ))}\r\n </div>\r\n\r\n <h3>Card Settings</h3>\r\n <div className=\"card-settings\">\r\n <div className=\"setting-group\">\r\n <label>Orientation</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.orientation === 'landscape' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('landscape')}\r\n >\r\n Landscape\r\n </button>\r\n <button\r\n className={`btn ${template.orientation === 'portrait' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('portrait')}\r\n >\r\n Portrait\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Sides</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.sides === 'single' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('single')}\r\n >\r\n Single\r\n </button>\r\n <button\r\n className={`btn ${template.sides === 'double' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('double')}\r\n >\r\n Double\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Size (px)</label>\r\n <div className=\"size-inputs\">\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.width}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, width: Number(e.target.value) })\r\n }\r\n placeholder=\"Width\"\r\n />\r\n <span>×</span>\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.height}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, height: Number(e.target.value) })\r\n }\r\n placeholder=\"Height\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <h3>Background</h3>\r\n <div className=\"background-upload\">\r\n <input\r\n type=\"file\"\r\n accept=\"image/*\"\r\n onChange={handleBackgroundUpload}\r\n id=\"bg-upload\"\r\n className=\"file-input\"\r\n />\r\n <label htmlFor=\"bg-upload\" className=\"btn btn-outline\">\r\n Upload {activeSide} Background\r\n </label>\r\n {template.backgrounds[activeSide] && (\r\n <button\r\n className=\"btn btn-danger btn-sm\"\r\n onClick={() => setBackground(activeSide, '')}\r\n >\r\n Remove\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Center - Preview */}\r\n <div className=\"designer-preview\">\r\n {/* Side tabs */}\r\n <div className=\"side-tabs\">\r\n <button\r\n className={`tab ${activeSide === 'front' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('front')}\r\n >\r\n Front\r\n </button>\r\n {template.sides === 'double' && (\r\n <button\r\n className={`tab ${activeSide === 'back' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('back')}\r\n >\r\n Back\r\n </button>\r\n )}\r\n <label className=\"grid-toggle\">\r\n <input\r\n type=\"checkbox\"\r\n checked={showGrid}\r\n onChange={(e) => setShowGrid(e.target.checked)}\r\n />\r\n Show Grid\r\n </label>\r\n </div>\r\n\r\n {/* Preview container */}\r\n <div\r\n ref={previewContainerRef}\r\n className=\"preview-wrapper\"\r\n onMouseDown={handleMouseDown}\r\n >\r\n <IDCardPreview\r\n template={template}\r\n data={sampleData}\r\n side={activeSide}\r\n showGrid={showGrid}\r\n onFieldSelect={handleFieldSelect}\r\n selectedFieldId={selectedFieldId}\r\n editable={true}\r\n />\r\n </div>\r\n\r\n {/* Field list */}\r\n <div className=\"fields-list\">\r\n <h4>Fields on {activeSide} side:</h4>\r\n {template.fields\r\n .filter((f) => f.side === activeSide)\r\n .map((field) => (\r\n <div\r\n key={field.id}\r\n className={`field-item ${field.id === selectedFieldId ? 'selected' : ''}`}\r\n onClick={() => setSelectedFieldId(field.id)}\r\n >\r\n <span className=\"field-type-icon\">\r\n {defaultFieldTypes.find((t) => t.type === field.type)?.icon}\r\n </span>\r\n <span className=\"field-key\">{field.fieldKey}</span>\r\n <button\r\n className=\"delete-btn\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n removeField(field.id);\r\n if (field.id === selectedFieldId) setSelectedFieldId(null);\r\n }}\r\n >\r\n ×\r\n </button>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n {/* Right Sidebar - Field Properties */}\r\n <div className=\"designer-sidebar right-sidebar\">\r\n <h3>Field Properties</h3>\r\n {selectedField ? (\r\n <div className=\"field-properties\">\r\n <div className=\"property-group\">\r\n <label>Field Key</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.fieldKey}\r\n onChange={(e) => handleFieldPropertyUpdate('fieldKey', e.target.value)}\r\n />\r\n </div>\r\n\r\n {selectedField.type !== 'label' && (\r\n <div className=\"property-group\">\r\n <label>Label</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.label || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('label', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {/* Vertical Align for text fields */}\r\n {selectedField.type === 'text' && (\r\n <>\r\n <button className=\"btn btn-outline btn-sm\" style={{ marginBottom: 12 }} onClick={handleDuplicateField}>\r\n Duplicate Field\r\n </button>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Label Style</strong>\r\n\r\n <div className=\"property-group\">\r\n <label>Label Position</label>\r\n <select\r\n value={selectedField.style?.labelPosition || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"left\">Left (Side)</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Vertical Align</label>\r\n <select\r\n value={selectedField.style?.labelVerticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.labelFontSize || '0.75em'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Weight</label>\r\n <select\r\n value={selectedField.style?.labelFontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.labelColor || '#666666'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelColor', e.target.value)}\r\n />\r\n </div>\r\n </div>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Text Style</strong>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Vertical Align</label>\r\n <select\r\n value={selectedField.style?.verticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n </div>\r\n </>\r\n )}\r\n\r\n {selectedField.type === 'label' && (\r\n <div className=\"property-group\">\r\n <label>Static Text</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.staticText || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('staticText', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {selectedField.type === 'qrcode' && (\r\n <div className=\"property-group\">\r\n <label>QR Code Data Fields</label>\r\n <small className=\"hint\">Select which fields to encode in the QR code:</small>\r\n <div style={{ marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }}>\r\n {template.fields\r\n .filter(f => f.type !== 'qrcode' && f.type !== 'label')\r\n .map((field) => (\r\n <label key={field.fieldKey} style={{ display: 'block', marginBottom: '6px', cursor: 'pointer' }}>\r\n <input\r\n type=\"checkbox\"\r\n checked={selectedField.qrFields?.includes(field.fieldKey) || false}\r\n onChange={(e) => {\r\n const currentFields = selectedField.qrFields || [];\r\n const newFields = e.target.checked\r\n ? [...currentFields, field.fieldKey]\r\n : currentFields.filter(f => f !== field.fieldKey);\r\n handleFieldPropertyUpdate('qrFields', newFields);\r\n }}\r\n style={{ marginRight: '6px' }}\r\n />\r\n {field.label || field.fieldKey}\r\n </label>\r\n ))}\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Border Radius for image fields */}\r\n {selectedField.type === 'image' && (\r\n <div className=\"property-group\">\r\n <label>Border Radius</label>\r\n <input\r\n type=\"text\"\r\n placeholder=\"e.g. 50% or 8px\"\r\n value={selectedField.style?.borderRadius || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('style.borderRadius', e.target.value)}\r\n />\r\n <small className=\"hint\">Use <b>50%</b> for a circle, <b>8px</b> for rounded corners, etc.</small>\r\n </div>\r\n )}\r\n\r\n {/* Only show these style controls for non-text fields */}\r\n {selectedField.type !== 'text' && <>\r\n <h4>Style</h4>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n </>}\r\n <div className=\"property-group\">\r\n <label>Background Color</label>\r\n <div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>\r\n <input\r\n type=\"checkbox\"\r\n id=\"transparent-bg-checkbox\"\r\n checked={selectedField.style?.backgroundColor === 'transparent'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.checked ? 'transparent' : '#ffffff')}\r\n />\r\n <label htmlFor=\"transparent-bg-checkbox\" style={{ margin: 0, fontWeight: 400, fontSize: '0.95em' }}>Transparent</label>\r\n {selectedField.style?.backgroundColor !== 'transparent' && (\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.backgroundColor || '#ffffff'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.value)}\r\n />\r\n )}\r\n </div>\r\n </div>\r\n\r\n <div className=\"property-group\">\r\n <label>Side</label>\r\n <select\r\n value={selectedField.side}\r\n onChange={(e) =>\r\n handleFieldPropertyUpdate('side', e.target.value as 'front' | 'back')\r\n }\r\n >\r\n <option value=\"front\">Front</option>\r\n {template.sides === 'double' && <option value=\"back\">Back</option>}\r\n </select>\r\n </div>\r\n\r\n <button className=\"btn btn-danger\" onClick={handleDeleteField}>\r\n Delete Field\r\n </button>\r\n </div>\r\n ) : (\r\n <p className=\"no-selection\">Select a field to edit its properties</p>\r\n )}\r\n\r\n <h3>Sample Data</h3>\r\n <div className=\"sample-data\">\r\n <p className=\"hint\">Edit sample data to preview:</p>\r\n {Object.entries(sampleData).map(([key, value]) => (\r\n <div key={key} className=\"property-group\">\r\n <label>{key}</label>\r\n <input\r\n type=\"text\"\r\n value={String(value)}\r\n onChange={(e) =>\r\n setSampleData((prev) => ({ ...prev, [key]: e.target.value }))\r\n }\r\n />\r\n </div>\r\n ))}\r\n <button\r\n className=\"btn btn-outline btn-sm\"\r\n onClick={() =>\r\n setSampleData((prev) => ({ ...prev, [`custom_${Date.now()}`]: '' }))\r\n }\r\n >\r\n + Add Field\r\n </button>\r\n </div>\r\n\r\n {/* Validation errors */}\r\n {validationErrors.length > 0 && (\r\n <div className=\"validation-errors\">\r\n <h4>⚠️ Validation Issues</h4>\r\n <ul>\r\n {validationErrors.map((error, index) => (\r\n <li key={index}>{error}</li>\r\n ))}\r\n </ul>\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\n\r\n"],"names":["_jsxs","_jsx","_Fragment"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"IDCardDesigner.js","sources":["../../../src/components/IDCardDesigner.tsx"],"sourcesContent":["\r\nimport React, { useState, useCallback, useRef, useEffect } from 'react';\r\nimport type {\r\n IDCardDesignerProps,\r\n FieldMapping,\r\n FieldType,\r\n CardOrientation,\r\n CardSides,\r\n IDCardData,\r\n} from '../types';\r\nimport { useIDCardTemplate } from '../hooks/useIDCardTemplate';\r\nimport { deepCleanUndefined } from '../utils/deepCleanUndefined';\r\nimport { IDCardPreview } from './IDCardPreview';\r\nimport { generateId, imageFileToBase64 } from '../storage/templateStorage';\r\nimport './IDCardDesigner.css';\r\n\r\n// Available field types in the designer\r\nconst defaultFieldTypes: { type: FieldType; label: string; icon: string }[] = [\r\n { type: 'text', label: 'Text Field', icon: '📝' },\r\n { type: 'label', label: 'Static Label', icon: '🏷️' },\r\n { type: 'image', label: 'Image/Photo', icon: '🖼️' },\r\n { type: 'qrcode', label: 'QR Code', icon: '📱' },\r\n];\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop template builder\r\n * \r\n * Allows users to:\r\n * - Add and position fields on the card\r\n * - Upload background images\r\n * - Configure field styles (fonts, colors, etc.)\r\n * - Choose card orientation and sides\r\n * - Preview the card with sample data\r\n */\r\n\r\n/**\r\n * IDCardDesigner - Visual drag-and-drop ID card template builder\r\n */\r\nexport const IDCardDesigner: React.FC<IDCardDesignerProps> = ({\r\n initialTemplate,\r\n onSave,\r\n onCancel,\r\n className = '',\r\n style = {},\r\n}) => {\r\n const {\r\n template,\r\n updateField,\r\n addField,\r\n removeField,\r\n setBackground,\r\n setCardSize,\r\n setOrientation,\r\n setSides,\r\n isValid,\r\n validationErrors,\r\n } = useIDCardTemplate(initialTemplate);\r\n\r\n const [activeSide, setActiveSide] = useState<'front' | 'back'>('front');\r\n const [selectedFieldId, setSelectedFieldId] = useState<string | null>(null);\r\n const [lineHeightInputFocused, setLineHeightInputFocused] = useState(false);\r\n const [showGrid, setShowGrid] = useState(true);\r\n const [isDragging, setIsDragging] = useState(false);\r\n const [isResizing, setIsResizing] = useState(false);\r\n const [templateName, setTemplateName] = useState(template.name);\r\n\r\n const previewContainerRef = useRef<HTMLDivElement>(null);\r\n const dragStartRef = useRef({ x: 0, y: 0, fieldX: 0, fieldY: 0 });\r\n const resizeStartRef = useRef({\r\n x: 0,\r\n y: 0,\r\n width: 0,\r\n height: 0,\r\n fieldX: 0,\r\n fieldY: 0,\r\n handle: '',\r\n });\r\n\r\n // Sample data for preview\r\n const [sampleData, setSampleData] = useState<IDCardData>({\r\n name: 'John Doe',\r\n idno: 'ID12345',\r\n department: 'Computer Science',\r\n designation: 'Student',\r\n dob: '01-01-2000',\r\n bloodgroup: 'O+',\r\n phoneno: '9876543210',\r\n address: 'Sample Address',\r\n });\r\n\r\n // Get selected field\r\n const selectedField = template.fields.find((f) => f.id === selectedFieldId);\r\n\r\n // Handle field selection\r\n const handleFieldSelect = useCallback((field: FieldMapping | null) => {\r\n setSelectedFieldId(field?.id || null);\r\n }, []);\r\n\r\n // Duplicate selected text field\r\n const handleDuplicateField = useCallback(() => {\r\n if (!selectedField || selectedField.type !== 'text') return;\r\n const { id, fieldKey, position, ...rest } = selectedField;\r\n const newField = {\r\n ...rest,\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n position: {\r\n ...position,\r\n x: Math.min(position.x + 20, template.cardSize.width - position.width),\r\n y: Math.min(position.y + 20, template.cardSize.height - position.height),\r\n },\r\n };\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n }, [selectedField, addField, setSelectedFieldId, template.cardSize.width, template.cardSize.height]);\r\n // Handle adding new field\r\n const handleAddField = useCallback(\r\n (type: FieldType) => {\r\n const newField: FieldMapping = {\r\n id: generateId('field'),\r\n fieldKey: `field_${Date.now()}`,\r\n label: type === 'label' ? 'Label' : '',\r\n type,\r\n side: activeSide,\r\n position: { x: 50, y: 50, width: 100, height: 30 },\r\n style: {\r\n fontSize: type === 'label' ? '10px' : '12px',\r\n fontWeight: type === 'label' ? 'bold' : 'normal',\r\n color: '#000000',\r\n textAlign: 'left',\r\n backgroundColor: 'transparent',\r\n },\r\n zIndex: template.fields.length + 1,\r\n staticText: type === 'label' ? 'Static Label' : '',\r\n ...(type === 'qrcode' ? { qrFields: [] } : {}),\r\n };\r\n\r\n // Adjust default sizes based on type\r\n if (type === 'image') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 100 };\r\n } else if (type === 'qrcode') {\r\n newField.position = { x: 50, y: 50, width: 80, height: 80 };\r\n }\r\n\r\n addField(newField);\r\n setSelectedFieldId(newField.id);\r\n },\r\n [activeSide, addField, template.fields.length]\r\n );\r\n\r\n // Handle background upload\r\n const handleBackgroundUpload = useCallback(\r\n async (e: React.ChangeEvent<HTMLInputElement>) => {\r\n const file = e.target.files?.[0];\r\n if (!file) return;\r\n\r\n try {\r\n const base64 = await imageFileToBase64(file);\r\n setBackground(activeSide, base64);\r\n } catch (error) {\r\n console.error('Failed to load background:', error);\r\n }\r\n },\r\n [activeSide, setBackground]\r\n );\r\n\r\n // Handle orientation change\r\n const handleOrientationChange = useCallback(\r\n (orientation: CardOrientation) => {\r\n setOrientation(orientation);\r\n // Update card size based on orientation\r\n const baseWidth = 340;\r\n const baseHeight = 215;\r\n if (orientation === 'portrait') {\r\n setCardSize({ width: baseHeight, height: baseWidth, unit: 'px' });\r\n } else {\r\n setCardSize({ width: baseWidth, height: baseHeight, unit: 'px' });\r\n }\r\n },\r\n [setOrientation, setCardSize]\r\n );\r\n\r\n // Handle sides change\r\n const handleSidesChange = useCallback(\r\n (sides: CardSides) => {\r\n setSides(sides);\r\n if (sides === 'single' && activeSide === 'back') {\r\n setActiveSide('front');\r\n }\r\n },\r\n [setSides, activeSide]\r\n );\r\n\r\n // Drag and drop handling\r\n const handleMouseDown = useCallback(\r\n (e: React.MouseEvent) => {\r\n if (!selectedField || !previewContainerRef.current) return;\r\n\r\n const target = e.target as HTMLElement;\r\n\r\n // Check if clicking on resize handle\r\n if (target.classList.contains('resize-handle')) {\r\n const handle = target.dataset.handle || '';\r\n setIsResizing(true);\r\n resizeStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n width: selectedField.position.width,\r\n height: selectedField.position.height,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n handle,\r\n };\r\n return;\r\n }\r\n\r\n // Check if clicking on field (for dragging)\r\n if (target.closest('.preview-field')) {\r\n setIsDragging(true);\r\n dragStartRef.current = {\r\n x: e.clientX,\r\n y: e.clientY,\r\n fieldX: selectedField.position.x,\r\n fieldY: selectedField.position.y,\r\n };\r\n }\r\n },\r\n [selectedField]\r\n );\r\n\r\n // Handle mouse move for dragging/resizing\r\n useEffect(() => {\r\n const handleMouseMove = (e: MouseEvent) => {\r\n if (!selectedField) return;\r\n\r\n if (isDragging) {\r\n const deltaX = e.clientX - dragStartRef.current.x;\r\n const deltaY = e.clientY - dragStartRef.current.y;\r\n\r\n // Unified drag logic for all field types\r\n const newX = Math.max(0, Math.min(\r\n template.cardSize.width - selectedField.position.width,\r\n dragStartRef.current.fieldX + deltaX\r\n ));\r\n const newY = Math.max(0, Math.min(\r\n template.cardSize.height - selectedField.position.height,\r\n dragStartRef.current.fieldY + deltaY\r\n ));\r\n\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, x: newX, y: newY },\r\n });\r\n }\r\n\r\n if (isResizing) {\r\n const { handle, x, y, width, height, fieldX, fieldY } = resizeStartRef.current;\r\n const deltaX = e.clientX - x;\r\n const deltaY = e.clientY - y;\r\n\r\n let newWidth = width;\r\n let newHeight = height;\r\n let newX = fieldX;\r\n let newY = fieldY;\r\n\r\n // Enforce fixed aspect ratio for QR code fields\r\n if (selectedField.type === 'qrcode') {\r\n // Use the larger delta for both width and height\r\n let delta = 0;\r\n if (handle.includes('e') || handle.includes('w')) {\r\n delta = deltaX;\r\n } else if (handle.includes('s') || handle.includes('n')) {\r\n delta = deltaY;\r\n }\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + delta);\r\n newHeight = newWidth;\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - delta);\r\n newHeight = newWidth;\r\n newX = Math.max(0, fieldX + delta);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + delta);\r\n newWidth = newHeight;\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - delta);\r\n newWidth = newHeight;\r\n newY = Math.max(0, fieldY + delta);\r\n }\r\n } else {\r\n if (handle.includes('e')) {\r\n newWidth = Math.max(20, width + deltaX);\r\n }\r\n if (handle.includes('w')) {\r\n newWidth = Math.max(20, width - deltaX);\r\n newX = Math.max(0, fieldX + deltaX);\r\n }\r\n if (handle.includes('s')) {\r\n newHeight = Math.max(20, height + deltaY);\r\n }\r\n if (handle.includes('n')) {\r\n newHeight = Math.max(20, height - deltaY);\r\n newY = Math.max(0, fieldY + deltaY);\r\n }\r\n }\r\n\r\n updateField(selectedField.id, {\r\n position: { x: newX, y: newY, width: newWidth, height: newHeight },\r\n });\r\n }\r\n };\r\n\r\n const handleMouseUp = () => {\r\n setIsDragging(false);\r\n setIsResizing(false);\r\n // Remove any accidental selection or pointer capture\r\n window.getSelection?.()?.removeAllRanges?.();\r\n if (previewContainerRef.current) {\r\n previewContainerRef.current.releasePointerCapture?.(0);\r\n }\r\n };\r\n\r\n if (isDragging || isResizing) {\r\n document.addEventListener('mousemove', handleMouseMove);\r\n window.addEventListener('mouseup', handleMouseUp);\r\n }\r\n\r\n return () => {\r\n document.removeEventListener('mousemove', handleMouseMove);\r\n window.removeEventListener('mouseup', handleMouseUp);\r\n };\r\n }, [isDragging, isResizing, selectedField, updateField, template.cardSize]);\r\n\r\n // Handle field property update\r\n const handleFieldPropertyUpdate = useCallback(\r\n (property: string, value: unknown) => {\r\n if (!selectedField) return;\r\n\r\n if (property.startsWith('style.')) {\r\n const styleKey = property.replace('style.', '');\r\n updateField(selectedField.id, {\r\n style: { ...selectedField.style, [styleKey]: value },\r\n });\r\n } else if (property.startsWith('position.')) {\r\n const posKey = property.replace('position.', '') as keyof typeof selectedField.position;\r\n updateField(selectedField.id, {\r\n position: { ...selectedField.position, [posKey]: Number(value) },\r\n });\r\n } else {\r\n // Only allow qrFields property on QR code fields\r\n if (property === 'qrFields') {\r\n if (selectedField.type === 'qrcode') {\r\n updateField(selectedField.id, { qrFields: value as string[] });\r\n } else {\r\n // do nothing if not a qrcode field\r\n }\r\n } else {\r\n updateField(selectedField.id, { [property]: value });\r\n }\r\n }\r\n },\r\n [selectedField, updateField]\r\n );\r\n\r\n // Handle save\r\n const handleSave = useCallback(() => {\r\n const updatedTemplate = {\r\n ...template,\r\n name: templateName,\r\n updatedAt: new Date().toISOString(),\r\n };\r\n const cleanedTemplate = deepCleanUndefined(updatedTemplate);\r\n onSave(cleanedTemplate);\r\n }, [template, templateName, onSave]);\r\n\r\n // Handle delete field\r\n const handleDeleteField = useCallback(() => {\r\n if (selectedFieldId) {\r\n removeField(selectedFieldId);\r\n setSelectedFieldId(null);\r\n }\r\n }, [selectedFieldId, removeField]);\r\n\r\n // Keyboard shortcuts\r\n useEffect(() => {\r\n let lineHeightInputFocused = false;\r\n // Listen for focus/blur on line height input\r\n const lhInput = document.getElementById('line-height-input');\r\n if (lhInput) {\r\n lhInput.addEventListener('focus', () => { lineHeightInputFocused = true; });\r\n lhInput.addEventListener('blur', () => { lineHeightInputFocused = false; });\r\n }\r\n\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (selectedFieldId) {\r\n const field = template.fields.find(f => f.id === selectedFieldId);\r\n // Arrow key movement for position\r\n const step = e.shiftKey ? 5 : 1;\r\n let dx = 0, dy = 0;\r\n if (e.key === 'ArrowLeft') dx = -step;\r\n if (e.key === 'ArrowRight') dx = step;\r\n if (e.key === 'ArrowUp') dy = -step;\r\n if (e.key === 'ArrowDown') dy = step;\r\n if ((dx !== 0 || dy !== 0) && field) {\r\n // If text field and Ctrl is pressed, adjust line height instead\r\n if (field.type === 'text' && (e.ctrlKey || e.metaKey)) {\r\n let lh = field.style?.lineHeight ? Number(field.style.lineHeight) : 1;\r\n if (e.key === 'ArrowUp') lh = Math.round((lh + 0.1) * 10) / 10;\r\n if (e.key === 'ArrowDown') lh = Math.max(0.1, Math.round((lh - 0.1) * 10) / 10);\r\n updateField(field.id, {\r\n style: { ...field.style, lineHeight: lh.toString() },\r\n });\r\n e.preventDefault();\r\n return;\r\n } else {\r\n let newX = Math.max(0, Math.min(template.cardSize.width - field.position.width, field.position.x + dx));\r\n let newY = Math.max(0, Math.min(template.cardSize.height - field.position.height, field.position.y + dy));\r\n updateField(field.id, {\r\n position: { ...field.position, x: newX, y: newY },\r\n });\r\n e.preventDefault();\r\n return;\r\n }\r\n }\r\n // Delete and Escape\r\n if (e.key === 'Delete') {\r\n handleDeleteField();\r\n }\r\n if (e.key === 'Escape') {\r\n setSelectedFieldId(null);\r\n }\r\n }\r\n };\r\n\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => document.removeEventListener('keydown', handleKeyDown);\r\n }, [selectedFieldId, handleDeleteField, template.fields, template.cardSize, updateField]);\r\n\r\n return (\r\n <div className={`idcard-designer ${className}`} style={style}>\r\n {/* Header */}\r\n <div className=\"designer-header\">\r\n <input\r\n type=\"text\"\r\n value={templateName}\r\n onChange={(e) => setTemplateName(e.target.value)}\r\n className=\"template-name-input\"\r\n placeholder=\"Template Name\"\r\n />\r\n <div className=\"header-actions\">\r\n {onCancel && (\r\n <button onClick={onCancel} className=\"btn btn-secondary\">\r\n Cancel\r\n </button>\r\n )}\r\n <button onClick={handleSave} className=\"btn btn-primary\" disabled={!isValid}>\r\n Save Template\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"designer-body\">\r\n {/* Left Sidebar - Field Types */}\r\n <div className=\"designer-sidebar left-sidebar\">\r\n <h3>Add Fields</h3>\r\n <div className=\"field-types\">\r\n {defaultFieldTypes.map((fieldType) => (\r\n <button\r\n key={fieldType.type}\r\n onClick={() => handleAddField(fieldType.type)}\r\n className=\"field-type-btn\"\r\n >\r\n <span className=\"field-icon\">{fieldType.icon}</span>\r\n <span className=\"field-label\">{fieldType.label}</span>\r\n </button>\r\n ))}\r\n </div>\r\n\r\n <h3>Card Settings</h3>\r\n <div className=\"card-settings\">\r\n <div className=\"setting-group\">\r\n <label>Orientation</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.orientation === 'landscape' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('landscape')}\r\n >\r\n Landscape\r\n </button>\r\n <button\r\n className={`btn ${template.orientation === 'portrait' ? 'active' : ''}`}\r\n onClick={() => handleOrientationChange('portrait')}\r\n >\r\n Portrait\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Sides</label>\r\n <div className=\"btn-group\">\r\n <button\r\n className={`btn ${template.sides === 'single' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('single')}\r\n >\r\n Single\r\n </button>\r\n <button\r\n className={`btn ${template.sides === 'double' ? 'active' : ''}`}\r\n onClick={() => handleSidesChange('double')}\r\n >\r\n Double\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div className=\"setting-group\">\r\n <label>Card Size (px)</label>\r\n <div className=\"size-inputs\">\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.width}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, width: Number(e.target.value) })\r\n }\r\n placeholder=\"Width\"\r\n />\r\n <span>×</span>\r\n <input\r\n type=\"number\"\r\n value={template.cardSize.height}\r\n onChange={(e) =>\r\n setCardSize({ ...template.cardSize, height: Number(e.target.value) })\r\n }\r\n placeholder=\"Height\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <h3>Background</h3>\r\n <div className=\"background-upload\">\r\n <input\r\n type=\"file\"\r\n accept=\"image/*\"\r\n onChange={handleBackgroundUpload}\r\n id=\"bg-upload\"\r\n className=\"file-input\"\r\n />\r\n <label htmlFor=\"bg-upload\" className=\"btn btn-outline\">\r\n Upload {activeSide} Background\r\n </label>\r\n {template.backgrounds[activeSide] && (\r\n <button\r\n className=\"btn btn-danger btn-sm\"\r\n onClick={() => setBackground(activeSide, '')}\r\n >\r\n Remove\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Center - Preview */}\r\n <div className=\"designer-preview\">\r\n {/* Side tabs */}\r\n <div className=\"side-tabs\">\r\n <button\r\n className={`tab ${activeSide === 'front' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('front')}\r\n >\r\n Front\r\n </button>\r\n {template.sides === 'double' && (\r\n <button\r\n className={`tab ${activeSide === 'back' ? 'active' : ''}`}\r\n onClick={() => setActiveSide('back')}\r\n >\r\n Back\r\n </button>\r\n )}\r\n <label className=\"grid-toggle\">\r\n <input\r\n type=\"checkbox\"\r\n checked={showGrid}\r\n onChange={(e) => setShowGrid(e.target.checked)}\r\n />\r\n Show Grid\r\n </label>\r\n </div>\r\n\r\n {/* Preview container */}\r\n <div\r\n ref={previewContainerRef}\r\n className=\"preview-wrapper\"\r\n onMouseDown={handleMouseDown}\r\n >\r\n <IDCardPreview\r\n template={template}\r\n data={sampleData}\r\n side={activeSide}\r\n showGrid={showGrid}\r\n onFieldSelect={handleFieldSelect}\r\n selectedFieldId={selectedFieldId}\r\n editable={true}\r\n />\r\n </div>\r\n\r\n {/* Field list */}\r\n <div className=\"fields-list\">\r\n <h4>Fields on {activeSide} side:</h4>\r\n {template.fields\r\n .filter((f) => f.side === activeSide)\r\n .map((field) => (\r\n <div\r\n key={field.id}\r\n className={`field-item ${field.id === selectedFieldId ? 'selected' : ''}`}\r\n onClick={() => setSelectedFieldId(field.id)}\r\n >\r\n <span className=\"field-type-icon\">\r\n {defaultFieldTypes.find((t) => t.type === field.type)?.icon}\r\n </span>\r\n <span className=\"field-key\">{field.fieldKey}</span>\r\n <button\r\n className=\"delete-btn\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n removeField(field.id);\r\n if (field.id === selectedFieldId) setSelectedFieldId(null);\r\n }}\r\n >\r\n ×\r\n </button>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n {/* Right Sidebar - Field Properties */}\r\n <div className=\"designer-sidebar right-sidebar\">\r\n <h3>Field Properties</h3>\r\n {selectedField ? (\r\n <div className=\"field-properties\">\r\n <div className=\"property-group\">\r\n <label>Field Key</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.fieldKey}\r\n onChange={(e) => handleFieldPropertyUpdate('fieldKey', e.target.value)}\r\n />\r\n </div>\r\n\r\n {selectedField.type !== 'label' && (\r\n <div className=\"property-group\">\r\n <label>Label</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.label || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('label', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {/* Vertical Align for text fields */}\r\n {selectedField.type === 'text' && (\r\n <>\r\n <button className=\"btn btn-outline btn-sm\" style={{ marginBottom: 12 }} onClick={handleDuplicateField}>\r\n Duplicate Field\r\n </button>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Label Style</strong>\r\n\r\n <div className=\"property-group\">\r\n <label>Label Position</label>\r\n <select\r\n value={selectedField.style?.labelPosition || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelPosition', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"left\">Left (Side)</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Vertical Align</label>\r\n <select\r\n value={selectedField.style?.labelVerticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelVerticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.labelFontSize || '0.75em'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Font Weight</label>\r\n <select\r\n value={selectedField.style?.labelFontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelFontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Label Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.labelColor || '#666666'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.labelColor', e.target.value)}\r\n />\r\n </div>\r\n </div>\r\n <div style={{ border: '1px solid #eee', borderRadius: 4, marginBottom: 12, padding: 8 }}>\r\n <strong style={{ fontSize: '1em', display: 'block', marginBottom: 6 }}>Text Style</strong>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Line Height</label>\r\n <input\r\n id=\"line-height-input\"\r\n type=\"number\"\r\n min={0.1}\r\n step={0.1}\r\n value={selectedField.style?.lineHeight ? Number(selectedField.style.lineHeight) : 1}\r\n onChange={(e) => handleFieldPropertyUpdate('style.lineHeight', e.target.value)}\r\n style={{ width: 80 }}\r\n onFocus={() => setLineHeightInputFocused(true)}\r\n onBlur={() => setLineHeightInputFocused(false)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Vertical Align</label>\r\n <select\r\n value={selectedField.style?.verticalAlign || 'top'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.verticalAlign', e.target.value)}\r\n >\r\n <option value=\"top\">Top</option>\r\n <option value=\"middle\">Middle</option>\r\n <option value=\"bottom\">Bottom</option>\r\n </select>\r\n </div>\r\n </div>\r\n </>\r\n )}\r\n\r\n {selectedField.type === 'label' && (\r\n <div className=\"property-group\">\r\n <label>Static Text</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.staticText || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('staticText', e.target.value)}\r\n />\r\n </div>\r\n )}\r\n\r\n {selectedField.type === 'qrcode' && (\r\n <div className=\"property-group\">\r\n <label>QR Code Data Fields</label>\r\n <small className=\"hint\">Select which fields to encode in the QR code:</small>\r\n <div style={{ marginTop: '8px', maxHeight: '150px', overflowY: 'auto', border: '1px solid #ddd', borderRadius: '4px', padding: '8px' }}>\r\n {template.fields\r\n .filter(f => f.type !== 'qrcode' && f.type !== 'label')\r\n .map((field) => (\r\n <label key={field.fieldKey} style={{ display: 'block', marginBottom: '6px', cursor: 'pointer' }}>\r\n <input\r\n type=\"checkbox\"\r\n checked={selectedField.qrFields?.includes(field.fieldKey) || false}\r\n onChange={(e) => {\r\n const currentFields = selectedField.qrFields || [];\r\n const newFields = e.target.checked\r\n ? [...currentFields, field.fieldKey]\r\n : currentFields.filter(f => f !== field.fieldKey);\r\n handleFieldPropertyUpdate('qrFields', newFields);\r\n }}\r\n style={{ marginRight: '6px' }}\r\n />\r\n {field.label || field.fieldKey}\r\n </label>\r\n ))}\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Border Radius for image fields */}\r\n {selectedField.type === 'image' && (\r\n <div className=\"property-group\">\r\n <label>Border Radius</label>\r\n <input\r\n type=\"text\"\r\n placeholder=\"e.g. 50% or 8px\"\r\n value={selectedField.style?.borderRadius || ''}\r\n onChange={(e) => handleFieldPropertyUpdate('style.borderRadius', e.target.value)}\r\n />\r\n <small className=\"hint\">Use <b>50%</b> for a circle, <b>8px</b> for rounded corners, etc.</small>\r\n </div>\r\n )}\r\n\r\n {/* Only show these style controls for non-text fields */}\r\n {selectedField.type !== 'text' && <>\r\n <h4>Style</h4>\r\n <div className=\"property-group\">\r\n <label>Font Size</label>\r\n <input\r\n type=\"text\"\r\n value={selectedField.style?.fontSize || '12px'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontSize', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Font Weight</label>\r\n <select\r\n value={selectedField.style?.fontWeight || 'normal'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.fontWeight', e.target.value)}\r\n >\r\n <option value=\"normal\">Normal</option>\r\n <option value=\"bold\">Bold</option>\r\n <option value=\"100\">100</option>\r\n <option value=\"200\">200</option>\r\n <option value=\"300\">300</option>\r\n <option value=\"400\">400</option>\r\n <option value=\"500\">500</option>\r\n <option value=\"600\">600</option>\r\n <option value=\"700\">700</option>\r\n <option value=\"800\">800</option>\r\n <option value=\"900\">900</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Color</label>\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.color || '#000000'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.color', e.target.value)}\r\n />\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Align</label>\r\n <select\r\n value={selectedField.style?.textAlign || 'left'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textAlign', e.target.value)}\r\n >\r\n <option value=\"left\">Left</option>\r\n <option value=\"center\">Center</option>\r\n <option value=\"right\">Right</option>\r\n </select>\r\n </div>\r\n <div className=\"property-group\">\r\n <label>Text Transform</label>\r\n <select\r\n value={selectedField.style?.textTransform || 'none'}\r\n onChange={(e) => handleFieldPropertyUpdate('style.textTransform', e.target.value)}\r\n >\r\n <option value=\"none\">None</option>\r\n <option value=\"uppercase\">UPPERCASE</option>\r\n <option value=\"lowercase\">lowercase</option>\r\n <option value=\"capitalize\">Capitalize</option>\r\n </select>\r\n </div>\r\n </>}\r\n <div className=\"property-group\">\r\n <label>Background Color</label>\r\n <div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>\r\n <input\r\n type=\"checkbox\"\r\n id=\"transparent-bg-checkbox\"\r\n checked={selectedField.style?.backgroundColor === 'transparent'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.checked ? 'transparent' : '#ffffff')}\r\n />\r\n <label htmlFor=\"transparent-bg-checkbox\" style={{ margin: 0, fontWeight: 400, fontSize: '0.95em' }}>Transparent</label>\r\n {selectedField.style?.backgroundColor !== 'transparent' && (\r\n <input\r\n type=\"color\"\r\n value={selectedField.style?.backgroundColor || '#ffffff'}\r\n onChange={e => handleFieldPropertyUpdate('style.backgroundColor', e.target.value)}\r\n />\r\n )}\r\n </div>\r\n </div>\r\n\r\n <div className=\"property-group\">\r\n <label>Side</label>\r\n <select\r\n value={selectedField.side}\r\n onChange={(e) =>\r\n handleFieldPropertyUpdate('side', e.target.value as 'front' | 'back')\r\n }\r\n >\r\n <option value=\"front\">Front</option>\r\n {template.sides === 'double' && <option value=\"back\">Back</option>}\r\n </select>\r\n </div>\r\n\r\n <button className=\"btn btn-danger\" onClick={handleDeleteField}>\r\n Delete Field\r\n </button>\r\n </div>\r\n ) : (\r\n <p className=\"no-selection\">Select a field to edit its properties</p>\r\n )}\r\n\r\n <h3>Sample Data</h3>\r\n <div className=\"sample-data\">\r\n <p className=\"hint\">Edit sample data to preview:</p>\r\n {Object.entries(sampleData).map(([key, value]) => (\r\n <div key={key} className=\"property-group\">\r\n <label>{key}</label>\r\n <input\r\n type=\"text\"\r\n value={String(value)}\r\n onChange={(e) =>\r\n setSampleData((prev) => ({ ...prev, [key]: e.target.value }))\r\n }\r\n />\r\n </div>\r\n ))}\r\n <button\r\n className=\"btn btn-outline btn-sm\"\r\n onClick={() =>\r\n setSampleData((prev) => ({ ...prev, [`custom_${Date.now()}`]: '' }))\r\n }\r\n >\r\n + Add Field\r\n </button>\r\n </div>\r\n\r\n {/* Validation errors */}\r\n {validationErrors.length > 0 && (\r\n <div className=\"validation-errors\">\r\n <h4>⚠️ Validation Issues</h4>\r\n <ul>\r\n {validationErrors.map((error, index) => (\r\n <li key={index}>{error}</li>\r\n ))}\r\n </ul>\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\n\r\n"],"names":["_jsxs","_jsx","_Fragment"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-id-card-generator",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.10",
|
|
4
4
|
"description": "A flexible React library for designing, configuring, and generating ID cards with drag-and-drop field positioning",
|
|
5
5
|
"main": "dist/cjs/index.js",
|
|
6
6
|
"type": "module",
|