zappyzep/dashboard/src/components/docs/Plugin.vue

207 lines
7.4 KiB
Vue
Raw Normal View History

2019-08-22 01:22:26 +03:00
<template>
<div v-if="loading">
Loading...
</div>
<div v-else>
<h1>{{ data.info.prettyName || data.name }}</h1>
2019-08-22 01:22:26 +03:00
2019-10-05 14:46:00 +03:00
<!-- Description -->
<MarkdownBlock :content="data.info.description" class="content"></MarkdownBlock>
<Tabs>
<Tab :active="tab === 'usage'">
<router-link v-bind:to="'/docs/plugins/' + pluginName + '/usage'">Usage</router-link>
</Tab>
<Tab :active="tab === 'configuration'">
<router-link v-bind:to="'/docs/plugins/' + pluginName + '/configuration'">Configuration</router-link>
</Tab>
</Tabs>
2019-08-22 02:58:32 +03:00
<!-- Usage tab -->
<div class="usage" v-if="tab === 'usage'">
2019-10-05 14:46:00 +03:00
<div v-if="!hasUsageInfo">
This plugin has no usage information.
See <router-link v-bind:to="'/docs/plugins/' + pluginName + '/configuration'">Configuration</router-link>.
</div>
2019-08-22 01:22:26 +03:00
<!-- Usage guide -->
<div v-if="data.info.usageGuide">
<h2 id="usage-guide">Usage guide</h2>
<MarkdownBlock :content="data.info.usageGuide" class="content"></MarkdownBlock>
2019-08-22 02:58:32 +03:00
</div>
<!-- Command list -->
<div v-if="data.commands.length">
<h2 id="commands">Commands</h2>
<div v-for="command in data.commands" class="mb-4">
<h3 class="text-xl">!{{ command.trigger }}</h3>
2019-10-05 14:46:00 +03:00
<div v-if="command.config.extra.requiredPermission">
Permission: <code class="inline-code">{{ command.config.extra.requiredPermission }}</code>
2019-08-22 02:58:32 +03:00
</div>
2019-10-05 14:46:00 +03:00
<div v-if="command.config.extra.info && command.config.extra.info.basicUsage">
Basic usage: <code class="inline-code">{{ command.config.extra.info.basicUsage }}</code>
</div>
<div v-if="command.config.aliases && command.config.aliases.length">
Shortcut:
<code class="inline-code" style="margin-right: 4px" v-for="alias in command.config.aliases">!{{ alias }}</code>
</div>
2019-10-10 22:55:31 +03:00
<MarkdownBlock v-if="command.config.extra.info && command.config.extra.info.description" :content="command.config.extra.info.description" class="content"></MarkdownBlock>
2019-08-22 02:58:32 +03:00
<Expandable class="mt-4">
<template v-slot:title>Additional information</template>
<template v-slot:content>
Signatures:
<ul>
<li>
2019-10-10 22:55:31 +03:00
<code class="inline-code bg-gray-900">
!{{ command.trigger }}
<span v-for="param in command.parameters">{{ renderParameter(param) }} </span>
</code>
2019-08-22 02:58:32 +03:00
</li>
</ul>
<div class="mt-2" v-if="command.parameters.length">
Command arguments:
<ul>
<li v-for="param in command.parameters">
<code>{{ renderParameter(param) }}</code>
2019-10-05 14:46:00 +03:00
<router-link :to="'/docs/reference/argument-types#' + (param.type || 'string')">{{ param.type || 'string' }}</router-link>
<MarkdownBlock v-if="command.config.info && command.config.info.parameterDescriptions && command.config.info.parameterDescriptions[param.name]"
:content="command.config.info.parameterDescriptions[param.name]"
class="content">
</MarkdownBlock>
</li>
</ul>
</div>
2019-10-05 14:46:00 +03:00
<div class="mt-2" v-if="command.config.options && command.config.options.length">
Options:
2019-10-10 22:55:31 +03:00
<ul>
2019-10-05 14:46:00 +03:00
<li v-for="opt in command.config.options">
<code>{{ renderOption(opt) }}</code>
<router-link :to="'/docs/reference/argument-types#' + (opt.type || 'string')">{{ opt.type || 'string' }}</router-link>
<MarkdownBlock v-if="command.config.info && command.config.info.optionDescriptions && command.config.info.optionDescriptions[opt.name]"
:content="command.config.info.optionDescriptions[opt.name]"
class="content">
</MarkdownBlock>
</li>
</ul>
</div>
</template>
</Expandable>
</div>
2019-08-22 01:22:26 +03:00
</div>
</div>
<!-- Configuration tab -->
<div class="configuration" v-if="tab === 'configuration'">
<!-- Basic config info -->
<p>
<strong>Name in config:</strong> <code>{{ data.name }}</code><br>
To enable this plugin with default configuration, add <code>{{ data.name }}: {}</code> to the <code>plugins</code> list in config
</p>
<!-- Configuration guide -->
<div v-if="data.info.configurationGuide">
<h2 id="configuration-guide">Configuration guide</h2>
<MarkdownBlock :content="data.info.configurationGuide" class="content"></MarkdownBlock>
</div>
<!-- Default configuration -->
<h2 id="default-configuration">Default configuration</h2>
<CodeBlock lang="yaml">{{ renderConfiguration(data.defaultOptions) }}</CodeBlock>
<!-- Config schema -->
<h2 id="config-schema">Config schema</h2>
<Expandable class="wide">
<template v-slot:title>Click to expand</template>
<template v-slot:content>
<CodeBlock lang="plain">{{ data.configSchema }}</CodeBlock>
</template>
</Expandable>
</div>
2019-08-22 01:22:26 +03:00
</div>
</template>
<script lang="ts">
2019-08-22 01:22:26 +03:00
import Vue from "vue";
import {mapState} from "vuex";
import yaml from "js-yaml";
import CodeBlock from "./CodeBlock.vue";
import MarkdownBlock from "./MarkdownBlock.vue";
import Tabs from "../Tabs.vue";
import Tab from "../Tab.vue";
import Expandable from "../Expandable.vue";
import { DocsState } from "../../store/types";
const validTabs = ['usage', 'configuration'];
const defaultTab = 'usage';
2019-08-22 01:22:26 +03:00
export default {
components: { CodeBlock, MarkdownBlock, Tabs, Tab, Expandable },
2019-08-22 01:22:26 +03:00
async mounted() {
this.loading = true;
2019-10-05 14:46:00 +03:00
2019-08-22 01:22:26 +03:00
await this.$store.dispatch("docs/loadPluginData", this.pluginName);
2019-10-05 14:46:00 +03:00
// If there's no usage info, use Configuration as the default tab
if (!this.hasUsageInfo && ! this.$route.params.tab) {
this.tab = 'configuration';
}
2019-08-22 01:22:26 +03:00
this.loading = false;
},
methods: {
renderConfiguration(options) {
return yaml.safeDump({
[this.pluginName]: options,
});
},
2019-08-22 02:58:32 +03:00
renderParameter(param) {
let str = `${param.name}`;
if (param.rest) str += '...';
if (param.required) {
return `<${str}>`;
} else {
return `[${str}]`;
}
},
2019-10-05 14:46:00 +03:00
renderOption(opt) {
let str = `-${opt.name}`;
2019-10-05 14:46:00 +03:00
if (opt.shortcut) {
str += `|-${opt.shortcut}`;
}
if (opt.required) {
return `<${str}>`;
} else {
return `[${str}]`;
}
},
2019-08-22 01:22:26 +03:00
},
data() {
return {
loading: true,
pluginName: this.$route.params.pluginName,
tab: validTabs.includes(this.$route.params.tab)
? this.$route.params.tab
: defaultTab,
2019-08-22 01:22:26 +03:00
};
},
computed: {
...mapState("docs", {
data(state: DocsState) {
2019-08-22 01:22:26 +03:00
return state.plugins[this.pluginName];
},
2019-10-05 14:46:00 +03:00
hasUsageInfo() {
if (!this.data) return true;
if (this.data.commands.length) return true;
if (this.data.info.usageGuide) return true;
return false;
},
2019-08-22 01:22:26 +03:00
}),
},
}
</script>