@maz-ui/mcp 5.0.0-beta.3 → 5.0.0-beta.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/mcp.d.mts +22 -9
- package/dist/mcp.d.ts +22 -9
- package/dist/mcp.mjs +160 -83
- package/docs/generated-docs/maz-avatar.doc.md +30 -30
- package/docs/generated-docs/maz-btn.doc.md +3 -2
- package/docs/generated-docs/maz-checkbox.doc.md +16 -17
- package/docs/generated-docs/maz-circular-progress-bar.doc.md +1 -1
- package/docs/generated-docs/maz-code-highlight.doc.md +11 -0
- package/docs/generated-docs/maz-container.doc.md +1 -0
- package/docs/generated-docs/maz-date-picker.doc.md +41 -41
- package/docs/generated-docs/maz-drawer.doc.md +7 -8
- package/docs/generated-docs/maz-dropdown.doc.md +3 -0
- package/docs/generated-docs/maz-expand-animation.doc.md +4 -4
- package/docs/generated-docs/maz-fullscreen-loader.doc.md +5 -5
- package/docs/generated-docs/maz-gallery.doc.md +15 -15
- package/docs/generated-docs/maz-input-code.doc.md +16 -16
- package/docs/generated-docs/maz-input-phone-number.doc.md +42 -38
- package/docs/generated-docs/maz-input-price.doc.md +14 -14
- package/docs/generated-docs/maz-input-tags.doc.md +16 -16
- package/docs/generated-docs/maz-input.doc.md +33 -33
- package/docs/generated-docs/maz-lazy-img.doc.md +14 -14
- package/docs/generated-docs/maz-loading-bar.doc.md +4 -4
- package/docs/generated-docs/maz-markdown-editor.doc.md +65 -0
- package/docs/generated-docs/maz-popover.doc.md +1 -1
- package/docs/generated-docs/maz-pull-to-refresh.doc.md +10 -10
- package/docs/generated-docs/maz-radio-buttons.doc.md +17 -17
- package/docs/generated-docs/maz-radio.doc.md +16 -16
- package/docs/generated-docs/maz-reading-progress-bar.doc.md +4 -4
- package/docs/generated-docs/maz-sidebar-content.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-footer.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-group.doc.md +11 -0
- package/docs/generated-docs/maz-sidebar-header.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-menu-button.doc.md +27 -0
- package/docs/generated-docs/maz-sidebar-menu-item.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-menu-sub.doc.md +16 -0
- package/docs/generated-docs/maz-sidebar-menu.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-separator.doc.md +0 -0
- package/docs/generated-docs/maz-sidebar-trigger.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar.doc.md +36 -0
- package/docs/generated-docs/maz-slider.doc.md +1 -1
- package/docs/generated-docs/maz-spinner.doc.md +4 -4
- package/docs/generated-docs/maz-switch.doc.md +14 -14
- package/docs/generated-docs/maz-table.doc.md +5 -5
- package/docs/generated-docs/maz-textarea.doc.md +25 -24
- package/docs/generated-docs/maz-ticker.doc.md +1 -1
- package/docs/generated-docs/maz-timeline.doc.md +4 -4
- package/docs/generated-docs/maz-window-mockup.doc.md +23 -0
- package/docs/src/blog/v4.md +1 -1
- package/docs/src/blog/v5.md +5 -7
- package/docs/src/components/maz-avatar.md +29 -0
- package/docs/src/components/maz-btn.md +1 -1
- package/docs/src/components/maz-code-highlight.md +233 -0
- package/docs/src/components/maz-container.md +2 -2
- package/docs/src/components/maz-date-picker.md +1 -1
- package/docs/src/components/maz-dialog.md +46 -0
- package/docs/src/components/maz-dropdown.md +32 -16
- package/docs/src/components/maz-icon.md +2 -2
- package/docs/src/components/maz-input-phone-number.md +106 -103
- package/docs/src/components/maz-markdown-editor.md +369 -0
- package/docs/src/components/maz-sidebar.md +719 -0
- package/docs/src/components/maz-textarea.md +27 -1
- package/docs/src/components/maz-timeline.md +60 -0
- package/docs/src/components/maz-window-mockup.md +249 -0
- package/docs/src/composables/use-form-validator.md +50 -11
- package/docs/src/directives/click-outside.md +8 -15
- package/docs/src/directives/fullscreen-img.md +1 -1
- package/docs/src/directives/lazy-img.md +5 -5
- package/docs/src/directives/tooltip.md +24 -1
- package/docs/src/directives/zoom-img.md +1 -1
- package/docs/src/ecosystem/eslint-config.md +95 -1
- package/docs/src/{guide/icons.md → ecosystem/icons/index.md} +1 -1
- package/docs/src/ecosystem/node/exec-promise.md +87 -0
- package/docs/src/ecosystem/node/index.md +53 -0
- package/docs/src/ecosystem/node/logger.md +146 -0
- package/docs/src/ecosystem/node/print-banner.md +93 -0
- package/docs/src/{guide → ecosystem}/nuxt.md +81 -47
- package/docs/src/{guide → ecosystem}/themes.md +153 -72
- package/docs/src/{guide → ecosystem}/translations.md +1 -1
- package/docs/src/ecosystem/utils/camel-case.md +31 -0
- package/docs/src/{helpers → ecosystem/utils}/capitalize.md +2 -3
- package/docs/src/ecosystem/utils/check-availability.md +79 -0
- package/docs/src/ecosystem/utils/cookie.md +80 -0
- package/docs/src/{helpers → ecosystem/utils}/currency.md +2 -2
- package/docs/src/{helpers → ecosystem/utils}/date.md +2 -2
- package/docs/src/ecosystem/utils/debounce-callback.md +38 -0
- package/docs/src/ecosystem/utils/debounce-id.md +69 -0
- package/docs/src/ecosystem/utils/debounce.md +65 -0
- package/docs/src/ecosystem/utils/fetch-locale-ip.md +33 -0
- package/docs/src/ecosystem/utils/format-json.md +33 -0
- package/docs/src/ecosystem/utils/format-phone-number.md +37 -0
- package/docs/src/ecosystem/utils/get-browser-locale.md +29 -0
- package/docs/src/ecosystem/utils/get-error-message.md +39 -0
- package/docs/src/ecosystem/utils/idle-timeout.md +90 -0
- package/docs/src/ecosystem/utils/index.md +60 -0
- package/docs/src/ecosystem/utils/is-client.md +32 -0
- package/docs/src/ecosystem/utils/is-equal.md +38 -0
- package/docs/src/ecosystem/utils/is-server.md +31 -0
- package/docs/src/ecosystem/utils/is-standalone-mode.md +43 -0
- package/docs/src/ecosystem/utils/kebab-case.md +36 -0
- package/docs/src/ecosystem/utils/normalize-string.md +77 -0
- package/docs/src/{helpers → ecosystem/utils}/number.md +2 -2
- package/docs/src/ecosystem/utils/pascal-case.md +35 -0
- package/docs/src/ecosystem/utils/script-loader.md +77 -0
- package/docs/src/ecosystem/utils/sleep.md +59 -0
- package/docs/src/ecosystem/utils/snake-case.md +36 -0
- package/docs/src/ecosystem/utils/swipe-handler.md +91 -0
- package/docs/src/ecosystem/utils/textarea-autogrow.md +41 -0
- package/docs/src/ecosystem/utils/throttle-id.md +48 -0
- package/docs/src/ecosystem/utils/throttle.md +57 -0
- package/docs/src/ecosystem/utils/truthy-filter.md +31 -0
- package/docs/src/ecosystem/utils/types/deep-key-of.md +48 -0
- package/docs/src/ecosystem/utils/types/deep-partial.md +42 -0
- package/docs/src/ecosystem/utils/types/deep-required.md +39 -0
- package/docs/src/ecosystem/utils/types/flatten-object-keys.md +44 -0
- package/docs/src/ecosystem/utils/types/generic-instance-type.md +42 -0
- package/docs/src/ecosystem/utils/types/infer-maybe-ref.md +35 -0
- package/docs/src/ecosystem/utils/upper-first.md +32 -0
- package/docs/src/ecosystem/utils/user-visibility.md +69 -0
- package/docs/src/guide/getting-started.md +15 -13
- package/docs/src/guide/global-defaults.md +101 -0
- package/docs/src/guide/maz-ui-provider.md +6 -3
- package/docs/src/guide/migration-v4.md +13 -9
- package/docs/src/guide/migration-v5.md +112 -13
- package/docs/src/guide/resolvers.md +7 -7
- package/docs/src/guide/tailwind.md +4 -0
- package/docs/src/guide/vue.md +4 -4
- package/docs/src/index.md +12 -12
- package/docs/src/plugins/aos.md +1 -1
- package/docs/src/plugins/wait.md +1 -1
- package/package.json +8 -7
- package/docs/src/helpers/camel-case.md +0 -14
- package/docs/src/helpers/check-availability.md +0 -14
- package/docs/src/helpers/debounce-callback.md +0 -14
- package/docs/src/helpers/debounce-id.md +0 -14
- package/docs/src/helpers/debounce.md +0 -14
- package/docs/src/helpers/is-client.md +0 -14
- package/docs/src/helpers/is-equal.md +0 -14
- package/docs/src/helpers/is-standalone-mode.md +0 -14
- package/docs/src/helpers/kebab-case.md +0 -14
- package/docs/src/helpers/normalize-string.md +0 -14
- package/docs/src/helpers/pascal-case.md +0 -14
- package/docs/src/helpers/script-loader.md +0 -14
- package/docs/src/helpers/sleep.md +0 -14
- package/docs/src/helpers/snake-case.md +0 -14
- package/docs/src/helpers/throttle-id.md +0 -14
- package/docs/src/helpers/throttle.md +0 -14
- /package/docs/src/{guide → ecosystem/icons}/icon-set.md +0 -0
- /package/docs/src/{guide → ecosystem}/mcp.md +0 -0
- /package/docs/src/{helpers → ecosystem/utils}/country-code-to-unicode-flag.md +0 -0
- /package/docs/src/{helpers → ecosystem/utils}/get-country-flag-url.md +0 -0
|
@@ -68,34 +68,28 @@ const results = ref<MazInputPhoneNumberData>()
|
|
|
68
68
|
Control which countries appear in the dropdown and their order.
|
|
69
69
|
|
|
70
70
|
<ComponentDemo>
|
|
71
|
-
<div class="maz:
|
|
72
|
-
<
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
<MazInputPhoneNumber
|
|
94
|
-
v-model="phone3"
|
|
95
|
-
:ignored-countries="['AF', 'AL', 'DZ']"
|
|
96
|
-
placeholder="Some countries are hidden"
|
|
97
|
-
/>
|
|
98
|
-
</div>
|
|
71
|
+
<div class="maz:flex maz:flex-col maz:gap-4">
|
|
72
|
+
<MazInputPhoneNumber
|
|
73
|
+
top-label="Preferred Countries"
|
|
74
|
+
assistive-text="Show your most common countries first"
|
|
75
|
+
v-model="phone1"
|
|
76
|
+
:preferred-countries="['US', 'FR', 'GB', 'DE', 'CA']"
|
|
77
|
+
placeholder="Common countries appear first"
|
|
78
|
+
/>
|
|
79
|
+
<MazInputPhoneNumber
|
|
80
|
+
top-label="Only Specific Countries"
|
|
81
|
+
assistive-text="Limit to certain countries only"
|
|
82
|
+
v-model="phone2"
|
|
83
|
+
:only-countries="['US', 'FR', 'GB', 'DE', 'IT', 'ES']"
|
|
84
|
+
placeholder="Only European + North American countries"
|
|
85
|
+
/>
|
|
86
|
+
<MazInputPhoneNumber
|
|
87
|
+
top-label="Ignore Countries"
|
|
88
|
+
assistive-text="Remove unwanted countries"
|
|
89
|
+
v-model="phone3"
|
|
90
|
+
:ignored-countries="['AF', 'AL', 'DZ']"
|
|
91
|
+
placeholder="Some countries are hidden"
|
|
92
|
+
/>
|
|
99
93
|
</div>
|
|
100
94
|
|
|
101
95
|
<template #code>
|
|
@@ -133,22 +127,22 @@ Control which countries appear in the dropdown and their order.
|
|
|
133
127
|
Choose how the country selector and phone input are arranged.
|
|
134
128
|
|
|
135
129
|
<ComponentDemo>
|
|
136
|
-
<div class="maz:
|
|
137
|
-
<
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
<
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
<
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
130
|
+
<div class="maz:flex maz:flex-col maz:gap-6">
|
|
131
|
+
<MazInputPhoneNumber
|
|
132
|
+
top-label="Responsive"
|
|
133
|
+
assistive-text="Stacks on mobile, side-by-side on desktop"
|
|
134
|
+
orientation="responsive"
|
|
135
|
+
/>
|
|
136
|
+
<MazInputPhoneNumber
|
|
137
|
+
top-label="Always Row"
|
|
138
|
+
assistive-text="Side-by-side on all screen sizes"
|
|
139
|
+
orientation="row"
|
|
140
|
+
/>
|
|
141
|
+
<MazInputPhoneNumber
|
|
142
|
+
top-label="Always Column"
|
|
143
|
+
assistive-text="Stacked on all screen sizes"
|
|
144
|
+
orientation="col"
|
|
145
|
+
/>
|
|
152
146
|
</div>
|
|
153
147
|
|
|
154
148
|
<template #code>
|
|
@@ -156,13 +150,25 @@ Choose how the country selector and phone input are arranged.
|
|
|
156
150
|
```vue
|
|
157
151
|
<template>
|
|
158
152
|
<!-- Responsive layout (default) -->
|
|
159
|
-
<MazInputPhoneNumber
|
|
153
|
+
<MazInputPhoneNumber
|
|
154
|
+
top-label="Responsive"
|
|
155
|
+
assistive-text="Stacks on mobile, side-by-side on desktop"
|
|
156
|
+
orientation="responsive"
|
|
157
|
+
/>
|
|
160
158
|
|
|
161
159
|
<!-- Always side-by-side -->
|
|
162
|
-
<MazInputPhoneNumber
|
|
160
|
+
<MazInputPhoneNumber
|
|
161
|
+
top-label="Always Row"
|
|
162
|
+
assistive-text="Side-by-side on all screen sizes"
|
|
163
|
+
orientation="row"
|
|
164
|
+
/>
|
|
163
165
|
|
|
164
166
|
<!-- Always stacked -->
|
|
165
|
-
<MazInputPhoneNumber
|
|
167
|
+
<MazInputPhoneNumber
|
|
168
|
+
top-label="Always Column"
|
|
169
|
+
assistive-text="Stacked on all screen sizes"
|
|
170
|
+
orientation="col"
|
|
171
|
+
/>
|
|
166
172
|
</template>
|
|
167
173
|
```
|
|
168
174
|
|
|
@@ -174,34 +180,30 @@ Choose how the country selector and phone input are arranged.
|
|
|
174
180
|
Customize what information is shown to users.
|
|
175
181
|
|
|
176
182
|
<ComponentDemo>
|
|
177
|
-
<div class="maz:
|
|
178
|
-
<
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
:
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
<h4 class="maz:font-semibold maz:mb-2">Hide Country Flags</h4>
|
|
202
|
-
<p class="maz:text-sm maz:text-muted maz:mb-2">Text-only country selection</p>
|
|
203
|
-
<MazInputPhoneNumber hide-flags />
|
|
204
|
-
</div>
|
|
183
|
+
<div class="maz:flex maz:flex-col maz:gap-4">
|
|
184
|
+
<MazInputPhoneNumber
|
|
185
|
+
top-label="Show Country Names"
|
|
186
|
+
assistive-text="Display country names instead of calling codes"
|
|
187
|
+
display-country-name
|
|
188
|
+
:translations="{
|
|
189
|
+
countrySelect: { placeholder: 'Choose country' }
|
|
190
|
+
}"
|
|
191
|
+
/>
|
|
192
|
+
<MazInputPhoneNumber
|
|
193
|
+
top-label="Show Calling Codes in List"
|
|
194
|
+
assistive-text="Help users see the dialing codes"
|
|
195
|
+
show-code-in-list
|
|
196
|
+
/>
|
|
197
|
+
<MazInputPhoneNumber
|
|
198
|
+
top-label="Hide Phone Examples"
|
|
199
|
+
assistive-text="Remove the example phone number hints (visible when the phone input is focused)"
|
|
200
|
+
:example="false"
|
|
201
|
+
/>
|
|
202
|
+
<MazInputPhoneNumber
|
|
203
|
+
top-label="Hide Country Flags"
|
|
204
|
+
assistive-text="Text-only country selection"
|
|
205
|
+
hide-flags
|
|
206
|
+
/>
|
|
205
207
|
</div>
|
|
206
208
|
|
|
207
209
|
<template #code>
|
|
@@ -762,34 +764,35 @@ const mobilePhone = ref()
|
|
|
762
764
|
Understanding what data the component provides.
|
|
763
765
|
|
|
764
766
|
<ComponentDemo>
|
|
765
|
-
<
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
<
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
<
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
<
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
<
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
<
|
|
791
|
-
|
|
792
|
-
|
|
767
|
+
<MazInputPhoneNumber
|
|
768
|
+
v-model="dataPhone"
|
|
769
|
+
v-model:country-code="dataCountry"
|
|
770
|
+
top-label="Your phone number"
|
|
771
|
+
placeholder="Enter a phone number to see data"
|
|
772
|
+
assistive-text="Enter your phone number in international format (e.g. +33612345678)"
|
|
773
|
+
@data="phoneData = $event"
|
|
774
|
+
/>
|
|
775
|
+
|
|
776
|
+
<div v-if="phoneData" class="maz:bg-surface-400 maz:pt-8 maz:rounded-md">
|
|
777
|
+
<h4 class="maz:font-semibold maz:mb-3">📊 Phone Number Data</h4>
|
|
778
|
+
<div class="maz:grid maz:grid-cols-1 maz:md:grid-cols-2 maz:gap-4 maz:text-sm">
|
|
779
|
+
<div>
|
|
780
|
+
<strong>Valid:</strong> {{ phoneData?.isValid ? '✅' : '❌' }}
|
|
781
|
+
</div>
|
|
782
|
+
<div>
|
|
783
|
+
<strong>Country:</strong> {{ phoneData?.countryCode || 'None' }}
|
|
784
|
+
</div>
|
|
785
|
+
<div>
|
|
786
|
+
<strong>National Format:</strong> {{ phoneData?.formatNational || 'None' }}
|
|
787
|
+
</div>
|
|
788
|
+
<div>
|
|
789
|
+
<strong>International:</strong> {{ phoneData?.formatInternational || 'None' }}
|
|
790
|
+
</div>
|
|
791
|
+
<div>
|
|
792
|
+
<strong>E164 Format:</strong> {{ phoneData?.e164 || 'None' }}
|
|
793
|
+
</div>
|
|
794
|
+
<div>
|
|
795
|
+
<strong>Phone Type:</strong> {{ phoneData?.type || 'Unknown' }}
|
|
793
796
|
</div>
|
|
794
797
|
</div>
|
|
795
798
|
</div>
|
|
@@ -0,0 +1,369 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: MazMarkdownEditor
|
|
3
|
+
description: MazMarkdownEditor is a GitHub-style markdown editor with Write/Preview/Split tabs, a configurable formatting toolbar, optional line numbers, and a sanitized preview. It shares the same states, labels and theming as MazTextarea, is SSR-friendly, and supports custom renderers.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# {{ $frontmatter.title }}
|
|
7
|
+
|
|
8
|
+
{{ $frontmatter.description }}
|
|
9
|
+
|
|
10
|
+
<!--@include: ./../../.vitepress/mixins/getting-started.md-->
|
|
11
|
+
|
|
12
|
+
## Installation requirement
|
|
13
|
+
|
|
14
|
+
The preview relies on [`marked`](https://marked.js.org) for parsing and [`dompurify`](https://github.com/cure53/DOMPurify) for sanitization. Both are loaded lazily (only when the preview is rendered), so install them in your project:
|
|
15
|
+
|
|
16
|
+
::: code-group
|
|
17
|
+
|
|
18
|
+
```bash [pnpm]
|
|
19
|
+
pnpm add marked dompurify
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
```bash [npm]
|
|
23
|
+
npm install marked dompurify
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
```bash [yarn]
|
|
27
|
+
yarn add marked dompurify
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
:::
|
|
31
|
+
|
|
32
|
+
If they are not installed, the preview falls back to a safe, escaped plain-text block. You can also provide your own renderer with the [`renderFunction`](#custom-renderer) prop to avoid these dependencies entirely.
|
|
33
|
+
|
|
34
|
+
## Basic usage
|
|
35
|
+
|
|
36
|
+
The component exposes a `v-model` bound to the raw markdown string and two tabs: **Write** (textarea) and **Preview** (rendered, sanitized HTML).
|
|
37
|
+
|
|
38
|
+
<ComponentDemo>
|
|
39
|
+
<MazMarkdownEditor v-model="basic" placeholder="markdown goes here" />
|
|
40
|
+
|
|
41
|
+
<template #code>
|
|
42
|
+
|
|
43
|
+
```vue
|
|
44
|
+
<template>
|
|
45
|
+
<MazMarkdownEditor v-model="content" />
|
|
46
|
+
</template>
|
|
47
|
+
|
|
48
|
+
<script lang="ts" setup>
|
|
49
|
+
import { ref } from 'vue'
|
|
50
|
+
import MazMarkdownEditor from 'maz-ui/components/MazMarkdownEditor'
|
|
51
|
+
|
|
52
|
+
const content = ref('# Hello maz-ui\n\nThis is **markdown** with a [link](https://maz-ui.com).')
|
|
53
|
+
</script>
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
</template>
|
|
57
|
+
</ComponentDemo>
|
|
58
|
+
|
|
59
|
+
## Toolbar
|
|
60
|
+
|
|
61
|
+
The formatting toolbar is opt-in. Set `toolbar` to `true` to display the full toolbar. Buttons act on the current textarea selection and preserve the native undo/redo history (`Cmd/Ctrl + Z`).
|
|
62
|
+
|
|
63
|
+
<ComponentDemo>
|
|
64
|
+
<MazMarkdownEditor v-model="withToolbar" toolbar />
|
|
65
|
+
|
|
66
|
+
<template #code>
|
|
67
|
+
|
|
68
|
+
```vue
|
|
69
|
+
<template>
|
|
70
|
+
<MazMarkdownEditor v-model="content" toolbar />
|
|
71
|
+
</template>
|
|
72
|
+
|
|
73
|
+
<script lang="ts" setup>
|
|
74
|
+
import { ref } from 'vue'
|
|
75
|
+
import MazMarkdownEditor from 'maz-ui/components/MazMarkdownEditor'
|
|
76
|
+
|
|
77
|
+
const content = ref('Select some text and click **Bold**.')
|
|
78
|
+
</script>
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
</template>
|
|
82
|
+
</ComponentDemo>
|
|
83
|
+
|
|
84
|
+
### Available actions
|
|
85
|
+
|
|
86
|
+
The full toolbar exposes the following action keys:
|
|
87
|
+
|
|
88
|
+
| Key | Result |
|
|
89
|
+
| --- | --- |
|
|
90
|
+
| `heading` | Heading dropdown (`#`, `##`, `###`) |
|
|
91
|
+
| `bold` | `**bold**` |
|
|
92
|
+
| `italic` | `_italic_` |
|
|
93
|
+
| `strikethrough` | `~~strikethrough~~` |
|
|
94
|
+
| `quote` | `> quote` |
|
|
95
|
+
| `code` | `` `inline code` `` |
|
|
96
|
+
| `codeBlock` | fenced ` ``` ` code block |
|
|
97
|
+
| `link` | `[text](url)` |
|
|
98
|
+
| `image` | `` |
|
|
99
|
+
| `bulletList` | `- item` |
|
|
100
|
+
| `orderedList` | `1. item` |
|
|
101
|
+
| `checkList` | `- [ ] task` |
|
|
102
|
+
| `table` | markdown table skeleton |
|
|
103
|
+
|
|
104
|
+
### Configure the toolbar
|
|
105
|
+
|
|
106
|
+
Pass an **ordered array of action keys** to display only a subset (and control their order):
|
|
107
|
+
|
|
108
|
+
<ComponentDemo>
|
|
109
|
+
<MazMarkdownEditor v-model="withToolbarConfig" :toolbar="['heading', 'bold', 'italic', 'link', 'codeBlock']" />
|
|
110
|
+
|
|
111
|
+
<template #code>
|
|
112
|
+
|
|
113
|
+
```vue
|
|
114
|
+
<template>
|
|
115
|
+
<MazMarkdownEditor
|
|
116
|
+
v-model="content"
|
|
117
|
+
:toolbar="['heading', 'bold', 'italic', 'link', 'codeBlock']"
|
|
118
|
+
/>
|
|
119
|
+
</template>
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
</template>
|
|
123
|
+
</ComponentDemo>
|
|
124
|
+
|
|
125
|
+
## Keyboard shortcuts
|
|
126
|
+
|
|
127
|
+
Classic markdown shortcuts are enabled by default and work whenever the textarea is focused. They preserve the native undo/redo history. The toolbar buttons also display their shortcut in the tooltip. Use `mod` for `Cmd` on macOS and `Ctrl` elsewhere.
|
|
128
|
+
|
|
129
|
+
| Shortcut | Action |
|
|
130
|
+
| --- | --- |
|
|
131
|
+
| `mod + B` | Bold |
|
|
132
|
+
| `mod + I` | Italic |
|
|
133
|
+
| `mod + Shift + X` | Strikethrough |
|
|
134
|
+
| `mod + K` | Link |
|
|
135
|
+
| `mod + E` | Inline code |
|
|
136
|
+
| `mod + Shift + E` | Code block |
|
|
137
|
+
| `mod + Shift + .` | Quote |
|
|
138
|
+
| `mod + Shift + 8` | Bulleted list |
|
|
139
|
+
| `mod + Shift + 7` | Numbered list |
|
|
140
|
+
| `mod + Shift + L` | Task list |
|
|
141
|
+
| `mod + Alt + 1/2/3` | Heading 1/2/3 |
|
|
142
|
+
|
|
143
|
+
Disable them with `:shortcuts="false"`:
|
|
144
|
+
|
|
145
|
+
```vue
|
|
146
|
+
<template>
|
|
147
|
+
<MazMarkdownEditor v-model="content" toolbar :shortcuts="false" />
|
|
148
|
+
</template>
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
::: tip
|
|
152
|
+
Image and table insertions have no default shortcut (to avoid clashing with browser shortcuts). Use the toolbar buttons or the `toolbar` slot helpers for those.
|
|
153
|
+
:::
|
|
154
|
+
|
|
155
|
+
## List continuation
|
|
156
|
+
|
|
157
|
+
Pressing <kbd>Enter</kbd> inside a list automatically inserts the next marker, just like a desktop markdown editor:
|
|
158
|
+
|
|
159
|
+
- Bulleted lists (`-`, `*`, `+`) repeat the marker.
|
|
160
|
+
- Numbered lists increment the index (`1.` → `2.`).
|
|
161
|
+
- Task lists insert a fresh unchecked box (`- [ ] `).
|
|
162
|
+
- Indentation is preserved.
|
|
163
|
+
|
|
164
|
+
Pressing <kbd>Enter</kbd> again on an empty item removes the marker and exits the list. This works out of the box, no configuration required.
|
|
165
|
+
|
|
166
|
+
## Label & assistive text
|
|
167
|
+
|
|
168
|
+
Like `MazTextarea`, the editor supports a static `top-label` (or `label`), the `required` asterisk and an `assistive-text` displayed below the editor.
|
|
169
|
+
|
|
170
|
+
<ComponentDemo>
|
|
171
|
+
<MazMarkdownEditor
|
|
172
|
+
v-model="withLabel"
|
|
173
|
+
top-label="Description"
|
|
174
|
+
placeholder="Markdown goes here"
|
|
175
|
+
assistive-text="Markdown is supported"
|
|
176
|
+
required
|
|
177
|
+
/>
|
|
178
|
+
|
|
179
|
+
<template #code>
|
|
180
|
+
|
|
181
|
+
```vue
|
|
182
|
+
<template>
|
|
183
|
+
<MazMarkdownEditor
|
|
184
|
+
v-model="content"
|
|
185
|
+
top-label="Description"
|
|
186
|
+
assistive-text="Markdown is supported"
|
|
187
|
+
required
|
|
188
|
+
/>
|
|
189
|
+
</template>
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
</template>
|
|
193
|
+
</ComponentDemo>
|
|
194
|
+
|
|
195
|
+
## States
|
|
196
|
+
|
|
197
|
+
Use `error`, `success`, `warning`, `disabled` and `readonly` to reflect validation states, consistent with the other form components.
|
|
198
|
+
|
|
199
|
+
<ComponentDemo>
|
|
200
|
+
<div class="maz:flex maz:flex-col maz:gap-4">
|
|
201
|
+
<MazMarkdownEditor v-model="stateError" error assistive-text="This field has an error" />
|
|
202
|
+
<MazMarkdownEditor v-model="stateSuccess" success assistive-text="Looks good!" />
|
|
203
|
+
<MazMarkdownEditor v-model="stateDisabled" disabled />
|
|
204
|
+
</div>
|
|
205
|
+
|
|
206
|
+
<template #code>
|
|
207
|
+
|
|
208
|
+
```vue
|
|
209
|
+
<template>
|
|
210
|
+
<MazMarkdownEditor v-model="content" error assistive-text="This field has an error" />
|
|
211
|
+
<MazMarkdownEditor v-model="content" success assistive-text="Looks good!" />
|
|
212
|
+
<MazMarkdownEditor v-model="content" disabled />
|
|
213
|
+
</template>
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
</template>
|
|
217
|
+
</ComponentDemo>
|
|
218
|
+
|
|
219
|
+
## Split mode
|
|
220
|
+
|
|
221
|
+
A third tab displays the editor and the preview side by side. Switch to it from the toolbar tabs, or control it with `v-model:mode` (`'write' | 'preview' | 'split'`). On small screens the two panes stack vertically.
|
|
222
|
+
|
|
223
|
+
<ComponentDemo>
|
|
224
|
+
<MazMarkdownEditor v-model="splitContent" mode="split" />
|
|
225
|
+
|
|
226
|
+
<template #code>
|
|
227
|
+
|
|
228
|
+
```vue
|
|
229
|
+
<template>
|
|
230
|
+
<MazMarkdownEditor v-model="content" mode="split" />
|
|
231
|
+
</template>
|
|
232
|
+
|
|
233
|
+
<script lang="ts" setup>
|
|
234
|
+
import { ref } from 'vue'
|
|
235
|
+
import MazMarkdownEditor from 'maz-ui/components/MazMarkdownEditor'
|
|
236
|
+
|
|
237
|
+
const content = ref('# Split view\n\nType on the left, see the **preview** on the right.')
|
|
238
|
+
</script>
|
|
239
|
+
```
|
|
240
|
+
|
|
241
|
+
</template>
|
|
242
|
+
</ComponentDemo>
|
|
243
|
+
|
|
244
|
+
## Line numbers
|
|
245
|
+
|
|
246
|
+
Enable the `line-numbers` prop to display a gutter on the left of the editor. Numbers reflect logical lines and stay in sync with the textarea scroll.
|
|
247
|
+
|
|
248
|
+
<ComponentDemo>
|
|
249
|
+
<MazMarkdownEditor v-model="lineNumbersContent" line-numbers />
|
|
250
|
+
|
|
251
|
+
<template #code>
|
|
252
|
+
|
|
253
|
+
```vue
|
|
254
|
+
<template>
|
|
255
|
+
<MazMarkdownEditor v-model="content" line-numbers />
|
|
256
|
+
</template>
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
</template>
|
|
260
|
+
</ComponentDemo>
|
|
261
|
+
|
|
262
|
+
## Custom renderer {#custom-renderer}
|
|
263
|
+
|
|
264
|
+
Provide a `render-function` to use your own markdown engine (e.g. `markdown-it`, a Nuxt Content renderer, or a server-side pipeline). It receives the raw markdown and returns an HTML string (sync or async). The result is still sanitized when `sanitize` is enabled.
|
|
265
|
+
|
|
266
|
+
<ComponentDemo>
|
|
267
|
+
<MazMarkdownEditor v-model="customRender" :render-function="upperCaseRenderer" />
|
|
268
|
+
|
|
269
|
+
<template #code>
|
|
270
|
+
|
|
271
|
+
```vue
|
|
272
|
+
<template>
|
|
273
|
+
<MazMarkdownEditor v-model="content" :render-function="renderer" />
|
|
274
|
+
</template>
|
|
275
|
+
|
|
276
|
+
<script lang="ts" setup>
|
|
277
|
+
import { ref } from 'vue'
|
|
278
|
+
import MazMarkdownEditor from 'maz-ui/components/MazMarkdownEditor'
|
|
279
|
+
|
|
280
|
+
const content = ref('Rendered by a custom function')
|
|
281
|
+
|
|
282
|
+
function renderer(markdown: string) {
|
|
283
|
+
return `<p>${markdown.toUpperCase()}</p>`
|
|
284
|
+
}
|
|
285
|
+
</script>
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
</template>
|
|
289
|
+
</ComponentDemo>
|
|
290
|
+
|
|
291
|
+
## Sanitization
|
|
292
|
+
|
|
293
|
+
By default, the rendered HTML is sanitized with DOMPurify to prevent XSS. Disabling it (`:sanitize="false"`) renders the raw output of the renderer; only do this when the markdown source is fully trusted.
|
|
294
|
+
|
|
295
|
+
```vue
|
|
296
|
+
<template>
|
|
297
|
+
<!-- Trusted content only -->
|
|
298
|
+
<MazMarkdownEditor v-model="content" :sanitize="false" />
|
|
299
|
+
</template>
|
|
300
|
+
```
|
|
301
|
+
|
|
302
|
+
## Controlled mode
|
|
303
|
+
|
|
304
|
+
The active tab is available through `v-model:mode` (`'write' | 'preview' | 'split'`).
|
|
305
|
+
|
|
306
|
+
```vue
|
|
307
|
+
<template>
|
|
308
|
+
<MazMarkdownEditor v-model="content" v-model:mode="mode" />
|
|
309
|
+
<p>Current tab: {{ mode }}</p>
|
|
310
|
+
</template>
|
|
311
|
+
|
|
312
|
+
<script lang="ts" setup>
|
|
313
|
+
import { ref } from 'vue'
|
|
314
|
+
import MazMarkdownEditor from 'maz-ui/components/MazMarkdownEditor'
|
|
315
|
+
|
|
316
|
+
const content = ref('')
|
|
317
|
+
const mode = ref<'write' | 'preview' | 'split'>('write')
|
|
318
|
+
</script>
|
|
319
|
+
```
|
|
320
|
+
|
|
321
|
+
## Custom translations
|
|
322
|
+
|
|
323
|
+
The tab labels, the empty-preview text and the toolbar button labels come from the `@maz-ui/translations` package (`markdownEditor.*`). You can override any key per-instance with the `translations` prop without touching the global locale:
|
|
324
|
+
|
|
325
|
+
<ComponentDemo>
|
|
326
|
+
<MazMarkdownEditor
|
|
327
|
+
v-model="translated"
|
|
328
|
+
toolbar
|
|
329
|
+
:translations="{ write: 'Édition', preview: 'Aperçu', emptyPreview: 'Rien à afficher' }"
|
|
330
|
+
/>
|
|
331
|
+
|
|
332
|
+
<template #code>
|
|
333
|
+
|
|
334
|
+
```vue
|
|
335
|
+
<template>
|
|
336
|
+
<MazMarkdownEditor
|
|
337
|
+
v-model="content"
|
|
338
|
+
toolbar
|
|
339
|
+
:translations="{ write: 'Édition', preview: 'Aperçu', emptyPreview: 'Rien à afficher' }"
|
|
340
|
+
/>
|
|
341
|
+
</template>
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
</template>
|
|
345
|
+
</ComponentDemo>
|
|
346
|
+
|
|
347
|
+
For app-wide translations, set up the [maz-ui translations plugin](/translations) and the component will pick up your locale automatically.
|
|
348
|
+
|
|
349
|
+
<script lang="ts" setup>
|
|
350
|
+
import { ref } from 'vue'
|
|
351
|
+
|
|
352
|
+
const basic = ref('# Hello maz-ui\n\nThis is **markdown** with a [link](https://maz-ui.com).')
|
|
353
|
+
const withToolbar = ref('Select some text and click **Bold**.')
|
|
354
|
+
const withToolbarConfig = ref('Only a few buttons here.')
|
|
355
|
+
const splitContent = ref('# Split view\n\nType on the left, see the **preview** on the right.')
|
|
356
|
+
const lineNumbersContent = ref('Line one\nLine two\nLine three')
|
|
357
|
+
const withLabel = ref('')
|
|
358
|
+
const stateError = ref('Invalid content')
|
|
359
|
+
const stateSuccess = ref('Valid content')
|
|
360
|
+
const stateDisabled = ref('Disabled editor')
|
|
361
|
+
const customRender = ref('Rendered by a custom function')
|
|
362
|
+
const translated = ref('Localized **markdown** editor.')
|
|
363
|
+
|
|
364
|
+
function upperCaseRenderer(markdown: string) {
|
|
365
|
+
return `<p>${markdown.toUpperCase()}</p>`
|
|
366
|
+
}
|
|
367
|
+
</script>
|
|
368
|
+
|
|
369
|
+
<!--@include: ./../../.vitepress/generated-docs/maz-markdown-editor.doc.md-->
|