Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/hikerpig/vue-classify

Convert option-object style vue component to typescript class component
https://github.com/hikerpig/vue-classify

babel transformer typescript vue

Last synced: 3 months ago
JSON representation

Convert option-object style vue component to typescript class component

Awesome Lists containing this project

README

        

# vue-classify

[![Build Status](https://travis-ci.org/hikerpig/vue-classify.svg?branch=master)](https://travis-ci.org/hikerpig/vue-classify)

[![Coverage Status](https://coveralls.io/repos/github/hikerpig/vue-classify/badge.svg?branch=master)](https://coveralls.io/github/hikerpig/vue-classify?branch=master) [![Greenkeeper badge](https://badges.greenkeeper.io/hikerpig/vue-classify.svg)](https://greenkeeper.io/)

Convert option-object style vue component to [vue-class-component](https://github.com/vuejs/vue-class-component) decorated class.

Inspired by [vue-to-react](https://github.com/dwqs/vue-to-react).

Here is an [online demo](https://vue-classify-demo.surge.sh)

# Install

```bash
npm i -g vue-classify # or yarn global add vue-classify
```

# Usage

```
Usage: vue-classify [options]

Options:
-V, --version output the version number
-i, --input the input path for vue component
-o, --output the output path for new component, which default value is process.cwd()
-n, --name the output file name, which default value is "classified.ts"
-h, --help output usage information

Examples:

# transform a vue option-object style component to class component.

$ vue-classify ./components/option-object.js ./components/Component.ts
$ vue-classify -i ./components/option-object.js -o ./components/ -n Component
```

# Preview Screenshots

## Convert props
![demo-1](http://vue-classify-demo.surge.sh/demo-1.png)

## SFC

![demo-2](http://vue-classify-demo.surge.sh/demo-2.png)

# Features

- props/watch -> vue-property-decorator decorated class properties
- computed -> class getter and setter
- lifecycle hooks -> class methods
- methods -> class methods
- other options will be passed to @Component decorator