mirror of
https://github.com/withastro/astro.git
synced 2025-01-13 22:11:20 -05:00
91 lines
2 KiB
TypeScript
91 lines
2 KiB
TypeScript
import chalk from 'chalk';
|
|
import type { Ora } from 'ora';
|
|
import ora from 'ora';
|
|
|
|
const gradientColors = [
|
|
`#ff5e00`,
|
|
`#ff4c29`,
|
|
`#ff383f`,
|
|
`#ff2453`,
|
|
`#ff0565`,
|
|
`#ff007b`,
|
|
`#f5008b`,
|
|
`#e6149c`,
|
|
`#d629ae`,
|
|
`#c238bd`,
|
|
];
|
|
|
|
export const rocketAscii = '■■▶';
|
|
|
|
// get a reference to scroll through while loading
|
|
// visual representation of what this generates:
|
|
// gradientColors: "..xxXX"
|
|
// referenceGradient: "..xxXXXXxx....xxXX"
|
|
const referenceGradient = [
|
|
...gradientColors,
|
|
// draw the reverse of the gradient without
|
|
// accidentally mutating the gradient (ugh, reverse())
|
|
...[...gradientColors].reverse(),
|
|
...gradientColors,
|
|
];
|
|
|
|
// async-friendly setTimeout
|
|
const sleep = (time: number) =>
|
|
new Promise((resolve) => {
|
|
setTimeout(resolve, time);
|
|
});
|
|
|
|
function getGradientAnimFrames() {
|
|
const frames = [];
|
|
for (let start = 0; start < gradientColors.length * 2; start++) {
|
|
const end = start + gradientColors.length - 1;
|
|
frames.push(
|
|
referenceGradient
|
|
.slice(start, end)
|
|
.map((g) => chalk.bgHex(g)(' '))
|
|
.join('')
|
|
);
|
|
}
|
|
return frames;
|
|
}
|
|
|
|
function getIntroAnimFrames() {
|
|
const frames = [];
|
|
for (let end = 1; end <= gradientColors.length; end++) {
|
|
const leadingSpacesArr = Array.from(
|
|
new Array(Math.abs(gradientColors.length - end - 1)),
|
|
() => ' '
|
|
);
|
|
const gradientArr = gradientColors.slice(0, end).map((g) => chalk.bgHex(g)(' '));
|
|
frames.push([...leadingSpacesArr, ...gradientArr].join(''));
|
|
}
|
|
return frames;
|
|
}
|
|
|
|
/**
|
|
* Generate loading spinner with rocket flames!
|
|
* @param text display text next to rocket
|
|
* @returns Ora spinner for running .stop()
|
|
*/
|
|
export async function loadWithRocketGradient(text: string): Promise<Ora> {
|
|
const frames = getIntroAnimFrames();
|
|
const intro = ora({
|
|
spinner: {
|
|
interval: 30,
|
|
frames,
|
|
},
|
|
text: `${rocketAscii} ${text}`,
|
|
});
|
|
intro.start();
|
|
await sleep((frames.length - 1) * intro.interval);
|
|
intro.stop();
|
|
const spinner = ora({
|
|
spinner: {
|
|
interval: 80,
|
|
frames: getGradientAnimFrames(),
|
|
},
|
|
text: `${rocketAscii} ${text}`,
|
|
}).start();
|
|
|
|
return spinner;
|
|
}
|