Skip to content

amirlix/nuxt-moment-jalaali

Repository files navigation

Nuxt Moment Jalaali

npm version npm downloads [![Github Actions CI][github-actions-ci-src]][github-actions-ci-href] [![Codecov][codecov-src]][codecov-href] License

Efficient Moment.js Jalaali integration for Nuxt.js

📖 Release Notes

Features

Setup

  1. Add nuxt-moment-jalaali dependency to your project
yarn add --dev nuxt-moment-jalaali
# or 
npm install --save-dev nuxt-moment-jalaali
  1. Add nuxt-moment-jalaali to the buildModules section of nuxt.config.js
export default {
  buildModules: [
    // Simple usage
    'nuxt-moment-jalaali',

    // With options
    ['nuxt-moment-jalaali', { /* module options */ }]
  ]
}

⚠️ If you are using Nuxt < v2.9 you have to install the module as a dependency (No --dev or --save-dev flags) and use modules section in nuxt.config.js instead of buildModules.

Using top level options

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ],
  moment: {
    /* module options */
  }
}

Typescript setup

Add the types to your "types" array in tsconfig.json after the @nuxt/types entry.

⚠️ Use @nuxt/vue-app instead of @nuxt/types for nuxt < 2.9.

tsconfig.json

{
  "compilerOptions": {
    "types": [
      "@nuxt/types",
      "nuxt-moment-jalaali"
    ]
  }
}

Why?

For typescript to be aware of the additions to the nuxt Context, the vue instance and the vuex store, the types need to be merged via declaration merging by adding nuxt-moment-jalaali to your types.

Configuration

To strip all locales except en:

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ]
}

To strip all locales except en, fr and fa:

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ],
  moment: {
    locales: ['fa', 'fr']
  }
}

Note: en is built into Moment and can’t be removed!

Set default locale

You can set a default locale via the defaultLocale option. It must be included int the locales you keep (or 'en') and will only work when using the plugin option.

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ],
  moment: {
    defaultLocale: 'fa',
    locales: ['fa']
  }
}

dialect

You can set dialect option. see more

default value : persian-modern
Possible values: persian-modern, persian, false

Plugins

You can import plugins to moment. See a list of plugins

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ],
  moment: {
    plugins: [
      'moment-strftime',
      'moment-fquarter'
    ]
  }
}

Note: Don't need import Jalaali Calendar to plugin.
Note: Don't forget to install each plugin.

Timezone

You can enable moment-timezone via the timezone option.

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ],
  moment: {
    timezone: true
  }
}

You can filter time zone data and thus produce significant savings in file size. See all options in moment-timezone-data-webpack-plugin.

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ],
  moment: {
    timezone: {
      matchZones: ['Iran'],
      startYear: 2000,
      endYear: 2030
    }
  }
}

Set default time zone

You can set a default time zone via the defaultTimezone option.

export default {
  buildModules: [
    '@nuxtjs/moment'
  ],
  moment: {
    defaultTimezone: 'Asia/Tehran'
  }
}

Disable plugin

This module also registers a plugin to include all needed locales as well as injecting moment as $moment to Vue context. You can disable this behaviour using plugin: false.

export default {
  buildModules: [
    'nuxt-moment-jalaali'
  ],
  moment: {
    plugin: false
  }
}

Using inside templates

You can easily use $moment service from templates.

<div v-text="$moment(...)"></div>
<div>{{ $moment(...) }}</div>
<div>{{ $moment(...).format('jYYYY/jM/jDD') }}</div>

License

MIT License

Copyright (c) Nuxt Community

About

Efficient Moment Jalaali integration for Nuxt.js

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published