Skip to content

Commit

Permalink
feat: better UI
Browse files Browse the repository at this point in the history
  • Loading branch information
sharevb committed Jul 14, 2024
1 parent d92a285 commit 4b78219
Show file tree
Hide file tree
Showing 4 changed files with 83 additions and 42 deletions.
3 changes: 3 additions & 0 deletions components.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@ declare module '@vue/runtime-core' {
MetaTagGenerator: typeof import('./src/tools/meta-tag-generator/meta-tag-generator.vue')['default']
MimeTypes: typeof import('./src/tools/mime-types/mime-types.vue')['default']
NavbarButtons: typeof import('./src/components/NavbarButtons.vue')['default']
NCheckbox: typeof import('naive-ui')['NCheckbox']
NCode: typeof import('naive-ui')['NCode']
NCollapseTransition: typeof import('naive-ui')['NCollapseTransition']
NColorPicker: typeof import('naive-ui')['NColorPicker']
Expand All @@ -147,7 +148,9 @@ declare module '@vue/runtime-core' {
NLayout: typeof import('naive-ui')['NLayout']
NLayoutSider: typeof import('naive-ui')['NLayoutSider']
NMenu: typeof import('naive-ui')['NMenu']
NP: typeof import('naive-ui')['NP']
NScrollbar: typeof import('naive-ui')['NScrollbar']
NSpace: typeof import('naive-ui')['NSpace']
NSpin: typeof import('naive-ui')['NSpin']
NumeronymGenerator: typeof import('./src/tools/numeronym-generator/numeronym-generator.vue')['default']
OtpCodeGeneratorAndValidator: typeof import('./src/tools/otp-code-generator-and-validator/otp-code-generator-and-validator.vue')['default']
Expand Down
2 changes: 2 additions & 0 deletions src/components/TextareaCopyable.vue
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import sqlHljs from 'highlight.js/lib/languages/sql';
import xmlHljs from 'highlight.js/lib/languages/xml';
import yamlHljs from 'highlight.js/lib/languages/yaml';
import iniHljs from 'highlight.js/lib/languages/ini';
import markdownHljs from 'highlight.js/lib/languages/markdown';
import { useCopy } from '@/composable/copy';
const props = withDefaults(
Expand All @@ -30,6 +31,7 @@ hljs.registerLanguage('html', xmlHljs);
hljs.registerLanguage('xml', xmlHljs);
hljs.registerLanguage('yaml', yamlHljs);
hljs.registerLanguage('toml', iniHljs);
hljs.registerLanguage('markdown', markdownHljs);
const { value, language, followHeightOf, copyPlacement, copyMessage } = toRefs(props);
const { height } = followHeightOf.value ? useElementSize(followHeightOf) : { height: ref(null) };
Expand Down
2 changes: 1 addition & 1 deletion src/tools/markdown-toc-generator/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ export const tool = defineTool({
name: 'Markdown toc generator',
path: '/markdown-toc-generator',
description: 'Generate a TOC from a markdown file/content',
keywords: ['markdown', 'toc', 'generator'],
keywords: ['markdown', 'md', 'toc', 'generator'],
component: () => import('./markdown-toc-generator.vue'),
icon: Table,
createdAt: new Date('2024-05-11'),
Expand Down
118 changes: 77 additions & 41 deletions src/tools/markdown-toc-generator/markdown-toc-generator.vue
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,36 @@ import {
} from './markdown-toc-generator.service';
import { useQueryParamOrStorage } from '@/composable/queryParams';
const markdown = ref('');
const markdown = ref(`# Some main title
[TOC]
## First Title
Some text
## Second Spaced Title
Some text
### Title with Link [TOC](http://it-tools.tech)
\`\`\`
## some bash code
echo 'test';
\`\`\`
### Title with code \`var\`
Some text
## Last Title`);
const generateAnchors = useQueryParamOrStorage({ name: 'anchors', storageName: 'md-toc-gen:anchors', defaultValue: true });
const indentChars = useQueryParamOrStorage({ name: 'bullets', storageName: 'md-toc-gen:bullets', defaultValue: '-*+' });
const indentSpaces = ref(2);
const indentSpaces = ref(3);
const maxLevel = useQueryParamOrStorage({ name: 'max', storageName: 'md-toc-gen:max', defaultValue: -1 });
const anchorPrefix = useQueryParamOrStorage({ name: 'prefix', storageName: 'md-toc-gen:prefix', defaultValue: '' });
const concatSpaces = useQueryParamOrStorage({ name: 'concat', storageName: 'md-toc-gen:concat', defaultValue: true });
const concatSpaces = useQueryParamOrStorage({ name: 'concat', storageName: 'md-toc-gen:concat', defaultValue: false });
const commentStyle = useQueryParamOrStorage({ name: 'comment', storageName: 'md-toc-gen:comment', defaultValue: 'html' });
const markdownWithTOC = computed(() => withDefaultOnError(() => {
Expand All @@ -31,53 +54,66 @@ const markdownWithTOC = computed(() => withDefaultOnError(() => {
<template>
<div>
<c-card title="Options" mb-2>
<n-form-item label="Generate Anchors" label-placement="left">
<n-checkbox v-model:checked="generateAnchors" mr-2 />
</n-form-item>
<n-space>
<n-form-item label-placement="left">
<n-checkbox v-model:checked="generateAnchors">
Generate Anchors
</n-checkbox>
</n-form-item>
<n-form-item label="Max Heading Level:" label-placement="left">
<n-input-number
v-model:value="maxLevel"
placeholder="Max Heading Level..."
:max="6" :min="-1"
/>
</n-form-item>
</n-space>

<c-input-text
v-model:value="indentChars"
label="Bullet Chars"
placeholder="Bullet Chars"
mb-2
/>

<n-form-item label="Indents: " label-placement="left">
<n-input-number v-model:value="indentSpaces" placeholder="Indents..." :max="10" :min="1" w-full />
</n-form-item>

<n-form-item label="Max Heading Level: " label-placement="left">
<n-input-number v-model:value="maxLevel" placeholder="Max Heading Level..." :max="6" :min="-1" w-full />
</n-form-item>

<c-input-text
v-model:value="anchorPrefix"
label="Anchors Prefix"
placeholder="Anchors Prefix"
mb-2
/>

<n-form-item label="Concat Spaces" label-placement="left">
<n-checkbox v-model:checked="concatSpaces" mr-2 />
</n-form-item>

<c-select
v-model:value="commentStyle"
label="Comment Styles"
:options="['html', 'liquid']"
placeholder="Comment Styles"
/>
<details>
<summary>Advanced</summary>
<n-space>
<n-form-item label-placement="left">
<n-checkbox v-model:checked="concatSpaces">

Check warning on line 76 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 12 spaces but found 10 spaces
Concat Spaces

Check warning on line 77 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 14 spaces but found 12 spaces
</n-checkbox>

Check warning on line 78 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 12 spaces but found 10 spaces
</n-form-item>

Check warning on line 79 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 10 spaces but found 8 spaces
<c-input-text

Check warning on line 80 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 10 spaces but found 8 spaces
v-model:value="indentChars"

Check warning on line 81 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 12 spaces but found 10 spaces
label="Bullet Chars"

Check warning on line 82 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 12 spaces but found 10 spaces
label-position="left"

Check warning on line 83 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 12 spaces but found 10 spaces
placeholder="Bullet Chars"

Check warning on line 84 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 12 spaces but found 10 spaces
/>

Check warning on line 85 in src/tools/markdown-toc-generator/markdown-toc-generator.vue

View workflow job for this annotation

GitHub Actions / ci

Expected indentation of 10 spaces but found 8 spaces
<c-input-text
v-model:value="anchorPrefix"
label="Anchors Prefix"
label-position="left"
placeholder="Anchors Prefix"
/>
<n-form-item label="Indents: " label-placement="left">
<n-input-number
v-model:value="indentSpaces"
placeholder="Indents..."
:max="10" :min="1"
/>
</n-form-item>
<c-select
v-model:value="commentStyle"
label="Comment Styles"
label-position="left"
:options="['html', 'liquid']"
placeholder="Comment Styles"
/>
</n-space>
</details>
</c-card>

<c-card title="Input markdown" mb-2>
<n-p>You can paste a document with existing TOC (generated by this tool) or add a <code>[TOC]</code> marker in your document (on a single line)</n-p>
<c-input-text
v-model:value="markdown"
placeholder="Put your markdown here..."
multline
multiline
rows="8"
mb-2
mt-2
/>
</c-card>

Expand Down

0 comments on commit 4b78219

Please sign in to comment.