Skip to content

Instantly share code, notes, and snippets.

View LazyFatArrow's full-sized avatar

Amenallah Hsoumi LazyFatArrow

View GitHub Profile
<template>
</template>
<script>
import { POLLS } from '@/gql/queries/poll.queries'
export default {
apollo: {
polls: {
query: POLLS,
import Vue from 'vue'
import Router from 'vue-router'
import Polls from './views/Polls.vue'
Vue.use(Router)
export default new Router({
mode: 'history',
base: process.env.BASE_URL,
import gql from 'graphql-tag'
export const POLLS = gql`
query Polls {
polls {
id
title
description
options {
id
import Vue from 'vue'
import BootstrapVue from 'bootstrap-vue'
import App from './App.vue'
import router from './router'
import { createProvider } from './vue-apollo'
import 'bootstrap/dist/css/bootstrap.css'
import 'bootstrap-vue/dist/bootstrap-vue.css'
type Subscription {
pollCreated: Poll
optionVoted: Option
}
// ... imports
export default {
// ... queries
mutations: {
// ... createPoll
async voteOnPoll(parent, args) {
const poll = await pollService.voteOnPoll(args.optionId).catch();
// ... imports
export default {
// ... queries
mutations: {
async createPoll(parent, args) {
const poll = await pollService.create(args.poll).catch();
pubsub.publish(POLL_CREATED, {
export const POLL_CREATED = 'pollCreated'
import { PubSub } from 'apollo-server'
import { POLL_CREATED } from '../events';
import * as pollService from '../services/poll.service'
const pubsub = new PubSub()
export default {
// ... queries and mutations
subscriptions: {
type Subscription {
pollCreated: Poll
}