Compare commits

..

4 Commits

4 changed files with 62 additions and 70 deletions

View File

@ -1,5 +1,9 @@
<template> <template>
<div class="bg-white rounded-lg shadow"> <div
class="bg-white rounded-lg shadow dark:bg-gray-800 dark:text-white dark:shadow-glass dark:border dark:border-white/10 dark:bg-gray-800/70 relative"
>
<BaseDarkHighlight class="z-[-1] mt-10" />
<div <div
v-if="hasHeaderSlot" v-if="hasHeaderSlot"
class="px-5 py-4 text-black border-b border-gray-100 border-solid" class="px-5 py-4 text-black border-b border-gray-100 border-solid"

View File

@ -0,0 +1,21 @@
<template>
<div
class="
hidden
top-0
w-full
absolute
ml-auto
mr-auto
left-0
right-0
text-center
h-full
rounded-full
bg-highlight/[.10]
blur-2xl
dark:block
z-[-1]
"
/>
</template>

View File

@ -16,15 +16,13 @@
text-left text-left
bg-white bg-white
border border-gray-200 border border-gray-200
dark:border-gray-600
rounded-md rounded-md
min-h-[200px] min-h-[200px]
overflow-hidden overflow-hidden
dark:bg-gray-700 dark:text-white
" "
> >
<div v-if="editor" class="editor-content"> <div v-if="editor" class="editor-content">
<div class="flex justify-end p-2 border-b border-gray-200 dark:border-gray-600 md:hidden"> <div class="flex justify-end p-2 border-b border-gray-200 md:hidden">
<BaseDropdown width-class="w-48"> <BaseDropdown width-class="w-48">
<template #activator> <template #activator>
<div <div
@ -44,7 +42,7 @@
<dots-vertical-icon class="w-6 h-6 text-gray-600" /> <dots-vertical-icon class="w-6 h-6 text-gray-600" />
</div> </div>
</template> </template>
<div class="flex flex-wrap space-x-1 dark:text-white"> <div class="flex flex-wrap space-x-1">
<span <span
class=" class="
flex flex
@ -55,9 +53,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('bold') }" :class="{ 'bg-gray-200': editor.isActive('bold') }"
@click="editor.chain().focus().toggleBold().run()" @click="editor.chain().focus().toggleBold().run()"
> >
<bold-icon class="h-3 cursor-pointer fill-current" /> <bold-icon class="h-3 cursor-pointer fill-current" />
@ -72,9 +69,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('italic') }" :class="{ 'bg-gray-200': editor.isActive('italic') }"
@click="editor.chain().focus().toggleItalic().run()" @click="editor.chain().focus().toggleItalic().run()"
> >
<italic-icon class="h-3 cursor-pointer fill-current" /> <italic-icon class="h-3 cursor-pointer fill-current" />
@ -89,9 +85,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('strike') }" :class="{ 'bg-gray-200': editor.isActive('strike') }"
@click="editor.chain().focus().toggleStrike().run()" @click="editor.chain().focus().toggleStrike().run()"
> >
<strikethrough-icon class="h-3 cursor-pointer fill-current" /> <strikethrough-icon class="h-3 cursor-pointer fill-current" />
@ -106,9 +101,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('code') }" :class="{ 'bg-gray-200': editor.isActive('code') }"
@click="editor.chain().focus().toggleCode().run()" @click="editor.chain().focus().toggleCode().run()"
> >
<coding-icon class="h-3 cursor-pointer fill-current" /> <coding-icon class="h-3 cursor-pointer fill-current" />
@ -123,9 +117,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('paragraph') }" :class="{ 'bg-gray-200': editor.isActive('paragraph') }"
@click="editor.chain().focus().setParagraph().run()" @click="editor.chain().focus().setParagraph().run()"
> >
<paragraph-icon class="h-3 cursor-pointer fill-current" /> <paragraph-icon class="h-3 cursor-pointer fill-current" />
@ -140,10 +133,9 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ :class="{
'bg-gray-200 dark:bg-gray-900': editor.isActive('heading', { level: 1 }), 'bg-gray-200': editor.isActive('heading', { level: 1 }),
}" }"
@click="editor.chain().focus().toggleHeading({ level: 1 }).run()" @click="editor.chain().focus().toggleHeading({ level: 1 }).run()"
> >
@ -159,10 +151,9 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ :class="{
'bg-gray-200 dark:bg-gray-900': editor.isActive('heading', { level: 2 }), 'bg-gray-200': editor.isActive('heading', { level: 2 }),
}" }"
@click="editor.chain().focus().toggleHeading({ level: 2 }).run()" @click="editor.chain().focus().toggleHeading({ level: 2 }).run()"
> >
@ -178,10 +169,9 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ :class="{
'bg-gray-200 dark:bg-gray-900': editor.isActive('heading', { level: 3 }), 'bg-gray-200': editor.isActive('heading', { level: 3 }),
}" }"
@click="editor.chain().focus().toggleHeading({ level: 3 }).run()" @click="editor.chain().focus().toggleHeading({ level: 3 }).run()"
> >
@ -198,9 +188,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('bulletList') }" :class="{ 'bg-gray-200': editor.isActive('bulletList') }"
@click="editor.chain().focus().toggleBulletList().run()" @click="editor.chain().focus().toggleBulletList().run()"
> >
<list-ul-icon class="h-3 cursor-pointer fill-current" /> <list-ul-icon class="h-3 cursor-pointer fill-current" />
@ -215,9 +204,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('orderedList') }" :class="{ 'bg-gray-200': editor.isActive('orderedList') }"
@click="editor.chain().focus().toggleOrderedList().run()" @click="editor.chain().focus().toggleOrderedList().run()"
> >
<list-icon class="h-3 cursor-pointer fill-current" /> <list-icon class="h-3 cursor-pointer fill-current" />
@ -232,9 +220,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('blockquote') }" :class="{ 'bg-gray-200': editor.isActive('blockquote') }"
@click="editor.chain().focus().toggleBlockquote().run()" @click="editor.chain().focus().toggleBlockquote().run()"
> >
<quote-icon class="h-3 cursor-pointer fill-current" /> <quote-icon class="h-3 cursor-pointer fill-current" />
@ -249,9 +236,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('codeBlock') }" :class="{ 'bg-gray-200': editor.isActive('codeBlock') }"
@click="editor.chain().focus().toggleCodeBlock().run()" @click="editor.chain().focus().toggleCodeBlock().run()"
> >
<code-block-icon class="h-3 cursor-pointer fill-current" /> <code-block-icon class="h-3 cursor-pointer fill-current" />
@ -266,9 +252,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('undo') }" :class="{ 'bg-gray-200': editor.isActive('undo') }"
@click="editor.chain().focus().undo().run()" @click="editor.chain().focus().undo().run()"
> >
<undo-icon class="h-3 cursor-pointer fill-current" /> <undo-icon class="h-3 cursor-pointer fill-current" />
@ -283,9 +268,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('redo') }" :class="{ 'bg-gray-200': editor.isActive('redo') }"
@click="editor.chain().focus().redo().run()" @click="editor.chain().focus().redo().run()"
> >
<redo-icon class="h-3 cursor-pointer fill-current" /> <redo-icon class="h-3 cursor-pointer fill-current" />
@ -293,7 +277,7 @@
</div> </div>
</BaseDropdown> </BaseDropdown>
</div> </div>
<div class="hidden p-2 border-b border-gray-200 dark:border-gray-600 md:flex"> <div class="hidden p-2 border-b border-gray-200 md:flex">
<div class="flex flex-wrap space-x-1"> <div class="flex flex-wrap space-x-1">
<span <span
class=" class="
@ -305,9 +289,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('bold') }" :class="{ 'bg-gray-200': editor.isActive('bold') }"
@click="editor.chain().focus().toggleBold().run()" @click="editor.chain().focus().toggleBold().run()"
> >
<bold-icon class="h-3 cursor-pointer fill-current" /> <bold-icon class="h-3 cursor-pointer fill-current" />
@ -322,9 +305,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('italic') }" :class="{ 'bg-gray-200': editor.isActive('italic') }"
@click="editor.chain().focus().toggleItalic().run()" @click="editor.chain().focus().toggleItalic().run()"
> >
<italic-icon class="h-3 cursor-pointer fill-current" /> <italic-icon class="h-3 cursor-pointer fill-current" />
@ -339,9 +321,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('strike') }" :class="{ 'bg-gray-200': editor.isActive('strike') }"
@click="editor.chain().focus().toggleStrike().run()" @click="editor.chain().focus().toggleStrike().run()"
> >
<strikethrough-icon class="h-3 cursor-pointer fill-current" /> <strikethrough-icon class="h-3 cursor-pointer fill-current" />
@ -356,9 +337,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('code') }" :class="{ 'bg-gray-200': editor.isActive('code') }"
@click="editor.chain().focus().toggleCode().run()" @click="editor.chain().focus().toggleCode().run()"
> >
<coding-icon class="h-3 cursor-pointer fill-current" /> <coding-icon class="h-3 cursor-pointer fill-current" />
@ -373,9 +353,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('paragraph') }" :class="{ 'bg-gray-200': editor.isActive('paragraph') }"
@click="editor.chain().focus().setParagraph().run()" @click="editor.chain().focus().setParagraph().run()"
> >
<paragraph-icon class="h-3 cursor-pointer fill-current" /> <paragraph-icon class="h-3 cursor-pointer fill-current" />
@ -390,9 +369,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('heading', { level: 1 }) }" :class="{ 'bg-gray-200': editor.isActive('heading', { level: 1 }) }"
@click="editor.chain().focus().toggleHeading({ level: 1 }).run()" @click="editor.chain().focus().toggleHeading({ level: 1 }).run()"
> >
H1 H1
@ -407,9 +385,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('heading', { level: 2 }) }" :class="{ 'bg-gray-200': editor.isActive('heading', { level: 2 }) }"
@click="editor.chain().focus().toggleHeading({ level: 2 }).run()" @click="editor.chain().focus().toggleHeading({ level: 2 }).run()"
> >
H2 H2
@ -424,9 +401,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('heading', { level: 3 }) }" :class="{ 'bg-gray-200': editor.isActive('heading', { level: 3 }) }"
@click="editor.chain().focus().toggleHeading({ level: 3 }).run()" @click="editor.chain().focus().toggleHeading({ level: 3 }).run()"
> >
H3 H3
@ -442,9 +418,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('bulletList') }" :class="{ 'bg-gray-200': editor.isActive('bulletList') }"
@click="editor.chain().focus().toggleBulletList().run()" @click="editor.chain().focus().toggleBulletList().run()"
> >
<list-ul-icon class="h-3 cursor-pointer fill-current" /> <list-ul-icon class="h-3 cursor-pointer fill-current" />
@ -459,9 +434,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('orderedList') }" :class="{ 'bg-gray-200': editor.isActive('orderedList') }"
@click="editor.chain().focus().toggleOrderedList().run()" @click="editor.chain().focus().toggleOrderedList().run()"
> >
<list-icon class="h-3 cursor-pointer fill-current" /> <list-icon class="h-3 cursor-pointer fill-current" />
@ -476,9 +450,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('blockquote') }" :class="{ 'bg-gray-200': editor.isActive('blockquote') }"
@click="editor.chain().focus().toggleBlockquote().run()" @click="editor.chain().focus().toggleBlockquote().run()"
> >
<quote-icon class="h-3 cursor-pointer fill-current" /> <quote-icon class="h-3 cursor-pointer fill-current" />
@ -493,9 +466,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('codeBlock') }" :class="{ 'bg-gray-200': editor.isActive('codeBlock') }"
@click="editor.chain().focus().toggleCodeBlock().run()" @click="editor.chain().focus().toggleCodeBlock().run()"
> >
<code-block-icon class="h-3 cursor-pointer fill-current" /> <code-block-icon class="h-3 cursor-pointer fill-current" />
@ -510,9 +482,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('undo') }" :class="{ 'bg-gray-200': editor.isActive('undo') }"
@click="editor.chain().focus().undo().run()" @click="editor.chain().focus().undo().run()"
> >
<undo-icon class="h-3 cursor-pointer fill-current" /> <undo-icon class="h-3 cursor-pointer fill-current" />
@ -527,9 +498,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive('redo') }" :class="{ 'bg-gray-200': editor.isActive('redo') }"
@click="editor.chain().focus().redo().run()" @click="editor.chain().focus().redo().run()"
> >
<redo-icon class="h-3 cursor-pointer fill-current" /> <redo-icon class="h-3 cursor-pointer fill-current" />
@ -544,9 +514,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive({ textAlign: 'left' }) }" :class="{ 'bg-gray-200': editor.isActive({ textAlign: 'left' }) }"
@click="editor.chain().focus().setTextAlign('left').run()" @click="editor.chain().focus().setTextAlign('left').run()"
> >
<menu-alt2-icon class="h-5 cursor-pointer fill-current" /> <menu-alt2-icon class="h-5 cursor-pointer fill-current" />
@ -561,9 +530,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive({ textAlign: 'right' }) }" :class="{ 'bg-gray-200': editor.isActive({ textAlign: 'right' }) }"
@click="editor.chain().focus().setTextAlign('right').run()" @click="editor.chain().focus().setTextAlign('right').run()"
> >
<menu-alt3-icon class="h-5 cursor-pointer fill-current" /> <menu-alt3-icon class="h-5 cursor-pointer fill-current" />
@ -578,10 +546,9 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ :class="{
'bg-gray-200 dark:bg-gray-900': editor.isActive({ textAlign: 'justify' }), 'bg-gray-200': editor.isActive({ textAlign: 'justify' }),
}" }"
@click="editor.chain().focus().setTextAlign('justify').run()" @click="editor.chain().focus().setTextAlign('justify').run()"
> >
@ -597,9 +564,8 @@
rounded-sm rounded-sm
cursor-pointer cursor-pointer
hover:bg-gray-100 hover:bg-gray-100
dark:hover:bg-gray-800
" "
:class="{ 'bg-gray-200 dark:bg-gray-900': editor.isActive({ textAlign: 'center' }) }" :class="{ 'bg-gray-200': editor.isActive({ textAlign: 'center' }) }"
@click="editor.chain().focus().setTextAlign('center').run()" @click="editor.chain().focus().setTextAlign('center').run()"
> >
<menu-center-icon class="h-5 cursor-pointer fill-current" /> <menu-center-icon class="h-5 cursor-pointer fill-current" />

View File

@ -36,6 +36,7 @@ module.exports = {
900: withOpacityValue('--color-primary-900'), 900: withOpacityValue('--color-primary-900'),
}, },
black: '#040405', black: '#040405',
highlight: 'rgb(56, 189, 248)',
red: colors.red, red: colors.red,
teal: colors.teal, teal: colors.teal,
gray: colors.slate, gray: colors.slate,