UNPKG

@nbxx/nb-input

Version:
169 lines (167 loc) 19.5 kB
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