How to train your

ue CLI plugin

Why should I care?

npm install electron --save dev
## or
yarn add electron --dev
// app.js

const electron = require('electron')
const app = electron.app
const BrowserWindow = electron.BrowserWindow
// app.js

let url
if(process.env.NODE_ENV === 'DEV') {
  url = 'http://localhost:8080'
} else {
  url = `file:/${process.cwd()}/dist/index.html`
}
// app.js

app.on('ready', () => {
  const window = new BrowserWindow({ width: 800, height: 600 })
  window.loadURL(url)
})
// package.json

"scripts": {
  "electron:serve": "NODE_ENV=DEV vue-cli-service serve &&
sleep 5 && NODE_ENV=DEV electron app.js",
  "electron:build": "electron app.js"
}
// vue.config.js

module.exports = {
  publicPath: process.env.NODE_ENV === "production"
  ? `${process.cwd()}/dist/`
  : '/'
}

vue add electron-builder

Natalia Tepluhina

@N_Tepluhina

Senior Frontend Engineer

Core Team Member

Google Dev Expert

@N_Tepluhina

Vue CLI

vue create my-project

npm install -g @vue/cli

@N_Tepluhina

Vue CLI

@N_Tepluhina

Vue CLI

494 plugins available!

(ノ◕ヮ◕)ノ*:・゚✧ ✧

vue add my-plugin

@N_Tepluhina

Let's create one more!

@N_Tepluhina

Naming

vue-cli-plugin-<name>

@scope/vue-cli-plugin-<name>

@N_Tepluhina

Naming

@N_Tepluhina

package.json

README.md

index.js

Required

generator.js

prompts.js

ui.js

Optional

@N_Tepluhina

Generator

- package

- templates

- imports

@N_Tepluhina

install

invoke

generator

@N_Tepluhina

Demo Time

@N_Tepluhina

Prompts

- ask questions

- pass answers

@N_Tepluhina

install

invoke

prompts

generator

@N_Tepluhina

Demo Time

@N_Tepluhina

Service

- webpack config

- vue-cli service     commands

@N_Tepluhina

Demo Time

@N_Tepluhina

UI integration

- config screen

- advanced tasks

- UI prompts

- widgets

- discoverability

Image by Tsuki Butterflah

@N_Tepluhina

Image by Tsuki Butterflah

Demo Time

Thank

you!

Plugin dev guide

cli.vuejs.org

Demo repository

bit.ly/cli-demo

How to train your Vue CLI plugin

By Natalia Tepluhina

How to train your Vue CLI plugin

This presentation shows main components of the Vue CLI plugin and how to make them work together

  • 2,098