123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321 |
- // Some helpful application constants.
- // TODO: Use these when rendering the pages (rather than just for head/meta tags...)
- export const options = {
- name: "Hoppscotch",
- shortDescription: "A free, fast and beautiful API request builder",
- description: "Helps you create requests faster, saving precious time on development.",
- loading: {
- color: "var(--ac-color)",
- background: "var(--bg-color)",
- },
- app: {
- background: "#202124",
- },
- social: {
- twitter: "@liyasthomas",
- },
- }
- export default {
- ssr: false,
- server: {
- host: "0.0.0.0", // default: localhost
- },
- /*
- ** Headers of the page
- */
- head: {
- title: `${options.name} • ${options.shortDescription}`,
- meta: [
- {
- name: "keywords",
- content:
- "hoppscotch, hopp scotch, hoppscotch online, hoppscotch app, 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, socketio",
- },
- {
- name: "X-UA-Compatible",
- content: "IE=edge, chrome=1",
- },
- {
- itemprop: "name",
- content: `${options.name} • ${options.shortDescription}`,
- },
- {
- itemprop: "description",
- content: options.description,
- },
- {
- itemprop: "image",
- content: `${process.env.BASE_URL}banner.jpg`,
- },
- {
- property: "og:image",
- content: `${process.env.BASE_URL}banner.jpg`,
- },
- // Add to homescreen for Chrome on Android. Fallback for PWA (handled by nuxt)
- {
- name: "application-name",
- content: options.name,
- },
- // Windows phone tile icon
- {
- name: "msapplication-TileImage",
- content: `/icon.png`,
- },
- {
- name: "msapplication-TileColor",
- content: options.app.background,
- },
- {
- name: "msapplication-tap-highlight",
- content: "no",
- },
- ],
- link: [
- {
- rel: "apple-touch-icon",
- href: "/icon.png",
- },
- {
- rel: "apple-touch-startup-image",
- href: "/icon.png",
- },
- ],
- },
- /*
- ** Customize the progress-bar color
- */
- loading: {
- color: options.loading.color,
- continuous: true,
- },
- /*
- ** Customize the loading indicator
- */
- loadingIndicator: {
- name: "pulse",
- color: options.loading.color,
- background: options.loading.background,
- },
- /*
- ** Global CSS
- */
- css: ["~/assets/scss/styles.scss", "~/assets/scss/themes.scss", "~/assets/scss/fonts.scss"],
- /*
- ** Plugins to load before mounting the App
- */
- plugins: ["~/plugins/vuex-persist", "~/plugins/v-tooltip"],
- /*
- ** Auto import components
- ** See https://nuxtjs.org/api/configuration-components
- */
- components: true,
- /*
- ** Nuxt.js dev-modules
- */
- buildModules: [
- // https://pwa.nuxtjs.org
- "@nuxtjs/pwa",
- // Doc: https://github.com/nuxt-community/analytics-module
- "@nuxtjs/google-analytics",
- // Doc: https://github.com/nuxt-community/gtm-module
- "@nuxtjs/gtm",
- // Doc: https://github.com/nuxt-community/svg-module
- "@nuxtjs/svg",
- // Doc: https://tailwindcss.nuxtjs.org
- "@nuxtjs/tailwindcss",
- // Doc: https://color-mode.nuxtjs.org
- "@nuxtjs/color-mode",
- ],
- /*
- ** Nuxt.js modules
- */
- modules: [
- // https://axios.nuxtjs.org
- "@nuxtjs/axios",
- // https://github.com/nuxt-community/modules/tree/master/packages/toast
- "@nuxtjs/toast",
- // Doc: https://github.com/nuxt-community/nuxt-i18n
- "nuxt-i18n",
- // Doc: https://github.com/nuxt-community/robots-module
- "@nuxtjs/robots",
- // Doc: https://github.com/nuxt-community/sitemap-module
- "@nuxtjs/sitemap",
- ],
- pwa: {
- meta: {
- ogHost: process.env.BASE_URL,
- twitterCard: "summary_large_image",
- twitterSite: options.social.twitter,
- twitterCreator: options.social.twitter,
- description: options.shortDescription,
- theme_color: options.app.background,
- },
- manifest: {
- name: options.name,
- short_name: options.name,
- description: options.shortDescription,
- start_url: "/",
- background_color: options.app.background,
- theme_color: options.app.background,
- },
- },
- toast: {
- position: "bottom-center",
- duration: 3000,
- theme: "bubble",
- keepOnHover: true,
- },
- googleAnalytics: {
- id: process.env.GA_ID,
- },
- gtm: {
- id: process.env.GTM_ID,
- },
- sitemap: {
- hostname: process.env.BASE_URL || "https://hoppscotch.io/",
- },
- robots: {
- UserAgent: "*",
- Disallow: "",
- Allow: "/",
- Sitemap: `${process.env.BASE_URL}sitemap.xml`,
- },
- colorMode: {
- classSuffix: "",
- preference: "dark",
- fallback: "dark",
- },
- i18n: {
- locales: [
- {
- code: "en",
- name: "English",
- iso: "en-US",
- file: "en-US.json",
- },
- {
- code: "es",
- name: "Español",
- iso: "es-ES",
- file: "es-ES.json",
- },
- {
- code: "fr",
- name: "Français",
- iso: "fr-FR",
- file: "fr-FR.json",
- },
- {
- code: "fa",
- name: "Farsi",
- iso: "fa-IR",
- file: "fa-IR.json",
- },
- {
- code: "pt",
- name: "Português",
- iso: "pt-PT",
- file: "pt-PT.json",
- },
- {
- code: "pt-br",
- name: "Português Brasileiro",
- iso: "pt-BR",
- file: "pt-BR.json",
- },
- {
- code: "cn",
- name: "简体中文",
- iso: "zh-CN",
- file: "zh-CN.json",
- },
- {
- code: "tw",
- name: "繁體中文",
- iso: "zh-TW",
- file: "zh-TW.json",
- },
- {
- code: "id",
- name: "Bahasa Indonesia",
- iso: "id-ID",
- file: "id-ID.json",
- },
- {
- code: "tr",
- name: "Türkçe",
- iso: "tr-TR",
- file: "tr-TR.json",
- },
- {
- code: "de",
- name: "Deutsch",
- iso: "de-DE",
- file: "de-DE.json",
- },
- {
- code: "ja",
- name: "日本語",
- iso: "ja-JP",
- file: "ja-JP.json",
- },
- {
- code: "ko",
- name: "한국어",
- iso: "ko-KR",
- file: "ko-KR.json",
- },
- ],
- defaultLocale: "en",
- vueI18n: {
- fallbackLocale: "en",
- },
- lazy: true,
- langDir: "lang/",
- detectBrowserLanguage: {
- alwaysRedirect: true,
- fallbackLocale: "en",
- },
- },
- /*
- ** Build configuration
- */
- build: {
- /*
- ** You can extend webpack config here
- */
- extend(config, ctx) {
- // Sets webpack's mode to development if `isDev` is true.
- if (ctx.isDev) {
- config.mode = "development"
- }
- config.node = {
- fs: "empty",
- }
- },
- parallel: true,
- cache: true,
- // hardSource: true,
- },
- /*
- ** Generate configuration
- */
- generate: {
- fallback: true,
- },
- publicRuntimeConfig: {
- GA_ID: process.env.GA_ID || "UA-61422507-4",
- GTM_ID: process.env.GTM_ID || "GTM-NMKVBMV",
- BASE_URL: process.env.BASE_URL || "https://hoppscotch.io/",
- },
- privateRuntimeConfig: {
- API_KEY: process.env.API_KEY,
- AUTH_DOMAIN: process.env.AUTH_DOMAIN,
- DATABASE_URL: process.env.DATABASE_URL,
- PROJECT_ID: process.env.PROJECT_ID,
- STORAGE_BUCKET: process.env.STORAGE_BUCKET,
- MESSAGING_SENDER_ID: process.env.MESSAGING_SENDER_ID,
- APP_ID: process.env.APP_ID,
- MEASUREMENT_ID: process.env.MEASUREMENT_ID,
- },
- }
|