1.0.1 • Published 3 months ago

multiple-sorting-array v1.0.1

Weekly downloads
-
License
-
Repository
github
Last release
3 months ago

multiple-sorting-array

multiple-sorting-array es una librería ligera y sencilla para ordenar arrays en TypeScript utilizando múltiples criterios de ordenación. Permite definir varias funciones de ordenación que se aplican secuencialmente para ordenar los elementos de un array.

Instalación

Puedes instalar la librería utilizando npm:

npm install multiple-sorting-array

Uso

La librería proporciona una función sortArray que toma un array y una o más funciones de ordenación. Cada función de ordenación toma un elemento del array y devuelve un número que se utiliza para ordenar los elementos.

Ejemplo básico

import { sortArray } from "multiple-sorting-array";

const array = [
  { name: "Alice", age: 25 },
  { name: "Bob", age: 30 },
  { name: "Charlie", age: 25 },
];

// Ordenar primero por edad y luego por nombre
const sortedArray = sortArray(
  array,
  (item) => item.age,
  (item) => item.name
);

console.log(sortedArray);
// Output:
// [
//     { name: 'Alice', age: 25 },
//     { name: 'Charlie', age: 25 },
//     { name: 'Bob', age: 30 }
// ]

Funcionamiento

La función sortArray ordena el array utilizando las funciones de ordenación proporcionadas en el orden en que se pasan. Si dos elementos son iguales según la primera función de ordenación, se utiliza la segunda función para desempatar, y así sucesivamente.

Tipos genéricos

La función sortArray es genérica y puede trabajar con cualquier tipo de dato. Las funciones de ordenación deben devolver un número que se utilizará para comparar los elementos.

export const sortArray = <T>(array: T[], ...by: ((t: T) => number)[]) =>
  array.sort((a, b) => {
    for (const f of by) {
      const [fa, fb] = [a, b].map((t) => f(t));
      if (fa !== fb) return fa - fb;
    }
    return 0;
  });