sk-front-lib 0.18.4 → 0.19.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/article/sk-article-editor-server.component.d.ts +1 -1
- package/article/sk-article-editor.component.d.ts +1 -1
- package/article/sk-froala-editor.directive.d.ts +1 -1
- package/crud/sk-auth-admin.guard.d.ts +2 -2
- package/crud/sk-auth.guard.d.ts +2 -2
- package/{esm2022 → esm2020}/api/sk-api.module.mjs +9 -9
- package/{esm2022 → esm2020}/api/sk-api.service.mjs +4 -4
- package/{esm2022 → esm2020}/article/sk-article-editor-server.component.mjs +4 -4
- package/{esm2022 → esm2020}/article/sk-article-editor.component.mjs +4 -4
- package/{esm2022 → esm2020}/article/sk-article-server.module.mjs +5 -5
- package/{esm2022 → esm2020}/article/sk-article.module.mjs +7 -7
- package/{esm2022 → esm2020}/article/sk-article.service.mjs +4 -4
- package/{esm2022 → esm2020}/article/sk-froala-editor.directive.mjs +7 -7
- package/{esm2022 → esm2020}/crud/sk-account.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-affiliate.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-auth-admin.guard.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-auth.guard.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-auth.service.mjs +7 -7
- package/{esm2022 → esm2020}/crud/sk-board.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-brand.service.mjs +4 -4
- package/esm2020/crud/sk-cart.service.mjs +256 -0
- package/{esm2022 → esm2020}/crud/sk-category.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-comment.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-config.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-contact.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-coupon.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-document.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-etc.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-file.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-keyword.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-order.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-point.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-product.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-promotion.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-search.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-store.service.mjs +4 -4
- package/{esm2022 → esm2020}/crud/sk-user.service.mjs +4 -4
- package/{esm2022 → esm2020}/google-analytics/google-analytics-router.module.mjs +9 -9
- package/{esm2022 → esm2020}/google-analytics/google-analytics.module.mjs +5 -5
- package/esm2020/google-analytics/services/google-analytics.service.mjs +200 -0
- package/{esm2022 → esm2020}/image/sk-image.component.mjs +6 -6
- package/esm2020/image/sk-image.module.mjs +40 -0
- package/{esm2022 → esm2020}/lib/sk-byte.pipe.mjs +4 -4
- package/{esm2022 → esm2020}/lib/sk-date-time.pipe.mjs +4 -4
- package/{esm2022 → esm2020}/lib/sk-date.pipe.mjs +4 -4
- package/{esm2022 → esm2020}/lib/sk-front-lib.module.mjs +13 -13
- package/{esm2022 → esm2020}/lib/sk-keys.pipe.mjs +4 -4
- package/{esm2022 → esm2020}/lib/sk-time.pipe.mjs +4 -4
- package/esm2020/model/lib/filetype.mjs +179 -0
- package/esm2020/model/lib/payment.mjs +35 -0
- package/esm2020/search-address/dialog/dialog.component.mjs +27 -0
- package/{esm2022 → esm2020}/search-address/sk-search-address.directive.mjs +6 -6
- package/esm2020/search-address/sk-search-address.module.mjs +47 -0
- package/{esm2022 → esm2020}/search-address/sk-search-address.service.mjs +4 -4
- package/esm2020/uploader/sk-uploader.component.mjs +120 -0
- package/esm2020/uploader/sk-uploader.directive.mjs +44 -0
- package/esm2020/uploader/sk-uploader.module.mjs +57 -0
- package/fesm2015/sk-front-lib-api.mjs +216 -0
- package/fesm2015/sk-front-lib-api.mjs.map +1 -0
- package/fesm2015/sk-front-lib-article.mjs +758 -0
- package/fesm2015/sk-front-lib-article.mjs.map +1 -0
- package/fesm2015/sk-front-lib-crud.mjs +1529 -0
- package/fesm2015/sk-front-lib-crud.mjs.map +1 -0
- package/fesm2015/sk-front-lib-google-analytics.mjs +334 -0
- package/fesm2015/sk-front-lib-google-analytics.mjs.map +1 -0
- package/fesm2015/sk-front-lib-image.mjs +303 -0
- package/fesm2015/sk-front-lib-image.mjs.map +1 -0
- package/{fesm2022 → fesm2015}/sk-front-lib-model.mjs +62 -57
- package/fesm2015/sk-front-lib-model.mjs.map +1 -0
- package/fesm2015/sk-front-lib-search-address.mjs +183 -0
- package/fesm2015/sk-front-lib-search-address.mjs.map +1 -0
- package/fesm2015/sk-front-lib-uploader.mjs +546 -0
- package/fesm2015/sk-front-lib-uploader.mjs.map +1 -0
- package/{fesm2022 → fesm2015}/sk-front-lib.mjs +27 -27
- package/{fesm2022 → fesm2015}/sk-front-lib.mjs.map +1 -1
- package/{fesm2022 → fesm2020}/sk-front-lib-api.mjs +11 -11
- package/{fesm2022 → fesm2020}/sk-front-lib-api.mjs.map +1 -1
- package/{fesm2022 → fesm2020}/sk-front-lib-article.mjs +25 -25
- package/{fesm2022 → fesm2020}/sk-front-lib-article.mjs.map +1 -1
- package/{fesm2022 → fesm2020}/sk-front-lib-crud.mjs +93 -93
- package/fesm2020/sk-front-lib-crud.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/sk-front-lib-google-analytics.mjs +16 -38
- package/fesm2020/sk-front-lib-google-analytics.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/sk-front-lib-image.mjs +21 -21
- package/fesm2020/sk-front-lib-image.mjs.map +1 -0
- package/fesm2020/sk-front-lib-model.mjs +1110 -0
- package/fesm2020/sk-front-lib-model.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/sk-front-lib-search-address.mjs +32 -32
- package/fesm2020/sk-front-lib-search-address.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/sk-front-lib-uploader.mjs +49 -48
- package/fesm2020/sk-front-lib-uploader.mjs.map +1 -0
- package/fesm2020/sk-front-lib.mjs +538 -0
- package/fesm2020/sk-front-lib.mjs.map +1 -0
- package/google-analytics/services/google-analytics.service.d.ts +1 -2
- package/google-analytics/types/ga-action.type.d.ts +1 -1
- package/google-analytics/types/ga-bind.type.d.ts +1 -1
- package/image/sk-image.component.d.ts +2 -2
- package/image/sk-image.module.d.ts +3 -3
- package/model/lib/payment.d.ts +6 -1
- package/package.json +68 -46
- package/search-address/dialog/dialog.component.d.ts +1 -1
- package/search-address/sk-search-address.directive.d.ts +2 -2
- package/search-address/sk-search-address.module.d.ts +3 -3
- package/uploader/sk-uploader.component.d.ts +1 -1
- package/uploader/sk-uploader.directive.d.ts +2 -2
- package/uploader/sk-uploader.module.d.ts +5 -5
- package/esm2022/crud/sk-cart.service.mjs +0 -256
- package/esm2022/google-analytics/services/google-analytics.service.mjs +0 -223
- package/esm2022/image/sk-image.module.mjs +0 -40
- package/esm2022/model/lib/filetype.mjs +0 -179
- package/esm2022/model/lib/payment.mjs +0 -30
- package/esm2022/search-address/dialog/dialog.component.mjs +0 -27
- package/esm2022/search-address/sk-search-address.module.mjs +0 -47
- package/esm2022/uploader/sk-uploader.component.mjs +0 -119
- package/esm2022/uploader/sk-uploader.directive.mjs +0 -44
- package/esm2022/uploader/sk-uploader.module.mjs +0 -57
- package/fesm2022/sk-front-lib-crud.mjs.map +0 -1
- package/fesm2022/sk-front-lib-google-analytics.mjs.map +0 -1
- package/fesm2022/sk-front-lib-image.mjs.map +0 -1
- package/fesm2022/sk-front-lib-model.mjs.map +0 -1
- package/fesm2022/sk-front-lib-search-address.mjs.map +0 -1
- package/fesm2022/sk-front-lib-uploader.mjs.map +0 -1
- /package/{esm2022 → esm2020}/api/model/api-config.mjs +0 -0
- /package/{esm2022 → esm2020}/api/model/api-pageable-param.mjs +0 -0
- /package/{esm2022 → esm2020}/api/model/api-pageable.mjs +0 -0
- /package/{esm2022 → esm2020}/api/model/api-response.mjs +0 -0
- /package/{esm2022 → esm2020}/api/model/index.mjs +0 -0
- /package/{esm2022 → esm2020}/api/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/api/sk-front-lib-api.mjs +0 -0
- /package/{esm2022 → esm2020}/article/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/article/sk-front-lib-article.mjs +0 -0
- /package/{esm2022 → esm2020}/crud/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/crud/sk-front-lib-crud.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/initializers/google-analytics-router.initializer.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/initializers/google-analytics.initializer.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/interfaces/google-analytics-command.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/interfaces/google-analytics-settings.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/sk-front-lib-google-analytics.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/tokens/google-analytics-settings-token.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/types/ga-action.type.mjs +0 -0
- /package/{esm2022 → esm2020}/google-analytics/types/ga-bind.type.mjs +0 -0
- /package/{esm2022 → esm2020}/image/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/image/sk-front-lib-image.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/sk-animations.mjs +0 -0
- /package/{esm2022 → esm2020}/lib/sk-utils.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/article.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/audit.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/auth.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/board.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/cart.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/comment.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/contact.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/coupon.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/document.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/etc.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/file.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/grid.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/nicepay.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/order.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/point.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/product-series.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/product.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/promotion.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/shipping.mjs +0 -0
- /package/{esm2022 → esm2020}/model/lib/user.mjs +0 -0
- /package/{esm2022 → esm2020}/model/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/model/sk-front-lib-model.mjs +0 -0
- /package/{esm2022 → esm2020}/public-api.mjs +0 -0
- /package/{esm2022 → esm2020}/search-address/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/search-address/sk-front-lib-search-address.mjs +0 -0
- /package/{esm2022 → esm2020}/search-address/sk-search-address.model.mjs +0 -0
- /package/{esm2022 → esm2020}/sk-front-lib.mjs +0 -0
- /package/{esm2022 → esm2020}/uploader/public_api.mjs +0 -0
- /package/{esm2022 → esm2020}/uploader/sk-front-lib-uploader.mjs +0 -0
- /package/{esm2022 → esm2020}/uploader/sk-uploader-file-item.model.mjs +0 -0
- /package/{esm2022 → esm2020}/uploader/sk-uploader.animation.mjs +0 -0
- /package/{esm2022 → esm2020}/uploader/sk-uploader.class.mjs +0 -0
|
@@ -2,19 +2,19 @@ import * as i3 from '@angular/common';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import * as i0 from '@angular/core';
|
|
4
4
|
import { Component, ViewEncapsulation, Inject, ViewChild, HostListener, EventEmitter, Directive, Input, Output, NgModule } from '@angular/core';
|
|
5
|
-
import * as i5 from '@angular/material/button';
|
|
6
|
-
import {
|
|
7
|
-
import * as i1 from '@angular/material/dialog';
|
|
8
|
-
import {
|
|
5
|
+
import * as i5 from '@angular/material/legacy-button';
|
|
6
|
+
import { MatLegacyButtonModule } from '@angular/material/legacy-button';
|
|
7
|
+
import * as i1 from '@angular/material/legacy-dialog';
|
|
8
|
+
import { MAT_LEGACY_DIALOG_DATA, MatLegacyDialogModule } from '@angular/material/legacy-dialog';
|
|
9
9
|
import * as i6 from '@angular/material/icon';
|
|
10
10
|
import { MatIconModule } from '@angular/material/icon';
|
|
11
|
-
import * as i7 from '@angular/material/list';
|
|
12
|
-
import {
|
|
13
|
-
import * as
|
|
14
|
-
import {
|
|
11
|
+
import * as i7 from '@angular/material/legacy-list';
|
|
12
|
+
import { MatLegacyListModule } from '@angular/material/legacy-list';
|
|
13
|
+
import * as i10 from '@angular/material/legacy-progress-bar';
|
|
14
|
+
import { MatLegacyProgressBarModule } from '@angular/material/legacy-progress-bar';
|
|
15
15
|
import * as i4 from '@angular/material/toolbar';
|
|
16
16
|
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
17
|
-
import * as
|
|
17
|
+
import * as i11 from 'sk-front-lib';
|
|
18
18
|
import { SkFrontLibModule } from 'sk-front-lib';
|
|
19
19
|
import { FileType, SkFile } from 'sk-front-lib/model';
|
|
20
20
|
import { animation, style, animate, trigger, transition, useAnimation, query, stagger, animateChild } from '@angular/animations';
|
|
@@ -22,7 +22,8 @@ import { HttpRequest, HttpHeaders, HttpEventType } from '@angular/common/http';
|
|
|
22
22
|
import { of } from 'rxjs';
|
|
23
23
|
import { tap, last, map, catchError } from 'rxjs/operators';
|
|
24
24
|
import * as i2 from 'sk-front-lib/api';
|
|
25
|
-
import * as i8 from '@angular/material/
|
|
25
|
+
import * as i8 from '@angular/material/core';
|
|
26
|
+
import * as i9 from '@angular/material/divider';
|
|
26
27
|
import * as _ from 'lodash';
|
|
27
28
|
|
|
28
29
|
var SkUploaderFileItemType;
|
|
@@ -425,16 +426,16 @@ class SkUploaderComponent {
|
|
|
425
426
|
event.preventDefault();
|
|
426
427
|
event.stopPropagation();
|
|
427
428
|
}
|
|
428
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SkUploaderComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i2.SkApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
429
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SkUploaderComponent, selector: "sk-uploader", host: { listeners: { "drop": "onDrop($event)", "dragover": "onDragOver($event)", "dragleave": "onDragLeave($event)" } }, viewQueries: [{ propertyName: "fileEl", first: true, predicate: ["file"], descendants: true }, { propertyName: "dragEl", first: true, predicate: ["drag"], descendants: true }], ngImport: i0, template: "<mat-toolbar class=\"dialog-title\" color=\"primary\">\n <span class=\"title dialog-title\">File Uploader</span>\n <div class=\"space-fill\"></div>\n <button mat-icon-button mat-dialog-close aria-label=\"Close dialog\">\n <mat-icon>close</mat-icon>\n </button>\n</mat-toolbar>\n<div class=\"dialog-content\">\n <input type=\"file\" style=\"display: none\" #file (change)=\"onBrowseFileComplete()\" multiple />\n <div class=\"drag-section\" #drag (click)=\"onDragComponentClick()\" [class.active]=\"dragClassActive\">\n <mat-icon>cloud_upload</mat-icon>\n <p>Drag and drop or <strong>click to browse</strong></p>\n </div>\n <mat-list [@animateStagger]=\"{value:uploader.queue.length}\">\n <h3 mat-subheader>Selected Files ({{uploader.queue.length}})</h3>\n <mat-list-item class=\"selected-file\" *ngFor=\"let file of uploader.queue\"\n [@animate]=\"{value:'*',params:{x:'-25px', opacity:'0',duration:'200ms'}}\"\n [@animateOut]=\"{value:'*',params:{delay:'100ms',x:'-25px', opacity:'0',duration:'200ms'}}\"\n dense>\n <mat-icon class=\"type-icon\" [ngClass]=\"file.icon\" matListIcon></mat-icon>\n <div mat-line>\n <span class=\"file-name\">{{ file.filename }}</span>\n <span>{{ file.size | skByte }}</span>\n </div>\n <mat-progress-bar mat-line [mode]=\"file.state == 3 ? 'query' : 'determinate'\" [value]=\"file.progress\" color=\"accent\"></mat-progress-bar>\n <div mat-line>\n <ng-container [ngSwitch]=\"file.state\">\n <div *ngSwitchCase=\"0\">\n Selected\n </div>\n <div *ngSwitchCase=\"1\">\n Wait for upload\n </div>\n <div *ngSwitchCase=\"2\">\n Uploading\n </div>\n <div *ngSwitchCase=\"3\">\n Processing..\n </div>\n <div *ngSwitchCase=\"4\">\n Done.\n </div>\n <div *ngSwitchCase=\"5\">\n Failed\n </div>\n </ng-container>\n </div>\n <button mat-icon-button (click)=\"uploader.removeFromQueue(file)\">\n <mat-icon>delete</mat-icon>\n </button>\n </mat-list-item>\n <mat-divider *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\"></mat-divider>\n <mat-list-item class=\"empty\" *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\">\n <h2 mat-line>No file selected..</h2>\n </mat-list-item>\n </mat-list>\n</div>\n<mat-progress-bar mat-line mode=\"determinate\" [value]=\"uploader.progress\"></mat-progress-bar>\n<div class=\"dialog-actions\">\n <div>\n <button mat-flat-button color=\"warn\" (click)=\"uploader.clearQueue()\" [disabled]=\"uploader.queue.length === 0\">Clear all</button>\n </div>\n <div>\n <button mat-flat-button color=\"primary\"\n *ngIf=\"uploader.getNotUploadedItems().length > 0\"\n (click)=\"uploader.uploadAll()\">Start Upload</button>\n <button mat-flat-button color=\"accent\"\n *ngIf=\"uploader.getDoneItems().length === uploader.queue.length && uploader.getDoneItems().length > 0 \"\n style=\"margin-left: 8px\" (click)=\"save()\">Save</button>\n </div>\n</div>\n", styles: ["sk-uploader{display:flex;flex-direction:column;min-width:50vw;position:relative}sk-uploader .dialog-title{flex-shrink:0}sk-uploader .dialog-title .space-fill{flex:1 0 auto}sk-uploader .dialog-content{padding:16px;margin:0;overflow:scroll;overflow-x:hidden;flex:0 0 500px;max-height:500px}sk-uploader .dialog-content .drag-section{border:3px dashed #ccc;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}sk-uploader .dialog-content .drag-section .mat-icon{width:64px;height:64px;line-height:64px;font-size:64px}sk-uploader .dialog-content .drag-section p{cursor:pointer;font-size:14px}sk-uploader .dialog-content .drag-section .mat-icon,sk-uploader .dialog-content .drag-section p{color:#ccc}sk-uploader .dialog-content .drag-section.active{position:absolute;inset:0;width:100%;z-index:10;background-color:#2c393f}sk-uploader .dialog-content mat-list mat-list-item.selected-file{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;margin-bottom:8px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-mdc-list-item-icon,sk-uploader .dialog-content mat-list mat-list-item.selected-file mat-icon{width:32px!important;height:32px!important;line-height:32px!important;font-size:32px!important}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-mdc-icon-button{margin-left:16px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-line{display:flex;flex-direction:row;align-items:center;justify-content:space-between}sk-uploader .dialog-content mat-list mat-list-item.selected-file .file-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}sk-uploader .dialog-actions{padding:16px;flex-shrink:0;border-top:1px solid rgba(0,0,0,.12);display:flex;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "component", type: i4.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatList, selector: "mat-list", exportAs: ["matList"] }, { kind: "component", type: i7.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "directive", type: i7.MatListSubheaderCssMatStyler, selector: "[mat-subheader], [matSubheader]" }, { kind: "component", type: i8.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i9.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "pipe", type: i10.SkBytePipe, name: "skByte" }], animations: uploaderAnimations, encapsulation: i0.ViewEncapsulation.None }); }
|
|
430
429
|
}
|
|
431
|
-
i0.ɵɵ
|
|
430
|
+
SkUploaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderComponent, deps: [{ token: MAT_LEGACY_DIALOG_DATA }, { token: i1.MatLegacyDialogRef }, { token: i2.SkApiService }], target: i0.ɵɵFactoryTarget.Component });
|
|
431
|
+
SkUploaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: SkUploaderComponent, selector: "sk-uploader", host: { listeners: { "drop": "onDrop($event)", "dragover": "onDragOver($event)", "dragleave": "onDragLeave($event)" } }, viewQueries: [{ propertyName: "fileEl", first: true, predicate: ["file"], descendants: true }, { propertyName: "dragEl", first: true, predicate: ["drag"], descendants: true }], ngImport: i0, template: "<mat-toolbar class=\"dialog-title\" color=\"primary\">\n <span class=\"title dialog-title\">File Uploader</span>\n <div class=\"space-fill\"></div>\n <button mat-icon-button mat-dialog-close aria-label=\"Close dialog\">\n <mat-icon>close</mat-icon>\n </button>\n</mat-toolbar>\n<div class=\"dialog-content\">\n <input type=\"file\" style=\"display: none\" #file (change)=\"onBrowseFileComplete()\" multiple />\n <div class=\"drag-section\" #drag (click)=\"onDragComponentClick()\" [class.active]=\"dragClassActive\">\n <mat-icon>cloud_upload</mat-icon>\n <p>Drag and drop or <strong>click to browse</strong></p>\n </div>\n <mat-list [@animateStagger]=\"{value:uploader.queue.length}\">\n <h3 mat-subheader>Selected Files ({{uploader.queue.length}})</h3>\n <mat-list-item class=\"selected-file\" *ngFor=\"let file of uploader.queue\"\n [@animate]=\"{value:'*',params:{x:'-25px', opacity:'0',duration:'200ms'}}\"\n [@animateOut]=\"{value:'*',params:{delay:'100ms',x:'-25px', opacity:'0',duration:'200ms'}}\"\n dense>\n <mat-icon class=\"type-icon\" [ngClass]=\"file.icon\" matListIcon></mat-icon>\n <div mat-line>\n <span class=\"file-name\">{{ file.filename }}</span>\n <span>{{ file.size | skByte }}</span>\n </div>\n <mat-progress-bar mat-line [mode]=\"file.state == 3 ? 'query' : 'determinate'\" [value]=\"file.progress\" color=\"accent\"></mat-progress-bar>\n <div mat-line>\n <ng-container [ngSwitch]=\"file.state\">\n <div *ngSwitchCase=\"0\">\n Selected\n </div>\n <div *ngSwitchCase=\"1\">\n Wait for upload\n </div>\n <div *ngSwitchCase=\"2\">\n Uploading\n </div>\n <div *ngSwitchCase=\"3\">\n Processing..\n </div>\n <div *ngSwitchCase=\"4\">\n Done.\n </div>\n <div *ngSwitchCase=\"5\">\n Failed\n </div>\n </ng-container>\n </div>\n <button mat-icon-button (click)=\"uploader.removeFromQueue(file)\">\n <mat-icon>delete</mat-icon>\n </button>\n </mat-list-item>\n <mat-divider *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\"></mat-divider>\n <mat-list-item class=\"empty\" *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\">\n <h2 mat-line>No file selected..</h2>\n </mat-list-item>\n </mat-list>\n</div>\n<mat-progress-bar mat-line mode=\"determinate\" [value]=\"uploader.progress\"></mat-progress-bar>\n<div class=\"dialog-actions\">\n <div>\n <button mat-flat-button color=\"warn\" (click)=\"uploader.clearQueue()\" [disabled]=\"uploader.queue.length === 0\">Clear all</button>\n </div>\n <div>\n <button mat-flat-button color=\"primary\"\n *ngIf=\"uploader.getNotUploadedItems().length > 0\"\n (click)=\"uploader.uploadAll()\">Start Upload</button>\n <button mat-flat-button color=\"accent\"\n *ngIf=\"uploader.getDoneItems().length === uploader.queue.length && uploader.getDoneItems().length > 0 \"\n style=\"margin-left: 8px\" (click)=\"save()\">Save</button>\n </div>\n</div>\n", styles: ["sk-uploader{display:flex;flex-direction:column;min-width:50vw;position:relative}sk-uploader .dialog-title{flex-shrink:0}sk-uploader .dialog-title .space-fill{flex:1 0 auto}sk-uploader .dialog-content{padding:16px;margin:0;overflow:scroll;overflow-x:hidden;flex:0 0 500px;max-height:500px}sk-uploader .dialog-content .drag-section{border:3px dashed #ccc;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}sk-uploader .dialog-content .drag-section .mat-icon{width:64px;height:64px;line-height:64px;font-size:64px}sk-uploader .dialog-content .drag-section p{cursor:pointer;font-size:14px}sk-uploader .dialog-content .drag-section .mat-icon,sk-uploader .dialog-content .drag-section p{color:#ccc}sk-uploader .dialog-content .drag-section.active{position:absolute;inset:0;width:100%;z-index:10;background-color:#2c393f}sk-uploader .dialog-content mat-list mat-list-item.selected-file{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;margin-bottom:8px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-list-icon,sk-uploader .dialog-content mat-list mat-list-item.selected-file mat-icon{width:32px!important;height:32px!important;line-height:32px!important;font-size:32px!important}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-icon-button{margin-left:16px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-line{display:flex;flex-direction:row;align-items:center;justify-content:space-between}sk-uploader .dialog-content mat-list mat-list-item.selected-file .file-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}sk-uploader .dialog-actions{padding:16px;flex-shrink:0;border-top:1px solid rgba(0,0,0,.12);display:flex;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.MatLegacyDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "component", type: i4.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i5.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatLegacyList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { kind: "component", type: i7.MatLegacyListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["disableRipple", "disabled"], exportAs: ["matListItem"] }, { kind: "directive", type: i8.MatLine, selector: "[mat-line], [matLine]" }, { kind: "directive", type: i7.MatLegacyListIconCssMatStyler, selector: "[mat-list-icon], [matListIcon]" }, { kind: "directive", type: i7.MatLegacyListSubheaderCssMatStyler, selector: "[mat-subheader], [matSubheader]" }, { kind: "component", type: i9.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i10.MatLegacyProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "pipe", type: i11.SkBytePipe, name: "skByte" }], animations: uploaderAnimations, encapsulation: i0.ViewEncapsulation.None });
|
|
432
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderComponent, decorators: [{
|
|
432
433
|
type: Component,
|
|
433
|
-
args: [{ selector: 'sk-uploader', encapsulation: ViewEncapsulation.None, animations: uploaderAnimations, template: "<mat-toolbar class=\"dialog-title\" color=\"primary\">\n <span class=\"title dialog-title\">File Uploader</span>\n <div class=\"space-fill\"></div>\n <button mat-icon-button mat-dialog-close aria-label=\"Close dialog\">\n <mat-icon>close</mat-icon>\n </button>\n</mat-toolbar>\n<div class=\"dialog-content\">\n <input type=\"file\" style=\"display: none\" #file (change)=\"onBrowseFileComplete()\" multiple />\n <div class=\"drag-section\" #drag (click)=\"onDragComponentClick()\" [class.active]=\"dragClassActive\">\n <mat-icon>cloud_upload</mat-icon>\n <p>Drag and drop or <strong>click to browse</strong></p>\n </div>\n <mat-list [@animateStagger]=\"{value:uploader.queue.length}\">\n <h3 mat-subheader>Selected Files ({{uploader.queue.length}})</h3>\n <mat-list-item class=\"selected-file\" *ngFor=\"let file of uploader.queue\"\n [@animate]=\"{value:'*',params:{x:'-25px', opacity:'0',duration:'200ms'}}\"\n [@animateOut]=\"{value:'*',params:{delay:'100ms',x:'-25px', opacity:'0',duration:'200ms'}}\"\n dense>\n <mat-icon class=\"type-icon\" [ngClass]=\"file.icon\" matListIcon></mat-icon>\n <div mat-line>\n <span class=\"file-name\">{{ file.filename }}</span>\n <span>{{ file.size | skByte }}</span>\n </div>\n <mat-progress-bar mat-line [mode]=\"file.state == 3 ? 'query' : 'determinate'\" [value]=\"file.progress\" color=\"accent\"></mat-progress-bar>\n <div mat-line>\n <ng-container [ngSwitch]=\"file.state\">\n <div *ngSwitchCase=\"0\">\n Selected\n </div>\n <div *ngSwitchCase=\"1\">\n Wait for upload\n </div>\n <div *ngSwitchCase=\"2\">\n Uploading\n </div>\n <div *ngSwitchCase=\"3\">\n Processing..\n </div>\n <div *ngSwitchCase=\"4\">\n Done.\n </div>\n <div *ngSwitchCase=\"5\">\n Failed\n </div>\n </ng-container>\n </div>\n <button mat-icon-button (click)=\"uploader.removeFromQueue(file)\">\n <mat-icon>delete</mat-icon>\n </button>\n </mat-list-item>\n <mat-divider *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\"></mat-divider>\n <mat-list-item class=\"empty\" *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\">\n <h2 mat-line>No file selected..</h2>\n </mat-list-item>\n </mat-list>\n</div>\n<mat-progress-bar mat-line mode=\"determinate\" [value]=\"uploader.progress\"></mat-progress-bar>\n<div class=\"dialog-actions\">\n <div>\n <button mat-flat-button color=\"warn\" (click)=\"uploader.clearQueue()\" [disabled]=\"uploader.queue.length === 0\">Clear all</button>\n </div>\n <div>\n <button mat-flat-button color=\"primary\"\n *ngIf=\"uploader.getNotUploadedItems().length > 0\"\n (click)=\"uploader.uploadAll()\">Start Upload</button>\n <button mat-flat-button color=\"accent\"\n *ngIf=\"uploader.getDoneItems().length === uploader.queue.length && uploader.getDoneItems().length > 0 \"\n style=\"margin-left: 8px\" (click)=\"save()\">Save</button>\n </div>\n</div>\n", styles: ["sk-uploader{display:flex;flex-direction:column;min-width:50vw;position:relative}sk-uploader .dialog-title{flex-shrink:0}sk-uploader .dialog-title .space-fill{flex:1 0 auto}sk-uploader .dialog-content{padding:16px;margin:0;overflow:scroll;overflow-x:hidden;flex:0 0 500px;max-height:500px}sk-uploader .dialog-content .drag-section{border:3px dashed #ccc;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}sk-uploader .dialog-content .drag-section .mat-icon{width:64px;height:64px;line-height:64px;font-size:64px}sk-uploader .dialog-content .drag-section p{cursor:pointer;font-size:14px}sk-uploader .dialog-content .drag-section .mat-icon,sk-uploader .dialog-content .drag-section p{color:#ccc}sk-uploader .dialog-content .drag-section.active{position:absolute;inset:0;width:100%;z-index:10;background-color:#2c393f}sk-uploader .dialog-content mat-list mat-list-item.selected-file{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;margin-bottom:8px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-
|
|
434
|
+
args: [{ selector: 'sk-uploader', encapsulation: ViewEncapsulation.None, animations: uploaderAnimations, template: "<mat-toolbar class=\"dialog-title\" color=\"primary\">\n <span class=\"title dialog-title\">File Uploader</span>\n <div class=\"space-fill\"></div>\n <button mat-icon-button mat-dialog-close aria-label=\"Close dialog\">\n <mat-icon>close</mat-icon>\n </button>\n</mat-toolbar>\n<div class=\"dialog-content\">\n <input type=\"file\" style=\"display: none\" #file (change)=\"onBrowseFileComplete()\" multiple />\n <div class=\"drag-section\" #drag (click)=\"onDragComponentClick()\" [class.active]=\"dragClassActive\">\n <mat-icon>cloud_upload</mat-icon>\n <p>Drag and drop or <strong>click to browse</strong></p>\n </div>\n <mat-list [@animateStagger]=\"{value:uploader.queue.length}\">\n <h3 mat-subheader>Selected Files ({{uploader.queue.length}})</h3>\n <mat-list-item class=\"selected-file\" *ngFor=\"let file of uploader.queue\"\n [@animate]=\"{value:'*',params:{x:'-25px', opacity:'0',duration:'200ms'}}\"\n [@animateOut]=\"{value:'*',params:{delay:'100ms',x:'-25px', opacity:'0',duration:'200ms'}}\"\n dense>\n <mat-icon class=\"type-icon\" [ngClass]=\"file.icon\" matListIcon></mat-icon>\n <div mat-line>\n <span class=\"file-name\">{{ file.filename }}</span>\n <span>{{ file.size | skByte }}</span>\n </div>\n <mat-progress-bar mat-line [mode]=\"file.state == 3 ? 'query' : 'determinate'\" [value]=\"file.progress\" color=\"accent\"></mat-progress-bar>\n <div mat-line>\n <ng-container [ngSwitch]=\"file.state\">\n <div *ngSwitchCase=\"0\">\n Selected\n </div>\n <div *ngSwitchCase=\"1\">\n Wait for upload\n </div>\n <div *ngSwitchCase=\"2\">\n Uploading\n </div>\n <div *ngSwitchCase=\"3\">\n Processing..\n </div>\n <div *ngSwitchCase=\"4\">\n Done.\n </div>\n <div *ngSwitchCase=\"5\">\n Failed\n </div>\n </ng-container>\n </div>\n <button mat-icon-button (click)=\"uploader.removeFromQueue(file)\">\n <mat-icon>delete</mat-icon>\n </button>\n </mat-list-item>\n <mat-divider *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\"></mat-divider>\n <mat-list-item class=\"empty\" *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\">\n <h2 mat-line>No file selected..</h2>\n </mat-list-item>\n </mat-list>\n</div>\n<mat-progress-bar mat-line mode=\"determinate\" [value]=\"uploader.progress\"></mat-progress-bar>\n<div class=\"dialog-actions\">\n <div>\n <button mat-flat-button color=\"warn\" (click)=\"uploader.clearQueue()\" [disabled]=\"uploader.queue.length === 0\">Clear all</button>\n </div>\n <div>\n <button mat-flat-button color=\"primary\"\n *ngIf=\"uploader.getNotUploadedItems().length > 0\"\n (click)=\"uploader.uploadAll()\">Start Upload</button>\n <button mat-flat-button color=\"accent\"\n *ngIf=\"uploader.getDoneItems().length === uploader.queue.length && uploader.getDoneItems().length > 0 \"\n style=\"margin-left: 8px\" (click)=\"save()\">Save</button>\n </div>\n</div>\n", styles: ["sk-uploader{display:flex;flex-direction:column;min-width:50vw;position:relative}sk-uploader .dialog-title{flex-shrink:0}sk-uploader .dialog-title .space-fill{flex:1 0 auto}sk-uploader .dialog-content{padding:16px;margin:0;overflow:scroll;overflow-x:hidden;flex:0 0 500px;max-height:500px}sk-uploader .dialog-content .drag-section{border:3px dashed #ccc;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}sk-uploader .dialog-content .drag-section .mat-icon{width:64px;height:64px;line-height:64px;font-size:64px}sk-uploader .dialog-content .drag-section p{cursor:pointer;font-size:14px}sk-uploader .dialog-content .drag-section .mat-icon,sk-uploader .dialog-content .drag-section p{color:#ccc}sk-uploader .dialog-content .drag-section.active{position:absolute;inset:0;width:100%;z-index:10;background-color:#2c393f}sk-uploader .dialog-content mat-list mat-list-item.selected-file{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;margin-bottom:8px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-list-icon,sk-uploader .dialog-content mat-list mat-list-item.selected-file mat-icon{width:32px!important;height:32px!important;line-height:32px!important;font-size:32px!important}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-icon-button{margin-left:16px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-line{display:flex;flex-direction:row;align-items:center;justify-content:space-between}sk-uploader .dialog-content mat-list mat-list-item.selected-file .file-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}sk-uploader .dialog-actions{padding:16px;flex-shrink:0;border-top:1px solid rgba(0,0,0,.12);display:flex;justify-content:space-between}\n"] }]
|
|
434
435
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
435
436
|
type: Inject,
|
|
436
|
-
args: [
|
|
437
|
-
}] }, { type: i1.
|
|
437
|
+
args: [MAT_LEGACY_DIALOG_DATA]
|
|
438
|
+
}] }, { type: i1.MatLegacyDialogRef }, { type: i2.SkApiService }]; }, propDecorators: { fileEl: [{
|
|
438
439
|
type: ViewChild,
|
|
439
440
|
args: ['file', { static: false }]
|
|
440
441
|
}], dragEl: [{
|
|
@@ -452,6 +453,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
452
453
|
}] } });
|
|
453
454
|
|
|
454
455
|
class SkUploaderDirective {
|
|
456
|
+
constructor(_dialog) {
|
|
457
|
+
this._dialog = _dialog;
|
|
458
|
+
this.skUploaderFileSelected = new EventEmitter();
|
|
459
|
+
}
|
|
455
460
|
onClick() {
|
|
456
461
|
this._dialog.open(SkUploaderComponent, {
|
|
457
462
|
panelClass: 'mat-dialog-no-padding',
|
|
@@ -467,19 +472,15 @@ class SkUploaderDirective {
|
|
|
467
472
|
}
|
|
468
473
|
});
|
|
469
474
|
}
|
|
470
|
-
constructor(_dialog) {
|
|
471
|
-
this._dialog = _dialog;
|
|
472
|
-
this.skUploaderFileSelected = new EventEmitter();
|
|
473
|
-
}
|
|
474
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SkUploaderDirective, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
475
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SkUploaderDirective, selector: "[skUploader]", inputs: { skUploaderOptions: "skUploaderOptions", skSelected: "skSelected" }, outputs: { skUploaderFileSelected: "skUploaderFileSelected" }, host: { listeners: { "click": "onClick()" } }, ngImport: i0 }); }
|
|
476
475
|
}
|
|
477
|
-
i0.ɵɵ
|
|
476
|
+
SkUploaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderDirective, deps: [{ token: i1.MatLegacyDialog }], target: i0.ɵɵFactoryTarget.Directive });
|
|
477
|
+
SkUploaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: SkUploaderDirective, selector: "[skUploader]", inputs: { skUploaderOptions: "skUploaderOptions", skSelected: "skSelected" }, outputs: { skUploaderFileSelected: "skUploaderFileSelected" }, host: { listeners: { "click": "onClick()" } }, ngImport: i0 });
|
|
478
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderDirective, decorators: [{
|
|
478
479
|
type: Directive,
|
|
479
480
|
args: [{
|
|
480
481
|
selector: '[skUploader]'
|
|
481
482
|
}]
|
|
482
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
483
|
+
}], ctorParameters: function () { return [{ type: i1.MatLegacyDialog }]; }, propDecorators: { skUploaderOptions: [{
|
|
483
484
|
type: Input
|
|
484
485
|
}], skSelected: [{
|
|
485
486
|
type: Input
|
|
@@ -491,37 +492,37 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
491
492
|
}] } });
|
|
492
493
|
|
|
493
494
|
class SkUploaderModule {
|
|
494
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SkUploaderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
495
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: SkUploaderModule, declarations: [SkUploaderComponent,
|
|
496
|
-
SkUploaderDirective], imports: [CommonModule,
|
|
497
|
-
MatDialogModule,
|
|
498
|
-
MatToolbarModule,
|
|
499
|
-
MatButtonModule,
|
|
500
|
-
MatIconModule,
|
|
501
|
-
MatListModule,
|
|
502
|
-
MatProgressBarModule,
|
|
503
|
-
SkFrontLibModule], exports: [SkUploaderComponent,
|
|
504
|
-
SkUploaderDirective] }); }
|
|
505
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SkUploaderModule, imports: [CommonModule,
|
|
506
|
-
MatDialogModule,
|
|
507
|
-
MatToolbarModule,
|
|
508
|
-
MatButtonModule,
|
|
509
|
-
MatIconModule,
|
|
510
|
-
MatListModule,
|
|
511
|
-
MatProgressBarModule,
|
|
512
|
-
SkFrontLibModule] }); }
|
|
513
495
|
}
|
|
514
|
-
i0.ɵɵ
|
|
496
|
+
SkUploaderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
497
|
+
SkUploaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderModule, declarations: [SkUploaderComponent,
|
|
498
|
+
SkUploaderDirective], imports: [CommonModule,
|
|
499
|
+
MatLegacyDialogModule,
|
|
500
|
+
MatToolbarModule,
|
|
501
|
+
MatLegacyButtonModule,
|
|
502
|
+
MatIconModule,
|
|
503
|
+
MatLegacyListModule,
|
|
504
|
+
MatLegacyProgressBarModule,
|
|
505
|
+
SkFrontLibModule], exports: [SkUploaderComponent,
|
|
506
|
+
SkUploaderDirective] });
|
|
507
|
+
SkUploaderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderModule, imports: [CommonModule,
|
|
508
|
+
MatLegacyDialogModule,
|
|
509
|
+
MatToolbarModule,
|
|
510
|
+
MatLegacyButtonModule,
|
|
511
|
+
MatIconModule,
|
|
512
|
+
MatLegacyListModule,
|
|
513
|
+
MatLegacyProgressBarModule,
|
|
514
|
+
SkFrontLibModule] });
|
|
515
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SkUploaderModule, decorators: [{
|
|
515
516
|
type: NgModule,
|
|
516
517
|
args: [{
|
|
517
518
|
imports: [
|
|
518
519
|
CommonModule,
|
|
519
|
-
|
|
520
|
+
MatLegacyDialogModule,
|
|
520
521
|
MatToolbarModule,
|
|
521
|
-
|
|
522
|
+
MatLegacyButtonModule,
|
|
522
523
|
MatIconModule,
|
|
523
|
-
|
|
524
|
-
|
|
524
|
+
MatLegacyListModule,
|
|
525
|
+
MatLegacyProgressBarModule,
|
|
525
526
|
SkFrontLibModule
|
|
526
527
|
],
|
|
527
528
|
declarations: [
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sk-front-lib-uploader.mjs","sources":["../../../projects/sk-front-lib/uploader/src/sk-uploader-file-item.model.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.animation.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.class.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.component.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.component.html","../../../projects/sk-front-lib/uploader/src/sk-uploader.directive.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.module.ts","../../../projects/sk-front-lib/uploader/src/sk-front-lib-uploader.ts"],"sourcesContent":["import {FileType, SkFile} from 'sk-front-lib/model';\n\nexport enum SkUploaderFileItemType {\n Local,\n API,\n Unidentified\n}\n\nexport enum SkUploaderFileItemStatus {\n WAIT,\n READY,\n UPLOADING,\n PROCESS,\n DONE,\n ERROR\n}\n\nexport class SkUploaderFileItem {\n\n private constructor(localFile?: File, skFile?: SkFile) {\n this.localFile = localFile;\n this.skFile = skFile;\n\n this.state = SkUploaderFileItemStatus.WAIT;\n this.progress = 0;\n\n if (this.localFile && !this.skFile) {\n this.itemType = SkUploaderFileItemType.Local;\n } else if (!this.localFile && this.skFile) {\n this.itemType = SkUploaderFileItemType.API;\n this.state = SkUploaderFileItemStatus.DONE;\n this.progress = 100;\n } else {\n this.itemType = SkUploaderFileItemType.Unidentified;\n }\n }\n\n get filename(): string {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return this.localFile.name;\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return this.skFile.sourceFilename;\n } else {\n return 'Unknown File';\n }\n }\n\n get size(): number {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return this.localFile.size;\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return this.skFile.fileSize;\n } else {\n return -1;\n }\n }\n\n get mime(): string {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return this.localFile.type;\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return this.skFile.mime;\n } else {\n return '';\n }\n }\n\n get icon(): string {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return FileType.getMimeClass(this.localFile);\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return FileType.getMimeClass(this.skFile);\n } else {\n return 'application';\n }\n }\n\n public localFile: File;\n public skFile: SkFile;\n public itemType: SkUploaderFileItemType;\n\n public state: SkUploaderFileItemStatus;\n public progress: number;\n\n\n\n // -----------------------------------------------------------------------------------------------------\n // @ Static Builder\n // -----------------------------------------------------------------------------------------------------\n\n static fromLocalFile(localFile: File): SkUploaderFileItem {\n return new SkUploaderFileItem(localFile);\n }\n\n static fromApi(skFile: SkFile): SkUploaderFileItem {\n return new SkUploaderFileItem(null, skFile);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ State Method\n // -----------------------------------------------------------------------------------------------------\n\n public prepareUpload(): void {\n this.state = SkUploaderFileItemStatus.READY;\n }\n}\n","import {animate, animateChild, animation, query, stagger, style, transition, trigger, useAnimation} from '@angular/animations';\n\nconst customAnimation = animation([\n style({\n opacity : '{{opacity}}',\n transform: 'scale({{scale}}) translate3d({{x}}, {{y}}, {{z}})'\n }),\n animate('{{duration}} {{delay}} cubic-bezier(0.0, 0.0, 0.2, 1)', style('*'))\n], {\n params: {\n duration: '200ms',\n delay : '0ms',\n opacity : '0',\n scale : '1',\n x : '0',\n y : '0',\n z : '0'\n }\n});\n\nconst customOutAnimation = animation([\n style('*'),\n animate('{{duration}} {{delay}} cubic-bezier(0.0, 0.0, 0.2, 1)', style({\n opacity : '{{opacity}}',\n transform: 'scale({{scale}}) translate3d({{x}}, {{y}}, {{z}})'\n }))\n], {\n params: {\n duration: '200ms',\n delay : '0ms',\n opacity : '0',\n scale : '1',\n x : '0',\n y : '0',\n z : '0'\n }\n});\n\nexport const uploaderAnimations = [\n trigger('animate', [transition('void => *', [useAnimation(customAnimation)])]),\n trigger('animateOut', [transition('* => void', [useAnimation(customOutAnimation)])]),\n\n trigger('animateStagger', [\n transition('* => *',\n query('@*',\n [\n stagger('100ms', [\n animateChild()\n ])\n ], {optional: true})),\n ]),\n];\n","import {HttpEventType, HttpHeaders, HttpRequest, HttpResponse} from '@angular/common/http';\nimport {of} from 'rxjs';\nimport {catchError, last, map, tap} from 'rxjs/operators';\n\nimport {SkApiService} from 'sk-front-lib/api';\nimport {FileType, SkFile} from 'sk-front-lib/model';\nimport {SkUploaderFileItem, SkUploaderFileItemStatus} from './sk-uploader-file-item.model';\n\nexport interface FilterFunction {\n name: string;\n fn: (item?: SkUploaderFileItem, options?: SkFileUploaderOptions) => boolean;\n}\n\nexport interface SkFileUploaderOptions {\n allowedMimeType?: string[];\n allowedFileType?: string[];\n autoUpload?: boolean;\n filters?: FilterFunction[];\n maxFileSize?: number;\n queueLimit?: number;\n asyncLimit?: number;\n additionalParameter?: { [key: string]: any };\n parametersBeforeFiles?: boolean;\n}\n\nexport class SkFileUploader {\n\n public queue: SkUploaderFileItem[] = [];\n public progress = 0;\n\n private _failFilterIndex: number;\n\n public options: SkFileUploaderOptions = {\n autoUpload: false,\n filters: [],\n maxFileSize: 2 * 1024 * 1024 * 1024, // 2GB\n queueLimit: 1,\n asyncLimit: 2,\n };\n\n constructor(private apiService: SkApiService, options?: SkFileUploaderOptions, selectedFiles: SkFile[] = []) {\n this.setOptions(options);\n this.setSelectedFiles(selectedFiles);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Data Accessor\n // -----------------------------------------------------------------------------------------------------\n\n\n // -----------------------------------------------------------------------------------------------------\n // @ Uploader - Public methods\n // -----------------------------------------------------------------------------------------------------\n\n public setOptions(options: SkFileUploaderOptions): void {\n this.options = Object.assign(this.options, options);\n\n this.options.filters.unshift({ name: 'queueLimit', fn: this._queueLimitFilter });\n\n if (this.options.maxFileSize) {\n this.options.filters.unshift({ name: 'fileSize', fn: this._fileSizeFilter });\n }\n\n if (this.options.allowedFileType) {\n this.options.filters.unshift({ name: 'fileType', fn: this._fileTypeFilter });\n }\n\n if (this.options.allowedMimeType) {\n this.options.filters.unshift({ name: 'mimeType', fn: this._mimeTypeFilter });\n }\n }\n\n public setSelectedFiles(files: SkFile[]): void {\n const items: SkUploaderFileItem[] = files.map(file => SkUploaderFileItem.fromApi(file));\n this.addToQueue(items);\n }\n\n public addToQueue(files: SkUploaderFileItem[], filters?: FilterFunction[] | string): void {\n const arrayOfFilters = this._getFilters(filters);\n\n files.forEach(item => {\n if (this._isValidFile(item, arrayOfFilters, this.options) && !this._findByFilenameInQueue(item.filename)) {\n this.queue.push(item);\n }\n });\n\n this.updateProgress();\n }\n\n public removeFromQueue(file: SkUploaderFileItem): void {\n const index = this.queue.findIndex(value => value.filename === file.filename);\n\n this.queue.splice(index, 1);\n this.updateProgress();\n }\n\n public clearQueue(): void {\n while (this.queue.length) {\n this.removeFromQueue(this.queue[0]);\n }\n this.progress = 0;\n }\n\n public upload(item: SkUploaderFileItem) {\n this._processUpload(item);\n }\n\n public uploadAll(): void {\n const targetItems = this.getNotUploadedItems();\n targetItems.forEach(item => {\n item.prepareUpload();\n });\n\n if (targetItems.length > 0) {\n const max = Math.min(targetItems.length, this.options.asyncLimit);\n for (let i = 0; i < max; i++) {\n this.upload(targetItems[i]);\n }\n }\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Private methods.\n // -----------------------------------------------------------------------------------------------------\n\n private updateProgress() {\n const uploaded = this.getDoneItems().length;\n const current = uploaded / this.queue.length * 100;\n this.progress = Math.ceil(current);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Uploader - Filters\n // -----------------------------------------------------------------------------------------------------\n\n protected _isValidFile(file: SkUploaderFileItem, filters: FilterFunction[], options: SkFileUploaderOptions): boolean {\n this._failFilterIndex = -1;\n return !filters.length ? true : filters.every((filter: FilterFunction) => {\n this._failFilterIndex++;\n return filter.fn.call(this, file, options);\n });\n }\n\n protected _getFilters(filters: FilterFunction[] | string): FilterFunction[] {\n if (!filters) {\n return this.options.filters;\n }\n if (Array.isArray(filters)) {\n return filters;\n }\n if (typeof filters === 'string') {\n const names = filters.match(/[^\\s,]+/g);\n return this.options.filters\n .filter((filter: any) => names.indexOf(filter.name) !== -1);\n }\n return this.options.filters;\n }\n\n protected _queueLimitFilter(): boolean {\n return this.options.queueLimit === undefined || this.queue.length < this.options.queueLimit;\n }\n\n public _mimeTypeFilter(item: SkUploaderFileItem): boolean {\n return !(this.options.allowedMimeType && this.options.allowedMimeType.indexOf(item.mime) === -1);\n }\n\n public _fileSizeFilter(item: SkUploaderFileItem): boolean {\n return !(this.options.maxFileSize && item.size > this.options.maxFileSize);\n }\n\n public _fileTypeFilter(item: SkUploaderFileItem): boolean {\n return !(this.options.allowedFileType &&\n this.options.allowedFileType.indexOf(FileType.getMimeClass(item.localFile ? item.localFile : item.skFile)) === -1);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Uploader - Upload biz logic\n // -----------------------------------------------------------------------------------------------------\n\n private _processUpload(item: SkUploaderFileItem) {\n if (item.state !== SkUploaderFileItemStatus.READY) {\n return;\n }\n\n const formData = new FormData();\n formData.append('file', item.localFile, item.filename);\n\n const request = new HttpRequest<any>('POST', this.apiService.apiServer + '/api/public/files/upload', formData, {\n reportProgress: true,\n headers: new HttpHeaders().set('Authorization', 'Bearer ' + this.apiService.getToken()).set('ngsw-bypass', 'true')\n });\n\n this.apiService.rawRequest<SkFile>(request).pipe(\n tap(event => {\n switch (event.type) {\n case HttpEventType.UploadProgress:\n // Compute and show the % done:\n const percentDone = Math.ceil(100 * event.loaded / event.total);\n item.progress = percentDone;\n\n if (item.progress >= 99) {\n item.state = SkUploaderFileItemStatus.PROCESS;\n } else {\n item.state = SkUploaderFileItemStatus.UPLOADING;\n }\n return;\n case HttpEventType.Response:\n item.state = SkUploaderFileItemStatus.DONE;\n return;\n default:\n return;\n }\n }),\n last(), // return last (completed) message to caller\n map((result: HttpResponse<any>) => result.body.data ? new SkFile(result.body.data) : null),\n catchError(err => {\n console.log(err);\n item.state = SkUploaderFileItemStatus.ERROR;\n return of(null);\n })\n ).subscribe(result => {\n if (result instanceof SkFile) {\n item.skFile = result;\n }\n\n this.updateProgress();\n const nextItems = this.getReadyItems();\n if (nextItems.length > 0) {\n this.upload(nextItems[0]);\n }\n });\n }\n\n\n\n\n\n\n\n\n // -----------------------------------------------------------------------------------------------------\n // @ Data Handlers\n // -----------------------------------------------------------------------------------------------------\n\n private _findByFilenameInQueue(name: string): boolean {\n return this.queue.findIndex(value => value.filename === name) > -1;\n }\n\n public getNotUploadedItems(): SkUploaderFileItem[] {\n return this.queue.filter((item: SkUploaderFileItem) => item.state === SkUploaderFileItemStatus.WAIT);\n }\n\n public getReadyItems(): SkUploaderFileItem[] {\n return this.queue.filter((item: SkUploaderFileItem) => item.state === SkUploaderFileItemStatus.READY);\n }\n\n public getDoneItems(): SkUploaderFileItem[] {\n return this.queue.filter((item: SkUploaderFileItem) => item.state === SkUploaderFileItemStatus.DONE);\n }\n\n}\n","import {Component, ElementRef, HostListener, Inject, OnInit, ViewChild, ViewEncapsulation} from '@angular/core';\nimport {MAT_LEGACY_DIALOG_DATA as MAT_DIALOG_DATA, MatLegacyDialogRef as MatDialogRef} from '@angular/material/legacy-dialog';\nimport {SkApiService} from 'sk-front-lib/api';\nimport {SkUploaderFileItem} from './sk-uploader-file-item.model';\nimport {uploaderAnimations} from './sk-uploader.animation';\nimport {SkFileUploader} from './sk-uploader.class';\n\n@Component({\n selector: 'sk-uploader',\n templateUrl: './sk-uploader.component.html',\n styleUrls: ['./sk-uploader.component.scss'],\n encapsulation: ViewEncapsulation.None,\n animations: uploaderAnimations\n})\nexport class SkUploaderComponent implements OnInit {\n\n constructor(@Inject(MAT_DIALOG_DATA) public data: any,\n public dialogRef: MatDialogRef<SkUploaderComponent>,\n private _apiService: SkApiService) {\n this.uploader = new SkFileUploader(this._apiService, data.options, data.selectedFile);\n }\n uploader: SkFileUploader;\n\n @ViewChild('file', {static: false})\n fileEl: ElementRef;\n\n @ViewChild('drag', {static: false})\n dragEl: ElementRef;\n\n\n dragClassActive = false;\n\n private static _getTransfer(event: any) {\n return event.dataTransfer ? event.dataTransfer : event.originalEvent.dataTransfer;\n }\n\n private static _haveFiles(types: any): any {\n if (!types) {\n return false;\n }\n\n if (types.indexOf) {\n return types.indexOf('Files') !== -1;\n } else if (types.contains) {\n return types.contains('Files');\n } else {\n return false;\n }\n }\n\n ngOnInit(): void {\n\n }\n\n save() {\n this.dialogRef.close(this.uploader.getDoneItems());\n }\n\n @HostListener('drop', ['$event'])\n public onDrop(event: any): void {\n const transfer = SkUploaderComponent._getTransfer(event);\n if (!transfer) {\n return;\n }\n this.preventAndStop(event);\n this.fileAdd(transfer.files);\n this.dragClassActive = false;\n }\n\n @HostListener('dragover', ['$event'])\n public onDragOver(event: any): void {\n const transfer = SkUploaderComponent._getTransfer(event);\n if (!SkUploaderComponent._haveFiles(transfer.types)) {\n return;\n }\n this.preventAndStop(event);\n this.dragClassActive = true;\n }\n\n @HostListener('dragleave', ['$event'])\n public onDragLeave(event: any): any {\n if (event.relatedTarget === this.dragEl.nativeElement) {\n return;\n }\n\n this.preventAndStop(event);\n this.dragClassActive = false;\n }\n\n\n // File methods\n // onFile\n\n public fileAdd(files: any) {\n if (!(files instanceof FileList)) {\n return;\n }\n\n const list: SkUploaderFileItem[] = [];\n for (let i = 0; i < files.length; i++) {\n list.push(SkUploaderFileItem.fromLocalFile(files.item(i)));\n }\n\n this.uploader.addToQueue(list);\n }\n\n public onBrowseFileComplete(): any {\n const files = this.fileEl.nativeElement.files;\n this.fileAdd(files);\n }\n\n public onDragComponentClick(): any {\n this.fileEl.nativeElement.click();\n }\n\n public preventAndStop(event: any): any {\n event.preventDefault();\n event.stopPropagation();\n }\n\n\n}\n","<mat-toolbar class=\"dialog-title\" color=\"primary\">\n <span class=\"title dialog-title\">File Uploader</span>\n <div class=\"space-fill\"></div>\n <button mat-icon-button mat-dialog-close aria-label=\"Close dialog\">\n <mat-icon>close</mat-icon>\n </button>\n</mat-toolbar>\n<div class=\"dialog-content\">\n <input type=\"file\" style=\"display: none\" #file (change)=\"onBrowseFileComplete()\" multiple />\n <div class=\"drag-section\" #drag (click)=\"onDragComponentClick()\" [class.active]=\"dragClassActive\">\n <mat-icon>cloud_upload</mat-icon>\n <p>Drag and drop or <strong>click to browse</strong></p>\n </div>\n <mat-list [@animateStagger]=\"{value:uploader.queue.length}\">\n <h3 mat-subheader>Selected Files ({{uploader.queue.length}})</h3>\n <mat-list-item class=\"selected-file\" *ngFor=\"let file of uploader.queue\"\n [@animate]=\"{value:'*',params:{x:'-25px', opacity:'0',duration:'200ms'}}\"\n [@animateOut]=\"{value:'*',params:{delay:'100ms',x:'-25px', opacity:'0',duration:'200ms'}}\"\n dense>\n <mat-icon class=\"type-icon\" [ngClass]=\"file.icon\" matListIcon></mat-icon>\n <div mat-line>\n <span class=\"file-name\">{{ file.filename }}</span>\n <span>{{ file.size | skByte }}</span>\n </div>\n <mat-progress-bar mat-line [mode]=\"file.state == 3 ? 'query' : 'determinate'\" [value]=\"file.progress\" color=\"accent\"></mat-progress-bar>\n <div mat-line>\n <ng-container [ngSwitch]=\"file.state\">\n <div *ngSwitchCase=\"0\">\n Selected\n </div>\n <div *ngSwitchCase=\"1\">\n Wait for upload\n </div>\n <div *ngSwitchCase=\"2\">\n Uploading\n </div>\n <div *ngSwitchCase=\"3\">\n Processing..\n </div>\n <div *ngSwitchCase=\"4\">\n Done.\n </div>\n <div *ngSwitchCase=\"5\">\n Failed\n </div>\n </ng-container>\n </div>\n <button mat-icon-button (click)=\"uploader.removeFromQueue(file)\">\n <mat-icon>delete</mat-icon>\n </button>\n </mat-list-item>\n <mat-divider *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\"></mat-divider>\n <mat-list-item class=\"empty\" *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\">\n <h2 mat-line>No file selected..</h2>\n </mat-list-item>\n </mat-list>\n</div>\n<mat-progress-bar mat-line mode=\"determinate\" [value]=\"uploader.progress\"></mat-progress-bar>\n<div class=\"dialog-actions\">\n <div>\n <button mat-flat-button color=\"warn\" (click)=\"uploader.clearQueue()\" [disabled]=\"uploader.queue.length === 0\">Clear all</button>\n </div>\n <div>\n <button mat-flat-button color=\"primary\"\n *ngIf=\"uploader.getNotUploadedItems().length > 0\"\n (click)=\"uploader.uploadAll()\">Start Upload</button>\n <button mat-flat-button color=\"accent\"\n *ngIf=\"uploader.getDoneItems().length === uploader.queue.length && uploader.getDoneItems().length > 0 \"\n style=\"margin-left: 8px\" (click)=\"save()\">Save</button>\n </div>\n</div>\n","import {Directive, EventEmitter, HostListener, Input, Output} from '@angular/core';\nimport {MatLegacyDialog as MatDialog} from '@angular/material/legacy-dialog';\nimport * as _ from 'lodash';\nimport {SkFile} from 'sk-front-lib/model';\nimport {SkUploaderFileItem} from './sk-uploader-file-item.model';\nimport {SkFileUploaderOptions} from './sk-uploader.class';\nimport {SkUploaderComponent} from './sk-uploader.component';\n\n@Directive({\n selector: '[skUploader]'\n})\nexport class SkUploaderDirective {\n\n @Input() skUploaderOptions: SkFileUploaderOptions;\n @Input() skSelected: SkFile[] | SkFile;\n\n @Output() skUploaderFileSelected: EventEmitter<any> = new EventEmitter<any>();\n\n @HostListener('click') onClick() {\n this._dialog.open(SkUploaderComponent, {\n panelClass: 'mat-dialog-no-padding',\n closeOnNavigation: true,\n autoFocus: false,\n data: {\n options: this.skUploaderOptions,\n selectedFile: !this.skSelected ? [] : (_.isArray(this.skSelected) ? this.skSelected : [<SkFile>this.skSelected])\n }\n }).afterClosed().subscribe((result: SkUploaderFileItem[]) => {\n if (result) {\n this.skUploaderFileSelected.emit(result.map(item => item.skFile));\n }\n });\n }\n\n constructor(private _dialog: MatDialog) { }\n}\n","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\nimport {MatLegacyButtonModule as MatButtonModule} from '@angular/material/legacy-button';\nimport {MatLegacyDialogModule as MatDialogModule} from '@angular/material/legacy-dialog';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatLegacyListModule as MatListModule} from '@angular/material/legacy-list';\nimport {MatLegacyProgressBarModule as MatProgressBarModule} from '@angular/material/legacy-progress-bar';\nimport {MatToolbarModule} from '@angular/material/toolbar';\n\nimport {SkFrontLibModule} from 'sk-front-lib';\n\nimport {SkUploaderComponent} from './sk-uploader.component';\nimport {SkUploaderDirective} from './sk-uploader.directive';\n\n\n@NgModule({\n imports: [\n CommonModule,\n MatDialogModule,\n MatToolbarModule,\n MatButtonModule,\n MatIconModule,\n MatListModule,\n MatProgressBarModule,\n SkFrontLibModule\n ],\n declarations: [\n SkUploaderComponent,\n SkUploaderDirective\n ],\n exports: [\n SkUploaderComponent,\n SkUploaderDirective\n ]\n})\nexport class SkUploaderModule {\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":["MAT_DIALOG_DATA","MatDialogModule","MatButtonModule","MatListModule","MatProgressBarModule"],"mappings":"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"}
|