10 lines
330 B
JavaScript
10 lines
330 B
JavaScript
const sortedLastIndexBy = (arr, n, fn) => {
|
|
const isDescending = fn(arr[0]) > fn(arr[arr.length - 1]);
|
|
const val = fn(n);
|
|
const index = arr
|
|
.map((val, i) => [i, fn(val)])
|
|
.reverse()
|
|
.findIndex(el => (isDescending ? val <= el[1] : val >= el[1]));
|
|
return index === -1 ? 0 : arr.length - index;
|
|
};
|
|
module.exports = sortedLastIndexBy; |