Skip to content

Commit 1836d22

Browse files
committed
Merge branch 'feat/ascii-drawer-enh' into chore/all-my-stuffs
2 parents 76f03ff + a8da319 commit 1836d22

File tree

2 files changed

+72
-4
lines changed

2 files changed

+72
-4
lines changed

src/tools/ascii-text-drawer/ascii-text-drawer.vue

Lines changed: 17 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,10 @@
11
<script setup lang="ts">
22
import figlet from 'figlet';
33
import TextareaCopyable from '@/components/TextareaCopyable.vue';
4+
import { languages, translateToLanguage } from '@/utils/ascii-lang-utils';
45
56
const input = ref('Ascii ART');
7+
const language = useStorage('ascii-text-drawer:language', 'raw');
68
const font = useStorage('ascii-text-drawer:font', 'Standard');
79
const width = useStorage('ascii-text-drawer:width', 80);
810
const output = ref('');
@@ -11,16 +13,24 @@ const processing = ref(false);
1113
1214
figlet.defaults({ fontPath: '//unpkg.com/[email protected]/fonts/' });
1315
16+
const languagesOptions = languages.map(lang => ({ value: lang.id, label: lang.name }));
17+
18+
figlet.defaults({ fontPath: '//unpkg.com/[email protected]/fonts/' });
19+
1420
watchEffect(async () => {
21+
const inputValue = input.value;
22+
const languageValue = language.value;
23+
const fontValue = font.value;
24+
const widthValue = width.value;
1525
processing.value = true;
1626
try {
1727
const options: figlet.Options = {
18-
font: font.value as figlet.Fonts,
19-
width: width.value,
28+
font: fontValue as figlet.Fonts,
29+
width: widthValue,
2030
whitespaceBreak: true,
2131
};
22-
output.value = await (new Promise<string>((resolve, reject) =>
23-
figlet.text(input.value, options,
32+
const rawOutput = await (new Promise<string>((resolve, reject) =>
33+
figlet.text(inputValue, options,
2434
(err, text) => {
2535
if (err) {
2636
reject(err);
@@ -29,6 +39,8 @@ watchEffect(async () => {
2939
3040
resolve(text ?? '');
3141
})));
42+
43+
output.value = translateToLanguage(rawOutput, languageValue);
3244
errored.value = false;
3345
}
3446
catch (e: any) {
@@ -50,6 +62,7 @@ const fonts = ['1Row', '3-D', '3D Diagonal', '3D-ASCII', '3x5', '4Max', '5 Line
5062
multiline
5163
rows="4"
5264
/>
65+
<c-select v-model:value="language" :options="languagesOptions" searchable mt-3 />
5366

5467
<n-divider />
5568

src/utils/ascii-lang-utils.ts

Lines changed: 55 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
function escapeXml(unsafe: string) {
2+
return unsafe.replace(/[<>&'"]/g, (c: string | undefined) => {
3+
switch (c) {
4+
case '<': return '&lt;';
5+
case '>': return '&gt;';
6+
case '&': return '&amp;';
7+
case '\'': return '&apos;';
8+
case '"': return '&quot;';
9+
}
10+
return '';
11+
});
12+
}
13+
14+
const dontEscape = '';
15+
const escapeBackslash = '\\\\';
16+
const escapeSingleQuote = '\'';
17+
const escapeDoubleQuote = '"';
18+
const defaultEscape = escapeBackslash + escapeSingleQuote + escapeDoubleQuote;
19+
export const languages = [
20+
{ id: 'raw', name: 'Raw Text', prefix: '', suffix: '', begin: '', end: '', escape: dontEscape },
21+
{ id: 'bash', name: 'Bash', prefix: 'echo "', suffix: '"', begin: '', end: '', escape: escapeBackslash + escapeDoubleQuote },
22+
{ id: 'pwsh', name: 'PowerShell', prefix: 'Write-Output \'', suffix: '\'', begin: '', end: '', escape: escapeBackslash + escapeSingleQuote },
23+
{ id: 'c', name: 'C', prefix: 'printf("', suffix: '\\n");', begin: '#include <stdio.h>\n', end: '', escape: defaultEscape },
24+
{ id: 'cpp', name: 'C++', prefix: 'std::cout << "', suffix: '\\n";', begin: '#include <iostream>\n', end: '', escape: defaultEscape },
25+
{ id: 'csharp', name: 'C#', prefix: 'Console.WriteLine(@"', suffix: '");', begin: 'using System;\n', end: '', escape: escapeDoubleQuote },
26+
{ id: 'vbnet', name: 'VB.Net', prefix: 'Console.WriteLine("', suffix: '")', begin: '', end: '', escape: (l: string) => l.replace('"', '""') },
27+
{ id: 'node', name: 'Node.js', prefix: 'console.log("', suffix: '");', begin: '', end: '', escape: defaultEscape },
28+
{ id: 'python', name: 'Python', prefix: 'print("', suffix: '")', begin: '', end: '', escape: escapeBackslash + escapeDoubleQuote },
29+
{ id: 'html', name: 'HTML', prefix: '', suffix: '', begin: '<pre>\n', end: '\n</pre>', escape: (l: string) => escapeXml(l) },
30+
{ id: 'rust', name: 'Rust', prefix: 'println!("', suffix: '");', begin: '', end: '', escape: defaultEscape },
31+
{ id: 'go', name: 'Go', prefix: 'fmt.Println("', suffix: '")', begin: 'import "fmt"\n', end: '', escape: defaultEscape },
32+
{ id: 'ruby', name: 'Ruby', prefix: 'puts "', suffix: '"', begin: '', end: '', escape: defaultEscape },
33+
{ id: 'php', name: 'PHP', prefix: 'echo "', suffix: '\\n";', begin: '<?php\n', end: '\n?>', escape: defaultEscape },
34+
{ id: 'swift', name: 'Swift', prefix: 'print("', suffix: '")', begin: '', end: '', escape: defaultEscape },
35+
{ id: 'kotlin', name: 'Kotlin', prefix: 'println("', suffix: '")', begin: '', end: '', escape: defaultEscape },
36+
{ id: 'sql', name: 'SQL', prefix: 'SELECT \'', suffix: '\\n\'', begin: '', end: '', escape: (l: string) => l.replace('\'', '\'\'') },
37+
{ id: 'java', name: 'Java', prefix: 'System.out.println("', suffix: '");', begin: '', end: '', escape: defaultEscape },
38+
];
39+
export function translateToLanguage(asciiArt: string, languageId: string) {
40+
const langConfig = languages.find(l => l.id === languageId);
41+
if (!langConfig) {
42+
return asciiArt;
43+
}
44+
45+
const escape = typeof langConfig.escape === 'function'
46+
? langConfig.escape
47+
: function (line: string) {
48+
return langConfig.escape
49+
? line.replace(new RegExp(`([${langConfig.escape}])`, 'g'), '\\$1')
50+
: line;
51+
};
52+
return langConfig.begin + asciiArt.split('\n').map((line) => {
53+
return langConfig.prefix + escape(line) + langConfig.suffix;
54+
}).join('\n') + langConfig.end;
55+
}

0 commit comments

Comments
 (0)