styleUrls: [ './edit-custom-config.component.scss' ]
})
export class EditCustomConfigComponent extends FormReactive implements OnInit {
- static videoQuotaOptions = [
- { value: -1, label: 'Unlimited' },
- { value: 0, label: '0' },
- { value: 100 * 1024 * 1024, label: '100MB' },
- { value: 500 * 1024 * 1024, label: '500MB' },
- { value: 1024 * 1024 * 1024, label: '1GB' },
- { value: 5 * 1024 * 1024 * 1024, label: '5GB' },
- { value: 20 * 1024 * 1024 * 1024, label: '20GB' },
- { value: 50 * 1024 * 1024 * 1024, label: '50GB' }
- ]
- static videoQuotaDailyOptions = [
- { value: -1, label: 'Unlimited' },
- { value: 0, label: '0' },
- { value: 10 * 1024 * 1024, label: '10MB' },
- { value: 50 * 1024 * 1024, label: '50MB' },
- { value: 100 * 1024 * 1024, label: '100MB' },
- { value: 500 * 1024 * 1024, label: '500MB' },
- { value: 2 * 1024 * 1024 * 1024, label: '2GB' },
- { value: 5 * 1024 * 1024 * 1024, label: '5GB' }
- ]
-
customConfig: CustomConfig
- resolutions = [ '240p', '360p', '480p', '720p', '1080p' ]
- transcodingThreadOptions = [
- { value: 0, label: 'Auto (via ffmpeg)' },
- { value: 1, label: '1' },
- { value: 2, label: '2' },
- { value: 4, label: '4' },
- { value: 8, label: '8' }
- ]
+ resolutions: string[] = []
+ transcodingThreadOptions: { label: string, value: number }[] = []
private oldCustomJavascript: string
private oldCustomCSS: string
private i18n: I18n
) {
super()
+
+ this.resolutions = [
+ this.i18n('240p'),
+ this.i18n('360p'),
+ this.i18n('480p'),
+ this.i18n('720p'),
+ this.i18n('1080p')
+ ]
+
+ this.transcodingThreadOptions = [
+ { value: 0, label: this.i18n('Auto (via ffmpeg)') },
+ { value: 1, label: '1' },
+ { value: 2, label: '2' },
+ { value: 4, label: '4' },
+ { value: 8, label: '8' }
+ ]
}
get videoQuotaOptions () {
- return EditCustomConfigComponent.videoQuotaOptions
+ return this.configService.videoQuotaOptions
}
get videoQuotaDailyOptions () {
- return EditCustomConfigComponent.videoQuotaDailyOptions
+ return this.configService.videoQuotaDailyOptions
}
getResolutionKey (resolution: string) {
import { CustomConfig } from '../../../../../../shared/models/server/custom-config.model'
import { environment } from '../../../../environments/environment'
import { RestExtractor } from '../../../shared'
+import { I18n } from '@ngx-translate/i18n-polyfill'
@Injectable()
export class ConfigService {
private static BASE_APPLICATION_URL = environment.apiUrl + '/api/v1/config'
+ videoQuotaOptions: { value: number, label: string }[] = []
+ videoQuotaDailyOptions: { value: number, label: string }[] = []
+
constructor (
private authHttp: HttpClient,
- private restExtractor: RestExtractor
- ) {}
+ private restExtractor: RestExtractor,
+ private i18n: I18n
+ ) {
+ this.videoQuotaOptions = [
+ { value: -1, label: this.i18n('Unlimited') },
+ { value: 0, label: '0' },
+ { value: 100 * 1024 * 1024, label: this.i18n('100MB') },
+ { value: 500 * 1024 * 1024, label: this.i18n('500MB') },
+ { value: 1024 * 1024 * 1024, label: this.i18n('1GB') },
+ { value: 5 * 1024 * 1024 * 1024, label: this.i18n('5GB') },
+ { value: 20 * 1024 * 1024 * 1024, label: this.i18n('20GB') },
+ { value: 50 * 1024 * 1024 * 1024, label: this.i18n('50GB') }
+ ]
+
+ this.videoQuotaDailyOptions = [
+ { value: -1, label: this.i18n('Unlimited') },
+ { value: 0, label: '0' },
+ { value: 10 * 1024 * 1024, label: this.i18n('10MB') },
+ { value: 50 * 1024 * 1024, label: this.i18n('50MB') },
+ { value: 100 * 1024 * 1024, label: this.i18n('100MB') },
+ { value: 500 * 1024 * 1024, label: this.i18n('500MB') },
+ { value: 2 * 1024 * 1024 * 1024, label: this.i18n('2GB') },
+ { value: 5 * 1024 * 1024 * 1024, label: this.i18n('5GB') }
+ ]
+ }
getCustomConfig () {
return this.authHttp.get<CustomConfig>(ConfigService.BASE_APPLICATION_URL + '/custom')
<td>{{ follow.score }}</td>
<td>{{ follow.follower.name }}</td>
<td>{{ follow.follower.host }}</td>
- <td>{{ follow.state }}</td>
+
+ <td *ngIf="follow.state === 'accepted'" i18n>Accepted</td>
+ <td *ngIf="follow.state === 'pending'" i18n>Pending</td>
+
<td>{{ follow.createdAt }}</td>
</tr>
</ng-template>
<tr>
<td>{{ follow.id }}</td>
<td>{{ follow.following.host }}</td>
- <td>{{ follow.state }}</td>
+
+ <td *ngIf="follow.state === 'accepted'" i18n>Accepted</td>
+ <td *ngIf="follow.state === 'pending'" i18n>Pending</td>
+
<td>{{ follow.createdAt }}</td>
<td>
<my-redundancy-checkbox
import { I18n } from '@ngx-translate/i18n-polyfill'
import { FormValidatorService } from '@app/shared/forms/form-validators/form-validator.service'
import { UserValidatorsService } from '@app/shared/forms/form-validators/user-validators.service'
+import { ConfigService } from '@app/+admin/config/shared/config.service'
@Component({
selector: 'my-user-create',
constructor (
protected serverService: ServerService,
protected formValidatorService: FormValidatorService,
+ protected configService: ConfigService,
private userValidatorsService: UserValidatorsService,
private router: Router,
private notificationsService: NotificationsService,
private i18n: I18n
) {
super()
+
+ this.buildQuotaOptions()
}
ngOnInit () {
import { FormReactive } from '../../../shared'
import { USER_ROLE_LABELS, VideoResolution } from '../../../../../../shared'
import { EditCustomConfigComponent } from '../../../+admin/config/edit-custom-config/'
+import { ConfigService } from '@app/+admin/config/shared/config.service'
export abstract class UserEdit extends FormReactive {
- // These are used by a HTML select, so convert key into strings
- videoQuotaOptions = EditCustomConfigComponent.videoQuotaOptions
- .map(q => ({ value: q.value.toString(), label: q.label }))
- videoQuotaDailyOptions = EditCustomConfigComponent.videoQuotaDailyOptions
- .map(q => ({ value: q.value.toString(), label: q.label }))
-
+ videoQuotaOptions: { value: string, label: string }[] = []
+ videoQuotaDailyOptions: { value: string, label: string }[] = []
roles = Object.keys(USER_ROLE_LABELS).map(key => ({ value: key.toString(), label: USER_ROLE_LABELS[key] }))
protected abstract serverService: ServerService
+ protected abstract configService: ConfigService
abstract isCreation (): boolean
abstract getFormButtonTitle (): string
return multiplier * parseInt(this.form.value['videoQuota'], 10)
}
+
+ protected buildQuotaOptions () {
+ // These are used by a HTML select, so convert key into strings
+ this.videoQuotaOptions = this.configService
+ .videoQuotaOptions.map(q => ({ value: q.value.toString(), label: q.label }))
+
+ this.videoQuotaDailyOptions = this.configService
+ .videoQuotaDailyOptions.map(q => ({ value: q.value.toString(), label: q.label }))
+ }
}
import { UserService } from '../shared'
import { ServerService } from '../../../core'
import { UserEdit } from './user-edit'
-import { UserUpdate, User } from '../../../../../../shared'
+import { User, UserUpdate } from '../../../../../../shared'
import { I18n } from '@ngx-translate/i18n-polyfill'
import { FormValidatorService } from '@app/shared/forms/form-validators/form-validator.service'
import { UserValidatorsService } from '@app/shared/forms/form-validators/user-validators.service'
+import { ConfigService } from '@app/+admin/config/shared/config.service'
@Component({
selector: 'my-user-update',
constructor (
protected formValidatorService: FormValidatorService,
protected serverService: ServerService,
+ protected configService: ConfigService,
private userValidatorsService: UserValidatorsService,
private route: ActivatedRoute,
private router: Router,
private i18n: I18n
) {
super()
+
+ this.buildQuotaOptions()
}
ngOnInit () {
})
it('Should list jobs with sort and pagination', async function () {
- const res = await getJobsListPaginationAndSort(servers[1].url, servers[1].accessToken, 'completed', 1, 1, 'createdAt')
+ const res = await getJobsListPaginationAndSort(servers[1].url, servers[1].accessToken, 'completed', 1, 2, 'createdAt')
expect(res.body.total).to.be.above(2)
- expect(res.body.data).to.have.lengthOf(1)
+ expect(res.body.data).to.have.lengthOf(2)
let job = res.body.data[0]
// Skip repeat jobs