@nbxx/nb-input
Version:
Angular - nbinput
169 lines (167 loc) • 19.5 kB
JavaScript
import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from "@angular/forms";
import { NbinputConfig, NbFieldType, SystemAttachment } from "./nbinput.entity";
import { NbinputUploadService } from "./nbinput-upload";
export class NbinputImageComponent {
constructor(uploader) {
this.uploader = uploader;
this.onTouchedCallback = () => { };
this.onChangeCallback = (_) => { };
this.config = new NbinputConfig();
this.readonly = false;
this.mime = '*';
this.type = NbFieldType.Image;
this.fileChanged = new EventEmitter();
this._data = [];
}
validate(c) {
this.data.forEach(e => {
if (!e.completed || !e.success) {
return {
FilesOnUploading: {
valid: false,
},
};
}
});
return null;
}
registerOnValidatorChange(fn) { }
writeValue(obj) {
if (obj && Array.isArray(obj)) {
this.data = obj;
}
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
registerOnChange(fn) {
if (fn) {
this.onChangeCallback = fn;
}
}
registerOnTouched(fn) { if (fn) {
this.onTouchedCallback = fn;
} }
onBlur() { this.onTouchedCallback(); }
submit() {
// 只提交上传完成的文件
const out = this.data.filter(e => e.completed && e.success);
this.fileChanged.emit(out);
this.onChangeCallback(out);
}
get value() {
return this.data;
}
;
set value(v) {
if (v !== this.data) {
this.data = v;
this.onChangeCallback(v);
}
}
set data(val) {
if (val && Array.isArray(val)) {
val.filter(v => v.url && v.url.length > 0).forEach(v => {
v.completed = true;
v.name = v.name || '未命名';
});
this._data = val;
}
else {
this._data = [];
}
}
get data() {
return this._data;
}
external(img) {
return img.indexOf("http://") == 0 || img.indexOf("https://") == 0;
}
onChange(event) {
for (let i = 0; i < event.target.files.length; i++) {
// event.target.data[i].callback = this.submit;
const a = new SystemAttachment(event.target.files[i]);
a.completed = false;
a.url = '';
this.data.push(a);
this.uploader.upload(event.target.files[i], this.config.uploadAPI)
.subscribe(e => {
Object.assign(a, e);
if (e.completed) {
this.submit();
}
});
}
event.target.value = '';
event.target.files = [];
}
delImg(img) {
for (let i = 0; i < this.data.length; i++) {
if (this.data[i] == img) {
this.data.splice(i, 1);
this.submit();
break;
}
}
}
}
NbinputImageComponent.decorators = [
{ type: Component, args: [{
selector: 'nbinput-image',
template: `
<div class="nbgallery" [ngClass]="{'disabled': disabled}">
<div class="item" *ngFor="let item of data">
<img [src]="(!external(item.url)&&config.downloadAPI ? config.downloadAPI + item.url : item.url) + (config.token ? '?token=' + config.token : '')" class="img-thumbnail">
<i *ngIf="!readonly&&!disabled" class="del fa fa-times-circle" (click)="delImg(item)"></i>
<div [ngClass]="{'text-muted':!readonly&&!disabled&&!item.completed}">
<nbinput-inline [(ngModel)]="item.name"></nbinput-inline>
{{item.size?'('+(item.size | filesize)+')':''}}
</div>
<div class="progress" *ngIf="!readonly&&!disabled&&!item.completed">
<div class="progress-bar bg-warning"
role="progressbar"
[style.width]="item.progressStyle"
aria-valuenow="item.progress"
aria-valuemin="0"
aria-valuemax="100"></div>
</div>
</div>
<div class="photor item" *ngIf="!readonly">
<!--<span class="helper"></span><img src="">-->
<input [disabled]="disabled" type="file" (change)="onChange($event)" [accept]="mime"/>
</div>
<div class="clearfix"></div>
</div>
`,
styles: [`
.nbgallery .item{float:left;padding:10px 10px;margin:10px 10px;min-width:128px;min-height:128px;position:relative;text-align:center;height:138px}.nbgallery .item img{max-width:100%;max-height:100%}.nbgallery .item i.del{color:#f00;position:absolute;top:0;right:0;font-size:20px;cursor:pointer}.nbgallery .photor{padding:10px;width:128px;height:128px;border:1px dashed #ddd;border-radius:10px;background:url("") no-repeat center;background-size:100%;background-origin:content-box}.nbgallery .photor input{width:108px;height:108px;display:inline-block;opacity:0;filter:alpha(opacity=0);-ms-filter:'alpha(opacity=0)'}.nbgallery.disabled{background-color:#e1e6ef}span img{max-width:100%}
`],
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => NbinputImageComponent),
multi: true
},
{
provide: NG_VALIDATORS,
useExisting: forwardRef(() => NbinputImageComponent),
multi: true,
}
]
},] },
];
/** @nocollapse */
NbinputImageComponent.ctorParameters = () => [
{ type: NbinputUploadService }
];
NbinputImageComponent.propDecorators = {
disabled: [{ type: Input }],
config: [{ type: Input }],
readonly: [{ type: Input }],
mime: [{ type: Input }],
type: [{ type: Input }],
fileChanged: [{ type: Output }],
data: [{ type: Input }]
};
//# sourceMappingURL=nbinput-image.component.js.map