Skip to content

Latest commit

 

History

History
189 lines (138 loc) · 4.7 KB

README.md

File metadata and controls

189 lines (138 loc) · 4.7 KB

🤖 Vue3 for Slack Application 🐼

Slackpanda provides UI building experience same as web in the slack. If you know Vue3, You can use awesome reactivity system of vue 3.

npm version LICENSE

Setup

# via npm
$ npm install @slackpanda/vue @slackpanda/slack

# via yarn
$ yarn add @slackpanda/vue @slackpanda/slack

If you not have build command for .vue file, Recommend vue3-node library.

# via npm
$ npm install vue3-node

# via yarn
$ yarn add vue3-node

Getting Started

Create New Slack App

  1. Go to https://api.slack.com/apps and click Create New App button

  2. Fill App Name and click Create App

  3. Save Client Secret and Signing Secret

  4. Go to OAuth & Permissions menu in side-bar. Then add chat:write scope

  5. If you need interaction handler (button, modal, ...), Go to Interactivity & Shortcuts menu in side-bar. Then set Request URL to https?://{ip}:{port (default 8080)}

Sending messages

  1. Create vue component file

    // VueIssues.vue
    <template>
      <pb-section text="Vue.js Issues" />
      <pb-section v-if="issues.length > 0">
        <pb-section-fields>
          <pb-text v-for="issue in issues" :key="issue.id">
            {{ issue.title }}
          </pb-text>
        </pb-section-fields>
      </pb-section>
      <pb-actions>
        <pb-button v-if="showsPrevButton" @click="onPrevButtonClicked">
          Prev Page
        </pb-button>
        <pb-button @click="onNextButtonClicked">Next Page</pb-button>
      </pb-actions>
    </template>
    
    <script lang="ts">
    import { defineComponent, onMounted, ref, computed } from 'vue';
    import axios from 'axios';
    import {
      PbButton,
      PbSection,
      PbSectionFields,
      PbText,
      PbActions,
    } from '@slackpanda/vue';
    
    export default defineComponent({
      name: 'VueIssues',
      components: {
        PbSection,
        PbSectionFields,
        PbText,
        PbButton,
        PbActions,
      },
      setup() {
        const page = ref(1);
    
        const issues = ref<any[]>([]);
    
        const showsPrevButton = computed(() => page.value > 1);
    
        async function fetchData() {
          const response = await axios.get(
            `https://api.github.com/repos/vuejs/vue/issues?per_page=5&page=${page.value}`
          );
    
          issues.value = response.data;
        }
    
        function onNextButtonClicked() {
          page.value += 1;
    
          fetchData();
        }
    
        function onPrevButtonClicked() {
          page.value -= 1;
    
          fetchData();
        }
    
        onMounted(() => {
          fetchData();
        });
    
        return {
          issues,
    
          showsPrevButton,
    
          onNextButtonClicked,
          onPrevButtonClicked,
        };
      },
    });
    </script>
  2. Create new client by calling function

    const { createClient } = require('@slackpanda/vue');
    const { SlackAdapter } = require('@slackpanda/slack');
    
    const adapter = new SlackAdapter({
      apiToken: process.env.SLACK_API_TOKEN, // Client Secret
      signingSecret: process.env.SLACK_SIGNING_SECRET, // Signing Secret
      port: 8080, // Default 8080
    });
    
    const client = createClient({
      adapter,
    });
  3. Send your slack app

    const VueIssues = reuqire('./VueIssues.vue');
    
    client.sendMessage(VueIssues, '#general');
  4. Works fine!

Feature Planning

  • Test
  • Friendly error report
  • Home tabs
  • CLI

Documentation

Examples

  • PingPong - Simple express example that sends "Pong" when calling /ping command
  • VueIssues - Show issues of vue.js repository with pagination
  • TodoList - ⏰ 🤖

Supported Platforms and Frameworks

Vue React
Slack
Discord
Teams