feat: Add portal empty state (#10277)
This commit is contained in:
@@ -0,0 +1,16 @@
|
|||||||
|
<script setup>
|
||||||
|
import PortalEmptyState from './PortalEmptyState.vue';
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<Story
|
||||||
|
title="Components/HelpCenter/EmptyState/PortalEmptyState"
|
||||||
|
:layout="{ type: 'single', width: '1100px' }"
|
||||||
|
>
|
||||||
|
<Variant title="Portal Empty State">
|
||||||
|
<div class="w-full h-full px-20 mx-auto bg-white dark:bg-slate-900">
|
||||||
|
<PortalEmptyState />
|
||||||
|
</div>
|
||||||
|
</Variant>
|
||||||
|
</Story>
|
||||||
|
</template>
|
||||||
@@ -0,0 +1,123 @@
|
|||||||
|
<script setup>
|
||||||
|
// import { ref } from 'vue';
|
||||||
|
import EmptyStateLayout from 'dashboard/components-next/EmptyStateLayout.vue';
|
||||||
|
import Button from 'dashboard/components-next/button/Button.vue';
|
||||||
|
import ArticleCard from 'dashboard/components-next/HelpCenter/ArticleCard/ArticleCard.vue';
|
||||||
|
import CategoryCard from 'dashboard/components-next/HelpCenter/CategoryCard/CategoryCard.vue';
|
||||||
|
import LocaleCard from 'dashboard/components-next/HelpCenter/LocaleCard/LocaleCard.vue';
|
||||||
|
// import CreatePortalDialog from 'dashboard/playground/HelpCenter/components/CreatePortalDialog.vue';
|
||||||
|
|
||||||
|
const articles = [
|
||||||
|
{
|
||||||
|
title: "How to get an SSL certificate for your Help Center's custom domain",
|
||||||
|
status: 'draft',
|
||||||
|
updatedAt: '2 days ago',
|
||||||
|
author: 'Michael',
|
||||||
|
category: '⚡️ Marketing',
|
||||||
|
views: 3400,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Setting up your first Help Center portal',
|
||||||
|
status: '',
|
||||||
|
updatedAt: '1 week ago',
|
||||||
|
author: 'John',
|
||||||
|
category: '🛠️ Development',
|
||||||
|
views: 400,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Best practices for organizing your Help Center content',
|
||||||
|
status: 'archived',
|
||||||
|
updatedAt: '3 days ago',
|
||||||
|
author: 'Fernando',
|
||||||
|
category: '💰 Finance',
|
||||||
|
views: 400,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Customizing the appearance of your Help Center',
|
||||||
|
status: '',
|
||||||
|
updatedAt: '5 days ago',
|
||||||
|
author: 'Jane',
|
||||||
|
category: '💰 Finance',
|
||||||
|
views: 400,
|
||||||
|
},
|
||||||
|
];
|
||||||
|
const categories = [
|
||||||
|
{
|
||||||
|
title: 'Getting Started',
|
||||||
|
description: 'Essential guides for new users',
|
||||||
|
articlesCount: '5',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Advanced Features',
|
||||||
|
description: 'In-depth tutorials for power users',
|
||||||
|
articlesCount: '8',
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const locales = [
|
||||||
|
{ name: 'English', isDefault: true },
|
||||||
|
{ name: 'Spanish', isDefault: false },
|
||||||
|
{ name: 'Malayalam', isDefault: false },
|
||||||
|
];
|
||||||
|
|
||||||
|
// const createPortalDialogRef = ref(null);
|
||||||
|
// const openDialog = () => {
|
||||||
|
// createPortalDialogRef.value.dialogRef.open();
|
||||||
|
// };
|
||||||
|
// const handleDialogConfirm = () => {
|
||||||
|
// // Add logic to create a new portal
|
||||||
|
// };
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<!-- TODO: Add i18n -->
|
||||||
|
<!-- eslint-disable vue/no-bare-strings-in-template -->
|
||||||
|
<template>
|
||||||
|
<EmptyStateLayout
|
||||||
|
title="Help Center"
|
||||||
|
subtitle="Create self-service portals to access articles and information. Streamline queries, enhance agent efficiency, and elevate customer support."
|
||||||
|
>
|
||||||
|
<template #empty-state-item>
|
||||||
|
<div class="grid grid-cols-2 gap-4">
|
||||||
|
<div class="space-y-4">
|
||||||
|
<ArticleCard
|
||||||
|
v-for="(article, index) in articles"
|
||||||
|
:key="`article-${index}`"
|
||||||
|
:title="article.title"
|
||||||
|
:status="article.status"
|
||||||
|
:updated-at="article.updatedAt"
|
||||||
|
:author="article.author"
|
||||||
|
:category="article.category"
|
||||||
|
:views="article.views"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div class="space-y-4">
|
||||||
|
<CategoryCard
|
||||||
|
v-for="(category, index) in categories"
|
||||||
|
:key="`category-${index}`"
|
||||||
|
:title="category.title"
|
||||||
|
:description="category.description"
|
||||||
|
:articles-count="category.articlesCount"
|
||||||
|
/>
|
||||||
|
<LocaleCard
|
||||||
|
v-for="(locale, index) in locales"
|
||||||
|
:key="`locale-${index}`"
|
||||||
|
:locale="locale.name"
|
||||||
|
:is-default="locale.isDefault"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<template #actions>
|
||||||
|
<Button
|
||||||
|
variant="default"
|
||||||
|
label="Create Portal"
|
||||||
|
icon="add"
|
||||||
|
@click="openDialog"
|
||||||
|
/>
|
||||||
|
<!-- <CreatePortalDialog
|
||||||
|
ref="createPortalDialogRef"
|
||||||
|
@confirm="handleDialogConfirm"
|
||||||
|
/> -->
|
||||||
|
</template>
|
||||||
|
</EmptyStateLayout>
|
||||||
|
</template>
|
||||||
Reference in New Issue
Block a user