Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bstavroulakis/vue-wordpress-pwa
An offline-first SPA using Vue.js, the WordPress REST API and Progressive Web Apps
https://github.com/bstavroulakis/vue-wordpress-pwa
azure es6-javascript offline progressive-web-app pwa pwa-apps pwapp service-worker spa vue vuejs vuejs-components vuejs2 webpack wordpress wordpress-starter-theme wordpress-theme
Last synced: 5 days ago
JSON representation
An offline-first SPA using Vue.js, the WordPress REST API and Progressive Web Apps
- Host: GitHub
- URL: https://github.com/bstavroulakis/vue-wordpress-pwa
- Owner: bstavroulakis
- License: mit
- Created: 2017-03-05T12:15:06.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-12-08T22:03:12.000Z (2 months ago)
- Last Synced: 2025-02-07T22:11:58.633Z (13 days ago)
- Topics: azure, es6-javascript, offline, progressive-web-app, pwa, pwa-apps, pwapp, service-worker, spa, vue, vuejs, vuejs-components, vuejs2, webpack, wordpress, wordpress-starter-theme, wordpress-theme
- Language: JavaScript
- Homepage: https://www.fullstackweekly.com/
- Size: 1.35 MB
- Stars: 699
- Watchers: 39
- Forks: 148
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# [vue-wordpress-pwa](https://www.fullstackweekly.com/category/blog)
> An offline-first SPA using Vue.js, the WordPress REST API and Progressive Web Apps
Live version: [https://www.fullstackweekly.com/](https://www.fullstackweekly.com/)
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="GitHub license"](https://raw.githubusercontent.com/singapore/renovate/master/license) [data:image/s3,"s3://crabby-images/87ec8/87ec87968fdcafabf701f810f9549f47bce040ce" alt="Build Status"](https://travis-ci.org/bstavroulakis/vue-wordpress-pwa) [data:image/s3,"s3://crabby-images/60584/6058492caf7b290a1d5fdd2cf8f199a855bc323d" alt="David"](https://david-dm.org/bstavroulakis/vue-wordpress-pwa)
[data:image/s3,"s3://crabby-images/91e0f/91e0fce42c9e4eb6da67d11f1e99aeebe8b299d6" alt="Lighthouse Accessibility Badge"](https://www.fullstackweekly.com/category/blog/) [data:image/s3,"s3://crabby-images/aa745/aa745fe47c0c9dc16d9e4db1f6a2c59d9f1344dc" alt="Lighthouse Best Practices Badge"](https://www.fullstackweekly.com/category/blog/) [data:image/s3,"s3://crabby-images/5616e/5616e8a06a5aaa9abee03cc2308da374c58f303b" alt="Lighthouse Progressive Web App Badge"](https://www.fullstackweekly.com/category/blog/) [data:image/s3,"s3://crabby-images/de16d/de16df082bfb9c9b46683671d65a943407fba87f" alt="Lighthouse Performance Badge"](https://www.fullstackweekly.com/category/blog/)data:image/s3,"s3://crabby-images/890bb/890bb5b894bd0f2c6d3e0d9c28c1ab97a2e828b4" alt="alt tag"
## Description
This is the code for the [FullStackWeekly](https://www.fullstackweekly.com/) website. You can use it as a starter pack for your WordPress site as well.
Since WordPress can expose a REST API, this project uses Vue.js, Vue-router, Vuex, Vue-resource & Progressive Web App techniques to create an offline-first web client.
You can also fork the project and host it on Azure App Services with continuous integration using the deploy.cmd file (included)
Live version: [https://www.fullstackweekly.com/](https://www.fullstackweekly.com/)
## Getting Started
### Prerequisites
Make sure that [Node v11](https://nodejs.org/en/download/releases/) is installed.
## Features
- Modern JavaScript syntax with [ES6](https://github.com/lukehoban/es6features) via [babel](https://babeljs.io/).
- Module bundler via [webpack](https://webpack.github.io/).
- Components-based architecture via [Vue.js](https://vuejs.org/).
- State management via [Vuex](https://vuex.vuejs.org/en/).
- Cache busting via [file-loader](https://webpack.github.io/)
- Progressive Web App enabled with [service workers](https://developers.google.com/web/fundamentals/getting-started/primers/service-workers)
- Offline capable with [service workers, app cache](https://developers.google.com/web/fundamentals/getting-started/primers/service-workers)
- CSS with [Sass](http://sass-lang.com/)### Instructions
First, install the WordPress plugins to enhance its REST API
- Better REST API Featured Images
- REST API Enabler
- WP REST API - filter fields
- WP REST API - Pure TaxonomiesThen, clone the repo or create a fork
```bash
$ git clone https://github.com/bstavroulakis/vue-wordpress-pwa.git
```Then, edit the config:
```bash
src/app.config.js
```Then, edit the theme, routes and assets:
```bash
src/theme/
src/components/routerTypes.js
src/components/router.js
src/assets
```Finally, to run the project for development with hot reload:
```bash
$ npm install
$ npm run dev
```Or, build the project for production:
```bash
$ npm run build
```### Deployment
Setup a new site on Azure App Services https://[fullstackweekly].azurewebsites.net
and as the path select your forked Github project.Your site should be running on the path you created (https://[fullstackweekly].azurewebsites.net)!
It should work offline as well and with every commit it will deploy the changes to Azure.
Once the user refreshes the site he will receive the new cached version `immediately`.License
MIT