https://github.com/femessage/update-popup
  
  
    💬Display an update message at right bottom 
    https://github.com/femessage/update-popup
  
nuxt nuxt-module popup qiankun update update-checker update-popup vercel vue-cli webpack zeit
        Last synced: 4 months ago 
        JSON representation
    
💬Display an update message at right bottom
- Host: GitHub
- URL: https://github.com/femessage/update-popup
- Owner: FEMessage
- License: mit
- Created: 2020-07-30T01:51:27.000Z (about 5 years ago)
- Default Branch: dev
- Last Pushed: 2023-10-20T03:39:47.000Z (about 2 years ago)
- Last Synced: 2025-04-23T03:04:37.714Z (6 months ago)
- Topics: nuxt, nuxt-module, popup, qiankun, update, update-checker, update-popup, vercel, vue-cli, webpack, zeit
- Language: JavaScript
- Homepage:
- Size: 203 KB
- Stars: 24
- Watchers: 4
- Forks: 11
- Open Issues: 1
- 
            Metadata Files:
            - Readme: README-zh.md
- License: LICENSE
 
Awesome Lists containing this project
README
          # update-popup
[](https://travis-ci.com/FEMessage/update-popup)
[](https://www.npmjs.com/package/@femessage/update-popup)
[](https://www.npmjs.com/package/@femessage/update-popup)
[](https://github.com/FEMessage/update-popup/blob/master/LICENSE)
[](https://github.com/FEMessage/update-popup/pulls)
[](https://github-tools.github.io/github-release-notes/)

## Table of Contents
- [Features](#features)
- [Install](#install)
- [Usage](#usage)
- [Options](#options)
- [Notice](#notice)
- [Contributing](#contributing)
- [Contributors](#contributors)
- [License](#license)
## Features
检测当前运行的应用是否是最新版本,如若不是,则提醒刷新以使用新版本。
[⬆ Back to Top](#table-of-contents)
## Install
```console
yarn add @femessage/update-popup
```
[⬆ Back to Top](#table-of-contents)
## Usage
你需要通过环境变量 `UPDATE_POPUP_VERSION` 来传入版本号,后续每次迭代更新只需要修改比当前大的版本号即可。
环境变量
```bash
# .env
UPDATE_POPUP_VERSION=1.0.0 # 如果有必要,可以支持更多位数。如:1.0.0.1,1.0.0.1.1
```
也可以使用 [options.auto](#options.auto) 来实现自动更新版本。
工程配置文件
```js
// nuxt.config.js
const config = {
  modules: ['@femessage/update-popup/nuxt', {options}]
}
// vue.config.js 或者 poi.config.js
const UpdatePopup = require('@femessage/update-popup')
const config = {
  chainWebpack: config => {
    config.plugin('femessage-update-popup').use(UpdatePopup, [{options}])
  }
}
```
就这么简单!
[⬆ Back to Top](#table-of-contents)
## Options
### options.publicPath
- Type: `string`
- Default: `webpackConfig.output.publicPath`
- Reference: [webpack publicPath](https://webpack.docschina.org/configuration/output/#outputpublicpath)
使用独立的 publicPath,一般情况下不需要设置此参数。
[⬆ Back to Top](#table-of-contents)
### options.auto
- Type: `boolean`
- Default: `false`
是否需要自动更新版本,需要配合 `options.versionType` 一起使用。
**注意**:开启此功能,环境变量 `UPDATE_POPUP_VERSION` 则不会再生效。
### options.versionType
- Type: `'timestamp' | 未来支持更多`
- Default: `timestamp`
自动生成的 version 的方式,可选值:
- `timestamp`:
  使用当前时间戳,它看上去是这样的:`1603184005919.0.0`,把时间戳放在版本号的第一位,是为了保证无论如何都会大于已有的版本。
  **注意**:这将失去版本语义化的控制。
### options.inject
- Type: `boolean`
- Default: `true`
是否自动添加到 webpack 入口文件,一般情况下不需要设置此参数。  
如果设置为 `false` 需要手动将 `@femessage/update-popup/app/main` 注入到你的代码中。  
何时需要设置此参数请参阅 [Notice.QianKun(乾坤)](#qiankun乾坤)。
### options.envKey
- Type: `string`
- Default: `'UPDATE_POPUP_VERSION'`
指定获取环境变量的 key 。e.g. `process.env.UPDATE_POPUP_VERSION=1.0.0`
### options.versionFileName
- Type: `string`
- Default: `'update_popup_version.txt'`
版本号文件名。
## Notice
### QianKun(乾坤)
此插件会自动生成一个普通的 js 文件并添加到 webpack 入口文件中,  
但由于子应用的入口文件需要 **[导出生命周期钩子](https://qiankun.umijs.org/zh/guide/getting-started#1-%E5%AF%BC%E5%87%BA%E7%9B%B8%E5%BA%94%E7%9A%84%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E9%92%A9%E5%AD%90)** 的要求,  
因此需要禁止自动添加入口文件,则做如下的调整:
#### 在子应用中使用
调整工程配置文件
```diff
# nuxt.config.js
const config = {
-  modules: ['@femessage/update-popup/nuxt']
+  modules: [['@femessage/update-popup/nuxt'], { inject: false }]
}
# vue.config.js 或者 poi.config.js
const config = {
  chainWebpack: config => {
    config.plugin('update-popup').use(UpdatePopup, [{
+     inject: false
    }])
  }
}
```
最后在你的**子应用**入口文件添加
```diff
+ import '@femessage/update-popup/app/main'
```
[⬆ Back to Top](#table-of-contents)
## Contributing
For those who are interested in contributing to this project, such as:
- report a bug
- request new feature
- fix a bug
- implement a new feature
Please refer to our [contributing guide](https://github.com/FEMessage/.github/blob/master/CONTRIBUTING.md).
[⬆ Back to Top](#table-of-contents)
## Contributors
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!
[⬆ Back to Top](#table-of-contents)
## License
[MIT](./LICENSE)
[⬆ Back to Top](#table-of-contents)