cps-ui-kit 18.4.0 → 18.5.0
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.
|
@@ -82,7 +82,7 @@ export class CpsFileUploadComponent {
|
|
|
82
82
|
}
|
|
83
83
|
}
|
|
84
84
|
updateExtensionsString() {
|
|
85
|
-
this.extensions = this.extensions.map((ext) => ext.startsWith('.') ? ext : '.' + ext);
|
|
85
|
+
this.extensions = this.extensions.map((ext) => ext.startsWith('.') ? ext.toLowerCase() : '.' + ext.toLowerCase());
|
|
86
86
|
this.extensionsString = this.extensions.join(', ');
|
|
87
87
|
this.extensionsStringAsterisks = this.extensions
|
|
88
88
|
.map((ext) => '*' + ext)
|
|
@@ -136,8 +136,9 @@ export class CpsFileUploadComponent {
|
|
|
136
136
|
return false;
|
|
137
137
|
if (this.extensions.length < 1)
|
|
138
138
|
return true;
|
|
139
|
+
const fileNameLowerCase = file.name.toLowerCase();
|
|
139
140
|
for (const ext of this.extensions) {
|
|
140
|
-
if (
|
|
141
|
+
if (fileNameLowerCase.endsWith(ext))
|
|
141
142
|
return true;
|
|
142
143
|
}
|
|
143
144
|
return false;
|
|
@@ -178,4 +179,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImpor
|
|
|
178
179
|
type: ViewChild,
|
|
179
180
|
args: ['fileInput']
|
|
180
181
|
}] } });
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-file-upload/cps-file-upload.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-file-upload/cps-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  numberAttribute,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { catchError, Observable, of, take } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport {\n  CpsTooltipDirective,\n  CpsTooltipPosition\n} from '../../directives/cps-tooltip/cps-tooltip.directive';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\n\n/**\n * CpsFileUploadComponent is an advanced uploader with dragdrop support.\n * @group Components\n */\n@Component({\n  selector: 'cps-file-upload',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsIconComponent,\n    CpsProgressLinearComponent,\n    CpsTooltipDirective\n  ],\n  templateUrl: './cps-file-upload.component.html',\n  styleUrls: ['./cps-file-upload.component.scss']\n})\nexport class CpsFileUploadComponent implements OnInit, OnChanges {\n  /**\n   * Expected extensions of a file to be uploaded. E.g. 'doc or .doc'.\n   * @group Props\n   */\n  @Input() extensions: string[] = [];\n\n  /**\n   * Expected file description. E.g. 'Word document'.\n   * @group Props\n   */\n  @Input() fileDesc = 'Any file';\n\n  /**\n   * Width of the component, a number denoting pixels or a string.\n   * @group Props\n   */\n  @Input() width: number | string = '100%';\n\n  /**\n   * Expected file info block, explaining some extra stuff about file.\n   * @group Props\n   */\n  @Input() fileInfo: string = '';\n\n  /**\n   * Callback for uploaded file processing.\n   * @group Props\n   */\n  @Input() fileProcessingCallback?: (file: File) => Observable<boolean> =\n    undefined;\n\n  /**\n   * Position of file name tooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() fileNameTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * File name tooltip offset for styling.\n   * @group Props\n   */\n  @Input({ transform: numberAttribute }) fileNameTooltipOffset: number = 12;\n\n  /**\n   * Callback to invoke when file is uploaded.\n   * @param {File} File\n   * @group Emits\n   */\n  @Output() fileUploaded = new EventEmitter<File>();\n\n  /**\n   * Callback to invoke when file upload fails.\n   * @param {string} - file name\n   * @group Emits\n   */\n  @Output() fileUploadFailed = new EventEmitter<string>();\n\n  /**\n   * Callback to invoke when uploaded file is removed.\n   * @param {string} - file name\n   * @group Emits\n   */\n  @Output() uploadedFileRemoved = new EventEmitter<string>();\n\n  @ViewChild('fileInput') fileInput?: ElementRef<HTMLInputElement>;\n\n  isDragoverFile = false;\n  uploadedFile?: File;\n  extensionsString = '';\n  extensionsStringAsterisks = '';\n  cvtWidth = '';\n\n  isProcessingFile = false;\n\n  ngOnInit(): void {\n    this.updateExtensionsString();\n    this.cvtWidth = convertSize(this.width);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.extensions) {\n      this.updateExtensionsString();\n    }\n  }\n\n  updateExtensionsString(): void {\n    this.extensions = this.extensions.map((ext) =>\n      ext.startsWith('.') ? ext : '.' + ext\n    );\n    this.extensionsString = this.extensions.join(', ');\n    this.extensionsStringAsterisks = this.extensions\n      .map((ext) => '*' + ext)\n      .join(', ');\n  }\n\n  tryUploadFile(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n\n    this.isDragoverFile = false;\n    let file: File | undefined;\n\n    if (event.type === 'drop') {\n      file = (event as DragEvent).dataTransfer?.files.item(0) ?? undefined;\n    } else {\n      const files = (event.target as HTMLInputElement).files;\n      if (!files || files.length < 1) return;\n      file = files.item(0) ?? undefined;\n    }\n\n    if (!this._isFileExtensionValid(file)) {\n      this.fileUploadFailed.emit(file?.name ?? '');\n      return;\n    }\n\n    this.uploadedFile = file;\n    if (this.uploadedFile) {\n      this.fileUploaded.emit(this.uploadedFile);\n      if (this.fileProcessingCallback) {\n        this.isProcessingFile = true;\n        this.fileProcessingCallback(this.uploadedFile)\n          .pipe(\n            take(1),\n            catchError(() => {\n              return of(false);\n            })\n          )\n          .subscribe((res) => {\n            if (!res) this.removeUploadedFile();\n            this.isProcessingFile = false;\n          });\n      }\n    }\n  }\n\n  removeUploadedFile() {\n    const name = this.uploadedFile?.name ?? '';\n    this.uploadedFile = undefined;\n    this.uploadedFileRemoved.emit(name);\n\n    if (this.fileInput) {\n      this.fileInput.nativeElement.value = '';\n    }\n  }\n\n  private _isFileExtensionValid(file?: File) {\n    if (!file) return false;\n\n    if (this.extensions.length < 1) return true;\n\n    for (const ext of this.extensions) {\n      if (file.name.endsWith(ext)) return true;\n    }\n\n    return false;\n  }\n}\n","<div class=\"cps-file-upload\" [ngStyle]=\"{ width: cvtWidth }\">\n  <div\n    class=\"cps-file-upload-dropzone\"\n    [ngClass]=\"{\n      'dragged-over': isDragoverFile,\n      'with-uploads': uploadedFile?.name\n    }\"\n    (dragend)=\"isDragoverFile = false\"\n    (dragenter)=\"isDragoverFile = true\"\n    (dragleave)=\"isDragoverFile = false\"\n    (dragover)=\"isDragoverFile = true\"\n    (mouseleave)=\"isDragoverFile = false\"\n    (drop)=\"tryUploadFile($event)\">\n    <input\n      #fileInput\n      (change)=\"tryUploadFile($event)\"\n      type=\"file\"\n      [accept]=\"extensionsString\"\n      title=\"\" />\n    <cps-icon icon=\"export\" size=\"large\" color=\"text-darkest\"></cps-icon>\n    <div class=\"cps-file-upload-dropzone-title\">\n      Drag&Drop or choose a file to upload\n    </div>\n    <span\n      class=\"cps-file-upload-dropzone-file-desc\"\n      *ngIf=\"fileDesc || extensionsStringAsterisks\"\n      >{{ fileDesc }}\n      {{\n        extensionsStringAsterisks ? '(' + extensionsStringAsterisks + ')' : ''\n      }}</span\n    >\n    @if(fileInfo) {\n      <div class=\"cps-file-upload-dropzone-content\">\n        <cps-icon color=\"calm\" icon=\"info-circle\" size=\"xsmall\"></cps-icon>\n        {{fileInfo}}\n      </div>\n    }\n    <cps-progress-linear\n      *ngIf=\"isProcessingFile && uploadedFile\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"cps-file-upload-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"uploadedFile\" class=\"cps-file-upload-uploaded-files\">\n    <div class=\"cps-file-upload-uploaded-file\">\n      <div class=\"cps-file-upload-uploaded-file-title\">\n        <cps-icon\n          class=\"cps-file-upload-uploaded-file-status-icon\"\n          [icon]=\"isProcessingFile ? 'pending' : 'toast-success'\"\n          [color]=\"isProcessingFile ? 'warn' : 'success'\">\n        </cps-icon>\n        <div class=\"cps-file-upload-uploaded-file-name\"\n             cpsTooltip=\"{{ uploadedFile.name }}\"\n             [tooltipPosition]=\"fileNameTooltipPosition\"\n             [tooltipOffset]=\"fileNameTooltipOffset\"\n             tooltipOpenOn=\"hover\">\n          {{ uploadedFile.name }}\n        </div>\n      </div>\n      <cps-icon\n        *ngIf=\"!isProcessingFile\"\n        class=\"cps-file-upload-uploaded-file-remove-icon\"\n        icon=\"remove\"\n        color=\"error\"\n        (click)=\"removeUploadedFile()\">\n      </cps-icon>\n    </div>\n  </div>\n</div>\n"]}
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-file-upload/cps-file-upload.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-file-upload/cps-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  numberAttribute,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { catchError, Observable, of, take } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport {\n  CpsTooltipDirective,\n  CpsTooltipPosition\n} from '../../directives/cps-tooltip/cps-tooltip.directive';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\n\n/**\n * CpsFileUploadComponent is an advanced uploader with dragdrop support.\n * @group Components\n */\n@Component({\n  selector: 'cps-file-upload',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsIconComponent,\n    CpsProgressLinearComponent,\n    CpsTooltipDirective\n  ],\n  templateUrl: './cps-file-upload.component.html',\n  styleUrls: ['./cps-file-upload.component.scss']\n})\nexport class CpsFileUploadComponent implements OnInit, OnChanges {\n  /**\n   * Expected extensions of a file to be uploaded. E.g. 'doc or .doc'.\n   * @group Props\n   */\n  @Input() extensions: string[] = [];\n\n  /**\n   * Expected file description. E.g. 'Word document'.\n   * @group Props\n   */\n  @Input() fileDesc = 'Any file';\n\n  /**\n   * Width of the component, a number denoting pixels or a string.\n   * @group Props\n   */\n  @Input() width: number | string = '100%';\n\n  /**\n   * Expected file info block, explaining some extra stuff about file.\n   * @group Props\n   */\n  @Input() fileInfo: string = '';\n\n  /**\n   * Callback for uploaded file processing.\n   * @group Props\n   */\n  @Input() fileProcessingCallback?: (file: File) => Observable<boolean> =\n    undefined;\n\n  /**\n   * Position of file name tooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() fileNameTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * File name tooltip offset for styling.\n   * @group Props\n   */\n  @Input({ transform: numberAttribute }) fileNameTooltipOffset: number = 12;\n\n  /**\n   * Callback to invoke when file is uploaded.\n   * @param {File} File\n   * @group Emits\n   */\n  @Output() fileUploaded = new EventEmitter<File>();\n\n  /**\n   * Callback to invoke when file upload fails.\n   * @param {string} - file name\n   * @group Emits\n   */\n  @Output() fileUploadFailed = new EventEmitter<string>();\n\n  /**\n   * Callback to invoke when uploaded file is removed.\n   * @param {string} - file name\n   * @group Emits\n   */\n  @Output() uploadedFileRemoved = new EventEmitter<string>();\n\n  @ViewChild('fileInput') fileInput?: ElementRef<HTMLInputElement>;\n\n  isDragoverFile = false;\n  uploadedFile?: File;\n  extensionsString = '';\n  extensionsStringAsterisks = '';\n  cvtWidth = '';\n\n  isProcessingFile = false;\n\n  ngOnInit(): void {\n    this.updateExtensionsString();\n    this.cvtWidth = convertSize(this.width);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.extensions) {\n      this.updateExtensionsString();\n    }\n  }\n\n  updateExtensionsString(): void {\n    this.extensions = this.extensions.map((ext) =>\n      ext.startsWith('.') ? ext.toLowerCase() : '.' + ext.toLowerCase()\n    );\n    this.extensionsString = this.extensions.join(', ');\n    this.extensionsStringAsterisks = this.extensions\n      .map((ext) => '*' + ext)\n      .join(', ');\n  }\n\n  tryUploadFile(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n\n    this.isDragoverFile = false;\n    let file: File | undefined;\n\n    if (event.type === 'drop') {\n      file = (event as DragEvent).dataTransfer?.files.item(0) ?? undefined;\n    } else {\n      const files = (event.target as HTMLInputElement).files;\n      if (!files || files.length < 1) return;\n      file = files.item(0) ?? undefined;\n    }\n\n    if (!this._isFileExtensionValid(file)) {\n      this.fileUploadFailed.emit(file?.name ?? '');\n      return;\n    }\n\n    this.uploadedFile = file;\n    if (this.uploadedFile) {\n      this.fileUploaded.emit(this.uploadedFile);\n      if (this.fileProcessingCallback) {\n        this.isProcessingFile = true;\n        this.fileProcessingCallback(this.uploadedFile)\n          .pipe(\n            take(1),\n            catchError(() => {\n              return of(false);\n            })\n          )\n          .subscribe((res) => {\n            if (!res) this.removeUploadedFile();\n            this.isProcessingFile = false;\n          });\n      }\n    }\n  }\n\n  removeUploadedFile() {\n    const name = this.uploadedFile?.name ?? '';\n    this.uploadedFile = undefined;\n    this.uploadedFileRemoved.emit(name);\n\n    if (this.fileInput) {\n      this.fileInput.nativeElement.value = '';\n    }\n  }\n\n  private _isFileExtensionValid(file?: File) {\n    if (!file) return false;\n\n    if (this.extensions.length < 1) return true;\n    const fileNameLowerCase = file.name.toLowerCase();\n    for (const ext of this.extensions) {\n      if (fileNameLowerCase.endsWith(ext)) return true;\n    }\n\n    return false;\n  }\n}\n","<div class=\"cps-file-upload\" [ngStyle]=\"{ width: cvtWidth }\">\n  <div\n    class=\"cps-file-upload-dropzone\"\n    [ngClass]=\"{\n      'dragged-over': isDragoverFile,\n      'with-uploads': uploadedFile?.name\n    }\"\n    (dragend)=\"isDragoverFile = false\"\n    (dragenter)=\"isDragoverFile = true\"\n    (dragleave)=\"isDragoverFile = false\"\n    (dragover)=\"isDragoverFile = true\"\n    (mouseleave)=\"isDragoverFile = false\"\n    (drop)=\"tryUploadFile($event)\">\n    <input\n      #fileInput\n      (change)=\"tryUploadFile($event)\"\n      type=\"file\"\n      [accept]=\"extensionsString\"\n      title=\"\" />\n    <cps-icon icon=\"export\" size=\"large\" color=\"text-darkest\"></cps-icon>\n    <div class=\"cps-file-upload-dropzone-title\">\n      Drag&Drop or choose a file to upload\n    </div>\n    <span\n      class=\"cps-file-upload-dropzone-file-desc\"\n      *ngIf=\"fileDesc || extensionsStringAsterisks\"\n      >{{ fileDesc }}\n      {{\n        extensionsStringAsterisks ? '(' + extensionsStringAsterisks + ')' : ''\n      }}</span\n    >\n    @if(fileInfo) {\n      <div class=\"cps-file-upload-dropzone-content\">\n        <cps-icon color=\"calm\" icon=\"info-circle\" size=\"xsmall\"></cps-icon>\n        {{fileInfo}}\n      </div>\n    }\n    <cps-progress-linear\n      *ngIf=\"isProcessingFile && uploadedFile\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"cps-file-upload-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"uploadedFile\" class=\"cps-file-upload-uploaded-files\">\n    <div class=\"cps-file-upload-uploaded-file\">\n      <div class=\"cps-file-upload-uploaded-file-title\">\n        <cps-icon\n          class=\"cps-file-upload-uploaded-file-status-icon\"\n          [icon]=\"isProcessingFile ? 'pending' : 'toast-success'\"\n          [color]=\"isProcessingFile ? 'warn' : 'success'\">\n        </cps-icon>\n        <div class=\"cps-file-upload-uploaded-file-name\"\n             cpsTooltip=\"{{ uploadedFile.name }}\"\n             [tooltipPosition]=\"fileNameTooltipPosition\"\n             [tooltipOffset]=\"fileNameTooltipOffset\"\n             tooltipOpenOn=\"hover\">\n          {{ uploadedFile.name }}\n        </div>\n      </div>\n      <cps-icon\n        *ngIf=\"!isProcessingFile\"\n        class=\"cps-file-upload-uploaded-file-remove-icon\"\n        icon=\"remove\"\n        color=\"error\"\n        (click)=\"removeUploadedFile()\">\n      </cps-icon>\n    </div>\n  </div>\n</div>\n"]}
|
package/fesm2022/cps-ui-kit.mjs
CHANGED
|
@@ -11557,7 +11557,7 @@ class CpsFileUploadComponent {
|
|
|
11557
11557
|
}
|
|
11558
11558
|
}
|
|
11559
11559
|
updateExtensionsString() {
|
|
11560
|
-
this.extensions = this.extensions.map((ext) => ext.startsWith('.') ? ext : '.' + ext);
|
|
11560
|
+
this.extensions = this.extensions.map((ext) => ext.startsWith('.') ? ext.toLowerCase() : '.' + ext.toLowerCase());
|
|
11561
11561
|
this.extensionsString = this.extensions.join(', ');
|
|
11562
11562
|
this.extensionsStringAsterisks = this.extensions
|
|
11563
11563
|
.map((ext) => '*' + ext)
|
|
@@ -11611,8 +11611,9 @@ class CpsFileUploadComponent {
|
|
|
11611
11611
|
return false;
|
|
11612
11612
|
if (this.extensions.length < 1)
|
|
11613
11613
|
return true;
|
|
11614
|
+
const fileNameLowerCase = file.name.toLowerCase();
|
|
11614
11615
|
for (const ext of this.extensions) {
|
|
11615
|
-
if (
|
|
11616
|
+
if (fileNameLowerCase.endsWith(ext))
|
|
11616
11617
|
return true;
|
|
11617
11618
|
}
|
|
11618
11619
|
return false;
|