Skip to content
Snippets Groups Projects
Select Git revision
  • f9c20658976f121f574ad53300e36217e075b00e
  • main default protected
  • optimize-storybook
  • OZG-8405-Alfa-Bearbeiter-auswählen-und-entfernen-Design
  • OZG-7986-mandat-anfragen
  • OZG-6978-prevent-other-pages-from-being-called
  • OZG-8378-ods-heading
  • OZG-8314-Alfa-Vorgang-Bearbeiter-Zuweisung-entfernen
  • testing-imports
  • storybook-improvements
  • OZG-7287-forward-saml-token
  • release-administration
  • OZG-8422-BenutzerSpeichern
  • release-info
  • release
  • OZG-7856_schadcode-scanner-e2e
  • OZG-7985-fix-sorting
  • OZG-8305-Create-webpack-sbom
  • tooltip-improvements
  • OZG-7714-UpgradeKeycloakDependencyTo25
  • OZG-8086-Admin-Datenanfrage-erstellen
  • 1.12.1-administration
  • 1.12.0-administration
  • 1.12.0-info
  • 2.27.0-alfa
  • 1.11.0-info
  • 1.11.0-administration
  • 2.26.0-alfa
  • 1.10.0-info
  • 1.10.0-administration
  • 2.25.0-alfa
  • 1.9.0-info
  • 1.9.0-administration
  • 2.24.0-alfa
  • 1.8.0-info
  • 1.8.0-administration
  • 2.23.0-alfa
  • 1.7.0-info
  • 1.7.0-administration
  • 2.22.0-alfa
  • 1.6.0-info
41 results

binary-file.service.ts

Blame
  • tech.validation.util.ts 4.19 KiB
    /*
     * Copyright (C) 2022 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 { AbstractControl, UntypedFormGroup } from '@angular/forms';
    import { isEmpty, isNil } from 'lodash-es';
    import { ApiError, InvalidParam, Issue, IssueParam } from '../tech.model';
    import { replacePlaceholder } from '../tech.util';
    import { VALIDATION_MESSAGES, ValidationMessageCode } from './tech.validation.messages';
    
    export function isValidationError(issue: Issue): boolean {
      return issue.messageCode.includes('javax.validation.constraints');
    }
    
    export function setIssueValidationError(
      form: UntypedFormGroup,
      issue: Issue,
      pathPrefix?: string,
    ): void {
      const control: AbstractControl = getControlForIssue(form, issue, pathPrefix);
    
      control.setErrors({ [issue.messageCode]: issue });
      control.markAsTouched();
    }
    
    export function getControlForIssue(
      form: UntypedFormGroup,
      issue: Issue,
      pathPrefix?: string,
    ): AbstractControl {
      const fieldPath: string = getFieldPath(issue.field, pathPrefix);
    
      let curControl: AbstractControl = form;
      fieldPath
        .split('.')
        .forEach((field) => (curControl = (<UntypedFormGroup>curControl).controls[field]));
    
      return curControl;
    }
    
    export function getMessageForIssue(label: string, issue: Issue): string {
      let msg: string = VALIDATION_MESSAGES[issue.messageCode];
    
      if (isNil(msg)) {
        console.warn('No message for code ' + issue.messageCode + ' found.');
        return issue.messageCode;
      }
    
      msg = replacePlaceholder(msg, 'field', label);
      issue.parameters.forEach(
        (param: IssueParam) => (msg = replacePlaceholder(msg, param.name, param.value)),
      );
      return msg;
    }
    
    export function isValidationFieldFileSizeExceedError(error: any) {
      return getMessageCode(error) === ValidationMessageCode.VALIDATION_FIELD_FILE_SIZE_EXCEEDED;
    }
    
    export function getMessageCode(apiError: ApiError): string {
      return apiError.issues[0].messageCode;
    }
    
    export function setInvalidParamValidationError(
      form: UntypedFormGroup,
      invalidParam: InvalidParam,
      pathPrefix?: string,
    ): void {
      const control: AbstractControl = getControlForInvalidParam(form, invalidParam, pathPrefix);
    
      control.setErrors({ [invalidParam.reason]: invalidParam });
      control.markAsTouched();
    }
    
    export function getControlForInvalidParam(
      form: UntypedFormGroup,
      invalidParam: InvalidParam,
      pathPrefix?: string,
    ): AbstractControl {
      return form.get(getFieldPath(invalidParam.name, pathPrefix));
    }
    
    export function getMessageForInvalidParam(label: string, invalidParam: InvalidParam): string {
      let msg: string = VALIDATION_MESSAGES[invalidParam.reason];
    
      if (isNil(msg)) {
        console.warn('No message for code ' + invalidParam.reason + ' found.');
        return invalidParam.reason;
      }
    
      msg = replacePlaceholder(msg, 'field', label);
      invalidParam.constraintParameters.forEach(
        (param: IssueParam) => (msg = replacePlaceholder(msg, param.name, param.value)),
      );
      return msg;
    }
    
    export function getFieldPath(name: string, pathPrefix?: string): string {
      return isEmpty(pathPrefix) ? getLastPart(name) : getPartsAfterPrefix(name, pathPrefix);
    }
    
    export function getLastPart(name: string): string {
      return name.split('.').pop();
    }
    
    export function getPartsAfterPrefix(name: string, pathPrefix: string): string {
      pathPrefix = `${pathPrefix}.`;
      const indexField = name.lastIndexOf(pathPrefix) + pathPrefix.length;
      return name.slice(indexField);
    }