File size: 13,619 Bytes
4bbdde2
f8c4765
4bbdde2
f8c4765
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4bbdde2
 
f8c4765
 
 
 
 
 
4bbdde2
f8c4765
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
39aba1c
f8c4765
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
0c2bbca
 
 
f8c4765
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
0c2bbca
f8c4765
 
 
 
 
 
 
 
 
 
 
0c2bbca
f8c4765
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<meta name="viewport" content="width=device-width, initial-scale=1.0">
		<title>Katty's Bot Helper</title>
		<style>
			body {
				font-family: 'Arial', sans-serif;
				background-color: #333;
				background-image: url('https://files.catbox.moe/qoycoe.png');
				background-size: cover;
				background-repeat: no-repeat;
				color: #fff;
				margin: 0;
				padding: 0;
			}

			.container {
				max-width: 600px;
				margin: 20px auto;
				background-color: #222;
				padding: 20px;
				border-radius: 10px;
				box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
			}

			label {
				display: block;
				margin-bottom: 8px;
			}

			input {
				width: 100%;
				padding: 8px;
				margin-bottom: 16px;
				box-sizing: border-box;
			}

			textarea {
				width: 100%;
				height: 100px;
				padding: 8px;
				margin-bottom: 16px;
				resize: none;
				box-sizing: border-box;
			}

			select {
				width: 100%;
				padding: 8px;
				margin-bottom: 16px;
				box-sizing: border-box;
			}

			button {
				background-color: #4CAF50;
				color: #fff;
				padding: 10px 15px;
				border: none;
				border-radius: 5px;
				cursor: pointer;
			}

			button:hover {
				background-color: #45a049;
			}

			/* Dark mode styles */
			body.dark-mode {
				background-color: #111;
				color: #ddd;
			}

			.container.dark-mode {
				background-color: #111;
				box-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
			}

			#outputBox {
				margin-top: 20px;
				padding: 10px;
				background-color: #444;
				border-radius: 5px;
				overflow: hidden;
				max-width: 600px;
				outline: 2px solid #7D12FF;
			}

			#generatedTemplate {
				word-wrap: break-word;
				white-space: pre-wrap;
			}
			
			#titleSection {
				text-align: center;
				margin-bottom: 20px;
			}

			#titleSection h2 {
				display: flex;
				align-items: center;
				justify-content: center;
				margin-bottom: 10px;
			}

			#titleSection img {
				width: 40px;
				height: 40px;
				margin-right: 10px;
				border-radius: 50%;
			}
			
			#logo a {
				color: #FF69B4 !important;
				text-decoration: none;
			}	

			.macro-button {
            	background-color: transparent;
            	color: #4CAF50;
            	border: none;
            	cursor: pointer;
            	outline: none; 
				font-weight: bold;
        	}

        	.macro-button:hover {
            	text-decoration: underline;
        	}

			.button-area {
            text-align: center;
            margin: 3px 0;
        }
		</style>
	</head>
	<body>
		<div id="titleSection">
			<h2>
				<img src="https://files.catbox.moe/wj5mmj.png" alt="Katty's Bot Helper Logo">
				Katty's Bot Helper
			</h2>
			<a id="logo" href="https://venus.chub.ai/users/KattyyKitty" target="_blank">KattyyKitty's Chub Profile ❤️</a>
		</div>

        <div style="padding: 5px; text-align: center; position: fixed; right: 0; bottom: 0; background-color: #333;">
			Copy Macros:
				  <button class="macro-button" onclick="copyToClipboard('{{char}}')">{{char}}</button>
				  <button class="macro-button" onclick="copyToClipboard('{{user}}')">{{user}}</button>
			  </div>
		
		<form id="botForm" class="container">
			<label for="charName">Character Name</label>
			<input type="text" id="charName" placeholder="Character Name" required>

			<label for="nationalityRaceToggle">Nationality/Race Toggle</label>
			<select id="nationalityRaceToggle" onchange="toggleField()">
				<option value="nationality">Nationality</option>
				<option value="race">Race (Fantasy)</option>
			</select>

			<label for="nationalityRace">Nationality/Race</label>
			<input type="text" id="nationalityRace" placeholder="Self Explanatory" required>

			<label for="characterClass">Character Class</label>
			<input type="text" id="characterClass" placeholder="Wizard, Warrior, etc." required>

			<label for="height">Height</label>
			<input type="text" id="height" placeholder="Height" required>

			<label for="age">Age</label>
			<input type="text" id="age" placeholder="Age" required>
			
			<label for="gender">Gender</label>
			<input type="text" id="gender" placeholder="Gender" required>
			
			<label for="appearance">Appearance</label>
			<input type="text" id="appearance" placeholder="Appearance formatted as: trait1 + trait2 etc" required>
			
			<div id="outfitSection">
				<label for="outfit">Outfit</label>
				<textarea id="outfit" placeholder="Give a general description of your character's outfit (ex. {{char}} generally wears dark clothing and a leather jacket)" required></textarea>
			</div>
			
			<div id="genitalsSection">
				<label for="genitals">Genitals Description</label>
				<textarea id="genitals" placeholder="Give a detailed description of the character's genitals. Be as descriptive as you'd like." required></textarea>
			</div>

			<label for="kinks">Kinks/Fetishes</label>
			<input type="text" id="kinks" placeholder="formatted as: kink1, kink2, etc"
			
			<label for="likes">Likes</label>
			<input type="text" id="likes" placeholder="Likes formatted as: like1, like2, etc" required>

			<label for="dislikes">Dislikes</label>
			<input type="text" id="dislikes" placeholder="Dislikes formatted as: dislike1, dislike2, etc" required>

			<label for="hobbies">Hobbies</label>
			<input type="text" id="hobbies" placeholder="List the character's hobbies; i.e. Baseball."
			
			<label for="occupation">Occupation</label>
			<input type="text" id="occupation" placeholder="Bot Occupation" required>
			
			<label for="personality1">Personality 1</label>
			<textarea id="personality1" placeholder="Personality Traits formatted as: trait1, trait2, etc" required></textarea>

			<label for="personality">Personality</label>
			<textarea id="personality" placeholder="Here you place all the bot’s personality in detail, be sure to be precise." required></textarea>

			<label for="skillsPowersToggle">Skills/Powers Toggle</label>
			<select id="skillsPowersToggle" onchange="toggleField()">
				<option value="Skills/Abilities">Skills/Abilities</option>
				<option value="Powers/Abilities">Powers/Abilities (Fantasy)</option>
			</select>

			<label for="skillsPowers">Powers/Abilities</label>
			<textarea id="skillsPowers" placeholder="List any powers, skills or abilities your bot has." required></textarea>

			<div id="dialogueStyleSection">
				<label for="dialogueStyle">Dialogue Style</label>
				<textarea id="dialogueStyle" placeholder="Decribe how your character talks and acts. Example: Slightly raspy voice, sarcastic tone laden with innuendo; speaks her mind without fear of consequence." required></textarea>
			</div>

			<div id="backgroundSection">
				<label for="background">Background</label>
				<textarea id="background" placeholder="Here you place all the important information about the bot, it has to be very descriptive and make sure to use {{char}} when referring to the bot, that way the bot will recognize its own information better." required></textarea>
			</div>

			<div id="rpSetupSection">
				<label for="rpSetup">RP Setup</label>
				<textarea id="rpSetup" placeholder="Here you place the information that you think is necessary for the development during the roleplay."></textarea>
			</div>

			<div id="motivationSection">
				<label for="motivation">Motivation</label>
				<textarea id="motivation" placeholder="Decribe your character's motivations." required></textarea>
			</div>			
			
			<div id="relationshipsSection">
				<label for="relationships">Relationships</label>
				<textarea id="relationships" placeholder="Describe your character's relationship types or specific relationship to {{user}}." required></textarea>
			</div>

			<label for="miscShit">Misc Stuff</label>
			<textarea id="miscShit" placeholder="You can put any misc stuff you want the AI to know in this box." required></textarea>

			<button type="button" onclick="generateTemplate()">Generate Template</button>
		</form>

		<div id="outputBox" class="container">
			<h3>Generated Template:</h3>
			<pre id="generatedTemplate"></pre>
			<button class="macro-button" onclick="copyGeneratedTemplate()">Copy Template⎘</button>
		</div>

		<div id="creditSection">
			<p>Background Image: <a href="https://wall.alphacoders.com/big.php?i=1338084" target="_blank">https://wall.alphacoders.com/big.php?i=1338084</a></p>
		</div>

		<script>
			function toggleNationalityRaceField() {
				const toggleValue = document.getElementById('nationalityRaceToggle').value;
				const label = toggleValue === 'nationality' ? 'Nationality' : 'Race';
				document.getElementById('nationalityRace').placeholder = `${label} - Self Explanatory`;
			}

			function toggleSkillsPowersField() {
    			const toggleValue = document.getElementById('skillsPowersToggle').value;
    			const label = toggleValue === 'Skills/Abilities' ? 'Skills' : 'Powers';
    			document.getElementById('skillsPowers').placeholder = `${label} - List any ${label.toLowerCase()}, ${label.toLowerCase()}, etc.`;
			}
		
			function toggleCharacterClass() {
				const characterClassToggle = document.getElementById('characterClassToggle');
				const characterClass = document.getElementById('characterClass');
		
				characterClassToggle.checked ? characterClass.removeAttribute('readonly') : characterClass.setAttribute('readonly', 'true');
			}
		
			function copyToClipboard(text) {
				const dummy = document.createElement("textarea");
				document.body.appendChild(dummy);
				dummy.value = text;
				dummy.select();
				document.execCommand("copy");
				document.body.removeChild(dummy);
			}

			function copyGeneratedTemplate() {
    			var generatedTemplate = document.getElementById('generatedTemplate');
    			var range = document.createRange();
    			range.selectNode(generatedTemplate);
   				window.getSelection().removeAllRanges(); // Clear previous selection
    			window.getSelection().addRange(range);

   			try {
       		document.execCommand('copy');
        	window.getSelection().removeAllRanges();

    		} catch (err) {
        	console.error('Unable to copy template: ', err);
			}
			}


		
			function generateTemplate() {
				var charName = document.getElementById('charName').value;
				var toggleNationalityRaceValue = document.getElementById('nationalityRaceToggle').value;
				var nationalityRace = document.getElementById('nationalityRace').value;
				var characterClass = document.getElementById('characterClass').value;
				var height = document.getElementById('height').value;
				var age = document.getElementById('age').value;
				var gender = document.getElementById('gender').value;
				var likes = document.getElementById('likes').value;
				var dislikes = document.getElementById('dislikes').value;
				var appearance = document.getElementById('appearance').value;
				var outfit = document.getElementById('outfit').value;
				var personality1 = document.getElementById('personality1').value;
				var personality = document.getElementById('personality').value;
				var occupation = document.getElementById('occupation').value;
				var genitals = document.getElementById('genitals').value;
				var kinks = document.getElementById('kinks').value;
				var background = document.getElementById('background').value;
				var rpSetup = document.getElementById('rpSetup').value;
				var miscShit = document.getElementById('miscShit').value;
				var toggleSkillsPowersValue = document.getElementById('skillsPowersToggle').value;
				var skillsPowers = document.getElementById('skillsPowers').value;
				var dialogueStyle = document.getElementById('dialogueStyle').value;
				var motivation = document.getElementById('motivation').value;
				var relationships = document.getElementById('relationships').value
				var hobbies = document.getElementById('hobbies').value
		
				var builder = [];
		
				if (charName) builder.push(`name: ${charName}`);
				if (nationalityRace) builder.push(`${toggleNationalityRaceValue}: ${nationalityRace}`);
				if (characterClass) builder.push(`character class: ${characterClass}`);
				if (height) builder.push(`height: ${height}`);
				if (age) builder.push(`age: ${age}`);
				if (gender) builder.push(`gender: ${gender}`);
				if (likes) builder.push(`likes: ${likes}`);
				if (dislikes) builder.push(`dislikes: ${dislikes}`);
				if (hobbies) builder.push(`hobbies: ${hobbies}`);
				if (appearance) builder.push(`appearance: ${appearance}`);
				if (outfit) builder.push(`outfit: ${outfit}`);
				if (personality1) builder.push(`personality: ${personality1}`);
				if (occupation) builder.push(`occupation: ${occupation}`);
				if (genitals) builder.push(`genitals: ${genitals}`);
				if (kinks) builder.push(`kinks/fetishes: ${kinks}`);
				if (dialogueStyle) builder.push(`Dialogue Style: ${dialogueStyle}`);		
				if (background) builder.push(`Background: ${background}`);
				if (personality) builder.push(`Personality: ${personality}`);
				if (skillsPowers) builder.push(`${toggleSkillsPowersValue}: ${skillsPowers}`);
				if (rpSetup) builder.push(`RP Setup: ${rpSetup}`);
				if (motivation) builder.push(`Motivations: ${motivation}`);				
				if (relationships) builder.push(`Relationships: ${relationships}`);				
				if (miscShit) builder.push(`${miscShit}`);
		
				var template = builder.join("\n");
		
				// Display the generated template in the output box
				document.getElementById('generatedTemplate').textContent = template;
			}
		</script>
		  <!-- This message won't be visible on the page -->
  		  <!-- Feel free to use and change my code but if you distribute it elsewhere please credit me. This took a lot of hard work! -->

		</body>
		</html>