diff options
author | Chocobozzz <me@florianbigard.com> | 2019-04-05 10:52:27 +0200 |
---|---|---|
committer | Chocobozzz <me@florianbigard.com> | 2019-04-05 10:53:09 +0200 |
commit | 3a0fb65c61f80b510bce979a45d59d17948745e8 (patch) | |
tree | c1be0b2158a008fea826835c8d2fd4e8d648bae9 /client/src/app/shared/video/modals/video-download.component.ts | |
parent | 693263e936763a851e3c8c020e3739def8bd4eca (diff) | |
download | PeerTube-3a0fb65c61f80b510bce979a45d59d17948745e8.tar.gz PeerTube-3a0fb65c61f80b510bce979a45d59d17948745e8.tar.zst PeerTube-3a0fb65c61f80b510bce979a45d59d17948745e8.zip |
Add video miniature dropdown
Diffstat (limited to 'client/src/app/shared/video/modals/video-download.component.ts')
-rw-r--r-- | client/src/app/shared/video/modals/video-download.component.ts | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/client/src/app/shared/video/modals/video-download.component.ts b/client/src/app/shared/video/modals/video-download.component.ts new file mode 100644 index 000000000..64aaeb3c8 --- /dev/null +++ b/client/src/app/shared/video/modals/video-download.component.ts | |||
@@ -0,0 +1,69 @@ | |||
1 | import { Component, ElementRef, ViewChild } from '@angular/core' | ||
2 | import { VideoDetails } from '../../../shared/video/video-details.model' | ||
3 | import { NgbModal } from '@ng-bootstrap/ng-bootstrap' | ||
4 | import { I18n } from '@ngx-translate/i18n-polyfill' | ||
5 | import { Notifier } from '@app/core' | ||
6 | |||
7 | @Component({ | ||
8 | selector: 'my-video-download', | ||
9 | templateUrl: './video-download.component.html', | ||
10 | styleUrls: [ './video-download.component.scss' ] | ||
11 | }) | ||
12 | export class VideoDownloadComponent { | ||
13 | @ViewChild('modal') modal: ElementRef | ||
14 | |||
15 | downloadType: 'direct' | 'torrent' | 'magnet' = 'torrent' | ||
16 | resolutionId: number | string = -1 | ||
17 | |||
18 | private video: VideoDetails | ||
19 | |||
20 | constructor ( | ||
21 | private notifier: Notifier, | ||
22 | private modalService: NgbModal, | ||
23 | private i18n: I18n | ||
24 | ) { } | ||
25 | |||
26 | show (video: VideoDetails) { | ||
27 | this.video = video | ||
28 | |||
29 | const m = this.modalService.open(this.modal) | ||
30 | m.result.then(() => this.onClose()) | ||
31 | .catch(() => this.onClose()) | ||
32 | |||
33 | this.resolutionId = this.video.files[0].resolution.id | ||
34 | } | ||
35 | |||
36 | onClose () { | ||
37 | this.video = undefined | ||
38 | } | ||
39 | |||
40 | download () { | ||
41 | window.location.assign(this.getLink()) | ||
42 | } | ||
43 | |||
44 | getLink () { | ||
45 | // HTML select send us a string, so convert it to a number | ||
46 | this.resolutionId = parseInt(this.resolutionId.toString(), 10) | ||
47 | |||
48 | const file = this.video.files.find(f => f.resolution.id === this.resolutionId) | ||
49 | if (!file) { | ||
50 | console.error('Could not find file with resolution %d.', this.resolutionId) | ||
51 | return | ||
52 | } | ||
53 | |||
54 | switch (this.downloadType) { | ||
55 | case 'direct': | ||
56 | return file.fileDownloadUrl | ||
57 | |||
58 | case 'torrent': | ||
59 | return file.torrentDownloadUrl | ||
60 | |||
61 | case 'magnet': | ||
62 | return file.magnetUri | ||
63 | } | ||
64 | } | ||
65 | |||
66 | activateCopiedMessage () { | ||
67 | this.notifier.success(this.i18n('Copied')) | ||
68 | } | ||
69 | } | ||