Skip to content
Snippets Groups Projects
spinner-icon.component.ts 2.17 KiB
Newer Older
  • Learn to ignore specific revisions
  • /*
     * Copyright (C) 2024 Das Land Schleswig-Holstein vertreten durch den
     * Ministerpräsidenten des Landes Schleswig-Holstein
     * Staatskanzlei
     * Abteilung Digitalisierung und zentrales IT-Management der Landesregierung
     *
     * Lizenziert unter der EUPL, Version 1.2 oder - sobald
     * diese von der Europäischen Kommission genehmigt wurden -
     * Folgeversionen der EUPL ("Lizenz");
     * Sie dürfen dieses Werk ausschließlich gemäß
     * dieser Lizenz nutzen.
     * Eine Kopie der Lizenz finden Sie hier:
     *
     * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
     *
     * Sofern nicht durch anwendbare Rechtsvorschriften
     * gefordert oder in schriftlicher Form vereinbart, wird
     * die unter der Lizenz verbreitete Software "so wie sie
     * ist", OHNE JEGLICHE GEWÄHRLEISTUNG ODER BEDINGUNGEN -
     * ausdrücklich oder stillschweigend - verbreitet.
     * Die sprachspezifischen Genehmigungen und Beschränkungen
     * unter der Lizenz sind dem Lizenztext zu entnehmen.
     */
    
    import { NgClass } from '@angular/common';
    import { Component, Input } from '@angular/core';
    
    
    import { IconVariants, iconVariants } from '../iconVariants';
    
    
    @Component({
      selector: 'ods-spinner-icon',
      standalone: true,
    
      imports: [NgClass],
    
    OZGCloud's avatar
    OZGCloud committed
          xmlns="http://www.w3.org/2000/svg"
    
          [ngClass]="iconVariants({ size })"
          class="animate-spin fill-primary text-gray-200 dark:text-gray-600"
    
    OZGCloud's avatar
    OZGCloud committed
          aria-hidden="true"
    
          viewBox="0 0 100 100"
          fill="none"
    
          data-test-class="spinner"
    
        >
          <path
            d="M100 50.59c0 27.615-22.386 50.001-50 50.001s-50-22.386-50-50 22.386-50 50-50 50 22.386 50 50Zm-90.919 0c0 22.6 18.32 40.92 40.919 40.92 22.599 0 40.919-18.32 40.919-40.92 0-22.598-18.32-40.918-40.919-40.918-22.599 0-40.919 18.32-40.919 40.919Z"
            fill="currentColor"
          />
          <path
            d="M93.968 39.04c2.425-.636 3.894-3.128 3.04-5.486A50 50 0 0 0 41.735 1.279c-2.474.414-3.922 2.919-3.285 5.344.637 2.426 3.12 3.849 5.6 3.484a40.916 40.916 0 0 1 44.131 25.769c.902 2.34 3.361 3.802 5.787 3.165Z"
          />
        </svg>
    
        <span class="sr-only">Loading...</span>
      `,
    
    export class SpinnerIconComponent {
      @Input() size: IconVariants['size'] = 'full';
    
      iconVariants = iconVariants;
    }