feat(ASCII Art Drawer): add coding languages support
Add support for outputing in many coding languages (Python , bash....) FIx other part of #934
This commit is contained in:
		
							parent
							
								
									2850dbd001
								
							
						
					
					
						commit
						093daa8fd2
					
				
							
								
								
									
										1
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -159,6 +159,7 @@ declare module '@vue/runtime-core' { | |||||||
|     RouterLink: typeof import('vue-router')['RouterLink'] |     RouterLink: typeof import('vue-router')['RouterLink'] | ||||||
|     RouterView: typeof import('vue-router')['RouterView'] |     RouterView: typeof import('vue-router')['RouterView'] | ||||||
|     RsaKeyPairGenerator: typeof import('./src/tools/rsa-key-pair-generator/rsa-key-pair-generator.vue')['default'] |     RsaKeyPairGenerator: typeof import('./src/tools/rsa-key-pair-generator/rsa-key-pair-generator.vue')['default'] | ||||||
|  |     SafelinkDecoder: typeof import('./src/tools/safelink-decoder/safelink-decoder.vue')['default'] | ||||||
|     SlugifyString: typeof import('./src/tools/slugify-string/slugify-string.vue')['default'] |     SlugifyString: typeof import('./src/tools/slugify-string/slugify-string.vue')['default'] | ||||||
|     SpanCopyable: typeof import('./src/components/SpanCopyable.vue')['default'] |     SpanCopyable: typeof import('./src/components/SpanCopyable.vue')['default'] | ||||||
|     SqlPrettify: typeof import('./src/tools/sql-prettify/sql-prettify.vue')['default'] |     SqlPrettify: typeof import('./src/tools/sql-prettify/sql-prettify.vue')['default'] | ||||||
|  | |||||||
| @ -1,8 +1,10 @@ | |||||||
| <script setup lang="ts"> | <script setup lang="ts"> | ||||||
| import figlet from 'figlet'; | import figlet from 'figlet'; | ||||||
| import TextareaCopyable from '@/components/TextareaCopyable.vue'; | import TextareaCopyable from '@/components/TextareaCopyable.vue'; | ||||||
|  | import { languages, translateToLanguage } from '@/utils/ascii-lang-utils'; | ||||||
| 
 | 
 | ||||||
| const input = ref('Ascii ART'); | const input = ref('Ascii ART'); | ||||||
|  | const language = useStorage('ascii-text-drawer:language', 'raw'); | ||||||
| const font = useStorage('ascii-text-drawer:font', 'Standard'); | const font = useStorage('ascii-text-drawer:font', 'Standard'); | ||||||
| const width = useStorage('ascii-text-drawer:width', 80); | const width = useStorage('ascii-text-drawer:width', 80); | ||||||
| const output = ref(''); | const output = ref(''); | ||||||
| @ -11,16 +13,24 @@ const processing = ref(false); | |||||||
| 
 | 
 | ||||||
| figlet.defaults({ fontPath: '//unpkg.com/figlet@1.6.0/fonts/' }); | figlet.defaults({ fontPath: '//unpkg.com/figlet@1.6.0/fonts/' }); | ||||||
| 
 | 
 | ||||||
|  | const languagesOptions = languages.map(lang => ({ value: lang.id, label: lang.name })); | ||||||
|  | 
 | ||||||
|  | figlet.defaults({ fontPath: '//unpkg.com/figlet@1.6.0/fonts/' }); | ||||||
|  | 
 | ||||||
| watchEffect(async () => { | watchEffect(async () => { | ||||||
|  |   const inputValue = input.value; | ||||||
|  |   const languageValue = language.value; | ||||||
|  |   const fontValue = font.value; | ||||||
|  |   const widthValue = width.value; | ||||||
|   processing.value = true; |   processing.value = true; | ||||||
|   try { |   try { | ||||||
|     const options: figlet.Options = { |     const options: figlet.Options = { | ||||||
|       font: font.value as figlet.Fonts, |       font: fontValue as figlet.Fonts, | ||||||
|       width: width.value, |       width: widthValue, | ||||||
|       whitespaceBreak: true, |       whitespaceBreak: true, | ||||||
|     }; |     }; | ||||||
|     output.value = await (new Promise<string>((resolve, reject) => |     const rawOutput = await (new Promise<string>((resolve, reject) => | ||||||
|       figlet.text(input.value, options, |       figlet.text(inputValue, options, | ||||||
|         (err, text) => { |         (err, text) => { | ||||||
|           if (err) { |           if (err) { | ||||||
|             reject(err); |             reject(err); | ||||||
| @ -29,6 +39,8 @@ watchEffect(async () => { | |||||||
| 
 | 
 | ||||||
|           resolve(text ?? ''); |           resolve(text ?? ''); | ||||||
|         }))); |         }))); | ||||||
|  | 
 | ||||||
|  |     output.value = translateToLanguage(rawOutput, languageValue); | ||||||
|     errored.value = false; |     errored.value = false; | ||||||
|   } |   } | ||||||
|   catch (e: any) { |   catch (e: any) { | ||||||
| @ -50,6 +62,7 @@ const fonts = ['1Row', '3-D', '3D Diagonal', '3D-ASCII', '3x5', '4Max', '5 Line | |||||||
|       multiline |       multiline | ||||||
|       rows="4" |       rows="4" | ||||||
|     /> |     /> | ||||||
|  |     <c-select v-model:value="language" :options="languagesOptions" searchable mt-3 /> | ||||||
| 
 | 
 | ||||||
|     <n-divider /> |     <n-divider /> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ function escapeXml(unsafe: string) { | |||||||
|       case '\'': return '''; |       case '\'': return '''; | ||||||
|       case '"': return '"'; |       case '"': return '"'; | ||||||
|     } |     } | ||||||
|  |     return ''; | ||||||
|   }); |   }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user