thedesk/app/node_modules/electron-dl/readme.md
2019-09-12 23:38:13 +09:00

180 lines
4.2 KiB
Markdown

# electron-dl [![Build Status](https://travis-ci.org/sindresorhus/electron-dl.svg?branch=master)](https://travis-ci.org/sindresorhus/electron-dl)
> Simplified file downloads for your [Electron](https://electronjs.org) app
## Why?
- One function call instead of having to manually implement a lot of [boilerplate](index.js).
- Saves the file to the users Downloads directory instead of prompting.
- Bounces the Downloads directory in the dock when done. *(macOS)*
- Handles multiple downloads.
- Shows badge count *(macOS & Linux only)* and download progress. Example on macOS:
<img src="screenshot.png" width="82">
## Install
```
$ npm install electron-dl
```
## Usage
### Register it for all windows
This is probably what you want for your app.
```js
const {app, BrowserWindow} = require('electron');
const electronDl = require('electron-dl');
electronDl();
let win;
(async () => {
await app.whenReady();
win = new BrowserWindow();
})();
```
### Use it manually
This can be useful if you need download functionality in a reusable module.
```js
const {BrowserWindow, ipcMain} = require('electron');
const {download} = require('electron-dl');
ipcMain.on('download-button', async (event, {url}) => {
const win = BrowserWindow.getFocusedWindow();
console.log(await download(win, url));
});
```
## API
It can only be used in the [main](https://electronjs.org/docs/glossary/#main-process) process.
### electronDl([options])
### electronDl.download(window, url, [options]): Promise<[DownloadItem](https://electronjs.org/docs/api/download-item)>
### window
Type: `BrowserWindow`
Window to register the behavior on.
### url
Type: `string`
URL to download.
### options
Type: `Object`
#### saveAs
Type: `boolean`<br>
Default: `false`
Show a `Save As…` dialog instead of downloading immediately.
Note: Only use this option when strictly necessary. Downloading directly without a prompt is a much better user experience.
#### directory
Type: `string`<br>
Default: [User's downloads directory](https://electronjs.org/docs/api/app/#appgetpathname)
Directory to save the file in.
#### filename
Type: `string`<br>
Default: [`downloadItem.getFilename()`](https://electronjs.org/docs/api/download-item/#downloaditemgetfilename)
Name of the saved file.
This option only makes sense for `electronDl.download()`.
#### errorTitle
Type: `string`<br>
Default: `Download Error`
Title of the error dialog. Can be customized for localization.
#### errorMessage
Type: `string`<br>
Default: `The download of {filename} was interrupted`
Message of the error dialog. `{filename}` is replaced with the name of the actual file. Can be customized for localization.
#### onStarted
Type: `Function`
Optional callback that receives the [download item](https://electronjs.org/docs/api/download-item).
You can use this for advanced handling such as canceling the item like `item.cancel()`.
#### onProgress
Type: `Function`
Optional callback that receives a number between `0` and `1` representing the progress of the current download.
#### onCancel
Type: `Function`
Optional callback that receives the [download item](https://electronjs.org/docs/api/download-item) for which the download has been cancelled.
#### openFolderWhenDone
Type: `boolean`<br>
Default: `false`
Reveal the downloaded file in the system file manager, and if possible, select the file.
#### showBadge
Type: `boolean`<br>
Default: `true`
Shows the file count badge on macOS/Linux dock icons when download is in progress.
## Development
After making changes, run the automated tests:
```
$ npm test
```
And before submitting a pull request, run the manual tests to manually verify that everything works:
```
npm start
```
## Related
- [electron-debug](https://github.com/sindresorhus/electron-debug) - Adds useful debug features to your Electron app
- [electron-context-menu](https://github.com/sindresorhus/electron-context-menu) - Context menu for your Electron app
- [electron-store](https://github.com/sindresorhus/electron-store) - Save and load data like user preferences, app state, cache, etc
- [electron-unhandled](https://github.com/sindresorhus/electron-unhandled) - Catch unhandled errors and promise rejections in your Electron app
## License
MIT © [Sindre Sorhus](https://sindresorhus.com)