@gloww/gloww 0.9.0-beta.41 → 0.9.0-beta.42

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.
@@ -18,9 +18,8 @@ export class UploadFileComponent {
18
18
  ngAfterViewInit() {
19
19
  const fileUpload = this.fileUpload.nativeElement;
20
20
  fileUpload.onchange = () => {
21
- if (!this.multiple) {
21
+ if (!this.multiple || !this.files) {
22
22
  this.files = [];
23
- //if (this.allowAltFileName) { this.fileNames.clear(); }
24
23
  }
25
24
  for (const file of fileUpload.files) {
26
25
  this.files.push({ data: file, inProgress: false, progress: 0, fileName: file.name, size: file.size, altFileName: '', status: '' });
@@ -52,6 +51,14 @@ export class UploadFileComponent {
52
51
  //throw new Error('Method not implemented.');
53
52
  }
54
53
  SelectFiles() {
54
+ if (this.files && this.files.length > 0 && !this.multiple) {
55
+ if (confirm("Do you want to replace current file ?")) {
56
+ this.files = [];
57
+ }
58
+ else {
59
+ return;
60
+ }
61
+ }
55
62
  this.fileUpload.nativeElement.click();
56
63
  }
57
64
  ChangeAltName(i, $event) {
@@ -135,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
135
142
  }], acceptMime: [{
136
143
  type: Input
137
144
  }] } });
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"","sources":["../../../../../../projects/gloww/src/lib/Components/upload-file/upload-file.component.ts","../../../../../../projects/gloww/src/lib/Components/upload-file/upload-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, Inject, Input, AfterViewInit } from '@angular/core';\r\nimport { FormGroup, FormBuilder, FormArray, NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'gloww-upload-file',\r\n  templateUrl: './upload-file.component.html',\r\n  styleUrls: ['./upload-file.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: UploadFileComponent\r\n    }\r\n  ]\r\n})\r\nexport class UploadFileComponent implements ControlValueAccessor, AfterViewInit {\r\n  @ViewChild('fileUpload') fileUpload: ElementRef;\r\n  @Input() multiple: boolean = false;\r\n  @Input() allowAltFileName: boolean = false;\r\n  @Input() acceptMime: string = '*/*';\r\n  onChange: any = () => { };\r\n  onTouched: any = () => { };\r\n  form: FormGroup;\r\n\r\n  files = [];\r\n\r\n  constructor() {\r\n\r\n  }\r\n  ngAfterViewInit(): void {\r\n    const fileUpload = this.fileUpload.nativeElement;\r\n    fileUpload.onchange = () => {\r\n      if (!this.multiple) {\r\n        this.files = [];\r\n        //if (this.allowAltFileName) { this.fileNames.clear(); }\r\n      }\r\n      for (const file of fileUpload.files) {\r\n        this.files.push({ data: file, inProgress: false, progress: 0, fileName: file.name, size: file.size, altFileName: '', status: '' });\r\n        //if (this.allowAltFileName) { this.fileNames.push(this.FileName(file.name)); }\r\n      }\r\n      this.onChange(this.files);\r\n      this.onTouched();\r\n    };\r\n  }\r\n\r\n  get value() {\r\n    return this.files;\r\n    //return this._value;\r\n  }\r\n\r\n  set value(val) {\r\n    this.files = val;\r\n    this.onChange(val);\r\n    this.onTouched();\r\n  }\r\n\r\n\r\n  writeValue(obj: any): void {\r\n    this.value = obj;\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    //throw new Error('Method not implemented.');\r\n  }\r\n\r\n  SelectFiles() {\r\n    this.fileUpload.nativeElement.click();\r\n  }\r\n\r\n  ChangeAltName(i, $event) {\r\n    this.files[i].altFileName = $event.target.value;\r\n    this.onChange(this.files);\r\n    this.onTouched();\r\n  }\r\n\r\n  onFileDropped($event) {\r\n    this.prepareFilesList($event);\r\n  }\r\n  prepareFilesList(files: Array<any>) {\r\n    if (files.length > 1 && !this.multiple) {\r\n      alert(\"You can only drop an only file at once\");\r\n      return;\r\n    }\r\n    if (this.files && this.files.length > 0 && !this.multiple) {\r\n      if (confirm(\"Do you want to replace current file ?\")) {\r\n        this.files = [];\r\n      } else {\r\n        return;\r\n      }\r\n    }\r\n    if (!this.files) this.files = [];\r\n    for (const file of files) {\r\n      this.files.push({ data: file, inProgress: false, progress: 0, fileName: file.name, size: file.size, altFileName: '', status: '' });\r\n    }\r\n    this.onChange(this.files);\r\n    this.onTouched();\r\n  }\r\n\r\n  /**\r\n * format bytes\r\n * @param bytes (File size in bytes)\r\n * @param decimals (Decimals point)\r\n */\r\n  formatBytes(bytes, decimals = 2) {\r\n    if (bytes === 0) {\r\n      return \"0 Bytes\";\r\n    }\r\n    const k = 1024;\r\n    const dm = decimals <= 0 ? 0 : decimals;\r\n    const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\", \"TB\", \"PB\", \"EB\", \"ZB\", \"YB\"];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + \" \" + sizes[i];\r\n  }\r\n\r\n  deleteFile(index: number) {\r\n    if (this.files[index].progress && this.files[index].progress < 100) {\r\n      console.log(\"Upload in progress.\");\r\n      return;\r\n    }\r\n    this.files.splice(index, 1);\r\n    this.onChange(this.files);\r\n    this.onTouched();\r\n  }\r\n}\r\n\r\n","<mat-card glowwFileSink (fileDropped)=\"onFileDropped($event)\" style=\"height:calc(100% - 40px)\">\r\n    <mat-card-content style=\"min-height:100px;height:calc(100% - 60px)\">\r\n        <div class=\"files-list\" *ngIf=\"files && files.length\" style=\"height:calc(100% - 60px)\">\r\n            <div class=\"single-file\" *ngFor=\"let file of files; let i = index\" [ngClass]=\"file.status\">\r\n                <i class=\"fa-thin fa-file fa-lg\"></i>\r\n                <div class=\"info\">\r\n                    <h4 class=\"name\">\r\n                        {{ file?.fileName }}\r\n                    </h4>\r\n                    <p class=\"size\">\r\n                        {{ formatBytes(file?.size) }}\r\n                    </p>\r\n                    <mat-progress-bar [value]=\"file.progress\"></mat-progress-bar>\r\n                </div>\r\n                <i class=\"fa-thin fa-trash fa-lg\" (click)=\"deleteFile(i)\"></i>\r\n            </div>\r\n        </div>\r\n        <div *ngIf=\"!files || !files.length\" style=\"height:calc(100% - 60px)\">No file(s) selected</div>\r\n        <input type=\"file\" #fileUpload id=\"fileUpload\" name=\"fileUpload\" [accept]=\"acceptMime\" style=\"display:none;\" [multiple]=\"multiple\" />\r\n    </mat-card-content>\r\n    <mat-card-actions style=\"text-align:center\">\r\n        <button mat-raised-button color=\"accent\" (click)=\"SelectFiles()\">\r\n      <i class=\"fal fa-file-upload\"></i> <span *ngIf=\"!multiple\">Select file or Drop a file</span>\r\n      <span *ngIf=\"multiple\">Select file(s) or drop file(s)</span>\r\n    </button>\r\n    </mat-card-actions>\r\n</mat-card>"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"","sources":["../../../../../../projects/gloww/src/lib/Components/upload-file/upload-file.component.ts","../../../../../../projects/gloww/src/lib/Components/upload-file/upload-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, Inject, Input, AfterViewInit } from '@angular/core';\r\nimport { FormGroup, FormBuilder, FormArray, NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'gloww-upload-file',\r\n  templateUrl: './upload-file.component.html',\r\n  styleUrls: ['./upload-file.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: UploadFileComponent\r\n    }\r\n  ]\r\n})\r\nexport class UploadFileComponent implements ControlValueAccessor, AfterViewInit {\r\n  @ViewChild('fileUpload') fileUpload: ElementRef;\r\n  @Input() multiple: boolean = false;\r\n  @Input() allowAltFileName: boolean = false;\r\n  @Input() acceptMime: string = '*/*';\r\n  onChange: any = () => { };\r\n  onTouched: any = () => { };\r\n  form: FormGroup;\r\n\r\n  files = [];\r\n\r\n  constructor() {\r\n\r\n  }\r\n  ngAfterViewInit(): void {\r\n    const fileUpload = this.fileUpload.nativeElement;\r\n    fileUpload.onchange = () => {\r\n      if (!this.multiple || !this.files) {\r\n        this.files = [];\r\n      }\r\n      for (const file of fileUpload.files) {\r\n        this.files.push({ data: file, inProgress: false, progress: 0, fileName: file.name, size: file.size, altFileName: '', status: '' });\r\n        //if (this.allowAltFileName) { this.fileNames.push(this.FileName(file.name)); }\r\n      }\r\n      this.onChange(this.files);\r\n      this.onTouched();\r\n    };\r\n  }\r\n\r\n  get value() {\r\n    return this.files;\r\n    //return this._value;\r\n  }\r\n\r\n  set value(val) {\r\n    this.files = val;\r\n    this.onChange(val);\r\n    this.onTouched();\r\n  }\r\n\r\n\r\n  writeValue(obj: any): void {\r\n    this.value = obj;\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    //throw new Error('Method not implemented.');\r\n  }\r\n\r\n  SelectFiles() {\r\n    if (this.files && this.files.length > 0 && !this.multiple) {\r\n      if (confirm(\"Do you want to replace current file ?\")) {\r\n        this.files = [];\r\n      } else {\r\n        return;\r\n      }\r\n    }\r\n    this.fileUpload.nativeElement.click();\r\n  }\r\n\r\n  ChangeAltName(i, $event) {\r\n    this.files[i].altFileName = $event.target.value;\r\n    this.onChange(this.files);\r\n    this.onTouched();\r\n  }\r\n\r\n  onFileDropped($event) {\r\n    this.prepareFilesList($event);\r\n  }\r\n  prepareFilesList(files: Array<any>) {\r\n    if (files.length > 1 && !this.multiple) {\r\n      alert(\"You can only drop an only file at once\");\r\n      return;\r\n    }\r\n    if (this.files && this.files.length > 0 && !this.multiple) {\r\n      if (confirm(\"Do you want to replace current file ?\")) {\r\n        this.files = [];\r\n      } else {\r\n        return;\r\n      }\r\n    }\r\n    if (!this.files) this.files = [];\r\n    for (const file of files) {\r\n      this.files.push({ data: file, inProgress: false, progress: 0, fileName: file.name, size: file.size, altFileName: '', status: '' });\r\n    }\r\n    this.onChange(this.files);\r\n    this.onTouched();\r\n  }\r\n\r\n  /**\r\n * format bytes\r\n * @param bytes (File size in bytes)\r\n * @param decimals (Decimals point)\r\n */\r\n  formatBytes(bytes, decimals = 2) {\r\n    if (bytes === 0) {\r\n      return \"0 Bytes\";\r\n    }\r\n    const k = 1024;\r\n    const dm = decimals <= 0 ? 0 : decimals;\r\n    const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\", \"TB\", \"PB\", \"EB\", \"ZB\", \"YB\"];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + \" \" + sizes[i];\r\n  }\r\n\r\n  deleteFile(index: number) {\r\n    if (this.files[index].progress && this.files[index].progress < 100) {\r\n      console.log(\"Upload in progress.\");\r\n      return;\r\n    }\r\n    this.files.splice(index, 1);\r\n    this.onChange(this.files);\r\n    this.onTouched();\r\n  }\r\n}\r\n\r\n","<mat-card glowwFileSink (fileDropped)=\"onFileDropped($event)\" style=\"height:calc(100% - 40px)\">\r\n    <mat-card-content style=\"min-height:100px;height:calc(100% - 60px)\">\r\n        <div class=\"files-list\" *ngIf=\"files && files.length\" style=\"height:calc(100% - 60px)\">\r\n            <div class=\"single-file\" *ngFor=\"let file of files; let i = index\" [ngClass]=\"file.status\">\r\n                <i class=\"fa-thin fa-file fa-lg\"></i>\r\n                <div class=\"info\">\r\n                    <h4 class=\"name\">\r\n                        {{ file?.fileName }}\r\n                    </h4>\r\n                    <p class=\"size\">\r\n                        {{ formatBytes(file?.size) }}\r\n                    </p>\r\n                    <mat-progress-bar [value]=\"file.progress\"></mat-progress-bar>\r\n                </div>\r\n                <i class=\"fa-thin fa-trash fa-lg\" (click)=\"deleteFile(i)\"></i>\r\n            </div>\r\n        </div>\r\n        <div *ngIf=\"!files || !files.length\" style=\"height:calc(100% - 60px)\">No file(s) selected</div>\r\n        <input type=\"file\" #fileUpload id=\"fileUpload\" name=\"fileUpload\" [accept]=\"acceptMime\" style=\"display:none;\" [multiple]=\"multiple\" />\r\n    </mat-card-content>\r\n    <mat-card-actions style=\"text-align:center\">\r\n        <button mat-raised-button color=\"accent\" (click)=\"SelectFiles()\">\r\n      <i class=\"fal fa-file-upload\"></i> <span *ngIf=\"!multiple\">Select file or Drop a file</span>\r\n      <span *ngIf=\"multiple\">Select file(s) or drop file(s)</span>\r\n    </button>\r\n    </mat-card-actions>\r\n</mat-card>"]}
@@ -482,9 +482,8 @@ class UploadFileComponent {
482
482
  ngAfterViewInit() {
483
483
  const fileUpload = this.fileUpload.nativeElement;
484
484
  fileUpload.onchange = () => {
485
- if (!this.multiple) {
485
+ if (!this.multiple || !this.files) {
486
486
  this.files = [];
487
- //if (this.allowAltFileName) { this.fileNames.clear(); }
488
487
  }
489
488
  for (const file of fileUpload.files) {
490
489
  this.files.push({ data: file, inProgress: false, progress: 0, fileName: file.name, size: file.size, altFileName: '', status: '' });
@@ -516,6 +515,14 @@ class UploadFileComponent {
516
515
  //throw new Error('Method not implemented.');
517
516
  }
518
517
  SelectFiles() {
518
+ if (this.files && this.files.length > 0 && !this.multiple) {
519
+ if (confirm("Do you want to replace current file ?")) {
520
+ this.files = [];
521
+ }
522
+ else {
523
+ return;
524
+ }
525
+ }
519
526
  this.fileUpload.nativeElement.click();
520
527
  }
521
528
  ChangeAltName(i, $event) {