ddosdor / me-vue-templates-pwa

PWA template for vue-cli based on the webpack template

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

me-vue-templates-pwa boilerplate

This is my pwa template for vue-cli. It's was forked from original pwa boilerplate - Oficial PWA Boilerplate.

This template includes, inter alia, scaffolding for components, containers and Vuex modules. It's still work in progress ;)

A full-featured PWA template with webpack, hot-reload, lint-on-save, unit testing & css extraction.

Install template

vue init ddosdor/me-vue-templates-pwa my-project

Project structure

Below is info about folders that are not in the original vue-cli template

"containers"

It's main component for routes. It contains child components dedicated to a given functionality.

To generate new container, type:

$ gulp container --name MyContainer

"store"

It's store for Vuex and is divided into modules.

To generate new Vuex module, type:

$ gulp container --name MyModule

"utils"

This folder contains all usable functionalities and helpers functions. It contains also decorator, which is used to store current asynchronous methods (api requests).

"components"

This folder is also in orginal Vue PWA boilerplate, but I decided that each component should be stored in folders corresponding to its container. I also seperate component structure to single files:

  • index.vue - main component file
  • component.js - component logic
  • style.sass - component SASS style

To generate new component, type:

$ gulp component --name MyComponent

The above command will generate component in the parent component folder. To generate it in the corresponding folder, type:

$ gulp component --name MyComponent --parent MyParentFolder

or

$ gulp component --name MyComponent --parent MyParentFolder/MyParentSubfolder

Original documentation

  • This template builds on top of the main webpack template, so please refer to the webpack template docs.

  • Check out the official Vue.js guide for general information about Vue that is not specific to this template.

Usage

This is a project template for vue-cli. It is recommended to use npm 3+ or yarn for a more efficient dependency tree.

$ npm install -g vue-cli
$ vue init pwa my-project
$ cd my-project
$ npm install
$ npm run dev

If port 8080 is already in use on your machine you must change the port number in /config/index.js. Otherwise npm run dev will fail.

What's Included

  • Service Worker precaching of application shell + static assets (prod)
  • Script (async chunk) preloading using <link rel="preload">
  • Web Application Manifest + favicons
  • Mobile-friendly meta-viewport
  • Lighthouse score of 90+/100
  • npm run dev: first-in-class development experience.

    • Webpack + vue-loader for single file Vue components.
    • State preserving hot-reload
    • State preserving compilation error overlay
    • Lint-on-save with ESLint
    • Source maps
  • npm run build: Production ready build.

    • JavaScript minified with UglifyJS.
    • HTML minified with html-minifier.
    • CSS across all components extracted into a single file and minified with cssnano.
    • All static assets compiled with version hashes for efficient long-term caching, and a production index.html is auto-generated with proper URLs to these generated assets.
    • Use npm run build --reportto build with bundle size analytics.
    • Generates a Service Worker for offline caching your static assets using sw-precache-webpack-plugin
  • npm run unit: Unit tests run in PhantomJS with Karma + Mocha + karma-webpack.

    • Supports ES2015+ in test files.
    • Supports all webpack loaders.
    • Easy mock injection.
  • npm run e2e: End-to-end tests with Nightwatch.

    • Run tests in multiple browsers in parallel.
    • Works with one command out of the box:
      • Selenium and chromedriver dependencies automatically handled.
      • Automatically spawns the Selenium server.

About

PWA template for vue-cli based on the webpack template

License:MIT License


Languages

Language:JavaScript 91.2%Language:HTML 4.6%Language:Vue 3.5%Language:Shell 0.6%Language:CSS 0.2%