npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

ntk-cms-fileuploader

v20.26.2

Published

Ntk Cms Api Uploader File For Typscript

Readme

NTK CMS File Uploader

ntk-cms-fileuploader - Simple and efficient file upload component with progress tracking and validation

📋 Overview

The NTK CMS File Uploader is a lightweight and efficient file upload component designed for Angular applications. It provides drag & drop functionality, progress tracking, file validation, and customizable upload interface with minimal configuration.

🚀 Installation

npm install ntk-cms-fileuploader

📦 Features

Core Features

  • Drag & Drop Upload - Intuitive file upload interface
  • Progress Tracking - Real-time upload progress
  • File Validation - Type and size validation
  • Multiple File Support - Upload multiple files simultaneously
  • Customizable UI - Flexible styling and theming
  • Error Handling - Comprehensive error management
  • Responsive Design - Mobile-friendly interface

Advanced Features

  • Chunked Upload - Large file upload support
  • Retry Mechanism - Automatic retry on failure
  • Preview Support - File preview before upload
  • Queue Management - Upload queue with priority
  • Cancel Upload - Ability to cancel ongoing uploads

🔧 Usage

Basic Setup

import { NgModule } from "@angular/core";
import { HttpClientModule } from "@angular/common/http";
import { NtkCmsFileuploaderModule } from "ntk-cms-fileuploader";

@NgModule({
  imports: [HttpClientModule, NtkCmsFileuploaderModule],
})
export class AppModule {}

Basic Implementation

<ntk-cms-fileuploader [apiUrl]="'https://api.example.com/upload'" [maxFileSize]="5242880" [allowedFileTypes]="['image/*', 'application/pdf']" (uploadComplete)="onUploadComplete($event)" (uploadError)="onUploadError($event)"> </ntk-cms-fileuploader>

Advanced Configuration

import { Component } from "@angular/core";

export class FileUploaderComponent {
  uploadConfig = {
    apiUrl: "https://api.example.com/upload",
    maxFileSize: 10485760, // 10MB
    allowedFileTypes: ["image/*", "application/pdf", "text/plain"],
    multiple: true,
    chunkSize: 1024 * 1024, // 1MB chunks
    retryAttempts: 3,
    autoUpload: true,
    showProgress: true,
    showPreview: true,
  };

  onUploadComplete(event: any): void {
    console.log("Upload completed:", event);
    // Handle successful upload
  }

  onUploadError(event: any): void {
    console.error("Upload failed:", event);
    // Handle upload error
  }

  onFileSelected(event: any): void {
    console.log("File selected:", event);
    // Handle file selection
  }

  onUploadProgress(event: any): void {
    console.log("Upload progress:", event.progress);
    // Handle progress updates
  }
}

📚 API Reference

Input Properties

| Property | Type | Default | Description | | ------------------ | -------- | ------------ | ----------------------------- | | apiUrl | string | - | Upload endpoint URL | | maxFileSize | number | 5242880 | Maximum file size (5MB) | | allowedFileTypes | string[] | [] | Allowed file types | | multiple | boolean | false | Allow multiple file selection | | chunkSize | number | 1024 * 1024 | Chunk size for large files | | retryAttempts | number | 3 | Number of retry attempts | | autoUpload | boolean | true | Auto-upload on file selection | | showProgress | boolean | true | Show progress bar | | showPreview | boolean | false | Show file preview | | disabled | boolean | false | Disable upload functionality |

Output Events

| Event | Type | Description | | ---------------- | ------------ | ------------------------- | | uploadComplete | EventEmitter | Upload completion event | | uploadError | EventEmitter | Upload error event | | fileSelected | EventEmitter | File selection event | | uploadProgress | EventEmitter | Upload progress event | | uploadCancel | EventEmitter | Upload cancellation event |

Service Methods

FileUploaderService

// Upload single file
uploadFile(file: File): Observable<any>

// Upload multiple files
uploadFiles(files: File[]): Observable<any>

// Cancel upload
cancelUpload(uploadId: string): void

// Get upload progress
getUploadProgress(uploadId: string): Observable<number>

// Validate file
validateFile(file: File): boolean

🎨 Customization

Custom Styling

// Custom uploader styles
.ntk-cms-fileuploader {
  .upload-zone {
    border: 2px dashed #ccc;
    border-radius: 8px;
    padding: 40px;
    text-align: center;
    transition: all 0.3s ease;

    &:hover {
      border-color: #2196f3;
      background-color: #f5f5f5;
    }

    &.drag-over {
      border-color: #2196f3;
      background-color: #e3f2fd;
      transform: scale(1.02);
    }
  }

  .file-item {
    display: flex;
    align-items: center;
    padding: 10px;
    margin: 5px 0;
    border: 1px solid #ddd;
    border-radius: 4px;
    background-color: #fafafa;

    .file-info {
      flex: 1;
      margin-left: 10px;
    }

    .file-name {
      font-weight: 500;
      color: #333;
    }

    .file-size {
      font-size: 12px;
      color: #666;
    }

    .progress-bar {
      height: 4px;
      background-color: #e0e0e0;
      border-radius: 2px;
      overflow: hidden;
      margin-top: 5px;

      .progress-fill {
        height: 100%;
        background-color: #2196f3;
        transition: width 0.3s ease;
      }
    }

    .upload-status {
      margin-left: 10px;

      &.success {
        color: #4caf50;
      }

      &.error {
        color: #f44336;
      }

      &.uploading {
        color: #2196f3;
      }
    }
  }
}

Custom Templates

<ntk-cms-fileuploader [config]="uploadConfig">
  <!-- Custom upload zone template -->
  <ng-template #uploadZoneTemplate>
    <div class="custom-upload-zone">
      <i class="upload-icon fas fa-cloud-upload-alt"></i>
      <h3>Drop files here or click to upload</h3>
      <p>Maximum file size: {{ maxFileSize | fileSize }}</p>
      <p>Allowed types: {{ allowedFileTypes.join(', ') }}</p>
    </div>
  </ng-template>

  <!-- Custom file item template -->
  <ng-template #fileItemTemplate let-file let-progress="progress">
    <div class="custom-file-item">
      <div class="file-icon">
        <i [class]="getFileIcon(file.type)"></i>
      </div>
      <div class="file-details">
        <div class="file-name">{{ file.name }}</div>
        <div class="file-size">{{ file.size | fileSize }}</div>
        <div class="progress-container">
          <div class="progress-bar">
            <div class="progress-fill" [style.width.%]="progress"></div>
          </div>
          <span class="progress-text">{{ progress }}%</span>
        </div>
      </div>
      <div class="file-actions">
        <button (click)="cancelUpload(file.id)" *ngIf="progress < 100">
          <i class="fas fa-times"></i>
        </button>
        <i class="fas fa-check success-icon" *ngIf="progress === 100"></i>
      </div>
    </div>
  </ng-template>
</ntk-cms-fileuploader>

🔐 Security

File Validation

export class FileUploaderComponent {
  validateFile(file: File): boolean {
    // Check file size
    if (file.size > this.maxFileSize) {
      this.showError(`File size exceeds ${this.formatFileSize(this.maxFileSize)}`);
      return false;
    }

    // Check file type
    const allowedTypes = this.allowedFileTypes;
    if (allowedTypes.length > 0) {
      const isValidType = allowedTypes.some((type) => {
        if (type.endsWith("/*")) {
          return file.type.startsWith(type.replace("/*", ""));
        }
        return file.type === type;
      });

      if (!isValidType) {
        this.showError(`File type ${file.type} is not allowed`);
        return false;
      }
    }

    // Check file name
    if (!this.isValidFileName(file.name)) {
      this.showError("Invalid file name");
      return false;
    }

    return true;
  }

  private isValidFileName(fileName: string): boolean {
    // Check for invalid characters
    const invalidChars = /[<>:"/\\|?*]/;
    return !invalidChars.test(fileName);
  }

  private formatFileSize(bytes: number): string {
    if (bytes === 0) return "0 Bytes";
    const k = 1024;
    const sizes = ["Bytes", "KB", "MB", "GB"];
    const i = Math.floor(Math.log(bytes) / Math.log(k));
    return parseFloat((bytes / Math.pow(k, i)).toFixed(2)) + " " + sizes[i];
  }

  private showError(message: string): void {
    // Show error message to user
    console.error(message);
  }
}

🧪 Testing

Unit Tests

import { ComponentFixture, TestBed } from "@angular/core/testing";
import { HttpClientTestingModule } from "@angular/common/http/testing";
import { NtkCmsFileuploaderModule } from "ntk-cms-fileuploader";

describe("FileUploaderComponent", () => {
  let component: FileUploaderComponent;
  let fixture: ComponentFixture<FileUploaderComponent>;

  beforeEach(async () => {
    await TestBed.configureTestingModule({
      imports: [HttpClientTestingModule, NtkCmsFileuploaderModule],
      declarations: [FileUploaderComponent],
    }).compileComponents();

    fixture = TestBed.createComponent(FileUploaderComponent);
    component = fixture.componentInstance;
    fixture.detectChanges();
  });

  it("should create", () => {
    expect(component).toBeTruthy();
  });

  it("should validate file size correctly", () => {
    const mockFile = new File(["test"], "test.txt", { type: "text/plain" });
    Object.defineProperty(mockFile, "size", { value: 1024 * 1024 }); // 1MB

    component.maxFileSize = 5242880; // 5MB
    expect(component.validateFile(mockFile)).toBe(true);

    component.maxFileSize = 512 * 1024; // 512KB
    expect(component.validateFile(mockFile)).toBe(false);
  });

  it("should validate file type correctly", () => {
    const mockFile = new File(["test"], "test.txt", { type: "text/plain" });

    component.allowedFileTypes = ["text/plain", "application/pdf"];
    expect(component.validateFile(mockFile)).toBe(true);

    component.allowedFileTypes = ["image/*"];
    expect(component.validateFile(mockFile)).toBe(false);
  });

  it("should handle upload completion", () => {
    const mockEvent = { file: "test.txt", response: { success: true } };
    spyOn(component.uploadComplete, "emit");

    component.onUploadComplete(mockEvent);

    expect(component.uploadComplete.emit).toHaveBeenCalledWith(mockEvent);
  });
});

📊 Performance

Optimization Tips

  1. Chunked Upload: Use chunked upload for large files
  2. Compression: Compress files before upload when possible
  3. Queue Management: Implement upload queue for better control
  4. Caching: Cache upload progress and file metadata
  5. Lazy Loading: Load uploader component on demand

Memory Management

export class FileUploaderComponent implements OnDestroy {
  private destroy$ = new Subject<void>();
  private uploadSubscriptions: Subscription[] = [];

  ngOnInit(): void {
    // Subscribe to upload events
    this.uploadService.uploadProgress$.pipe(takeUntil(this.destroy$)).subscribe((progress) => {
      this.updateProgress(progress);
    });
  }

  uploadFile(file: File): void {
    const uploadSub = this.uploadService
      .uploadFile(file)
      .pipe(takeUntil(this.destroy$))
      .subscribe(
        (result) => this.onUploadComplete(result),
        (error) => this.onUploadError(error)
      );

    this.uploadSubscriptions.push(uploadSub);
  }

  ngOnDestroy(): void {
    this.destroy$.next();
    this.destroy$.complete();

    // Cancel all ongoing uploads
    this.uploadSubscriptions.forEach((sub) => sub.unsubscribe());
  }
}

🔄 Version History

v18.26.4

  • Initial release with core functionality
  • Drag & drop support
  • Progress tracking
  • File validation
  • Basic error handling

v18.26.3

  • Bug fixes and performance improvements
  • Enhanced error handling
  • Improved UI/UX

🤝 Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests for new features
  5. Submit a pull request

📄 License

This library is licensed under the ISC License.

🆘 Support

For support and questions:

  • Create an issue on GitHub
  • Contact: ntk.ir
  • Documentation: Check the main README.md

Note: This library is part of the NTK CMS Angular Libraries collection. For more information, see the main project README.