Skip to content
This repository has been archived by the owner on Jul 8, 2022. It is now read-only.

[Snyk] Upgrade vuex from 3.6.2 to 4.0.1 #184

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

snyk-bot
Copy link

Snyk has created this PR to upgrade vuex from 3.6.2 to 4.0.1.

ℹ️ Keep your dependencies up-to-date. This makes it easier to fix existing vulnerabilities and to more quickly identify and fix newly disclosed vulnerabilities when they affect your project.


Warning: This is a major version upgrade, and may be a breaking change.

  • The recommended version is 9 versions ahead of your current version.
  • The recommended version was released 8 months ago, on 2021-05-24.
Release notes
Package name: vuex
  • 4.0.1 - 2021-05-24

    Features

    • dx: add devtools integration (#1949)
  • 4.0.0 - 2021-02-02

    This is the official Vuex 4 release.

    The focus for Vuex 4 is compatibility. Vuex 4 supports Vue 3, and it provides the exact same API as Vuex 3, so users can reuse their existing Vuex code with Vue 3.

    There are a few breaking changes described in a later section, so please check them out.

    You can find basic usage with both Option and Composition API in the example directory.

    It's still released under next tag in NPM package as same as Vue 3. We're planning to remove next tag once Vue 3 is ready to remove it.

    There have been a lot of contribution to make Vuex 4 stable. Thank you all for your very much appreciated help. It wouldn't have been possible without this wonderful Vue community!

    Documentation

    To check out docs, visit next.vuex.vuejs.org.

    Breaking changes

    Installation process has changed

    To align with the new Vue 3 initialization process, the installation process of Vuex has changed.

    To create a new store instance, users are now encouraged to use the newly introduced createStore function.

    import { createStore } from 'vuex'

    export const store = createStore({
    state() {
    return {
    count: 1
    }
    }
    })

    Whilst this is not technically a breaking change, you may still use the new Store(...) syntax, we recommend this approach to align with Vue 3 and Vue Router 4.

    To install Vuex to a Vue instance, pass the store instance instead of Vuex.

    import { createApp } from 'vue'
    import { store } from './store'
    import App from './App.vue'

    const app = createApp(App)

    app.use(store)

    app.mount('#app')

    Bundles are now aligned with Vue 3

    The following bundles are generated to align with Vue 3 bundles:

    • vuex.global(.prod).js
      • For direct use with <script src="..."> in the browser. Exposes the Vuex global.
      • Global build is built as IIFE, and not UMD, and is only meant for direct use with <script src="...">.
      • Contains hard-coded prod/dev branches and the prod build is pre-minified. Use the .prod.js files for production.
    • vuex.esm-browser(.prod).js
      • For use with native ES module imports (including module supporting browsers via <script type="module">.
    • vuex.esm-bundler.js
      • For use with bundlers such as webpack, rollup and parcel.
      • Leaves prod/dev branches with process.env.NODE_ENV guards (must be replaced by bundler).
      • Does not ship minified builds (to be done together with the rest of the code after bundling).
    • vuex.cjs.js
      • For use in Node.js server-side rendering with require().

    Typings for ComponentCustomProperties

    Vuex 4 removes its global typings for this.$store within Vue Component to solve issue #994. When used with TypeScript, you must declare your own module augmentation.

    Place the following code in your project to allow this.$store to be typed correctly:

    // vuex-shim.d.ts

    import { ComponentCustomProperties } from 'vue'
    import { Store } from 'vuex'

    declare module '@ vue/runtime-core' {
    // Declare your own store states.
    interface State {
    count: number
    }

    interface ComponentCustomProperties {
    $store: Store<State>
    }
    }

    createLogger function is exported from the core module

    In Vuex 3, createLogger function was exported from vuex/dist/logger but it's now included in the core package. You should import the function directly from vuex package.

    import { createLogger } from 'vuex'

    Bug Fixes Included Since 4.0.0-rc.2

  • 4.0.0-rc.2 - 2020-11-25

    Bug Fixes

    • fix getters stop working when component is destroyed (#1884) (c3a695e)
    • stop throwing an error on hasModule when parent does not exists (#1850) (f76d72d)

    Features

    • build: enable named esm module import on node.js >= 14 (4f4a909)
  • 4.0.0-rc.1 - 2020-10-30

    Bug Fixes

    Features

    • types: adding logger type for logger plugin (#1853) (cb3198d)
  • 4.0.0-beta.4 - 2020-06-29

    Bug Fixes

    • types: add missing logger.d.ts file to the package (#1789) (a477334)
    • warn when unregistering non existing module (#1786) (7cec79d)
  • 4.0.0-beta.3 - 2020-06-29

    Bug Fixes

    Features

    • include createLogger function in core export (afa566d)
  • 4.0.0-beta.2 - 2020-05-11
  • 4.0.0-beta.1 - 2020-04-25
  • 4.0.0-alpha.1 - 2020-03-15
  • 3.6.2 - 2021-01-26

    Bug Fixes

    • build: fix wrong path name for the export module (679313b)
from vuex GitHub release notes

Note: You are seeing this because you or someone else with access to this repository has authorized Snyk to open upgrade PRs.

For more information:

🧐 View latest project report

🛠 Adjust upgrade PR settings

🔕 Ignore this dependency or unsubscribe from future upgrade PRs

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant