Add video image components
This commit is contained in:
parent
c8a5b03785
commit
702785a54c
|
@ -0,0 +1,16 @@
|
|||
<div class="root">
|
||||
<div>
|
||||
<div class="button-file">
|
||||
<span>{{ inputLabel }}</span>
|
||||
<input
|
||||
type="file"
|
||||
[name]="inputName" [id]="inputName" [accept]="videoImageExtensions"
|
||||
(change)="fileChange($event)"
|
||||
/>
|
||||
</div>
|
||||
<div class="image-constraints">(extensions: {{ videoImageExtensions }}, max size: {{ maxVideoImageSize | bytes }})</div>
|
||||
</div>
|
||||
|
||||
<img *ngIf="imageSrc" [ngStyle]="{ width: previewWidth, height: previewHeight }" [src]="imageSrc" class="preview" />
|
||||
<div *ngIf="!imageSrc" [ngStyle]="{ width: previewWidth, height: previewHeight }" class="preview no-image"></div>
|
||||
</div>
|
|
@ -0,0 +1,26 @@
|
|||
@import '_variables';
|
||||
@import '_mixins';
|
||||
|
||||
.root {
|
||||
height: 150px;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
|
||||
.button-file {
|
||||
@include peertube-button-file(190px);
|
||||
}
|
||||
|
||||
.image-constraints {
|
||||
font-size: 13px;
|
||||
}
|
||||
|
||||
.preview {
|
||||
border: 2px solid grey;
|
||||
border-radius: 4px;
|
||||
margin-left: 50px;
|
||||
|
||||
&.no-image {
|
||||
background-color: #ececec;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,74 @@
|
|||
import { Component, forwardRef, Input } from '@angular/core'
|
||||
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms'
|
||||
import { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser'
|
||||
import { ServerService } from '@app/core'
|
||||
import 'rxjs/add/observable/forkJoin'
|
||||
|
||||
@Component({
|
||||
selector: 'my-video-image',
|
||||
styleUrls: [ './video-image.component.scss' ],
|
||||
templateUrl: './video-image.component.html',
|
||||
providers: [
|
||||
{
|
||||
provide: NG_VALUE_ACCESSOR,
|
||||
useExisting: forwardRef(() => VideoImageComponent),
|
||||
multi: true
|
||||
}
|
||||
]
|
||||
})
|
||||
|
||||
export class VideoImageComponent implements ControlValueAccessor {
|
||||
@Input() inputLabel: string
|
||||
@Input() inputName: string
|
||||
@Input() previewWidth: string
|
||||
@Input() previewHeight: string
|
||||
|
||||
imageSrc: SafeResourceUrl
|
||||
|
||||
private file: Blob
|
||||
|
||||
constructor (
|
||||
private sanitizer: DomSanitizer,
|
||||
private serverService: ServerService
|
||||
) {}
|
||||
|
||||
get videoImageExtensions () {
|
||||
return this.serverService.getConfig().video.image.extensions.join(',')
|
||||
}
|
||||
|
||||
get maxVideoImageSize () {
|
||||
return this.serverService.getConfig().video.image.size.max
|
||||
}
|
||||
|
||||
fileChange (event: any) {
|
||||
if (event.target.files && event.target.files.length) {
|
||||
const [ file ] = event.target.files
|
||||
|
||||
this.file = file
|
||||
this.propagateChange(this.file)
|
||||
this.updatePreview()
|
||||
}
|
||||
}
|
||||
|
||||
propagateChange = (_: any) => { /* empty */ }
|
||||
|
||||
writeValue (file: any) {
|
||||
this.file = file
|
||||
this.updatePreview()
|
||||
}
|
||||
|
||||
registerOnChange (fn: (_: any) => void) {
|
||||
this.propagateChange = fn
|
||||
}
|
||||
|
||||
registerOnTouched () {
|
||||
// Unused
|
||||
}
|
||||
|
||||
private updatePreview () {
|
||||
if (this.file) {
|
||||
const url = URL.createObjectURL(this.file)
|
||||
this.imageSrc = this.sanitizer.bypassSecurityTrustResourceUrl(url)
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue