Merge branch 'front-styles' of ssh://git.ma-al.com:8822/goc_daniel/b2b into translate
This commit is contained in:
160
bo/src/components/inner/ProductEditor.vue
Normal file
160
bo/src/components/inner/ProductEditor.vue
Normal file
@@ -0,0 +1,160 @@
|
||||
<template>
|
||||
<UEditor v-slot="{ editor }" v-model="localValue" content-type="html"
|
||||
:ui="{ base: 'p-8 sm:px-16', root: 'p-2' }"
|
||||
class="min-w-full border rounded-md border-(--border-light)" placeholder="Write there ...">
|
||||
<UEditorToolbar :editor="editor" :items="toolbarItems" class="sm:px-8 flex-wrap!">
|
||||
<template #link>
|
||||
<EditorLinkPopover :editor="editor" auto-open />
|
||||
</template>
|
||||
</UEditorToolbar>
|
||||
</UEditor>
|
||||
</template>
|
||||
|
||||
<script lang="ts" setup>
|
||||
import type { EditorToolbarItem } from '@nuxt/ui';
|
||||
import { computed } from 'vue';
|
||||
|
||||
const props = defineProps<{
|
||||
modelValue: string
|
||||
}>()
|
||||
|
||||
const emit = defineEmits<{
|
||||
(e: 'update:modelValue', value: string): void
|
||||
}>()
|
||||
|
||||
const localValue = computed({
|
||||
get: () => props.modelValue,
|
||||
set: (value: string) => emit('update:modelValue', value)
|
||||
})
|
||||
|
||||
const toolbarItems: EditorToolbarItem[][] = [
|
||||
// History controls
|
||||
[{
|
||||
kind: 'undo',
|
||||
icon: 'i-lucide-undo',
|
||||
tooltip: { text: 'Undo' }
|
||||
}, {
|
||||
kind: 'redo',
|
||||
icon: 'i-lucide-redo',
|
||||
tooltip: { text: 'Redo' }
|
||||
}],
|
||||
// Block types
|
||||
[{
|
||||
icon: 'i-lucide-heading',
|
||||
tooltip: { text: 'Headings' },
|
||||
content: {
|
||||
align: 'start'
|
||||
},
|
||||
items: [{
|
||||
kind: 'heading',
|
||||
level: 1,
|
||||
icon: 'i-lucide-heading-1',
|
||||
label: 'Heading 1'
|
||||
}, {
|
||||
kind: 'heading',
|
||||
level: 2,
|
||||
icon: 'i-lucide-heading-2',
|
||||
label: 'Heading 2'
|
||||
}, {
|
||||
kind: 'heading',
|
||||
level: 3,
|
||||
icon: 'i-lucide-heading-3',
|
||||
label: 'Heading 3'
|
||||
}, {
|
||||
kind: 'heading',
|
||||
level: 4,
|
||||
icon: 'i-lucide-heading-4',
|
||||
label: 'Heading 4'
|
||||
}]
|
||||
}, {
|
||||
icon: 'i-lucide-list',
|
||||
tooltip: { text: 'Lists' },
|
||||
content: {
|
||||
align: 'start'
|
||||
},
|
||||
items: [{
|
||||
kind: 'bulletList',
|
||||
icon: 'i-lucide-list',
|
||||
label: 'Bullet List'
|
||||
}, {
|
||||
kind: 'orderedList',
|
||||
icon: 'i-lucide-list-ordered',
|
||||
label: 'Ordered List'
|
||||
}]
|
||||
}, {
|
||||
kind: 'blockquote',
|
||||
icon: 'i-lucide-text-quote',
|
||||
tooltip: { text: 'Blockquote' }
|
||||
}, {
|
||||
kind: 'codeBlock',
|
||||
icon: 'i-lucide-square-code',
|
||||
tooltip: { text: 'Code Block' }
|
||||
}, {
|
||||
kind: 'horizontalRule',
|
||||
icon: 'i-lucide-separator-horizontal',
|
||||
tooltip: { text: 'Horizontal Rule' }
|
||||
}],
|
||||
// Text formatting
|
||||
[{
|
||||
kind: 'mark',
|
||||
mark: 'bold',
|
||||
icon: 'i-lucide-bold',
|
||||
tooltip: { text: 'Bold' }
|
||||
}, {
|
||||
kind: 'mark',
|
||||
mark: 'italic',
|
||||
icon: 'i-lucide-italic',
|
||||
tooltip: { text: 'Italic' }
|
||||
}, {
|
||||
kind: 'mark',
|
||||
mark: 'underline',
|
||||
icon: 'i-lucide-underline',
|
||||
tooltip: { text: 'Underline' }
|
||||
}, {
|
||||
kind: 'mark',
|
||||
mark: 'strike',
|
||||
icon: 'i-lucide-strikethrough',
|
||||
tooltip: { text: 'Strikethrough' }
|
||||
}, {
|
||||
kind: 'mark',
|
||||
mark: 'code',
|
||||
icon: 'i-lucide-code',
|
||||
tooltip: { text: 'Code' }
|
||||
}],
|
||||
// Link
|
||||
[{
|
||||
kind: 'link',
|
||||
icon: 'i-lucide-link',
|
||||
tooltip: { text: 'Link' }
|
||||
}],
|
||||
// Text alignment
|
||||
[{
|
||||
icon: 'i-lucide-align-justify',
|
||||
tooltip: { text: 'Text Align' },
|
||||
content: {
|
||||
align: 'end'
|
||||
},
|
||||
items: [{
|
||||
kind: 'textAlign',
|
||||
align: 'left',
|
||||
icon: 'i-lucide-align-left',
|
||||
label: 'Align Left'
|
||||
}, {
|
||||
kind: 'textAlign',
|
||||
align: 'center',
|
||||
icon: 'i-lucide-align-center',
|
||||
label: 'Align Center'
|
||||
}, {
|
||||
kind: 'textAlign',
|
||||
align: 'right',
|
||||
icon: 'i-lucide-align-right',
|
||||
label: 'Align Right'
|
||||
}, {
|
||||
kind: 'textAlign',
|
||||
align: 'justify',
|
||||
icon: 'i-lucide-align-justify',
|
||||
label: 'Align Justify'
|
||||
}]
|
||||
}]
|
||||
]
|
||||
</script>
|
||||
Reference in New Issue
Block a user