UNPKG

material-dynamic-forms

Version:

¡Crea formularios dinámicos, potentes y configurables en Angular usando Material Design! 🚀

96 lines 11.4 kB
import { ConfirmEventType } from 'primeng/api'; import { throwError } from 'rxjs'; export function handleError(error) { let errorData = { status: 0, message: '', }; switch (error.status) { case 401 /* HttpStatusCode.Unauthorized */: removeItemStorage(); return throwError(error.error.message); case 400 /* HttpStatusCode.BadRequest */: case 409 /* HttpStatusCode.Conflict */: return throwError(error.error.message); case 402 /* HttpStatusCode.PaymentRequired */: errorData.status = error.status; errorData.message = error.error.data.mensaje; return throwError(errorData); case 422 /* HttpStatusCode.UnprocessableEntity */: return throwError(error.error); case 425 /* HttpStatusCode.TooEarly */: return throwError(error.error.message.errors); case 500 /* HttpStatusCode.InternalServerError */: return throwError(error.error.previous.message); default: return throwError('Something bad happened; please try again later.'); } } export function removeNullValuesFromQueryParams(params) { const paramsKeysAux = params.keys(); paramsKeysAux.forEach((key) => { const value = params.get(key); if (value === null || value === undefined || value === '' || value === 'undefined') { params['map'].delete(key); } }); return params; } export const FunctionRejectData = (type, _messageService) => { switch (type) { case ConfirmEventType.REJECT: _messageService.add({ severity: 'error', summary: 'Rechazada', detail: 'Rechazada la acción', }); break; case ConfirmEventType.CANCEL: _messageService.add({ severity: 'warn', summary: 'Cancelado', detail: 'Cancelada la acción', }); break; } }; export function filterObjectKeys(obj, keysToKeep) { const newObj = {}; keysToKeep.forEach((key) => { if (key in obj) { newObj[key] = obj[key]; } }); return newObj; } export function getValueFromProperty(row, property) { if (!row || !property) { return undefined; } const properties = property.split('.'); // Itera sobre las propiedades para acceder al valor final let value = row; for (const prop of properties) { value = value[prop]; if (value === undefined) { return undefined; } } return value; } export function removeItemStorage() { localStorage.removeItem('token'); localStorage.removeItem('refresh_token'); localStorage.removeItem('session_id'); localStorage.removeItem('remember'); } export const transformToObject = (objectSelect) => { return { id: Number(objectSelect.key), nombre: objectSelect.value, }; }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"functions.js","sourceRoot":"","sources":["../../../../../projects/dynamic-form/src/lib/functions/functions.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  HttpErrorResponse,\r\n  HttpParams,\r\n  HttpStatusCode,\r\n} from '@angular/common/http';\r\nimport { ConfirmEventType, MessageService } from 'primeng/api';\r\nimport { throwError } from 'rxjs';\r\nimport { ObjectKeyValue } from '../interfaces';\r\n\r\nexport function handleError(error: HttpErrorResponse) {\r\n  let errorData = {\r\n    status: 0,\r\n    message: '',\r\n  };\r\n  switch (error.status) {\r\n    case HttpStatusCode.Unauthorized:\r\n      removeItemStorage();\r\n      return throwError(error.error.message);\r\n\r\n    case HttpStatusCode.BadRequest:\r\n    case HttpStatusCode.Conflict:\r\n      return throwError(error.error.message);\r\n    case HttpStatusCode.PaymentRequired:\r\n      errorData.status = error.status;\r\n      errorData.message = error.error.data.mensaje;\r\n      return throwError(errorData);\r\n    case HttpStatusCode.UnprocessableEntity:\r\n      return throwError(error.error);\r\n    case HttpStatusCode.TooEarly:\r\n      return throwError(error.error.message.errors);\r\n    case HttpStatusCode.InternalServerError:\r\n      return throwError(error.error.previous.message);\r\n\r\n    default:\r\n      return throwError('Something bad happened; please try again later.');\r\n  }\r\n}\r\n\r\nexport function removeNullValuesFromQueryParams(params: HttpParams) {\r\n  const paramsKeysAux = params.keys();\r\n  paramsKeysAux.forEach((key) => {\r\n    const value = params.get(key);\r\n    if (\r\n      value === null ||\r\n      value === undefined ||\r\n      value === '' ||\r\n      value === 'undefined'\r\n    ) {\r\n      params['map'].delete(key);\r\n    }\r\n  });\r\n  return params;\r\n}\r\n\r\nexport const FunctionRejectData = (\r\n  type: any,\r\n  _messageService: MessageService\r\n) => {\r\n  switch (type) {\r\n    case ConfirmEventType.REJECT:\r\n      _messageService.add({\r\n        severity: 'error',\r\n        summary: 'Rechazada',\r\n        detail: 'Rechazada la acción',\r\n      });\r\n      break;\r\n    case ConfirmEventType.CANCEL:\r\n      _messageService.add({\r\n        severity: 'warn',\r\n        summary: 'Cancelado',\r\n        detail: 'Cancelada la acción',\r\n      });\r\n      break;\r\n  }\r\n};\r\n\r\nexport function filterObjectKeys<T extends object, K extends keyof T>(\r\n  obj: T,\r\n  keysToKeep: readonly K[]\r\n): Pick<T, K> {\r\n  const newObj: Partial<T> = {};\r\n\r\n  keysToKeep.forEach((key: K) => {\r\n    if (key in obj) {\r\n      newObj[key] = obj[key];\r\n    }\r\n  });\r\n\r\n  return newObj as Pick<T, K>;\r\n}\r\n\r\nexport function getValueFromProperty(row: any, property: string): any {\r\n  if (!row || !property) {\r\n    return undefined;\r\n  }\r\n  const properties = property.split('.');\r\n  // Itera sobre las propiedades para acceder al valor final\r\n  let value = row;\r\n  for (const prop of properties) {\r\n    value = value[prop];\r\n    if (value === undefined) {\r\n      return undefined;\r\n    }\r\n  }\r\n  return value;\r\n}\r\n\r\nexport function removeItemStorage() {\r\n  localStorage.removeItem('token');\r\n  localStorage.removeItem('refresh_token');\r\n  localStorage.removeItem('session_id');\r\n  localStorage.removeItem('remember');\r\n}\r\n\r\nexport const transformToObject = (\r\n  objectSelect: ObjectKeyValue\r\n): { id: number; nombre: string } => {\r\n  return {\r\n    id: Number(objectSelect.key),\r\n    nombre: objectSelect.value,\r\n  };\r\n};\r\n"]}