mirror of
https://github.com/Tzahi12345/YoutubeDL-Material.git
synced 2026-03-07 20:10:03 +03:00
fixed two bugs for audio only files: sometimes downloads failed as extensions were improperly removed and readded, removing a single character from the filename. Fixed another extension-related bug where metadata from deleted audio files persisted
160 lines
5.0 KiB
TypeScript
160 lines
5.0 KiB
TypeScript
import { Component, OnInit } from '@angular/core';
|
|
import { PostsService } from 'app/posts.services';
|
|
import { CheckOrSetPinDialogComponent } from 'app/dialogs/check-or-set-pin-dialog/check-or-set-pin-dialog.component';
|
|
import { isoLangs } from './locales_list';
|
|
import { MatSnackBar } from '@angular/material/snack-bar';
|
|
import {DomSanitizer} from '@angular/platform-browser';
|
|
import { MatDialog } from '@angular/material/dialog';
|
|
import { ArgModifierDialogComponent } from 'app/dialogs/arg-modifier-dialog/arg-modifier-dialog.component';
|
|
import { CURRENT_VERSION } from 'app/consts';
|
|
import { MatCheckboxChange } from '@angular/material/checkbox';
|
|
|
|
@Component({
|
|
selector: 'app-settings',
|
|
templateUrl: './settings.component.html',
|
|
styleUrls: ['./settings.component.scss']
|
|
})
|
|
export class SettingsComponent implements OnInit {
|
|
all_locales = isoLangs;
|
|
supported_locales = ['en', 'es'];
|
|
initialLocale = localStorage.getItem('locale');
|
|
|
|
initial_config = null;
|
|
new_config = null
|
|
loading_config = false;
|
|
generated_bookmarklet_code = null;
|
|
bookmarkletAudioOnly = false;
|
|
|
|
_settingsSame = true;
|
|
|
|
latestGithubRelease = null;
|
|
CURRENT_VERSION = CURRENT_VERSION
|
|
|
|
get settingsAreTheSame() {
|
|
this._settingsSame = this.settingsSame()
|
|
return this._settingsSame;
|
|
}
|
|
|
|
set settingsAreTheSame(val) {
|
|
this._settingsSame = val;
|
|
}
|
|
|
|
constructor(private postsService: PostsService, private snackBar: MatSnackBar, private sanitizer: DomSanitizer,
|
|
private dialog: MatDialog) { }
|
|
|
|
ngOnInit() {
|
|
this.getConfig();
|
|
|
|
this.generated_bookmarklet_code = this.sanitizer.bypassSecurityTrustUrl(this.generateBookmarkletCode());
|
|
|
|
this.getLatestGithubRelease();
|
|
}
|
|
|
|
getConfig() {
|
|
this.loading_config = true;
|
|
this.postsService.loadNavItems().subscribe(res => {
|
|
this.loading_config = false;
|
|
// successfully loaded config
|
|
|
|
this.initial_config = !this.postsService.debugMode ? res['config_file']['YoutubeDLMaterial'] : res['YoutubeDLMaterial'];
|
|
this.new_config = JSON.parse(JSON.stringify(this.initial_config));
|
|
});
|
|
}
|
|
|
|
settingsSame() {
|
|
return JSON.stringify(this.new_config) === JSON.stringify(this.initial_config);
|
|
}
|
|
|
|
saveSettings() {
|
|
const settingsToSave = {'YoutubeDLMaterial': this.new_config};
|
|
this.postsService.setConfig(settingsToSave).subscribe(res => {
|
|
if (res['success']) {
|
|
// sets new config as old config
|
|
this.postsService.settings_changed.next(true);
|
|
this.initial_config = JSON.parse(JSON.stringify(this.new_config));
|
|
}
|
|
}, err => {
|
|
console.error('Failed to save config!');
|
|
})
|
|
}
|
|
|
|
setNewPin() {
|
|
const dialogRef = this.dialog.open(CheckOrSetPinDialogComponent, {
|
|
data: {
|
|
resetMode: true
|
|
}
|
|
});
|
|
}
|
|
|
|
localeSelectChanged(new_val) {
|
|
localStorage.setItem('locale', new_val);
|
|
this.openSnackBar('Language successfully changed! Reload to update the page.')
|
|
}
|
|
|
|
generateBookmarklet() {
|
|
this.bookmarksite('YTDL-Material', this.generated_bookmarklet_code);
|
|
}
|
|
|
|
generateBookmarkletCode() {
|
|
const currentURL = window.location.href.split('#')[0];
|
|
const homePageWithArgsURL = currentURL + '#/home;url=';
|
|
const audioOnly = this.bookmarkletAudioOnly;
|
|
// tslint:disable-next-line: max-line-length
|
|
const bookmarkletCode = `javascript:(function()%7Bwindow.open('${homePageWithArgsURL}' + encodeURIComponent(window.location) + ';audioOnly=${audioOnly}')%7D)()`;
|
|
return bookmarkletCode;
|
|
}
|
|
|
|
bookmarkletAudioOnlyChanged(event: MatCheckboxChange): void {
|
|
this.bookmarkletAudioOnly = event.checked;
|
|
this.generated_bookmarklet_code = this.sanitizer.bypassSecurityTrustUrl(this.generateBookmarkletCode());
|
|
}
|
|
|
|
// not currently functioning on most platforms. hence not in use
|
|
bookmarksite(title, url) {
|
|
// Internet Explorer
|
|
if (document.all) {
|
|
window['external']['AddFavorite'](url, title);
|
|
} else if (window['chrome']) {
|
|
// Google Chrome
|
|
this.openSnackBar('Chrome users must drag the \'Alternate URL\' link to your bookmarks.');
|
|
} else if (window['sidebar']) {
|
|
// Firefox
|
|
window['sidebar'].addPanel(title, url, '');
|
|
} else if (window['opera'] && window.print) {
|
|
// Opera
|
|
const elem = document.createElement('a');
|
|
elem.setAttribute('href', url);
|
|
elem.setAttribute('title', title);
|
|
elem.setAttribute('rel', 'sidebar');
|
|
elem.click();
|
|
}
|
|
}
|
|
|
|
openArgsModifierDialog() {
|
|
const dialogRef = this.dialog.open(ArgModifierDialogComponent, {
|
|
data: {
|
|
initial_args: this.new_config['Downloader']['custom_args']
|
|
}
|
|
});
|
|
dialogRef.afterClosed().subscribe(new_args => {
|
|
if (new_args) {
|
|
this.new_config['Downloader']['custom_args'] = new_args;
|
|
}
|
|
});
|
|
}
|
|
|
|
getLatestGithubRelease() {
|
|
this.postsService.getLatestGithubRelease().subscribe(res => {
|
|
this.latestGithubRelease = res;
|
|
});
|
|
}
|
|
|
|
// snackbar helper
|
|
public openSnackBar(message: string, action: string = '') {
|
|
this.snackBar.open(message, action, {
|
|
duration: 2000,
|
|
});
|
|
}
|
|
|
|
}
|