Chatwoot/app/javascript/dashboard/routes/dashboard/helpcenter/pages/articles/ArticleSettings.vue
2022-08-10 11:58:19 +05:30

232 lines
5.8 KiB
Vue

<template>
<transition name="popover-animation">
<div class="article-settings--container">
<h3 class="block-title">
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.TITLE') }}
</h3>
<div class="form-wrap">
<label>
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.FORM.CATEGORY.LABEL') }}
<multiselect-dropdown
:options="categoryList"
:selected-item="selectedCategory"
:has-thumbnail="false"
:multiselector-title="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.CATEGORY.TITLE')
"
:multiselector-placeholder="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.CATEGORY.PLACEHOLDER')
"
:no-search-result="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.CATEGORY.NO_RESULT')
"
:input-placeholder="
$t(
'HELP_CENTER.ARTICLE_SETTINGS.FORM.CATEGORY.SEARCH_PLACEHOLDER'
)
"
@click="onClickSelectCategory"
/>
</label>
<label>
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.FORM.AUTHOR.LABEL') }}
<multiselect-dropdown
:options="authorList"
:selected-item="assignedAuthor"
:multiselector-title="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.AUTHOR.TITLE')
"
:multiselector-placeholder="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.AUTHOR.PLACEHOLDER')
"
:no-search-result="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.AUTHOR.NO_RESULT')
"
:input-placeholder="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.AUTHOR.SEARCH_PLACEHOLDER')
"
@click="onClickAssignAuthor"
/>
</label>
<label>
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.FORM.META_TITLE.LABEL') }}
<textarea
v-model="title"
rows="3"
type="text"
:placeholder="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.META_TITLE.PLACEHOLDER')
"
/>
</label>
<label>
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.FORM.META_DESCRIPTION.LABEL') }}
<textarea
v-model="description"
rows="3"
type="text"
:placeholder="
$t(
'HELP_CENTER.ARTICLE_SETTINGS.FORM.META_DESCRIPTION.PLACEHOLDER'
)
"
/>
</label>
<label>
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.FORM.META_TAGS.LABEL') }}
<multiselect
ref="tagInput"
v-model="values"
:placeholder="
$t('HELP_CENTER.ARTICLE_SETTINGS.FORM.META_TAGS.PLACEHOLDER')
"
label="name"
track-by="name"
:options="options"
:multiple="true"
:taggable="true"
@tag="addTagValue"
/>
</label>
</div>
<div class="action-buttons">
<woot-button
icon="archive"
size="small"
variant="clear"
color-scheme="secondary"
@click="onClickArchiveArticle"
>
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.BUTTONS.ARCHIVE') }}
</woot-button>
<woot-button
icon="delete"
size="small"
variant="clear"
color-scheme="alert"
@click="onClickDeleteArticle"
>
{{ $t('HELP_CENTER.ARTICLE_SETTINGS.BUTTONS.DELETE') }}
</woot-button>
</div>
</div>
</transition>
</template>
<script>
import MultiselectDropdown from 'shared/components/ui/MultiselectDropdown';
export default {
components: {
MultiselectDropdown,
},
data() {
return {
// Dummy value
categoryList: [
{
id: 1,
name: 'Getting started',
},
{
id: 2,
name: 'Features',
},
],
selectedCategory: {
id: 1,
name: 'Features',
},
authorList: [
{
id: 1,
name: 'John Doe',
},
{
id: 2,
name: 'Jane Doe',
},
],
assignedAuthor: {
id: 1,
name: 'John Doe',
},
title: '',
description: '',
values: [],
options: [],
};
},
methods: {
addTagValue(tagValue) {
const tag = {
name: tagValue,
};
this.values.push(tag);
this.$refs.tagInput.$el.focus();
},
onClickSelectCategory() {
this.$emit('select-category');
},
onClickAssignAuthor() {
this.$emit('assign-author');
},
onClickArchiveArticle() {
this.$emit('archive-article');
},
onClickDeleteArticle() {
this.$emit('delete-article');
},
},
};
</script>
<style lang="scss" scoped>
.article-settings--container {
flex: 0.3;
min-width: var(--space-giga);
overflow: scroll;
border-left: 1px solid var(--color-border-light);
margin-left: var(--space-normal);
padding-left: var(--space-normal);
padding-top: var(--space-small);
padding-bottom: var(--space-small);
.form-wrap {
margin-top: var(--space-normal);
margin-bottom: var(--space-medium);
textarea {
font-size: var(--font-size-small);
}
}
.action-buttons {
display: flex;
flex-direction: column;
::v-deep .button {
padding-left: 0;
}
}
}
::v-deep {
.multiselect {
margin-bottom: 0;
}
.multiselect__content-wrapper {
display: none;
}
.multiselect--active .multiselect__tags {
border-radius: var(--border-radius-normal);
padding-right: var(--space-small) !important;
}
.multiselect__placeholder {
color: var(--s-300);
padding-top: var(--space-small);
margin-bottom: 0;
}
.multiselect__select {
display: none;
}
}
</style>