1 import { Component, OnInit } from '@angular/core'
2 import { ConfigService } from '@app/+admin/config/shared/config.service'
3 import { ServerService } from '@app/core/server/server.service'
4 import { CustomConfigValidatorsService, FormReactive, UserValidatorsService } from '@app/shared'
5 import { Notifier } from '@app/core'
6 import { CustomConfig } from '../../../../../../shared/models/server/custom-config.model'
7 import { I18n } from '@ngx-translate/i18n-polyfill'
8 import { FormValidatorService } from '@app/shared/forms/form-validators/form-validator.service'
9 import { SelectItem } from 'primeng/api'
10 import { forkJoin } from 'rxjs'
11 import { first } from 'rxjs/operators'
14 selector: 'my-edit-custom-config',
15 templateUrl: './edit-custom-config.component.html',
16 styleUrls: [ './edit-custom-config.component.scss' ]
18 export class EditCustomConfigComponent extends FormReactive implements OnInit {
19 customConfig: CustomConfig
21 resolutions: { id: string, label: string }[] = []
22 transcodingThreadOptions: { label: string, value: number }[] = []
24 languageItems: SelectItem[] = []
25 categoryItems: SelectItem[] = []
28 protected formValidatorService: FormValidatorService,
29 private customConfigValidatorsService: CustomConfigValidatorsService,
30 private userValidatorsService: UserValidatorsService,
31 private notifier: Notifier,
32 private configService: ConfigService,
33 private serverService: ServerService,
41 label: this.i18n('240p')
45 label: this.i18n('360p')
49 label: this.i18n('480p')
53 label: this.i18n('720p')
57 label: this.i18n('1080p')
61 label: this.i18n('2160p')
65 this.transcodingThreadOptions = [
66 { value: 0, label: this.i18n('Auto (via ffmpeg)') },
67 { value: 1, label: '1' },
68 { value: 2, label: '2' },
69 { value: 4, label: '4' },
70 { value: 8, label: '8' }
74 get videoQuotaOptions () {
75 return this.configService.videoQuotaOptions
78 get videoQuotaDailyOptions () {
79 return this.configService.videoQuotaDailyOptions
82 get availableThemes () {
83 return this.serverService.getConfig().theme.registered
87 getResolutionKey (resolution: string) {
88 return 'transcoding.resolutions.' + resolution
92 const formGroupData: { [key in keyof CustomConfig ]: any } = {
94 name: this.customConfigValidatorsService.INSTANCE_NAME,
95 shortDescription: this.customConfigValidatorsService.INSTANCE_SHORT_DESCRIPTION,
99 defaultNSFWPolicy: null,
104 creationReason: null,
105 moderationInformation: null,
107 maintenanceLifetime: null,
110 hardwareInformation: null,
115 defaultClientRoute: null,
127 username: this.customConfigValidatorsService.SERVICES_TWITTER_USERNAME,
133 size: this.customConfigValidatorsService.CACHE_PREVIEWS_SIZE
136 size: this.customConfigValidatorsService.CACHE_CAPTIONS_SIZE
141 limit: this.customConfigValidatorsService.SIGNUP_LIMIT,
142 requiresEmailVerification: null
155 email: this.customConfigValidatorsService.ADMIN_EMAIL
161 videoQuota: this.userValidatorsService.USER_VIDEO_QUOTA,
162 videoQuotaDaily: this.userValidatorsService.USER_VIDEO_QUOTA_DAILY
166 threads: this.customConfigValidatorsService.TRANSCODING_THREADS,
167 allowAdditionalExtensions: null,
168 allowAudioFiles: null,
191 indexUrl: this.customConfigValidatorsService.INDEX_URL
197 const defaultValues = {
202 for (const resolution of this.resolutions) {
203 defaultValues.transcoding.resolutions[resolution.id] = 'false'
204 formGroupData.transcoding.resolutions[resolution.id] = null
207 this.buildForm(formGroupData)
210 this.configService.getCustomConfig(),
211 this.serverService.videoLanguagesLoaded.pipe(first()), // First so the observable completes
212 this.serverService.videoCategoriesLoaded.pipe(first())
215 this.customConfig = config
217 const languages = this.serverService.getVideoLanguages()
218 this.languageItems = languages.map(l => ({ label: l.label, value: l.id }))
220 const categories = this.serverService.getVideoCategories()
221 this.categoryItems = categories.map(l => ({ label: l.label, value: l.id }))
224 // Force form validation
228 err => this.notifier.error(err.message)
232 isTranscodingEnabled () {
233 return this.form.value['transcoding']['enabled'] === true
237 return this.form.value['signup']['enabled'] === true
240 async formValidated () {
241 this.configService.updateCustomConfig(this.form.value)
244 this.customConfig = res
246 // Reload general configuration
247 this.serverService.loadConfig()
251 this.notifier.success(this.i18n('Configuration updated.'))
254 err => this.notifier.error(err.message)
258 getSelectedLanguageLabel () {
259 return this.i18n('{{\'{0} languages selected')
262 getDefaultLanguageLabel () {
263 return this.i18n('No language')
266 getSelectedCategoryLabel () {
267 return this.i18n('{{\'{0} categories selected')
270 getDefaultCategoryLabel () {
271 return this.i18n('No category')
274 private updateForm () {
275 this.form.patchValue(this.customConfig)