-
Notifications
You must be signed in to change notification settings - Fork 6.5k
Expand file tree
/
Copy pathutils.ts
More file actions
43 lines (33 loc) · 1.25 KB
/
utils.ts
File metadata and controls
43 lines (33 loc) · 1.25 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import { createHash } from 'node:crypto';
import type {
RandomPartnerListConfig,
Partners,
} from '#site/types/partners.js';
// Fisher-Yates shuffle algorithm with a seed for deterministic results
function shuffle(array: Array<Partners>, seed: number): Array<Partners> {
const shuffled = [...array];
const hash = createHash('sha256').update(String(seed)).digest();
for (let i = shuffled.length - 1; i > 0; i--) {
// Use hash bytes to generate deterministic "random" index
const hashIndex = (i + seed) % 32;
// Normalize to 0-1
const randomValue = hash[hashIndex] / 255;
const j = Math.floor(randomValue * (i + 1));
[shuffled[i], shuffled[j]] = [shuffled[j], shuffled[i]];
}
return shuffled;
}
function randomPartnerList(
partners: Array<Partners>,
config: RandomPartnerListConfig
) {
const { pick = 4, dateSeed = 5, category } = config;
// Generate a deterministic seed based on current time that changes every X minutes
const seed = Math.floor(Date.now() / (dateSeed * 60 * 1000));
// Filter by category if provided
const filtered = category
? partners.filter(p => p.categories.includes(category))
: partners;
return shuffle(filtered, seed).slice(0, pick ?? filtered.length);
}
export { randomPartnerList };