# Getting Started

# Choose a platform to use

Vssue can enable comments for your static pages via the Issue System of Github, Gitlab, Bitbucket, Gitee or Gitea, and you can choose one of those platforms.

Go to Supported Platforms - Set up OAuth App for detailed instructions.

After this step, you will get client id and client secret of your OAuth App, which will be used for Vssue options:

  • owner: the account / group that owns the repository
  • repo: the name of the repository to store comments
  • clientId: the client id of your oauth app
  • clientSecret: the client secret of your oauth app (only required for some of the platforms)

# In Browser

Vssue can be used directly via a <script> tag in browser. As Vssue depends on Vue.js, you should also import Vue.

<head>
  <!-- style sheet of Vssue -->
  <link rel="stylesheet" href="https://unpkg.com/vssue/dist/vssue.min.css">
</head>

<body>
  <div id="vssue"></div>

  <!-- Introduce Vue first -->

  <!-- vue runtime build (runtime only)  -->
  <script src="https://unpkg.com/vue@2.7.14/dist/vue.runtime.min.js"></script>
  <!-- OR: vue full build (runtime + compiler)  -->
  <script src="https://unpkg.com/vue@2.7.14/dist/vue.min.js"></script>

  <!-- Introduce Vssue after Vue -->

  <!-- Vssue Github build -->
  <script src="https://unpkg.com/vssue/dist/vssue.github.min.js"></script>
  <!-- OR: Vssue Gitlab build -->
  <script src="https://unpkg.com/vssue/dist/vssue.gitlab.min.js"></script>
  <!-- OR: Vssue Bitbucket build -->
  <script src="https://unpkg.com/vssue/dist/vssue.bitbucket.min.js"></script>
  <!-- OR: Vssue Gitee build -->
  <script src="https://unpkg.com/vssue/dist/vssue.gitee.min.js"></script>
  <!-- OR: Vssue Gitea build -->
  <script src="https://unpkg.com/vssue/dist/vssue.gitea.min.js"></script>

  <!-- Use Vssue as a Vue component -->

  <!-- use render function for vue runtime build -->
  <script>
    new Vue({
      el: '#vssue',

      render: h => h('Vssue', {
        props: {
          // here set the title of issue of current page
          title: 'Vssue Dev',

          // here set the options for your OAuth App
          options: {
            owner: 'OWNER_OF_REPO',
            repo: 'NAME_OF_REPO',
            clientId: 'YOUR_CLIENT_ID',
            clientSecret: 'YOUR_CLIENT_SECRET', // only required for some of the platforms
          },
        }
      })
    })
  </script>

  <!-- OR: use template for vue full build -->
  <script>
    new Vue({
      el: '#vssue',

      data: {
        title: 'Vssue Dev',

        options: {
          owner: 'OWNER_OF_REPO',
          repo: 'NAME_OF_REPO',
          clientId: 'YOUR_CLIENT_ID',
          clientSecret: 'YOUR_CLIENT_SECRET', // only required for some of the platforms
        },
      },

      template: `<vssue :title="title" :options="options"></vssue>`,
    })
  </script>
</body>

TIP

If you are not familiar with the different builds of Vue (i.e. vue.runtime.min.js, vue.min.js, etc.), see Vue Docs.

Vssue also provide multiple builds. See Explanation-of-Different-Builds section for more details.

# In Vue App

Vssue is a Vue Plugin / Component, so could be imported in Vue Apps.

TIP

Vssue only provides ES2015 code as we assume you are using vue-cli or other tools.

# Install via npm

Install vssue:

npm install vssue

Install the api package for different platform:

See Supported Platforms for more details.

# use Github V3
npm install @vssue/api-github-v3
# OR: use Github V4
npm install @vssue/api-github-v4
# OR: use Gitlab V4
npm install @vssue/api-gitlab-v4
# OR: use Bitbucket V2
npm install @vssue/api-bitbucket-v2
# OR: use Gitee V5
npm install @vssue/api-gitee-v5
# OR: use Gitea V1
npm install @vssue/api-gitea-v1

# Use as a Vue Plugin

By import Vssue from 'vssue' you will get a Vue plugin. Call Vue.use() to use it and set the options. A global component named Vssue will be registered.

For the details of options, see Options Reference - Vssue Options

// import vue
import Vue from 'vue'
// import vssue
import Vssue from 'vssue'
// import the api package for specific platform
import GithubV3 from '@vssue/api-github-v3'
// import the stylesheet of vssue
import 'vssue/dist/vssue.css'

Vue.use(Vssue, {
  // set the platform api
  api: GithubV3,

  // here set the default options for your OAuth App
  owner: 'OWNER_OF_REPO',
  repo: 'NAME_OF_REPO',
  clientId: 'YOUR_CLIENT_ID',
  clientSecret: 'YOUR_CLIENT_SECRET', // only required for some of the platforms
})

Then you can use Vssue Component in your SFC:

For the details of component props, see Options Reference - Component Props

<template>
  <Vssue
    :title="title"
    :options="options"
  />
</template>

<script>
export default {
  name: 'VssueDemo',

  data () {
    return {
      // here set the title of issue of current page
      title: 'Vssue Demo',

      // notice that, the options here will override the default options set by `Vue.use()` above
      // if you do not want to change them, just set the `title` prop, and ignore the `options` prop
      options: {
        // owner: 'OWNER_OF_REPO',
        // repo: 'NAME_OF_REPO',
        // clientId: 'YOUR_CLIENT_ID',
        // clientSecret: 'YOUR_CLIENT_SECRET', // only required for some of the platforms
      },
    }
  },
}
</script>

# Use as a Vue Component

By import { VssueComponent } from 'vssue' you will get a Vue component.

TIP

When you use Vssue as a Plugin by Vue.use(), this component has already been registered as a global component named Vssue via Vue.component().

If you don't want to register it globally, you can import it this way.

Notice that if you only import the Vssue component, there is no "global" options set by Vue.use(), and you have to set all required Vssue Options via the prop options. See Component Props - options.

<template>
  <Vssue
    :title="title"
    :options="options"
  />
</template>

<script>
import { VssueComponent } from 'vssue'
import GithubV3 from '@vssue/api-github-v3'
import 'vssue/dist/vssue.css'

export default {
  name: 'VssueDemo',

  components: {
    'Vssue': VssueComponent,
  },

  data () {
    return {
      title: 'Vssue Demo',
      options: {
        api: GithubV3,
        owner: 'OWNER_OF_REPO',
        repo: 'NAME_OF_REPO',
        clientId: 'YOUR_CLIENT_ID',
        clientSecret: 'YOUR_CLIENT_SECRET', // only required for some of the platforms
      },
    }
  },
}
</script>

# Explanation of Different Builds

Similar to Vue, Vssue also provide different builds for different usage.

These files are located in the dist folder:

Filename Type Minified Polyfills Usage
vssue.js ES Module false false with bundler
vssue.[platform].min.js UMD true false in modern browser via a <script> tag
vssue.[platform].polyfill.min.js UMD true true in old browser via a <script> tag

See different builds of Vue