]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - client/src/app/+admin/config/edit-custom-config/edit-custom-config.component.ts
Add contact form checkbox in admin form
[github/Chocobozzz/PeerTube.git] / client / src / app / +admin / config / edit-custom-config / edit-custom-config.component.ts
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 { BuildFormDefaultValues, FormValidatorService } from '@app/shared/forms/form-validators/form-validator.service'
9
10 @Component({
11 selector: 'my-edit-custom-config',
12 templateUrl: './edit-custom-config.component.html',
13 styleUrls: [ './edit-custom-config.component.scss' ]
14 })
15 export class EditCustomConfigComponent extends FormReactive implements OnInit {
16 customConfig: CustomConfig
17
18 resolutions: string[] = []
19 transcodingThreadOptions: { label: string, value: number }[] = []
20
21 constructor (
22 protected formValidatorService: FormValidatorService,
23 private customConfigValidatorsService: CustomConfigValidatorsService,
24 private userValidatorsService: UserValidatorsService,
25 private notifier: Notifier,
26 private configService: ConfigService,
27 private serverService: ServerService,
28 private i18n: I18n
29 ) {
30 super()
31
32 this.resolutions = [
33 this.i18n('240p'),
34 this.i18n('360p'),
35 this.i18n('480p'),
36 this.i18n('720p'),
37 this.i18n('1080p')
38 ]
39
40 this.transcodingThreadOptions = [
41 { value: 0, label: this.i18n('Auto (via ffmpeg)') },
42 { value: 1, label: '1' },
43 { value: 2, label: '2' },
44 { value: 4, label: '4' },
45 { value: 8, label: '8' }
46 ]
47 }
48
49 get videoQuotaOptions () {
50 return this.configService.videoQuotaOptions
51 }
52
53 get videoQuotaDailyOptions () {
54 return this.configService.videoQuotaDailyOptions
55 }
56
57 getResolutionKey (resolution: string) {
58 return 'transcoding.resolutions.' + resolution
59 }
60
61 ngOnInit () {
62 const formGroupData: { [key in keyof CustomConfig ]: any } = {
63 instance: {
64 name: this.customConfigValidatorsService.INSTANCE_NAME,
65 shortDescription: this.customConfigValidatorsService.INSTANCE_SHORT_DESCRIPTION,
66 description: null,
67 terms: null,
68 defaultClientRoute: null,
69 defaultNSFWPolicy: null,
70 customizations: {
71 javascript: null,
72 css: null
73 }
74 },
75 services: {
76 twitter: {
77 username: this.customConfigValidatorsService.SERVICES_TWITTER_USERNAME,
78 whitelisted: null
79 }
80 },
81 cache: {
82 previews: {
83 size: this.customConfigValidatorsService.CACHE_PREVIEWS_SIZE
84 },
85 captions: {
86 size: this.customConfigValidatorsService.CACHE_CAPTIONS_SIZE
87 }
88 },
89 signup: {
90 enabled: null,
91 limit: this.customConfigValidatorsService.SIGNUP_LIMIT,
92 requiresEmailVerification: null
93 },
94 import: {
95 videos: {
96 http: {
97 enabled: null
98 },
99 torrent: {
100 enabled: null
101 }
102 }
103 },
104 admin: {
105 email: this.customConfigValidatorsService.ADMIN_EMAIL
106 },
107 contactForm: {
108 enabled: null
109 },
110 user: {
111 videoQuota: this.userValidatorsService.USER_VIDEO_QUOTA,
112 videoQuotaDaily: this.userValidatorsService.USER_VIDEO_QUOTA_DAILY
113 },
114 transcoding: {
115 enabled: null,
116 threads: this.customConfigValidatorsService.TRANSCODING_THREADS,
117 allowAdditionalExtensions: null,
118 resolutions: {}
119 }
120 }
121
122 const defaultValues = {
123 transcoding: {
124 resolutions: {}
125 }
126 }
127 for (const resolution of this.resolutions) {
128 defaultValues.transcoding.resolutions[resolution] = 'false'
129 formGroupData.transcoding.resolutions[resolution] = null
130 }
131
132 this.buildForm(formGroupData)
133
134 this.configService.getCustomConfig()
135 .subscribe(
136 res => {
137 this.customConfig = res
138
139 this.updateForm()
140 // Force form validation
141 this.forceCheck()
142 },
143
144 err => this.notifier.error(err.message)
145 )
146 }
147
148 isTranscodingEnabled () {
149 return this.form.value['transcoding']['enabled'] === true
150 }
151
152 isSignupEnabled () {
153 return this.form.value['signup']['enabled'] === true
154 }
155
156 async formValidated () {
157 this.configService.updateCustomConfig(this.form.value)
158 .subscribe(
159 res => {
160 this.customConfig = res
161
162 // Reload general configuration
163 this.serverService.loadConfig()
164
165 this.updateForm()
166
167 this.notifier.success(this.i18n('Configuration updated.'))
168 },
169
170 err => this.notifier.error(err.message)
171 )
172 }
173
174 private updateForm () {
175 this.form.patchValue(this.customConfig)
176 }
177
178 }