mirror of
https://github.com/Tzahi12345/YoutubeDL-Material.git
synced 2026-05-26 23:19:39 +00:00
Removed tomp3 and tomp4 routes, replaced with /downloadFile Simplified category->playlist conversion Simplified playlist creation Simplified file deletion Playlist duration calculation is now done on the backend (categories uses this now too) removeIDFromArchive moved from subscriptions->utils Added plumbing to support type agnostic playlists
81 lines
2.3 KiB
TypeScript
81 lines
2.3 KiB
TypeScript
import { Component, OnInit, Inject } from '@angular/core';
|
|
import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
|
|
import { FormControl } from '@angular/forms';
|
|
import { PostsService } from 'app/posts.services';
|
|
|
|
@Component({
|
|
selector: 'app-create-playlist',
|
|
templateUrl: './create-playlist.component.html',
|
|
styleUrls: ['./create-playlist.component.scss']
|
|
})
|
|
export class CreatePlaylistComponent implements OnInit {
|
|
// really "createPlaylistDialogComponent"
|
|
|
|
filesToSelectFrom = null;
|
|
type = null;
|
|
filesSelect = new FormControl();
|
|
audiosToSelectFrom = null;
|
|
videosToSelectFrom = null;
|
|
name = '';
|
|
|
|
create_in_progress = false;
|
|
|
|
constructor(@Inject(MAT_DIALOG_DATA) public data: any,
|
|
private postsService: PostsService,
|
|
public dialogRef: MatDialogRef<CreatePlaylistComponent>) { }
|
|
|
|
|
|
ngOnInit() {
|
|
if (this.data) {
|
|
this.filesToSelectFrom = this.data.filesToSelectFrom;
|
|
this.type = this.data.type;
|
|
}
|
|
|
|
if (!this.filesToSelectFrom) {
|
|
this.getMp3s();
|
|
this.getMp4s();
|
|
}
|
|
}
|
|
|
|
getMp3s() {
|
|
this.postsService.getMp3s().subscribe(result => {
|
|
this.audiosToSelectFrom = result['mp3s'];
|
|
});
|
|
}
|
|
|
|
getMp4s() {
|
|
this.postsService.getMp4s().subscribe(result => {
|
|
this.videosToSelectFrom = result['mp4s'];
|
|
});
|
|
}
|
|
|
|
createPlaylist() {
|
|
const thumbnailURL = this.getThumbnailURL();
|
|
this.create_in_progress = true;
|
|
this.postsService.createPlaylist(this.name, this.filesSelect.value, this.type, thumbnailURL).subscribe(res => {
|
|
this.create_in_progress = false;
|
|
if (res['success']) {
|
|
this.dialogRef.close(true);
|
|
} else {
|
|
this.dialogRef.close(false);
|
|
}
|
|
});
|
|
}
|
|
|
|
getThumbnailURL() {
|
|
let properFilesToSelectFrom = this.filesToSelectFrom;
|
|
if (!this.filesToSelectFrom) {
|
|
properFilesToSelectFrom = this.type === 'audio' ? this.audiosToSelectFrom : this.videosToSelectFrom;
|
|
}
|
|
for (let i = 0; i < properFilesToSelectFrom.length; i++) {
|
|
const file = properFilesToSelectFrom[i];
|
|
if (file.id === this.filesSelect.value[0]) {
|
|
// different services store the thumbnail in different places
|
|
if (file.thumbnailURL) { return file.thumbnailURL };
|
|
if (file.thumbnail) { return file.thumbnail };
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
}
|