Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/vsimko/gridsome-plugin-composition-api

Composition API for Gridsome with Vue2
https://github.com/vsimko/gridsome-plugin-composition-api

composition-api gridsome gridsome-plugin migration vue vue2

Last synced: about 2 months ago
JSON representation

Composition API for Gridsome with Vue2

Awesome Lists containing this project

README

        

# gridsome-plugin-composition-api

> Composition API for Gridsome with Vue2

### Quick overview

This plugin enables Composition API inside your Gridsome project even though Gridsome currently relies on Vue2.
Once Gridsome migrates to Vue3 this plugin becomes obsolete, but you'll have an easier migration path.

### Install

Use yarn or npm to install it:

* `yarn add -D gridsome-plugin-composition-api`
* `npm install -D gridsome-plugin-composition-api`
* add `gridsome-plugin-composition-api` in `devDependencies` section in your `package.json` file.

### Usage

Add `gridsome-plugin-composition-api` in your `gridsome.config`

```javascript
module.exports = {
plugins: [
{
use: 'gridsome-plugin-composition-api',
}
]
}
```

Now you can use Composition API in your *.vue files and other *.js or *.ts files:
```html

import {defineComponent, computed} from "@vue/composition-api";

export default defineComponent({
props: {
title: { type:String, required:true }
}
setup(props) {
const titleUpper = computed(() => props.title.toUpperCase());
return {
titleUpper,
}
}
});

```

### Possible stuff to come ...

Accessing `$static` and `$page` Vue global variables needs to be done differently in Composition API.
In my other codebase, I already have functions `usePageQuery()` and `useStaticQuery()`.
I might publish them as a part of this package if someone requests it.

Here is my work-in-progress implementation in TypeScript:

```typescript
export function useStaticQuery() {
type ComponentWith$Static = ReturnType & { $static: T };
return computed(() => {
const thisComponent = getCurrentInstance() as ComponentWith$Static;
return thisComponent.$static;
})
}

export function usePageQuery() {
type ComponentWith$Page = ReturnType & { $page: T };
return computed(() => {
const thisComponent = getCurrentInstance() as ComponentWith$Page;
return thisComponent.$page;
})
}
```