![Create React App Officially Deprecated Amid React 19 Compatibility Issues](https://cdn.sanity.io/images/cgdhsj6q/production/04fa08cf844d798abc0e1a6391c129363cc7e2ab-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Create React App Officially Deprecated Amid React 19 Compatibility Issues
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.
A collection of sorting algorithms written in JavaScript.
Detailed information on the complexity of each algorithm is located here. To learn more about how some of the algorithms are implemented, have a look at the technical articles on my blog.
npm install --save js-sorting
See the source files for a list sorts available and their public interfaces, Here is an example for merge sort.
var mergeSort = require("js-sorting").mergeSort;
// Sort normally
mergeSort([5, 3, 2, 4, 1]);
// Sort in reverse
var reverseCompare = function (a, b) {
return b - a;
};
mergeSort([5, 3, 2, 4, 1], reverseCompare);
// Sort complex objects
var list = [
{ 'firstname': 'John', 'lastname': 'Smith' },
{ 'firstname': 'Daniel', 'lastname': 'Imms' },
{ 'firstname': 'Mary', 'lastname': 'Jackson' },
{ 'firstname': 'John', 'lastname': 'Brown' },
{ 'firstname': 'Mary', 'lastname': 'Harris' },
];
var complexNameSort = function (a, b) {
// Sort by first name first
if (a.firstname.toLowerCase() < b.firstname.toLowerCase()) return -1;
if (a.firstname.toLowerCase() > b.firstname.toLowerCase()) return 1;
// Sort by last name second
if (a.lastname.toLowerCase() < b.lastname.toLowerCase()) return -1;
if (a.lastname.toLowerCase() > b.lastname.toLowerCase()) return 1;
return 0;
};
mergeSort.sort(list, complexNameSort);
In order to support one of my other projects, various methods are exposed for each sort that allow observation of internal array changes. This can be done by wrapping the functions like so:
bubbleSort.attachCompareObserver = function (array, a, b) {
alert('Comparing "' + array[a] + '" (i=' + a + ') with "' +
array[b] + '" (i=' + b + ')');
};
bubbleSort.attachSwapObserver(function (array, a, b) {
alert('Swapping "' + array[a] + '" (i=' + a + ') with "' +
array[b] + '" (i=' + b + ')');
});
The functions available are different for each algorithm since not all sorts only do compares and swaps to transform the array in a standard way. For example insertion sort exposes a shift
function which shifts an item to a particular index. While this is the same as swapping the item with the adjacent item until it reaches the index, it is achieved in half the number of assignments by only assigning the item being shifted once. The way that this operation is visualised is quite different to just x swaps.
I'd love to get some contributions for other sorting algorithms, if you want to make a pull request try to follow the existing style of the code and make sure you add tests for the new algorithm.
npm install
npm test
# generate coverage report in ./coverage/
grunt coverage
MIT © Daniel Imms
FAQs
A collection of sorting algorithms written in JavaScript.
The npm package js-sorting receives a total of 10 weekly downloads. As such, js-sorting popularity was classified as not popular.
We found that js-sorting demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.