Spaces:
Running
Running
Update app.py
Browse files
app.py
CHANGED
|
@@ -547,7 +547,7 @@ HTML_TEMPLATE = '''
|
|
| 547 |
resize: none;
|
| 548 |
outline: none;
|
| 549 |
font-family: inherit;
|
| 550 |
-
font-size:
|
| 551 |
color: black;
|
| 552 |
text-align: center;
|
| 553 |
padding: 5px;
|
|
@@ -782,7 +782,7 @@ HTML_TEMPLATE = '''
|
|
| 782 |
</div>
|
| 783 |
<div class="property-group">
|
| 784 |
<label>๊ธ์ ํฌ๊ธฐ</label>
|
| 785 |
-
<input type="number" id="fontSizeInput" value="
|
| 786 |
</div>
|
| 787 |
<div class="property-group">
|
| 788 |
<label>๊ธ์ ๊ตต๊ธฐ</label>
|
|
@@ -856,6 +856,63 @@ HTML_TEMPLATE = '''
|
|
| 856 |
let selectedColor = 'black';
|
| 857 |
let uploadedImages = [];
|
| 858 |
let currentDragElement = null;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 859 |
|
| 860 |
// ์์ฐ์ค๋ฌ์ด ์ ๋ ฌ ํจ์
|
| 861 |
function naturalSort(a, b) {
|
|
@@ -955,7 +1012,7 @@ HTML_TEMPLATE = '''
|
|
| 955 |
});
|
| 956 |
}
|
| 957 |
|
| 958 |
-
// ์ปดํฌ๋ํธ ์ถ๊ฐ
|
| 959 |
function addComponent(type) {
|
| 960 |
const canvas = document.getElementById('canvas');
|
| 961 |
const component = document.createElement('div');
|
|
@@ -976,14 +1033,14 @@ HTML_TEMPLATE = '''
|
|
| 976 |
case 'speech':
|
| 977 |
innerContent = `
|
| 978 |
<div class="speech-bubble">
|
| 979 |
-
<textarea class="component-text" placeholder="๋์ฌ ์
๋ ฅ..."></textarea>
|
| 980 |
<div class="speech-bubble-tail"></div>
|
| 981 |
</div>`;
|
| 982 |
break;
|
| 983 |
case 'thought':
|
| 984 |
innerContent = `
|
| 985 |
<div class="thought-bubble">
|
| 986 |
-
<textarea class="component-text" placeholder="์๊ฐ ์
๋ ฅ..."></textarea>
|
| 987 |
<div class="thought-bubble-dots">
|
| 988 |
<div class="thought-dot large"></div>
|
| 989 |
<div class="thought-dot small"></div>
|
|
@@ -993,49 +1050,49 @@ HTML_TEMPLATE = '''
|
|
| 993 |
case 'shout':
|
| 994 |
innerContent = `
|
| 995 |
<div class="shout-bubble">
|
| 996 |
-
<textarea class="component-text" placeholder="์ธ์นจ!" style="font-weight: bold;"></textarea>
|
| 997 |
</div>`;
|
| 998 |
break;
|
| 999 |
case 'whisper':
|
| 1000 |
innerContent = `
|
| 1001 |
<div class="whisper-bubble">
|
| 1002 |
-
<textarea class="component-text" placeholder="์์ญ์..." style="font-style: italic;"></textarea>
|
| 1003 |
</div>`;
|
| 1004 |
break;
|
| 1005 |
case 'emotion':
|
| 1006 |
innerContent = `
|
| 1007 |
<div class="emotion-bubble">
|
| 1008 |
-
<textarea class="component-text" placeholder="โฅ โช โ
"></textarea>
|
| 1009 |
</div>`;
|
| 1010 |
break;
|
| 1011 |
case 'action':
|
| 1012 |
innerContent = `
|
| 1013 |
<div class="action-effect">
|
| 1014 |
-
<textarea class="component-text" placeholder="์ฟต!" style="font-size:
|
| 1015 |
</div>`;
|
| 1016 |
break;
|
| 1017 |
case 'narration':
|
| 1018 |
innerContent = `
|
| 1019 |
<div class="narration-box">
|
| 1020 |
-
<textarea class="component-text" placeholder="๋๋ ์ด์
..."></textarea>
|
| 1021 |
</div>`;
|
| 1022 |
break;
|
| 1023 |
case 'box':
|
| 1024 |
innerContent = `
|
| 1025 |
<div class="text-box">
|
| 1026 |
-
<textarea class="component-text" placeholder="ํ
์คํธ ์
๋ ฅ..."></textarea>
|
| 1027 |
</div>`;
|
| 1028 |
break;
|
| 1029 |
case 'transparent':
|
| 1030 |
innerContent = `
|
| 1031 |
<div class="transparent-box">
|
| 1032 |
-
<textarea class="component-text" placeholder="ํ
์คํธ ์
๋ ฅ..."></textarea>
|
| 1033 |
</div>`;
|
| 1034 |
break;
|
| 1035 |
case 'gradient':
|
| 1036 |
innerContent = `
|
| 1037 |
<div class="gradient-box">
|
| 1038 |
-
<textarea class="component-text" placeholder="ํน์ ํจ๊ณผ!"></textarea>
|
| 1039 |
</div>`;
|
| 1040 |
break;
|
| 1041 |
}
|
|
@@ -1084,13 +1141,13 @@ HTML_TEMPLATE = '''
|
|
| 1084 |
const textArea = component.querySelector('.component-text');
|
| 1085 |
if (textArea) {
|
| 1086 |
document.getElementById('textInput').value = textArea.value;
|
| 1087 |
-
document.getElementById('fontSizeInput').value = parseInt(textArea.style.fontSize) ||
|
| 1088 |
document.getElementById('fontSelect').value = textArea.style.fontFamily || "'Noto Sans KR'";
|
| 1089 |
document.getElementById('fontWeightSelect').value = textArea.style.fontWeight || '400';
|
| 1090 |
}
|
| 1091 |
}
|
| 1092 |
|
| 1093 |
-
// ๋๋๊ทธ ์์
|
| 1094 |
function startDrag(e) {
|
| 1095 |
if (e.target.classList.contains('resize-handle')) return;
|
| 1096 |
if (e.target.classList.contains('component-text')) return;
|
|
@@ -1116,7 +1173,7 @@ HTML_TEMPLATE = '''
|
|
| 1116 |
e.preventDefault();
|
| 1117 |
}
|
| 1118 |
|
| 1119 |
-
// ๋๋๊ทธ ์ค
|
| 1120 |
function drag(e) {
|
| 1121 |
if (!isDragging || !currentDragElement) return;
|
| 1122 |
|
|
@@ -1137,7 +1194,7 @@ HTML_TEMPLATE = '''
|
|
| 1137 |
e.preventDefault();
|
| 1138 |
}
|
| 1139 |
|
| 1140 |
-
// ๋๋๊ทธ ์ข
๋ฃ
|
| 1141 |
function stopDrag(e) {
|
| 1142 |
if (currentDragElement) {
|
| 1143 |
currentDragElement.classList.remove('dragging');
|
|
@@ -1297,7 +1354,7 @@ HTML_TEMPLATE = '''
|
|
| 1297 |
tempContainer.style.left = '-9999px';
|
| 1298 |
document.body.appendChild(tempContainer);
|
| 1299 |
|
| 1300 |
-
// html2canvas ์ต์
|
| 1301 |
html2canvas(tempContainer, {
|
| 1302 |
backgroundColor: '#ffffff',
|
| 1303 |
scale: 2,
|
|
|
|
| 547 |
resize: none;
|
| 548 |
outline: none;
|
| 549 |
font-family: inherit;
|
| 550 |
+
font-size: 22px;
|
| 551 |
color: black;
|
| 552 |
text-align: center;
|
| 553 |
padding: 5px;
|
|
|
|
| 782 |
</div>
|
| 783 |
<div class="property-group">
|
| 784 |
<label>๊ธ์ ํฌ๊ธฐ</label>
|
| 785 |
+
<input type="number" id="fontSizeInput" value="22" min="8" max="72" onchange="updateSelectedComponent()">
|
| 786 |
</div>
|
| 787 |
<div class="property-group">
|
| 788 |
<label>๊ธ์ ๊ตต๊ธฐ</label>
|
|
|
|
| 856 |
let selectedColor = 'black';
|
| 857 |
let uploadedImages = [];
|
| 858 |
let currentDragElement = null;
|
| 859 |
+
const DEFAULT_FONT_SIZE = 22; // ๊ธฐ๋ณธ ๊ธ์ ํฌ๊ธฐ ์์
|
| 860 |
+
|
| 861 |
+
// ํ์ด์ง ๋ก๋ ์ ๊ธฐ๋ณธ ์ด๋ฏธ์ง ๋ก๋
|
| 862 |
+
window.addEventListener('DOMContentLoaded', function() {
|
| 863 |
+
loadDefaultImage();
|
| 864 |
+
});
|
| 865 |
+
|
| 866 |
+
// ๊ธฐ๋ณธ ์ด๋ฏธ์ง ๋ก๋ ํจ์
|
| 867 |
+
function loadDefaultImage() {
|
| 868 |
+
const canvas = document.getElementById('canvas');
|
| 869 |
+
|
| 870 |
+
// ์ด๋ฏธ์ง ์ปจํ
์ด๋ ์์ฑ
|
| 871 |
+
const container = document.createElement('div');
|
| 872 |
+
container.className = 'image-container';
|
| 873 |
+
container.id = 'image-container-1';
|
| 874 |
+
|
| 875 |
+
// ๋ฒํธ ๋ผ๋ฒจ ์์ฑ
|
| 876 |
+
const numberLabel = document.createElement('div');
|
| 877 |
+
numberLabel.className = 'image-number';
|
| 878 |
+
numberLabel.textContent = '1';
|
| 879 |
+
|
| 880 |
+
// ์ด๋ฏธ์ง ์์ฑ
|
| 881 |
+
const img = document.createElement('img');
|
| 882 |
+
img.src = 'webtoon.png';
|
| 883 |
+
img.className = 'webtoon-image';
|
| 884 |
+
img.alt = 'webtoon.png';
|
| 885 |
+
img.id = 'webtoon-image-1';
|
| 886 |
+
|
| 887 |
+
// ์ด๋ฏธ์ง ๋ก๋ ์๋ฌ ์ฒ๋ฆฌ
|
| 888 |
+
img.onerror = function() {
|
| 889 |
+
console.error('๊ธฐ๋ณธ ์ด๋ฏธ์ง(webtoon.png)๋ฅผ ๋ถ๋ฌ์ฌ ์ ์์ต๋๋ค.');
|
| 890 |
+
// ์๋ฌ ์ ํ์ผ ๋ฆฌ์คํธ์ ๋ฉ์์ง ํ์
|
| 891 |
+
const fileList = document.getElementById('fileList');
|
| 892 |
+
fileList.innerHTML = '<p style="font-size: 12px; color: #ff6b6b;">โ ๏ธ webtoon.png ํ์ผ์ ์ฐพ์ ์ ์์ต๋๋ค.</p>';
|
| 893 |
+
};
|
| 894 |
+
|
| 895 |
+
// ์ด๋ฏธ์ง ๋ก๋ ์ฑ๊ณต ์
|
| 896 |
+
img.onload = function() {
|
| 897 |
+
// ํ์ผ ๋ฆฌ์คํธ ์
๋ฐ์ดํธ
|
| 898 |
+
const fileList = document.getElementById('fileList');
|
| 899 |
+
fileList.innerHTML = '<p style="font-size: 12px; color: #4a9eff; margin-bottom: 10px;">โ
๊ธฐ๋ณธ ์ด๋ฏธ์ง ๋ก๋๋จ</p><div class="file-list"><div class="file-item">1. webtoon.png (๊ธฐ๋ณธ)</div></div>';
|
| 900 |
+
|
| 901 |
+
// uploadedImages ๋ฐฐ์ด์ ์ถ๊ฐ
|
| 902 |
+
uploadedImages.push({
|
| 903 |
+
id: 1,
|
| 904 |
+
name: 'webtoon.png',
|
| 905 |
+
element: img
|
| 906 |
+
});
|
| 907 |
+
|
| 908 |
+
// ์ด๋ฏธ์ง ๊ฐ๊ฒฉ ์ ์ฉ
|
| 909 |
+
updateImageSpacing();
|
| 910 |
+
};
|
| 911 |
+
|
| 912 |
+
container.appendChild(numberLabel);
|
| 913 |
+
container.appendChild(img);
|
| 914 |
+
canvas.appendChild(container);
|
| 915 |
+
}
|
| 916 |
|
| 917 |
// ์์ฐ์ค๋ฌ์ด ์ ๋ ฌ ํจ์
|
| 918 |
function naturalSort(a, b) {
|
|
|
|
| 1012 |
});
|
| 1013 |
}
|
| 1014 |
|
| 1015 |
+
// ์ปดํฌ๋ํธ ์ถ๊ฐ (๊ธฐ๋ณธ ํฐํธ ํฌ๊ธฐ ์์ )
|
| 1016 |
function addComponent(type) {
|
| 1017 |
const canvas = document.getElementById('canvas');
|
| 1018 |
const component = document.createElement('div');
|
|
|
|
| 1033 |
case 'speech':
|
| 1034 |
innerContent = `
|
| 1035 |
<div class="speech-bubble">
|
| 1036 |
+
<textarea class="component-text" placeholder="๋์ฌ ์
๋ ฅ..." style="font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1037 |
<div class="speech-bubble-tail"></div>
|
| 1038 |
</div>`;
|
| 1039 |
break;
|
| 1040 |
case 'thought':
|
| 1041 |
innerContent = `
|
| 1042 |
<div class="thought-bubble">
|
| 1043 |
+
<textarea class="component-text" placeholder="์๊ฐ ์
๋ ฅ..." style="font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1044 |
<div class="thought-bubble-dots">
|
| 1045 |
<div class="thought-dot large"></div>
|
| 1046 |
<div class="thought-dot small"></div>
|
|
|
|
| 1050 |
case 'shout':
|
| 1051 |
innerContent = `
|
| 1052 |
<div class="shout-bubble">
|
| 1053 |
+
<textarea class="component-text" placeholder="์ธ์นจ!" style="font-weight: bold; font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1054 |
</div>`;
|
| 1055 |
break;
|
| 1056 |
case 'whisper':
|
| 1057 |
innerContent = `
|
| 1058 |
<div class="whisper-bubble">
|
| 1059 |
+
<textarea class="component-text" placeholder="์์ญ์..." style="font-style: italic; font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1060 |
</div>`;
|
| 1061 |
break;
|
| 1062 |
case 'emotion':
|
| 1063 |
innerContent = `
|
| 1064 |
<div class="emotion-bubble">
|
| 1065 |
+
<textarea class="component-text" placeholder="โฅ โช โ
" style="font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1066 |
</div>`;
|
| 1067 |
break;
|
| 1068 |
case 'action':
|
| 1069 |
innerContent = `
|
| 1070 |
<div class="action-effect">
|
| 1071 |
+
<textarea class="component-text" placeholder="์ฟต!" style="font-size: 28px; font-weight: bold;"></textarea>
|
| 1072 |
</div>`;
|
| 1073 |
break;
|
| 1074 |
case 'narration':
|
| 1075 |
innerContent = `
|
| 1076 |
<div class="narration-box">
|
| 1077 |
+
<textarea class="component-text" placeholder="๋๋ ์ด์
..." style="font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1078 |
</div>`;
|
| 1079 |
break;
|
| 1080 |
case 'box':
|
| 1081 |
innerContent = `
|
| 1082 |
<div class="text-box">
|
| 1083 |
+
<textarea class="component-text" placeholder="ํ
์คํธ ์
๋ ฅ..." style="font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1084 |
</div>`;
|
| 1085 |
break;
|
| 1086 |
case 'transparent':
|
| 1087 |
innerContent = `
|
| 1088 |
<div class="transparent-box">
|
| 1089 |
+
<textarea class="component-text" placeholder="ํ
์คํธ ์
๋ ฅ..." style="font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1090 |
</div>`;
|
| 1091 |
break;
|
| 1092 |
case 'gradient':
|
| 1093 |
innerContent = `
|
| 1094 |
<div class="gradient-box">
|
| 1095 |
+
<textarea class="component-text" placeholder="ํน์ ํจ๊ณผ!" style="font-size: ${DEFAULT_FONT_SIZE}px;"></textarea>
|
| 1096 |
</div>`;
|
| 1097 |
break;
|
| 1098 |
}
|
|
|
|
| 1141 |
const textArea = component.querySelector('.component-text');
|
| 1142 |
if (textArea) {
|
| 1143 |
document.getElementById('textInput').value = textArea.value;
|
| 1144 |
+
document.getElementById('fontSizeInput').value = parseInt(textArea.style.fontSize) || DEFAULT_FONT_SIZE;
|
| 1145 |
document.getElementById('fontSelect').value = textArea.style.fontFamily || "'Noto Sans KR'";
|
| 1146 |
document.getElementById('fontWeightSelect').value = textArea.style.fontWeight || '400';
|
| 1147 |
}
|
| 1148 |
}
|
| 1149 |
|
| 1150 |
+
// ๋๋๊ทธ ์์
|
| 1151 |
function startDrag(e) {
|
| 1152 |
if (e.target.classList.contains('resize-handle')) return;
|
| 1153 |
if (e.target.classList.contains('component-text')) return;
|
|
|
|
| 1173 |
e.preventDefault();
|
| 1174 |
}
|
| 1175 |
|
| 1176 |
+
// ๋๋๊ทธ ์ค
|
| 1177 |
function drag(e) {
|
| 1178 |
if (!isDragging || !currentDragElement) return;
|
| 1179 |
|
|
|
|
| 1194 |
e.preventDefault();
|
| 1195 |
}
|
| 1196 |
|
| 1197 |
+
// ๋๋๊ทธ ์ข
๋ฃ
|
| 1198 |
function stopDrag(e) {
|
| 1199 |
if (currentDragElement) {
|
| 1200 |
currentDragElement.classList.remove('dragging');
|
|
|
|
| 1354 |
tempContainer.style.left = '-9999px';
|
| 1355 |
document.body.appendChild(tempContainer);
|
| 1356 |
|
| 1357 |
+
// html2canvas ์ต์
|
| 1358 |
html2canvas(tempContainer, {
|
| 1359 |
backgroundColor: '#ffffff',
|
| 1360 |
scale: 2,
|