Improving performance

This commit is contained in:
Liyas Thomas
2019-11-28 20:41:52 +05:30
parent 2a81c2611b
commit b10a209daf
28 changed files with 1028 additions and 585 deletions

View File

@@ -3,50 +3,57 @@
export const meta = {
name: "Postwoman",
shortDescription: "API request builder",
description: "The Postwoman API request builder helps you create your requests faster, saving you precious time on your development."
description:
"The Postwoman API request builder helps you create your requests faster, saving you precious time on your development."
};
// Sets the base path for the router.
// Important for deploying to GitHub pages.
// -- Travis includes the author in the repo slug,
// so if there's a /, we need to get everything after it.
let repoName = (process.env.TRAVIS_REPO_SLUG || '').split('/').pop();
export const routerBase = process.env.DEPLOY_ENV === 'GH_PAGES' ? {
router: {
base: `/${repoName}/`
}
} : {
router: {
base: '/'
}
};
let repoName = (process.env.TRAVIS_REPO_SLUG || "").split("/").pop();
export const routerBase =
process.env.DEPLOY_ENV === "GH_PAGES"
? {
router: {
base: `/${repoName}/`
}
}
: {
router: {
base: "/"
}
};
export default {
mode: 'spa',
mode: "spa",
/*
** Headers of the page
*/
server: {
host: '0.0.0.0', // default: localhost
host: "0.0.0.0" // default: localhost
},
head: {
title: `${meta.name} \u2022 ${meta.shortDescription}`,
meta: [{
charset: 'utf-8'
meta: [
{
charset: "utf-8"
},
{
name: 'viewport',
content: 'width=device-width, initial-scale=1, minimum-scale=1, viewport-fit=cover, minimal-ui'
name: "viewport",
content:
"width=device-width, initial-scale=1, minimum-scale=1, viewport-fit=cover, minimal-ui"
},
{
hid: 'description',
name: 'description',
content: meta.description || ''
hid: "description",
name: "description",
content: meta.description || ""
},
{
name: 'keywords',
content: 'postwoman, postwoman chrome, postwoman online, postwoman for mac, postwoman app, postwoman for windows, postwoman google chrome, postwoman chrome app, get postwoman, postwoman web, postwoman android, postwoman app for chrome, postwoman mobile app, postwoman web app, api, request, testing, tool, rest, websocket, sse, graphql'
name: "keywords",
content:
"postwoman, postwoman chrome, postwoman online, postwoman for mac, postwoman app, postwoman for windows, postwoman google chrome, postwoman chrome app, get postwoman, postwoman web, postwoman android, postwoman app for chrome, postwoman mobile app, postwoman web app, api, request, testing, tool, rest, websocket, sse, graphql"
},
{
name: 'X-UA-Compatible',
name: "X-UA-Compatible",
content: "IE=edge, chrome=1"
},
{
@@ -63,152 +70,154 @@ export default {
},
// Add to homescreen for Chrome on Android. Fallback for PWA (handled by nuxt)
{
name: 'application-name',
name: "application-name",
content: meta.name
},
// Add to homescreen for Safari on iOS
{
name: 'apple-mobile-web-app-capable',
content: 'yes'
name: "apple-mobile-web-app-capable",
content: "yes"
},
{
name: 'apple-mobile-web-app-status-bar-style',
content: 'black-translucent'
name: "apple-mobile-web-app-status-bar-style",
content: "black-translucent"
},
{
name: 'apple-mobile-web-app-title',
name: "apple-mobile-web-app-title",
content: meta.name
},
// Windows phone tile icon
{
name: 'msapplication-TileImage',
name: "msapplication-TileImage",
content: `${routerBase.router.base}icons/icon-144x144.png`
},
{
name: 'msapplication-TileColor',
content: '#252628'
name: "msapplication-TileColor",
content: "#252628"
},
{
name: 'msapplication-tap-highlight',
content: 'no'
name: "msapplication-tap-highlight",
content: "no"
},
// OpenGraph
{
property: 'og:site_name',
property: "og:site_name",
content: meta.name
},
{
property: 'og:url',
content: 'https://postwoman.io'
property: "og:url",
content: "https://postwoman.io"
},
{
property: 'og:type',
content: 'website'
property: "og:type",
content: "website"
},
{
property: 'og:title',
property: "og:title",
content: `${meta.name} \u2022 ${meta.shortDescription}`
},
{
property: 'og:description',
property: "og:description",
content: meta.description
},
{
property: 'og:image',
property: "og:image",
content: `${routerBase.router.base}logo.jpg`
},
// Twitter
{
name: 'twitter:card',
name: "twitter:card",
content: "summary_large_image"
},
{
name: 'twitter:site',
name: "twitter:site",
content: "@liyasthomas"
},
{
name: 'twitter:creator',
name: "twitter:creator",
content: "@liyasthomas"
},
{
name: 'twitter:url',
name: "twitter:url",
content: "https://postwoman.io"
},
{
name: 'twitter:title',
name: "twitter:title",
content: `${meta.name} \u2022 ${meta.shortDescription}`
},
{
name: 'twitter:description',
name: "twitter:description",
content: meta.description
},
{
name: 'twitter:image',
name: "twitter:image",
content: `${routerBase.router.base}logo.jpg`
},
}
],
link: [{
rel: 'icon',
type: 'image/x-icon',
link: [
{
rel: "icon",
type: "image/x-icon",
href: `${routerBase.router.base}favicon.ico`
},
// Home-screen icons (iOS)
{
rel: 'apple-touch-icon',
rel: "apple-touch-icon",
href: `${routerBase.router.base}icons/icon-48x48.png`
},
{
rel: 'apple-touch-icon',
sizes: '72x72',
rel: "apple-touch-icon",
sizes: "72x72",
href: `${routerBase.router.base}icons/icon-72x72.png`
},
{
rel: 'apple-touch-icon',
sizes: '96x96',
rel: "apple-touch-icon",
sizes: "96x96",
href: `${routerBase.router.base}icons/icon-96x96.png`
},
{
rel: 'apple-touch-icon',
sizes: '144x144',
rel: "apple-touch-icon",
sizes: "144x144",
href: `${routerBase.router.base}icons/icon-144x144.png`
},
{
rel: 'apple-touch-icon',
sizes: '192x192',
rel: "apple-touch-icon",
sizes: "192x192",
href: `${routerBase.router.base}icons/icon-192x192.png`
},
}
]
},
/*
** Customize the progress-bar color
*/
loading: {
color: 'var(--ac-color)'
color: "var(--ac-color)"
},
/*
** Customize the loading indicator
*/
loadingIndicator: {
name: 'pulse',
color: 'var(--ac-color)',
background: 'var(--bg-color)'
name: "pulse",
color: "var(--ac-color)",
background: "var(--bg-color)"
},
/*
** Global CSS
*/
css: [
'~/assets/css/styles.scss',
'~/assets/css/themes.scss',
'~/assets/css/fonts.scss'
"~/assets/css/styles.scss",
"~/assets/css/themes.scss",
"~/assets/css/fonts.scss"
],
/*
** Plugins to load before mounting the App
*/
plugins: [{
src: '~/plugins/vuex-persist'
plugins: [
{
src: "~/plugins/vuex-persist"
},
{
src: '~/plugins/v-tooltip'
src: "~/plugins/v-tooltip"
}
],
/*
@@ -220,16 +229,19 @@ export default {
*/
modules: [
// See https://goo.gl/OOhYW5
['@nuxtjs/pwa'],
['@nuxtjs/axios'],
['@nuxtjs/toast'],
['@nuxtjs/google-analytics'],
['@nuxtjs/sitemap'],
['@nuxtjs/google-tag-manager', {
id: process.env.GTM_ID || 'GTM-MXWD8NQ'
}],
['@nuxtjs/robots'],
['nuxt-i18n']
["@nuxtjs/pwa"],
["@nuxtjs/axios"],
["@nuxtjs/toast"],
["@nuxtjs/google-analytics"],
["@nuxtjs/sitemap"],
[
"@nuxtjs/google-tag-manager",
{
id: process.env.GTM_ID || "GTM-MXWD8NQ"
}
],
["@nuxtjs/robots"],
["nuxt-i18n"]
],
pwa: {
manifest: {
@@ -245,86 +257,87 @@ export default {
meta: {
description: meta.shortDescription,
theme_color: "#252628",
theme_color: "#252628"
},
icons: ((sizes) => {
icons: (sizes => {
let icons = [];
for (let size of sizes) {
icons.push({
"src": `${routerBase.router.base}icons/icon-${size}x${size}.png`,
"type": "image/png",
"sizes": `${size}x${size}`
src: `${routerBase.router.base}icons/icon-${size}x${size}.png`,
type: "image/png",
sizes: `${size}x${size}`
});
}
return icons;
})([48, 72, 96, 144, 192, 512])
},
toast: {
position: 'bottom-center',
position: "bottom-center",
duration: 3000,
theme: 'bubble',
theme: "bubble",
keepOnHover: true
},
googleAnalytics: {
id: process.env.GA_ID || 'UA-61422507-2'
id: process.env.GA_ID || "UA-61422507-2"
},
sitemap: {
hostname: 'https://postwoman.io'
hostname: "https://postwoman.io"
},
robots: {
UserAgent: '*',
Disallow: '',
Allow: '/',
Sitemap: 'https://postwoman.io/sitemap.xml'
UserAgent: "*",
Disallow: "",
Allow: "/",
Sitemap: "https://postwoman.io/sitemap.xml"
},
i18n: {
locales: [{
code: 'en',
name: 'English',
iso: 'en-US',
file: 'en-US.js'
locales: [
{
code: "en",
name: "English",
iso: "en-US",
file: "en-US.js"
},
{
code: 'es',
name: 'Español',
iso: 'es-ES',
file: 'es-ES.js'
code: "es",
name: "Español",
iso: "es-ES",
file: "es-ES.js"
},
{
code: 'fr',
name: 'Français',
iso: 'fr-FR',
file: 'fr-FR.js'
code: "fr",
name: "Français",
iso: "fr-FR",
file: "fr-FR.js"
},
{
code: 'fa',
name: 'Farsi',
iso: 'fa-IR',
file: 'fa-IR.js'
code: "fa",
name: "Farsi",
iso: "fa-IR",
file: "fa-IR.js"
},
{
code: 'pt',
name: 'Português Brasileiro',
iso: 'pt-BR',
file: 'pt-BR.js'
code: "pt",
name: "Português Brasileiro",
iso: "pt-BR",
file: "pt-BR.js"
},
{
code: 'cn',
name: '简体中文',
iso: 'zh-CN',
file: 'zh-CN.js'
code: "cn",
name: "简体中文",
iso: "zh-CN",
file: "zh-CN.js"
},
{
code: 'id',
name: 'Bahasa Indonesia',
iso: 'id-ID',
file: 'id-ID.js'
code: "id",
name: "Bahasa Indonesia",
iso: "id-ID",
file: "id-ID.js"
}
],
defaultLocale: 'en',
defaultLocale: "en",
lazy: true,
langDir: 'lang/'
langDir: "lang/"
},
/*
** Build configuration
@@ -345,4 +358,4 @@ export default {
** Router configuration
*/
...routerBase
}
};