123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- // Some helpful application constants.
- // TODO: Use these when rendering the pages (rather than just for head/meta tags...)
- 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."
- };
- // 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: '/'
- }
- };
- export default {
- mode: 'spa',
- /*
- ** Headers of the page
- */
- server: {
- host: '0.0.0.0', // default: localhost
- },
- head: {
- title: `${meta.name} \u2022 ${meta.shortDescription}`,
- meta: [
- {
- charset: 'utf-8'
- },
- {
- name: 'viewport',
- content: 'width=device-width, initial-scale=1, minimum-scale=1, shrink-to-fit=no, minimal-ui'
- },
- {
- 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'
- },
- {
- name: 'X-UA-Compatible',
- content: "IE=edge, chrome=1"
- },
- {
- itemprop: "name",
- content: `${meta.name} \u2022 ${meta.shortDescription}`
- },
- {
- itemprop: "description",
- content: meta.description
- },
- {
- itemprop: "image",
- content: `${routerBase.router.base}icons/icon-192x192.png`
- },
- // Add to homescreen for Chrome on Android. Fallback for PWA (handled by nuxt)
- {
- 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-status-bar-style',
- content: 'black-translucent'
- },
- {
- name: 'apple-mobile-web-app-title',
- content: meta.name
- },
- // Windows phone tile icon
- {
- name: 'msapplication-TileImage',
- content: `${routerBase.router.base}icons/icon-144x144.png`
- },
- {
- name: 'msapplication-TileColor',
- content: '#252628'
- },
- {
- name: 'msapplication-tap-highlight',
- content: 'no'
- },
- // OpenGraph
- {
- property: 'og:site_name',
- content: meta.name
- },
- {
- property: 'og:url',
- content: 'https://postwoman.io'
- },
- {
- property: 'og:type',
- content: 'website'
- },
- {
- property: 'og:title',
- content: `${meta.name} \u2022 ${meta.shortDescription}`
- },
- {
- property: 'og:description',
- content: meta.description
- },
- {
- property: 'og:image',
- content: `${routerBase.router.base}icons/icon-144x144.png`
- },
- // Twitter
- {
- name: 'twitter:card',
- content: "summary"
- },
- {
- name: 'twitter:site',
- content: "@liyasthomas"
- },
- {
- name: 'twitter:creator',
- content: "@liyasthomas"
- },
- {
- name: 'twitter:url',
- content: "https://postwoman.io"
- },
- {
- name: 'twitter:title',
- content: meta.name
- },
- {
- name: 'twitter:description',
- content: meta.shortDescription
- },
- {
- name: 'twitter:image',
- content: `${routerBase.router.base}icons/icon-144x144.png`
- },
- ],
- link: [
- {
- rel: 'icon',
- type: 'image/x-icon',
- href: `${routerBase.router.base}favicon.ico`
- },
- // Home-screen icons (iOS)
- {
- rel: 'apple-touch-icon',
- href: `${routerBase.router.base}icons/icon-48x48.png`
- },
- {
- rel: 'apple-touch-icon',
- sizes: '72x72',
- href: `${routerBase.router.base}icons/icon-72x72.png`
- },
- {
- rel: 'apple-touch-icon',
- sizes: '96x96',
- href: `${routerBase.router.base}icons/icon-96x96.png`
- },
- {
- rel: 'apple-touch-icon',
- sizes: '144x144',
- href: `${routerBase.router.base}icons/icon-144x144.png`
- },
- {
- rel: 'apple-touch-icon',
- sizes: '192x192',
- href: `${routerBase.router.base}icons/icon-192x192.png`
- },
- ]
- },
- /*
- ** Customize the progress-bar color
- */
- loading: {
- color: 'var(--ac-color)'
- },
- /*
- ** Global CSS
- */
- css: [
- '@/assets/css/themes.scss',
- '@/assets/css/fonts.scss',
- '@/assets/css/styles.scss'
- ],
- /*
- ** Plugins to load before mounting the App
- */
- plugins: [
- {
- src: '~/plugins/vuex-persist'
- }
- ],
- /*
- ** Nuxt.js dev-modules
- */
- buildModules: [
- ],
- /*
- ** Nuxt.js modules
- */
- modules: [
- // See https://goo.gl/OOhYW5
- ['@nuxtjs/pwa', {
- manifest: {
- name: meta.name,
- short_name: meta.name,
- description: meta.shortDescription,
- display: "standalone",
- theme_color: "#252628",
- background_color: "#252628",
- start_url: `${routerBase.router.base}`,
- 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}`
- });
- }
- return icons;
- })([48, 72, 96, 144, 192, 512])
- }
- }],
- ['@nuxtjs/axios'],
- ['@nuxtjs/toast']
- ],
- /*
- ** Build configuration
- */
- build: {
- /*
- ** You can extend webpack config here
- */
- extend(config, ctx) {}
- },
- /*
- ** Generate configuration
- */
- generate: {
- fallback: true
- },
- /*
- ** Router configuration
- */
- ...routerBase
- }
|